/* ============================================================
   Vanity Resource — shared design system (mockup)
   Forum + Lato · cream / slate-navy / brass · refined traditional
   ============================================================ */
:root{
  --cream:#f6f2ea;
  --paper:#fbf9f4;
  --ink:#1f2c38;          /* deep slate navy */
  --ink-soft:#3c4a56;
  --body:#33414d;
  --brass:#a98b5d;        /* warm brass/gold */
  --brass-deep:#8c7048;
  --sage:#9aa896;
  --sage-deep:#7d8c79;
  --line:#e0d8c9;
  --shadow:rgba(31,44,56,.10);
  --studio:radial-gradient(ellipse at 50% 40%,#ffffff 0%,#f5f1e8 100%);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Lato',system-ui,sans-serif;color:var(--ink);background:var(--cream);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,.display{font-family:'Forum','Cormorant Garamond',Georgia,serif;font-weight:400;letter-spacing:.01em;line-height:1.08}
.eyebrow{font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;color:var(--brass-deep);font-weight:700}
a{color:inherit;text-decoration:none}
img{display:block;width:100%;height:100%;object-fit:cover}
.wrap{max-width:1240px;margin:0 auto;padding:0 40px}
.narrow{max-width:840px}

/* reveal animation */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* buttons */
.btn{display:inline-block;padding:15px 34px;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;transition:.3s;border:1.5px solid transparent;cursor:pointer;text-align:center}
.btn-solid{background:var(--brass-deep);color:#fff}
.btn-solid:hover{background:var(--ink);color:#fff}
.btn-ink{background:var(--ink);color:#fff}
.btn-ink:hover{background:var(--brass);color:#fff}
.btn-ghost{border-color:rgba(255,255,255,.7);color:#fff}
.btn-ghost:hover{background:#fff;color:var(--ink)}
.btn-outline{border-color:var(--ink);color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:#fff}

/* ---------- announcement + header ---------- */
.topbar{background:var(--ink);color:#efe9dc;text-align:center;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;padding:9px 16px;font-weight:700}
.topbar span{color:var(--brass)}
header{position:sticky;top:0;z-index:50;background:rgba(246,242,234,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:84px}
.logo{font-family:'Forum',serif;font-size:1.62rem;letter-spacing:.06em;line-height:1;color:var(--ink)}
.logo small{display:block;font-family:'Lato',sans-serif;font-size:.52rem;letter-spacing:.42em;text-transform:uppercase;color:var(--brass-deep);margin-top:5px;font-weight:700}
.logo img{height:54px;width:auto;display:block}
.fbrand .logo img{height:62px}
.menu{display:flex;gap:30px;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);font-weight:700}
.menu a{position:relative;padding:6px 0;transition:color .25s}
.menu a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--brass);transition:width .3s}
.menu a:hover,.menu a.active{color:var(--ink)}.menu a:hover::after,.menu a.active::after{width:100%}
.icons{display:flex;gap:22px;align-items:center;color:var(--ink-soft)}
.icons svg{width:21px;height:21px;stroke:currentColor;fill:none;stroke-width:1.4}

/* ---------- hero ---------- */
.hero{position:relative;height:88vh;min-height:620px;max-height:860px;overflow:hidden;display:flex;align-items:center}
.hero img{position:absolute;inset:0;width:100%;height:100%;transform:scale(1.04);animation:kb 14s ease-out forwards}
@keyframes kb{to{transform:scale(1)}}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(18,27,34,.82) 0%,rgba(18,27,34,.55) 40%,rgba(18,27,34,.12) 78%,rgba(18,27,34,0) 100%)}
.hero-inner{position:relative;z-index:2;color:#fdfbf6;max-width:600px;text-shadow:0 2px 22px rgba(15,22,28,.45)}
.hero .eyebrow{color:#e6d4ad}
.hero h1{font-size:clamp(2.6rem,5vw,4.35rem);margin:18px 0 22px;color:#fdfbf6}
.hero p{font-size:1.12rem;max-width:460px;color:#efe9dd;font-weight:300}
.btnrow{display:flex;gap:16px;margin-top:34px;flex-wrap:wrap}

/* ---------- trust strip ---------- */
.trust{background:var(--paper);border-bottom:1px solid var(--line)}
.trust .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding:30px 40px}
.trust div{text-align:center}
.trust .t{font-family:'Forum',serif;font-size:1.05rem;color:var(--ink);margin-bottom:2px}
.trust .s{font-size:.78rem;color:var(--ink-soft);letter-spacing:.04em}

/* ---------- section heading ---------- */
.sec{padding:96px 0}
.sec-head{text-align:center;max-width:640px;margin:0 auto 56px}
.sec-head h2{font-size:clamp(2rem,3.4vw,2.85rem);margin:14px 0 16px}
.sec-head p{color:var(--ink-soft);font-size:1.04rem}
.rule{width:48px;height:1.5px;background:var(--brass);margin:0 auto}

/* ---------- page header (interior pages) ---------- */
.pagehead{background:var(--paper);border-bottom:1px solid var(--line);text-align:center;padding:60px 0 54px}
.pagehead h1{font-size:clamp(2.4rem,4vw,3.4rem);margin:14px 0 14px}
.pagehead p{max-width:640px;margin:0 auto;color:var(--ink-soft);font-size:1.05rem}

/* ---------- breadcrumb ---------- */
.crumb{padding:20px 0;font-size:.78rem;letter-spacing:.04em;color:var(--ink-soft)}
.crumb a:hover{color:var(--brass-deep)}
.crumb i{opacity:.5;margin:0 9px;font-style:normal}

/* ---------- categories ---------- */
.cats{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.cat{position:relative;height:340px;overflow:hidden;cursor:pointer}
.cat img{transition:transform 1s cubic-bezier(.2,.7,.2,1)}
.cat:hover img{transform:scale(1.07)}
.cat::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(20,30,38,.66),rgba(20,30,38,.05) 60%)}
.cat-label{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:26px;color:#fff}
.cat-label .c{font-family:'Forum',serif;font-size:1.5rem}
.cat-label .n{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;opacity:.82;margin-top:3px}
.cat .arrow{position:absolute;top:22px;right:22px;z-index:2;width:38px;height:38px;border:1px solid rgba(255,255,255,.5);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;opacity:0;transform:translateX(-6px);transition:.4s}
.cat:hover .arrow{opacity:1;transform:none}

/* ---------- filter chips + product grid + card ---------- */
.filters{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:46px}
.chip{padding:9px 20px;border:1px solid var(--line);background:var(--paper);font-size:.76rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);font-weight:700;border-radius:40px;cursor:pointer;transition:.25s}
.chip:hover{border-color:var(--brass);color:var(--ink)}
.chip.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px 26px}
.card{background:#fff;border:1px solid var(--line);transition:transform .5s,box-shadow .5s;display:block}
.card .ph{position:relative;height:360px;overflow:hidden;background:var(--paper)}
.card .ph img{width:100%;height:100%;object-fit:cover;object-position:center 62%;transition:transform 1s cubic-bezier(.2,.7,.2,1)}
.card:hover{transform:translateY(-6px);box-shadow:0 24px 50px -24px var(--shadow)}
.card:hover .ph img{transform:scale(1.05)}
.tag{position:absolute;top:14px;left:14px;z-index:2;background:var(--sage-deep);color:#fff;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;padding:6px 12px;font-weight:700}
.tag.clear{background:var(--brass-deep)}
.card .body{padding:22px 22px 26px}
.card .meta{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass-deep);font-weight:700}
.card h3{font-size:1.4rem;margin:8px 0 4px}
.card .price{font-size:1.02rem;color:var(--ink-soft)}
.card .price b{font-weight:700;color:var(--ink)}
.card .view{margin-top:18px;display:block;width:100%;text-align:center;padding:13px;background:transparent;border:1.5px solid var(--ink);color:var(--ink);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;transition:.3s}
.card .view:hover{background:var(--ink);color:#fff}
.seeall{text-align:center;margin-top:54px}

/* ---------- shop / collection ---------- */
.shop{display:grid;grid-template-columns:248px 1fr;gap:50px;align-items:start;padding:46px 0 30px}
.side{position:sticky;top:104px}
.side .ftitle{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);font-weight:700;padding-bottom:16px;border-bottom:1.5px solid var(--ink)}
.facet{border-bottom:1px solid var(--line);padding:18px 0}
.facet h5{font-family:'Forum',serif;font-size:1.12rem;margin-bottom:10px;font-weight:400}
.facet label{display:flex;align-items:center;gap:11px;font-size:.92rem;color:var(--ink-soft);padding:5px 0;cursor:pointer;transition:color .2s}
.facet label:hover{color:var(--ink)}
.facet input{width:15px;height:15px;accent-color:var(--brass-deep)}
.facet .ct{margin-left:auto;font-size:.78rem;opacity:.6}
.shopbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.shopbar .count{font-size:.86rem;color:var(--ink-soft);letter-spacing:.04em}
.shopbar .count b{color:var(--ink)}
.sortwrap{display:flex;align-items:center;gap:10px;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);font-weight:700}
.sortwrap select{font-family:'Lato';font-size:.85rem;padding:9px 12px;border:1px solid var(--line);background:#fff;color:var(--ink);cursor:pointer}
.shop .grid{grid-template-columns:repeat(3,1fr)}
.pager{display:flex;gap:8px;justify-content:center;margin-top:52px}
.pager a{min-width:42px;height:42px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--ink-soft);transition:.25s;padding:0 12px}
.pager a.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.pager a:hover{border-color:var(--brass);color:var(--ink)}

/* ---------- SEO / AEO copy block ---------- */
.seoblock{background:var(--paper);border-top:1px solid var(--line);padding:74px 0}
.seoblock .wrap{max-width:860px}
.seoblock h2{font-size:1.9rem;margin-bottom:8px}
.seoblock .rule{margin:0 0 26px}
.seoblock h3{font-size:1.32rem;margin:30px 0 8px}
.seoblock p{color:var(--body);margin-bottom:14px;font-size:1.02rem}
.seoblock a{color:var(--brass-deep);border-bottom:1px solid var(--line)}
.seoblock a:hover{border-color:var(--brass-deep)}

/* ---------- PDP ---------- */
.pdp{display:grid;grid-template-columns:1.08fr 1fr;gap:58px;padding:18px 0 76px;align-items:start}
.gallery{position:sticky;top:104px}
.gmain{position:relative;aspect-ratio:1/1;background:var(--studio);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;padding:40px;margin-bottom:14px}
.gmain img{width:100%;height:100%;object-fit:contain;mix-blend-mode:multiply}
.gmain .tag{top:18px;left:18px}
.gthumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
.gthumbs button{aspect-ratio:1/1;border:1px solid var(--line);background:#fff;padding:6px;cursor:pointer;transition:border-color .25s}
.gthumbs button.on{border-color:var(--brass)}
.gthumbs img{width:100%;height:100%;object-fit:contain;mix-blend-mode:multiply}
.pdp-info .meta{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-deep);font-weight:700}
.pdp-info h1{font-size:clamp(2.2rem,3.4vw,3rem);margin:10px 0 14px}
.pdp-info .reviewrow{display:flex;align-items:center;gap:10px;margin-bottom:18px;font-size:.86rem;color:var(--ink-soft)}
.pdp-info .reviewrow .stars{color:var(--brass);letter-spacing:2px}
.pricelg{font-size:1.8rem;color:var(--ink);font-family:'Forum',serif;margin-bottom:6px}
.pricelg .from{font-size:.84rem;font-family:'Lato';letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-right:8px;vertical-align:middle}
.lede{color:var(--body);font-size:1.05rem;margin:18px 0 4px;padding-bottom:24px;border-bottom:1px solid var(--line)}
.opt{margin:24px 0}
.opt .lab{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);font-weight:700;margin-bottom:10px;display:block}
.opt .lab span{color:var(--ink-soft);font-weight:400;text-transform:none;letter-spacing:0;margin-left:6px}
.swatch{display:flex;gap:10px;flex-wrap:wrap}
.swatch button{padding:11px 17px;border:1px solid var(--line);background:#fff;cursor:pointer;font-family:'Lato';font-size:.85rem;color:var(--ink-soft);transition:.2s;display:flex;align-items:center;gap:8px}
.swatch button:hover{border-color:var(--brass)}
.swatch button.on{border-color:var(--ink);color:var(--ink);font-weight:700}
.swatch .dot{width:16px;height:16px;border-radius:50%;border:1px solid rgba(0,0,0,.12)}
.addbar{display:flex;gap:12px;margin:30px 0 14px}
.qty{display:flex;align-items:center;border:1.5px solid var(--ink)}
.qty button{width:46px;height:100%;background:none;border:none;font-size:1.1rem;cursor:pointer;color:var(--ink)}
.qty span{min-width:36px;text-align:center;font-weight:700}
.addbar .btn{flex:1}
.assure{list-style:none;margin-top:24px;border-top:1px solid var(--line);padding-top:22px}
.assure li{display:flex;gap:12px;align-items:flex-start;font-size:.92rem;color:var(--ink-soft);margin-bottom:13px}
.assure svg{width:19px;height:19px;flex:none;stroke:var(--brass-deep);fill:none;stroke-width:1.5;margin-top:2px}
.assure b{color:var(--ink)}

/* accordion (PDP details + FAQ) */
.acc{margin-top:18px;border-top:1px solid var(--line)}
.acc details{border-bottom:1px solid var(--line)}
.acc summary{padding:18px 2px;cursor:pointer;font-family:'Forum',serif;font-size:1.18rem;display:flex;justify-content:space-between;align-items:center;list-style:none}
.acc summary::-webkit-details-marker{display:none}
.acc summary::after{content:"+";color:var(--brass-deep);font-size:1.3rem;transition:transform .25s}
.acc details[open] summary::after{content:"–"}
.acc .accbody{padding:2px 2px 22px;color:var(--body);font-size:1rem}
.acc .accbody p{margin-bottom:12px}
.acc .accbody ul{margin:0 0 4px 20px}
.acc .accbody li{margin-bottom:8px}
.spectable{width:100%;border-collapse:collapse;font-size:.95rem}
.spectable td{padding:11px 0;border-bottom:1px solid var(--line);color:var(--body)}
.spectable td:first-child{color:var(--ink-soft);width:42%;font-weight:700}

/* section band on PDP */
.band{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

/* ---------- article / blog ---------- */
.article{max-width:744px;margin:0 auto;padding:46px 0 30px}
.article .k{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-deep);font-weight:700}
.article h1{font-size:clamp(2.2rem,4vw,3.1rem);margin:14px 0 16px}
.article .byline{font-size:.86rem;color:var(--ink-soft);letter-spacing:.04em;padding-bottom:30px;margin-bottom:34px;border-bottom:1px solid var(--line)}
.article .lead{font-size:1.24rem;line-height:1.7;color:var(--ink);font-family:'Cormorant Garamond',serif;margin-bottom:26px}
.article h2{font-size:1.78rem;margin:42px 0 14px}
.article h3{font-size:1.34rem;margin:30px 0 10px}
.article p{font-size:1.1rem;line-height:1.82;color:var(--body);margin-bottom:20px}
.article ul,.article ol{margin:0 0 22px 24px}
.article li{font-size:1.1rem;line-height:1.7;color:var(--body);margin-bottom:11px}
.article strong{color:var(--ink)}
.article a{color:var(--brass-deep);border-bottom:1px solid var(--line)}
.article img{border:1px solid var(--line);margin:14px 0}
.tldr{background:var(--paper);border-left:3px solid var(--brass);padding:24px 28px;margin:0 0 34px}
.tldr .lab{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-deep);font-weight:700;margin-bottom:8px}
.tldr p{font-size:1.04rem;margin:0;color:var(--ink)}
.keyfacts{background:#fff;border:1px solid var(--line);padding:26px 30px;margin:34px 0}
.keyfacts .lab{font-family:'Forum',serif;font-size:1.3rem;margin-bottom:14px}
.keyfacts dl{display:grid;grid-template-columns:auto 1fr;gap:10px 18px}
.keyfacts dt{color:var(--ink-soft);font-weight:700;font-size:.94rem}
.keyfacts dd{color:var(--body);font-size:.94rem}
.cta-inline{background:var(--ink);color:#efe9dd;padding:40px 44px;margin:40px 0;text-align:center}
.cta-inline h3{color:#fbf9f4;font-size:1.6rem;margin-bottom:10px}
.cta-inline p{color:#cfc9bd;margin-bottom:22px;font-size:1rem}

/* ---------- journal index ---------- */
.jfeature{display:grid;grid-template-columns:1.2fr 1fr;gap:0;border:1px solid var(--line);margin-bottom:54px;background:#fff}
.jfeature .ph{min-height:380px;overflow:hidden}
.jfeature .txt{padding:54px 56px;display:flex;flex-direction:column;justify-content:center}
.jfeature h2{font-size:2.1rem;margin:12px 0 14px}
.jfeature p{color:var(--ink-soft);margin-bottom:22px}
.journal{display:grid;grid-template-columns:repeat(3,1fr);gap:34px 26px}
.post{cursor:pointer;display:block}
.post .ph{height:230px;overflow:hidden;margin-bottom:20px}
.post .ph img{transition:transform 1s}
.post:hover .ph img{transform:scale(1.06)}
.post .k{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass-deep);font-weight:700}
.post h3{font-size:1.34rem;margin:8px 0 10px;line-height:1.22}
.post p{color:var(--ink-soft);font-size:.95rem}
.post .read{margin-top:14px;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--ink);border-bottom:1.5px solid var(--brass);display:inline-block;padding-bottom:3px}

/* ---------- story page ---------- */
.story-hero{position:relative;height:64vh;min-height:440px;overflow:hidden;display:flex;align-items:flex-end}
.story-hero img{position:absolute;inset:0}
.story-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(18,27,34,.78),rgba(18,27,34,.1))}
.story-hero .inner{position:relative;z-index:2;color:#fff;padding-bottom:54px}
.story-hero h1{font-size:clamp(2.6rem,5vw,4rem);color:#fff}
.splittxt{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.splittxt.rev .imgcol{order:2}
.imgcol{position:relative;aspect-ratio:4/5;overflow:hidden;border:1px solid var(--line)}
.splittxt h2{font-size:2.1rem;margin-bottom:18px}
.splittxt p{color:var(--body);margin-bottom:16px;font-size:1.05rem}
.valband{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.valgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:46px}
.valgrid .item{text-align:center}
.valgrid .num{font-family:'Forum',serif;font-size:2.4rem;color:var(--brass);line-height:1}
.valgrid h3{font-size:1.35rem;margin:14px 0 10px}
.valgrid p{color:var(--ink-soft);font-size:.96rem}

/* ---------- makers band (homepage) ---------- */
.makers{background:var(--ink);color:#efe9dd}
.makers .wrap{display:grid;grid-template-columns:1.05fr 1fr;gap:0;align-items:stretch;padding:0;max-width:none}
.makers-img{position:relative;min-height:560px;overflow:hidden}
.makers-img img{filter:saturate(.96)}
.makers-img .stamp{position:absolute;bottom:26px;left:26px;z-index:2;width:118px;height:118px;border:1px solid rgba(255,255,255,.45);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#fff;background:rgba(20,30,38,.35);backdrop-filter:blur(2px)}
.makers-img .stamp b{font-family:'Forum',serif;font-size:.95rem;letter-spacing:.04em;line-height:1.1}
.makers-img .stamp span{font-size:.5rem;letter-spacing:.22em;text-transform:uppercase;margin-top:5px;opacity:.85}
.makers-txt{padding:92px 78px;display:flex;flex-direction:column;justify-content:center;max-width:680px}
.makers-txt .eyebrow{color:#e6d4ad}
.makers-txt h2{font-size:clamp(2rem,3vw,2.7rem);color:#fbf9f4;margin:16px 0 22px}
.makers-txt p{color:#cfc9bd;font-size:1.05rem;font-weight:300;margin-bottom:18px}
.makers-txt .sig{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.5rem;color:#e6d4ad;margin-top:10px}

/* ---------- materials band ---------- */
.mat .wrap{display:grid;grid-template-columns:repeat(3,1fr);gap:46px}
.mat .item{text-align:center}
.mat .num{font-family:'Forum',serif;font-size:2.4rem;color:var(--brass);line-height:1}
.mat h3{font-size:1.35rem;margin:14px 0 10px}
.mat p{color:var(--ink-soft);font-size:.96rem}

/* ---------- reviews ---------- */
.reviews{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.rgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.quote{background:var(--cream);padding:38px 32px;border:1px solid var(--line)}
.stars{color:var(--brass);letter-spacing:3px;font-size:.9rem;margin-bottom:16px}
.quote p{font-family:'Cormorant Garamond',serif;font-size:1.28rem;line-height:1.5;color:var(--ink);margin-bottom:18px}
.quote .who{font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brass-deep);font-weight:700}

/* ---------- email signup ---------- */
.signup{background:var(--sage-deep);color:#fff;text-align:center}
.signup h2{font-size:clamp(1.9rem,3vw,2.6rem);color:#fff;margin:14px 0 14px}
.signup p{color:#eef1ea;max-width:480px;margin:0 auto 30px;font-weight:300}
.signup .eyebrow{color:#e6d4ad}
.form{display:flex;max-width:480px;margin:0 auto;gap:0}
.form input{flex:1;padding:16px 20px;border:none;font-family:'Lato';font-size:.95rem;color:var(--ink)}
.form button{padding:16px 30px;background:var(--ink);color:#fff;border:none;font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;cursor:pointer;transition:.3s}
.form button:hover{background:var(--brass)}

/* ---------- footer ---------- */
footer{background:var(--ink);color:#bcb6aa;padding:74px 0 36px}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:50px;border-bottom:1px solid rgba(255,255,255,.12)}
.fcol h4{font-family:'Lato';font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:#e6d4ad;margin-bottom:18px;font-weight:700}
.fcol a{display:block;font-size:.92rem;margin-bottom:11px;color:#bcb6aa;transition:color .25s}
.fcol a:hover{color:#fff}
.fbrand .logo{color:#fbf9f4}
.fbrand p{font-size:.92rem;margin-top:18px;max-width:280px;font-weight:300;color:#aaa39a}
.fbot{display:flex;justify-content:space-between;align-items:center;padding-top:26px;font-size:.78rem;color:#8d877d;flex-wrap:wrap;gap:10px}
.fbot .made{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.05rem;color:#e6d4ad}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .wrap{padding:0 24px}
  .trust .wrap{display:none}
  .nav{flex-wrap:wrap;row-gap:10px}
  .menu{order:3;width:100%;gap:20px;font-size:.7rem;overflow-x:auto;white-space:nowrap;padding-bottom:2px;-webkit-overflow-scrolling:touch}
  .menu::-webkit-scrollbar{display:none}
  .menu a{flex:none}
  .cats,.grid,.rgrid,.journal,.mat .wrap,.valgrid{grid-template-columns:1fr 1fr}
  .makers .wrap,.pdp,.splittxt,.jfeature{grid-template-columns:1fr}
  .splittxt.rev .imgcol{order:0}
  .makers-txt{padding:56px 28px}
  .fgrid{grid-template-columns:1fr 1fr}
  .sec{padding:64px 0}
  .shop{grid-template-columns:1fr}
  .side{position:static;display:grid;grid-template-columns:1fr 1fr;gap:0 30px;margin-bottom:30px}
  .gallery{position:static}
}
@media(max-width:600px){
  .cats,.grid,.rgrid,.journal,.mat .wrap,.shop .grid,.valgrid,.fgrid{grid-template-columns:1fr}
  .hero{height:92vh}
  .gthumbs{grid-template-columns:repeat(5,1fr)}
}

/* ---------- conversion polish ---------- */
.finance{font-size:.86rem;color:var(--ink-soft);margin:-4px 0 16px}
.finance b{color:var(--brass-deep)}
.makerline{margin-top:20px;padding:16px 18px;background:var(--paper);border:1px solid var(--line);font-size:.9rem;color:var(--ink-soft);line-height:1.55}
.makerline b{color:var(--ink)}
.makerline a{color:var(--brass-deep);font-weight:700;border-bottom:1px solid var(--line)}
.makerline .nk{display:block;margin-top:8px;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}
.stickybar{position:fixed;left:0;right:0;bottom:0;z-index:60;display:none;gap:10px;padding:10px 16px;background:rgba(251,249,244,.97);border-top:1px solid var(--line);align-items:center}
.stickybar .sp{font-family:'Forum',serif;font-size:1.15rem;color:var(--ink);white-space:nowrap}
.stickybar .btn{flex:1;padding:12px 8px;font-size:.72rem}
@media(max-width:760px){.stickybar{display:flex}body{padding-bottom:64px}}
