:root{
  --bg:#0e0c0a;
  --surface:#16130f;
  --surface-2:#1d1813;
  --cream:#f7f1e6;
  --ink:#f2ece0;
  --muted:#9a9183;
  --line:#2a251e;
  --line-soft:#211c16;
  --accent:#c5a253;
  --accent-soft:#e6cf94;
  --accent-deep:#a8853c;
  --gold:#c5a253;
  --maxw:1260px;
  --serif:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --sans:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
}
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400&family=Inter:wght@400;500;600;700&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);line-height:1.7;font-size:16px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;letter-spacing:.005em;line-height:1.06}
img{display:block;max-width:100%;height:auto;object-fit:cover}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;color:inherit}
::selection{background:var(--accent);color:#0e0c0a}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.section{padding:96px 0}
.tint{background:var(--surface)}
.center{text-align:center}
.eyebrow{color:var(--accent);text-transform:uppercase;letter-spacing:.32em;font-weight:600;font-size:.7rem}
.eyebrow.light{color:var(--accent-soft)}
.section-head{margin-bottom:52px}
.section-head.center{display:flex;flex-direction:column;align-items:center;text-align:center}
.section-head.between{display:flex;justify-content:space-between;align-items:flex-end;gap:24px}
.section-head h2{font-size:clamp(2.2rem,4.6vw,3.6rem);margin-top:14px}
.section-head p{color:var(--muted);margin-top:14px;max-width:58ch;font-size:1.04rem}
.stars{color:var(--gold);letter-spacing:.14em}
.link-arrow{color:var(--accent);font-weight:500;letter-spacing:.04em;white-space:nowrap}
.link-arrow:hover{color:var(--accent-soft)}
.rte p{margin-bottom:1em}
.rte h2,.rte h3{margin:1.2em 0 .4em}
.rte ul{list-style:disc;padding-left:1.2em;margin-bottom:1em}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:2px;font-weight:500;padding:15px 32px;border:1px solid transparent;cursor:pointer;font-size:.82rem;text-transform:uppercase;letter-spacing:.18em;transition:transform .25s,box-shadow .25s,background .25s,border-color .25s,color .25s}
.btn:hover{transform:translateY(-2px)}
.btn-lg{padding:18px 40px}
.btn-primary{background:var(--accent);color:#0e0c0a}
.btn-primary:hover{background:var(--accent-soft);box-shadow:0 16px 36px rgba(197,162,83,.28)}
.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn-ghost-light{background:transparent;border:1px solid rgba(247,241,230,.5);color:#fff}
.btn-ghost-light:hover{border-color:#fff;background:rgba(247,241,230,.08)}
.btn-block{width:100%}

/* Price */
.price{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}
.price b,.price .reg{font-family:var(--serif);font-weight:600;font-size:1.5rem}
.price s{color:var(--muted);font-size:1rem}

/* Announcement */
.announce{overflow:hidden;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;border-bottom:1px solid var(--line);padding:11px 0;background:#0e0c0a;color:#e9e2d4}
.announce-track{display:flex;width:max-content;animation:marquee 32s linear infinite}
.announce-group{display:flex;align-items:center}
.announce-group span{padding:0 6px;white-space:nowrap}
.announce-group .dot{color:var(--accent);padding:0 22px}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Header */
header.site{position:sticky;top:0;z-index:90;background:rgba(14,12,10,.85);border-bottom:1px solid var(--line);backdrop-filter:saturate(140%) blur(10px)}
header.site.is-scrolled{box-shadow:0 12px 30px rgba(0,0,0,.45)}
.nav{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:18px;padding-top:22px;padding-bottom:22px}
.logo{display:flex;flex-direction:column;align-items:center;line-height:1}
.logo .name{font-family:var(--serif);font-size:1.65rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;padding-left:.28em}
.logo .tag{font-size:.58rem;letter-spacing:.36em;text-transform:uppercase;color:var(--muted);margin-top:6px}
.nav-links{grid-column:1;justify-self:start;display:flex;gap:30px}
.nav-links a{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);position:relative;padding:4px 0;transition:color .2s}
.nav-links a::after{content:'';position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--accent);transition:width .3s}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.logo-center{grid-column:2;justify-self:center}
.nav-right{grid-column:3;justify-self:end;display:flex;align-items:center;gap:6px}
.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:2px;background:transparent;border:none;cursor:pointer;color:var(--ink);position:relative;transition:color .2s,background .2s}
.icon-btn:hover{color:var(--accent);background:var(--surface-2)}
.icon-btn svg{width:20px;height:20px}
.cart-count{position:absolute;top:5px;right:4px;background:var(--accent);color:#0e0c0a;font-size:.62rem;font-weight:700;min-width:16px;height:16px;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 4px}
.menu-toggle{display:none}
.mobile-menu{border-top:1px solid var(--line);padding:14px 32px 22px}
.mobile-menu ul{display:flex;flex-direction:column;gap:4px}
.mobile-menu a{display:block;padding:12px 0;font-size:1rem;letter-spacing:.08em;text-transform:uppercase;border-bottom:1px solid var(--line-soft)}

/* Hero */
.hero{position:relative;min-height:88vh;display:flex;align-items:flex-end;overflow:hidden}
.hero-media{position:absolute;inset:0}
.hero-media img{width:100%;height:100%;object-fit:cover;animation:heroZoom 14s ease-out forwards}
@keyframes heroZoom{from{transform:scale(1.12)}to{transform:scale(1)}}
.hero-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,12,10,.4) 0%,rgba(14,12,10,.15) 40%,rgba(14,12,10,.92) 100%)}
.hero-inner{position:relative;width:100%;padding-bottom:120px;padding-top:120px}
.hero-text{max-width:680px}
.hero-text .eyebrow{display:inline-block;animation:fadeUp .9s ease both}
.hero-text h1{font-size:clamp(2.8rem,7vw,6rem);margin-top:20px;font-weight:600;letter-spacing:.01em;animation:fadeUp 1s ease .1s both}
.hero-text h1 em{font-style:italic;color:var(--accent-soft)}
.hero-text p{margin-top:24px;font-size:1.12rem;color:#d8d0c0;max-width:54ch;animation:fadeUp 1s ease .2s both}
.hero-cta{margin-top:38px;display:flex;gap:16px;flex-wrap:wrap;animation:fadeUp 1s ease .3s both}
.hero-scroll{position:absolute;right:32px;bottom:38px;font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);writing-mode:vertical-rl;animation:floatY 2.4s ease-in-out infinite}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}

/* USP */
.usp{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:30px 0;background:var(--surface)}
.usp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.usp-item{display:flex;align-items:center;gap:14px}
.usp-item svg{width:30px;height:30px;color:var(--accent);flex-shrink:0}
.usp-item b{display:block;font-size:.92rem}
.usp-item span{color:var(--muted);font-size:.82rem}

/* Collection list */
.coll-grid{display:grid;grid-template-columns:repeat(var(--cols,4),1fr);gap:22px}
.coll{position:relative;display:block;overflow:hidden;border-radius:2px}
.coll img{width:100%;aspect-ratio:7/9;transition:transform .8s cubic-bezier(.2,.8,.2,1)}
.coll:hover img{transform:scale(1.06)}
.coll::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,12,10,0) 40%,rgba(14,12,10,.88) 100%)}
.coll-ov{position:absolute;left:0;right:0;bottom:0;padding:26px;z-index:2;text-align:center}
.coll-ov h3{font-size:1.7rem;letter-spacing:.04em}
.coll-ov span{display:inline-block;margin-top:8px;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent-soft)}

/* Product grid / cards */
.pgrid{display:grid;grid-template-columns:repeat(var(--cols,4),1fr);gap:26px}
.card{display:flex;flex-direction:column}
.card-media{position:relative;overflow:hidden;border-radius:2px;background:var(--surface-2)}
.card-media img{width:100%;aspect-ratio:4/5;transition:transform .8s cubic-bezier(.2,.8,.2,1)}
.card:hover .card-media img{transform:scale(1.05)}
.card-tag{position:absolute;top:14px;left:14px;z-index:2;background:var(--accent);color:#0e0c0a;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;padding:5px 11px;border-radius:2px;font-weight:600}
.card-body{padding:20px 4px 0;display:flex;flex-direction:column;gap:8px;text-align:center;align-items:center}
.card-cat{font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.card-title{font-size:1.4rem;font-weight:500}
.card-title a:hover{color:var(--accent)}
.card-notes{color:var(--muted);font-size:.85rem;font-style:italic;font-family:var(--serif)}
.card .price{justify-content:center}
.card .price .reg{font-size:1.3rem}
.card-add{width:100%;margin-top:6px;font-size:.7rem;padding:13px 20px}

/* Image with text */
.iwt{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.iwt.rev{direction:rtl}
.iwt.rev>*{direction:ltr}
.iwt-media{position:relative;overflow:hidden;border-radius:2px}
.iwt-media img{width:100%;aspect-ratio:5/4}
.iwt-badge{position:absolute;bottom:22px;left:22px;background:var(--bg);color:var(--accent);border:1px solid var(--accent);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;padding:9px 16px;border-radius:2px}
.iwt-text h2{font-size:clamp(2rem,3.6vw,3rem);margin:14px 0 18px}
.iwt-text p{color:var(--muted)}
.iwt-list{margin:22px 0 28px;display:flex;flex-direction:column;gap:12px}
.iwt-list li{display:flex;align-items:center;gap:12px}
.iwt-list svg{width:18px;height:18px;color:var(--accent);flex-shrink:0}

/* Scent finder */
.scent-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.scent{display:block;text-align:center;padding:42px 26px;border:1px solid var(--line);border-radius:2px;background:var(--bg);transition:transform .35s,border-color .35s,background .35s}
.scent:hover{transform:translateY(-6px);border-color:var(--accent);background:var(--surface-2)}
.scent svg{width:36px;height:36px;color:var(--accent);margin-bottom:18px}
.scent h3{font-size:1.6rem;margin-bottom:8px}
.scent p{color:var(--muted);font-size:.9rem;margin-bottom:14px}
.scent-notes{font-family:var(--serif);font-style:italic;color:var(--accent-soft);font-size:1rem}

/* Featured product */
.fprod{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.fprod-media{position:relative;overflow:hidden;border-radius:2px}
.fprod-media img{width:100%;aspect-ratio:10/11}
.fprod-badge{position:absolute;top:22px;left:22px;background:var(--accent);color:#0e0c0a;font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;padding:8px 14px;border-radius:2px;font-weight:600}
.fprod-text h2{font-size:clamp(2.2rem,4vw,3.4rem);margin:14px 0 12px}
.fprod-text>p{color:var(--muted);margin-top:18px}
.fprod-notes{margin:28px 0;border-top:1px solid var(--line)}
.fprod-note{display:flex;justify-content:space-between;gap:20px;padding:14px 0;border-bottom:1px solid var(--line)}
.fprod-note .lbl{text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:var(--muted)}
.fprod-note .val{font-family:var(--serif);font-style:italic;color:var(--accent-soft);font-size:1.05rem}
.fprod-buy{display:flex;align-items:center;gap:28px;flex-wrap:wrap}

/* Testimonials */
.tgrid{display:grid;grid-template-columns:repeat(var(--cols,3),1fr);gap:24px}
.tcard{background:var(--bg);border:1px solid var(--line);border-radius:2px;padding:36px 30px;display:flex;flex-direction:column;gap:16px;transition:border-color .3s,transform .3s}
.tint .tcard{background:var(--surface-2)}
.tcard:hover{border-color:var(--accent);transform:translateY(-4px)}
.tcard blockquote{font-family:var(--serif);font-size:1.3rem;line-height:1.4}
.who{display:flex;align-items:center;gap:12px;margin-top:auto}
.who img{width:48px;height:48px;border-radius:999px}
.who b{display:block;font-size:.92rem}
.who small{color:var(--accent);font-size:.74rem}

/* Instagram */
.ig-handle{display:inline-flex;align-items:center;gap:8px;margin-top:14px;color:var(--accent);letter-spacing:.06em}
.ig-handle svg{width:20px;height:20px}
.ig-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.ig-item{position:relative;overflow:hidden;border-radius:2px;display:block}
.ig-item img{width:100%;aspect-ratio:1;transition:transform .6s}
.ig-item:hover img{transform:scale(1.08)}
.ig-hover{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(14,12,10,.55);color:var(--accent-soft);opacity:0;transition:opacity .3s}
.ig-item:hover .ig-hover{opacity:1}
.ig-hover svg{width:28px;height:28px}

/* FAQ */
.faq-wrap{max-width:840px;margin:0 auto}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{display:flex;align-items:center;justify-content:space-between;gap:20px;cursor:pointer;list-style:none;padding:24px 0;font-family:var(--serif);font-size:1.4rem}
.faq-q::-webkit-details-marker{display:none}
.faq-icon{color:var(--accent);font-size:1.5rem;transition:transform .3s;line-height:1}
.faq-item[open] .faq-icon{transform:rotate(45deg)}
.faq-a{padding:0 0 24px;color:var(--muted);max-width:64ch}

/* Newsletter */
.news{text-align:center;max-width:620px;margin:0 auto;background:var(--surface-2);border:1px solid var(--line);padding:64px 40px;border-radius:2px}
.news h2{font-size:clamp(2rem,3.6vw,2.8rem);margin:14px 0 14px}
.news p{color:var(--muted)}
.news form{display:flex;gap:10px;max-width:440px;margin:28px auto 0}
.news input[type=email]{flex:1;padding:15px 18px;background:var(--bg);border:1px solid var(--line);border-radius:2px;color:var(--ink);font-family:inherit}
.news input:focus{outline:none;border-color:var(--accent)}

/* CTA band */
.cta-band{display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;background:linear-gradient(120deg,var(--surface),var(--surface-2));border:1px solid var(--line);border-radius:2px;padding:56px;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;top:-40%;right:-10%;width:380px;height:380px;background:radial-gradient(circle,rgba(197,162,83,.18),transparent 70%)}
.cta-band>*{position:relative;z-index:1}
.cta-band h2{font-size:clamp(1.9rem,3.4vw,2.8rem);margin-top:12px}
.cta-band p{color:var(--muted);margin-top:12px;max-width:52ch}

/* Page hero (subpages) */
.page-hero{padding:64px 0 28px;border-bottom:1px solid var(--line)}
.page-hero h1{font-size:clamp(2.6rem,5vw,4rem);margin-top:14px}
.page-hero p{color:var(--muted);margin-top:14px;max-width:60ch}
.breadcrumb{font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.breadcrumb a:hover{color:var(--accent)}

/* Shop toolbar */
.toolbar{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;margin:36px 0;padding-bottom:24px;border-bottom:1px solid var(--line)}
.filters{display:flex;gap:10px;flex-wrap:wrap}
.filter-pill{padding:9px 18px;border:1px solid var(--line);border-radius:2px;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);cursor:pointer;transition:all .2s;background:none}
.filter-pill:hover,.filter-pill.active{border-color:var(--accent);color:var(--accent)}
.sort select{padding:11px 16px;background:var(--surface-2);border:1px solid var(--line);border-radius:2px;color:var(--ink);font-family:inherit;font-size:.82rem;cursor:pointer}

/* PDP */
.pdp{padding:48px 0 96px}
.pdp-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:start}
.pdp-media{position:sticky;top:110px}
.pdp-main img{width:100%;aspect-ratio:11/13;border-radius:2px;background:var(--surface-2)}
.pdp-thumbs{display:flex;gap:12px;margin-top:14px}
.pdp-thumbs img{width:90px;height:110px;border:1px solid var(--line);border-radius:2px;cursor:pointer;transition:border-color .2s}
.pdp-thumbs img:hover,.pdp-thumbs img.sel{border-color:var(--accent)}
.pdp-info h1{font-size:clamp(2.4rem,4.4vw,3.6rem);margin:10px 0 16px}
.pdp-rating{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.pdp-rating span{color:var(--muted);font-size:.86rem}
.pdp-desc{color:var(--muted);margin:24px 0}
.notes{border-top:1px solid var(--line);margin:24px 0}
.notes-row{display:flex;justify-content:space-between;gap:20px;padding:13px 0;border-bottom:1px solid var(--line)}
.notes-row .lbl{text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;color:var(--muted)}
.notes-row .val{font-family:var(--serif);font-style:italic;color:var(--accent-soft);font-size:1.05rem}
.pdp-opt{margin:24px 0}
.pdp-opt>label{display:block;text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;color:var(--muted);margin-bottom:12px}
.pills{display:flex;gap:10px;flex-wrap:wrap}
.pill{padding:11px 20px;border:1px solid var(--line);border-radius:2px;font-size:.82rem;letter-spacing:.06em;cursor:pointer;transition:all .2s;background:none}
.pill:hover{border-color:var(--accent)}
.pill.active{border-color:var(--accent);background:rgba(197,162,83,.1);color:var(--accent-soft)}
.pdp-buy{display:flex;gap:14px;margin:28px 0}
.qty{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:2px;overflow:hidden}
.qty button{width:46px;background:none;border:none;cursor:pointer;color:var(--ink);font-size:1.2rem;padding:13px 0}
.qty button:hover{color:var(--accent)}
.qty input{width:52px;text-align:center;border:none;border-left:1px solid var(--line);border-right:1px solid var(--line);background:var(--bg);color:var(--ink);font-family:inherit;padding:13px 0;-moz-appearance:textfield}
.qty input::-webkit-outer-spin-button,.qty input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.pdp-add{flex:1}
.trust-row{display:flex;flex-wrap:wrap;gap:18px;padding:22px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin:8px 0 24px}
.trust-row span{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-size:.8rem}
.trust-row svg{width:18px;height:18px;color:var(--accent)}
.pdp-related{margin-top:80px}

/* sticky atc */
.sticky-atc{position:fixed;left:0;right:0;bottom:0;z-index:80;background:rgba(14,12,10,.96);border-top:1px solid var(--line);backdrop-filter:blur(10px);animation:slideUp .4s ease}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.sticky-atc-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:14px 0}
.sticky-atc-info{display:flex;align-items:center;gap:14px}
.sticky-atc-info img{width:48px;height:56px;border-radius:2px}
.sticky-atc-info b{display:block;font-family:var(--serif);font-size:1.1rem}

/* Reviews on PDP */
.reviews-block{margin-top:64px;border-top:1px solid var(--line);padding-top:48px}
.review{padding:24px 0;border-bottom:1px solid var(--line-soft)}
.review .who{margin-top:0;margin-bottom:8px}
.review p{color:var(--muted)}

/* Cart page */
.cart-page{padding:64px 0 96px}
.cart-page h1{font-size:clamp(2.4rem,4.4vw,3.4rem);margin-bottom:36px}
.cart-row{display:grid;grid-template-columns:auto 1fr auto auto auto;gap:18px;align-items:center;padding:22px 0;border-bottom:1px solid var(--line)}
.cart-row img{width:90px;height:110px;border-radius:2px}
.cart-row .cname{font-family:var(--serif);font-size:1.3rem}
.cart-row .cvar{color:var(--muted);font-size:.85rem}
.cart-row .lt{font-family:var(--serif);font-size:1.25rem;color:var(--accent)}
.rm{color:var(--muted);font-size:.76rem;text-decoration:underline;background:none;border:none;cursor:pointer}
.rm:hover{color:var(--accent)}
.cart-foot{margin-top:34px;display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.cart-sub{display:flex;gap:30px;align-items:baseline;font-size:1.1rem}
.cart-sub strong{font-family:var(--serif);font-size:1.8rem;color:var(--accent)}
.cart-note{color:var(--muted);font-size:.82rem}
.cart-actions{display:flex;gap:12px;margin-top:14px}
.cart-empty{text-align:center;padding:60px 0}
.cart-empty p{color:var(--muted);margin-bottom:22px}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.form-field{margin-bottom:20px}
.form-field label{display:block;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.form-field input,.form-field textarea,.form-field select{width:100%;padding:14px 16px;background:var(--surface-2);border:1px solid var(--line);border-radius:2px;color:var(--ink);font-family:inherit}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{outline:none;border-color:var(--accent)}
.form-field textarea{min-height:140px;resize:vertical}
.form-field.invalid input,.form-field.invalid textarea{border-color:#d98a82}
.form-field .err{display:none;color:#d98a82;font-size:.78rem;margin-top:6px}
.form-field.invalid .err{display:block}
.form-success{display:none;background:rgba(197,162,83,.12);border:1px solid var(--accent);color:var(--accent-soft);padding:16px;border-radius:2px;margin-bottom:18px}
.contact-info{background:var(--surface-2);border:1px solid var(--line);border-radius:2px;padding:36px}
.contact-info h3{font-size:1.5rem;margin-bottom:18px}
.contact-info .info-row{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--line-soft)}
.contact-info .info-row svg{width:20px;height:20px;color:var(--accent);flex-shrink:0;margin-top:3px}
.contact-info small{color:var(--muted);display:block}

/* Blog */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.bcard{display:flex;flex-direction:column}
.bcard .media{overflow:hidden;border-radius:2px}
.bcard img{width:100%;aspect-ratio:35/23;transition:transform .7s}
.bcard:hover img{transform:scale(1.05)}
.bcard .body{padding:20px 0 0}
.bcard .date{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.bcard h2{font-size:1.6rem;margin:10px 0 10px}
.bcard h2 a:hover{color:var(--accent)}
.bcard p{color:var(--muted);font-size:.92rem;margin-bottom:12px}
.bcard .more{color:var(--accent);font-size:.82rem;letter-spacing:.08em}

/* Footer */
footer.site{border-top:1px solid var(--line);padding:72px 0 40px;background:var(--surface)}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
.foot-brand .name{font-family:var(--serif);font-size:1.4rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase}
.foot-brand p{color:var(--muted);margin-top:16px;max-width:34ch;font-size:.9rem}
.foot-social{display:flex;gap:10px;margin-top:20px}
.foot-social a{display:inline-flex;width:40px;height:40px;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:2px;color:var(--muted);transition:all .2s}
.foot-social a svg{width:18px;height:18px}
.foot-social a:hover{border-color:var(--accent);color:var(--accent)}
.foot-col h4{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;font-family:var(--sans);margin-bottom:18px}
.foot-col ul{display:flex;flex-direction:column;gap:11px}
.foot-col a{color:var(--muted);font-size:.88rem}
.foot-col a:hover{color:var(--accent)}
.foot-pay{display:flex;flex-wrap:wrap;gap:8px;margin-top:48px;padding-top:28px;border-top:1px solid var(--line)}
.foot-pay span{font-size:.66rem;color:var(--muted);border:1px solid var(--line);padding:5px 10px;border-radius:2px}
.foot-disclaimer{color:var(--muted);font-size:.74rem;margin-top:22px;max-width:90ch;line-height:1.7}
.foot-bottom{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-top:24px;padding-top:22px;border-top:1px solid var(--line);color:var(--muted);font-size:.8rem}

/* Reveal */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}
.reveal.is-visible{opacity:1;transform:none}

/* Responsive */
@media (max-width:1100px){
  .pgrid,.coll-grid{grid-template-columns:repeat(2,1fr)!important}
  .scent-grid,.usp-grid{grid-template-columns:repeat(2,1fr)}
  .ig-grid{grid-template-columns:repeat(3,1fr)}
  .tgrid{grid-template-columns:1fr 1fr!important}
  .foot-grid,.blog-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:860px){
  .section{padding:64px 0}
  .wrap{padding:0 22px}
  .nav{grid-template-columns:auto 1fr auto}
  .menu-toggle{display:inline-flex}
  .nav-links{display:none}
  .iwt,.fprod,.pdp-grid,.contact-grid{grid-template-columns:1fr;gap:36px}
  .pdp-media{position:static}
  .iwt.rev{direction:ltr}
  .hero{min-height:78vh}.hero-inner{padding-bottom:80px}
}
@media (max-width:600px){
  .pgrid,.coll-grid,.tgrid,.blog-grid,.scent-grid,.usp-grid,.foot-grid{grid-template-columns:1fr!important}
  .ig-grid{grid-template-columns:repeat(2,1fr)}
  .cart-row{grid-template-columns:auto 1fr;row-gap:8px}
  .pdp-buy,.news form{flex-direction:column}
  .hero-scroll{display:none}
}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .reveal{opacity:1;transform:none}
  .hero-media img{animation:none}
}
