/* ============================================================
   GlowMerald — Quiet-luxury masstige skincare
   Cream + gold dominant · emerald as a rare jewel accent
   Mobile-first
   ============================================================ */

:root{
  /* Neutrals */
  --cream:#FAF7F0;          /* page bg (light) */
  --cream-deep:#F2E9D8;     /* accent bg band */
  --paper:#FFFDF8;          /* card surface */
  --ink:#2C2C2A;            /* charcoal text */
  --ink-soft:#55504733;     /* (unused token slot) */
  --text:#33302A;           /* default body text */
  --muted:#8A8475;          /* warm muted text */
  --line:#E7DFCF;           /* hairline divider */
  --line-2:#D9CEB7;         /* stronger divider */
  /* Gold (primary accent) */
  --gold:#C4A052;
  --gold-deep:#A0751F;      /* gold text / hover */
  --gold-soft:#E8D9AE;      /* light gold wash */
  --gold-hi:#F4E08C;
  /* Emerald (rare jewel accent) */
  --emerald:#0B493A;
  --emerald-mid:#1A6B55;
  --emerald-wash:#E8F2EF;
  /* Dark surfaces */
  --dark:#211C16;           /* warm near-black hero/footer */
  --dark-2:#2C2620;
  --on-dark:#F6EFE2;        /* cream text on dark */
  --on-dark-muted:#B6AC97;

  --radius:3px;
  --radius-lg:6px;
  --maxw:1240px;
  --nav-h:64px;

  --serif:'Playfair Display', Georgia, serif;
  --sans:'Montserrat', system-ui, sans-serif;
}

*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
body{
  font-family:var(--sans);
  font-weight:400;
  color:var(--text);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.6;
}
img{ display:block; max-width:100%; }
button{ font-family:inherit; cursor:pointer; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--gold-soft); color:var(--ink); }

/* ---- Typography ---- */
.serif{ font-family:var(--serif); font-weight:400; }
.ital{ font-family:var(--serif); font-style:italic; font-weight:400; }
h1,h2,h3,h4{ font-family:var(--serif); font-weight:400; color:var(--ink); margin:0; line-height:1.12; letter-spacing:.2px; }
h1{ font-size:clamp(2.1rem,8vw,3.6rem); }
h2{ font-size:clamp(1.7rem,5vw,2.5rem); }
h3{ font-size:1.25rem; }
p{ margin:0 0 1em; text-wrap:pretty; }

.eyebrow{
  font-family:var(--sans); font-weight:500; font-size:.68rem;
  letter-spacing:.32em; text-transform:uppercase; color:var(--gold-deep);
  margin:0 0 1rem;
}
.eyebrow.on-dark{ color:var(--gold); }
.muted{ color:var(--muted); }
.center{ text-align:center; }

/* ---- Layout ---- */
.container{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 20px; }
.section{ padding:64px 0; }
@media(min-width:768px){ .section{ padding:96px 0; } }
.app{ min-height:100vh; display:flex; flex-direction:column; }
main{ flex:1; }
.pad-bottom-nav{ padding-bottom:72px; }
@media(min-width:900px){ .pad-bottom-nav{ padding-bottom:0; } }

/* ---- Hairline divider + deco ---- */
.hr-gold{ height:1px; background:linear-gradient(90deg,transparent,var(--gold) 18%,var(--gold) 82%,transparent); border:0; opacity:.55; margin:0; }
.rule{ display:flex; align-items:center; gap:14px; justify-content:center; color:var(--gold-deep); }
.rule::before,.rule::after{ content:""; height:1px; width:48px; background:var(--gold); opacity:.5; }
.deco-circle{ position:absolute; border:1px solid var(--gold); border-radius:50%; opacity:.18; pointer-events:none; }

/* ---- Buttons ---- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--sans); font-weight:600; font-size:.74rem;
  letter-spacing:.16em; text-transform:uppercase;
  padding:15px 28px; border-radius:var(--radius); border:1px solid transparent;
  transition:all .25s ease; white-space:nowrap; line-height:1;
}
.btn-gold{ background:var(--gold); color:var(--ink); border-color:var(--gold); }
.btn-gold:hover{ background:var(--gold-deep); border-color:var(--gold-deep); color:#fff; }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line-2); }
.btn-ghost:hover{ border-color:var(--gold); color:var(--gold-deep); }
.btn-ghost.on-dark{ color:var(--on-dark); border-color:#5a5040; }
.btn-ghost.on-dark:hover{ border-color:var(--gold); color:var(--gold); }
.btn-dark{ background:var(--ink); color:var(--cream); }
.btn-dark:hover{ background:#000; }
.btn-block{ width:100%; }
.btn-sm{ padding:11px 18px; font-size:.66rem; }
.btn[disabled]{ opacity:.45; cursor:not-allowed; }
.btn .added{ display:inline-flex; align-items:center; gap:7px; }

.link-gold{ color:var(--gold-deep); font-weight:500; font-size:.8rem; letter-spacing:.04em; display:inline-flex; align-items:center; gap:7px; border-bottom:1px solid transparent; transition:.2s; }
.link-gold:hover{ border-color:var(--gold); }

/* ---- Chips ---- */
.chips{ display:flex; flex-wrap:wrap; gap:6px; }
.chip{
  font-size:.62rem; letter-spacing:.1em; text-transform:uppercase; font-weight:500;
  padding:5px 10px; border:1px solid var(--line-2); border-radius:100px; color:var(--ink);
  background:transparent; white-space:nowrap;
}
.chip.ghost-gold{ border-color:var(--gold-soft); color:var(--gold-deep); }
.chip.filled{ background:var(--cream-deep); border-color:var(--cream-deep); }

/* ---- Stars ---- */
.stars{ display:inline-flex; align-items:center; gap:1px; color:var(--gold); }
.stars svg{ width:14px; height:14px; }
.stars .empty{ color:var(--line-2); }

/* ---- Cards ---- */
.card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; transition:border-color .25s, transform .25s; }
.card:hover{ border-color:var(--gold-soft); }

/* Product card */
.pcard{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; display:flex; flex-direction:column; transition:border-color .25s, box-shadow .3s; position:relative; }
.pcard:hover{ border-color:var(--gold-soft); }
.pcard .pcard-media{ position:relative; cursor:pointer; }
.pcard .pcard-body{ padding:18px 18px 20px; display:flex; flex-direction:column; gap:10px; flex:1; }
.pcard .pname{ font-family:var(--serif); font-size:1.12rem; line-height:1.2; color:var(--ink); cursor:pointer; }
.pcard .price{ font-weight:500; font-size:1rem; color:var(--ink); letter-spacing:.01em; }
.pcard .price .strike{ color:var(--muted); text-decoration:line-through; font-weight:300; font-size:.82rem; margin-left:8px; }
.badge-best{ position:absolute; top:12px; left:12px; z-index:2; background:var(--emerald); color:#EAD9A6; font-size:.58rem; letter-spacing:.18em; text-transform:uppercase; font-weight:600; padding:6px 11px; border-radius:2px; }
.badge-save{ position:absolute; top:12px; left:12px; z-index:2; background:var(--gold); color:var(--ink); font-size:.6rem; letter-spacing:.1em; font-weight:600; padding:6px 11px; border-radius:2px; }
.wish-btn{ position:absolute; top:10px; right:10px; z-index:2; width:36px; height:36px; border-radius:50%; background:rgba(255,253,248,.86); border:1px solid var(--line); display:flex; align-items:center; justify-content:center; color:var(--ink); transition:.2s; }
.wish-btn:hover{ color:var(--gold-deep); border-color:var(--gold-soft); }
.wish-btn.active{ color:#b5483f; border-color:#e7c2bd; }

/* ---- Product visual stand-ins (CSS rendered) ---- */
.prod-visual{ aspect-ratio:1/1; display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; }
.prod-visual.serum{ background:radial-gradient(120% 100% at 50% 0%, #F7EEDD 0%, #EFE2C9 60%, #E7D6B6 100%); }
.prod-visual.mask{ background:radial-gradient(120% 100% at 50% 0%, #EFF4F1 0%, #E2ECE7 70%, #D7E5DE 100%); }
.prod-visual.bundle{ background:radial-gradient(120% 100% at 50% 0%, #F4ECF0 0%, #EFE3D6 100%); }
.prod-visual .pv-tag{ position:absolute; bottom:12px; left:0; right:0; text-align:center; font-family:'Montserrat',monospace; font-size:.58rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); }

/* serum bottle */
.bottle{ position:relative; width:78px; height:170px; filter:drop-shadow(0 8px 16px rgba(120,90,30,.12)); }
.bottle .cap{ position:absolute; top:0; left:50%; transform:translateX(-50%); width:34px; height:30px; background:linear-gradient(180deg,#5b4a2c,#3c2f1a); border-radius:3px 3px 1px 1px; }
.bottle .collar{ position:absolute; top:28px; left:50%; transform:translateX(-50%); width:42px; height:8px; background:#cdb375; border-radius:2px; }
.bottle .glass{ position:absolute; top:34px; left:50%; transform:translateX(-50%); width:72px; height:132px; border-radius:8px 8px 12px 12px; background:linear-gradient(150deg, rgba(196,134,42,.92), rgba(150,96,22,.95)); overflow:hidden; }
.bottle .glass::after{ content:""; position:absolute; top:8px; left:9px; width:13px; height:96px; border-radius:8px; background:linear-gradient(180deg,rgba(255,255,255,.5),rgba(255,255,255,0)); }
.bottle .label{ position:absolute; bottom:18px; left:50%; transform:translateX(-50%); width:54px; height:56px; background:var(--cream); border-radius:2px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:4px; }
.bottle .label .lg{ font-family:var(--serif); font-size:.9rem; color:var(--emerald); }
.bottle .label .ll{ width:26px; height:1px; background:var(--gold); }
.bottle .label .ls{ font-size:.4rem; letter-spacing:.12em; color:var(--gold-deep); text-transform:uppercase; }

/* mask pouch */
.pouch{ position:relative; width:128px; height:158px; background:linear-gradient(160deg,#F3F8F5,#E4EFE9); border-radius:6px; border:1px solid #D6E4DD; filter:drop-shadow(0 8px 16px rgba(20,80,60,.1)); display:flex; align-items:center; justify-content:center; }
.pouch::before{ content:""; position:absolute; top:0; left:0; right:0; height:14px; background:repeating-linear-gradient(90deg,#cdb375 0 5px, #e3d3a5 5px 10px); border-radius:6px 6px 0 0; }
.pouch .pl{ text-align:center; display:flex; flex-direction:column; align-items:center; gap:6px; }
.pouch .pl .lg{ font-family:var(--serif); font-size:1.3rem; color:var(--emerald); }
.pouch .pl .ld{ width:34px; height:1px; background:var(--gold); }
.pouch .pl .ls{ font-size:.46rem; letter-spacing:.22em; color:var(--gold-deep); text-transform:uppercase; }

/* generic striped placeholder */
.ph{ position:relative; background:
    repeating-linear-gradient(45deg, rgba(138,132,117,.07) 0 10px, rgba(138,132,117,.0) 10px 20px), var(--cream-deep);
  display:flex; align-items:center; justify-content:center; color:var(--muted);
  font-family:'Montserrat',monospace; font-size:.62rem; letter-spacing:.16em; text-transform:uppercase; text-align:center; padding:10px; }
.ph.circle{ border-radius:50%; }
.avatar{ border-radius:50%; overflow:hidden; background:var(--cream-deep); display:flex; align-items:center; justify-content:center; font-family:var(--serif); color:var(--gold-deep); }

/* ---- Forms ---- */
label.field{ display:block; margin-bottom:14px; }
.field .lab{ display:block; font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-bottom:6px; font-weight:500; }
input[type=text],input[type=email],input[type=tel],input[type=number],select,textarea{
  width:100%; font-family:var(--sans); font-size:.92rem; color:var(--ink);
  padding:12px 14px; border:1px solid var(--line-2); border-radius:var(--radius);
  background:var(--paper); transition:.2s; }
input:focus,select:focus,textarea:focus{ outline:none; border-color:var(--gold); box-shadow:0 0 0 3px var(--gold-soft); }
.qty{ display:inline-flex; align-items:center; border:1px solid var(--line-2); border-radius:var(--radius); overflow:hidden; }
.qty button{ width:38px; height:40px; background:var(--paper); border:0; color:var(--ink); font-size:1.1rem; }
.qty button:hover{ background:var(--cream-deep); }
.qty span{ min-width:40px; text-align:center; font-weight:500; }

/* ---- Toast ---- */
.toast-wrap{ position:fixed; left:0; right:0; bottom:84px; z-index:300; display:flex; flex-direction:column; align-items:center; gap:8px; pointer-events:none; padding:0 16px; }
@media(min-width:900px){ .toast-wrap{ bottom:28px; } }
.toast{ pointer-events:auto; background:var(--ink); color:var(--cream); padding:13px 18px; border-radius:var(--radius); font-size:.82rem; display:flex; align-items:center; gap:11px; box-shadow:0 10px 30px rgba(0,0,0,.18); animation:toastIn .35s cubic-bezier(.2,.8,.2,1); max-width:380px; }
.toast .tdot{ color:var(--gold); display:flex; }
@keyframes toastIn{ from{ opacity:0; transform:translateY(14px); } to{ opacity:1; transform:none; } }

/* ---- Skeleton ---- */
.skeleton{ background:linear-gradient(90deg,var(--cream-deep) 25%, #EDE3D2 50%, var(--cream-deep) 75%); background-size:200% 100%; animation:shimmer 1.3s infinite; border-radius:var(--radius); }
@keyframes shimmer{ from{ background-position:200% 0; } to{ background-position:-200% 0; } }

/* ---- Generic grids ---- */
.grid{ display:grid; gap:18px; }
.grid-2{ grid-template-columns:1fr; }
.grid-3{ grid-template-columns:repeat(2,1fr); }
@media(min-width:560px){ .grid-2{ grid-template-columns:repeat(2,1fr); } }
@media(min-width:900px){ .grid-3{ grid-template-columns:repeat(3,1fr); } }

/* ---- Nav ---- */
.navicon{ background:none; border:0; color:inherit; display:flex; padding:8px; border-radius:50%; transition:.2s; position:relative; }
.navicon:hover{ color:var(--gold-deep); }
.nav-badge{ position:absolute; top:0; right:0; min-width:17px; height:17px; padding:0 4px; border-radius:9px; background:var(--gold); color:var(--ink); font-size:.58rem; font-weight:600; display:flex; align-items:center; justify-content:center; }
.navlinks{ display:none; }
.navhide-desk{ display:flex; }
@media(min-width:900px){
  .navlinks{ display:flex; }
  .navhide-desk{ display:none; }
  .nav-logo{ margin-left:0; }
}
@media(max-width:899px){
  .navhide-mob{ display:none; }
  .nav-logo{ margin:0 auto; position:absolute; left:50%; transform:translateX(-50%); }
}

/* Drawer */
.drawer-overlay{ position:fixed; inset:0; z-index:400; background:rgba(33,28,22,.45); animation:fadeIn .25s; }
@keyframes fadeIn{ from{opacity:0} to{opacity:1} }
.drawer{ position:absolute; top:0; left:0; bottom:0; width:min(82vw,330px); background:var(--cream); padding:24px 26px; box-shadow:2px 0 40px rgba(0,0,0,.15); animation:slideIn .3s cubic-bezier(.2,.8,.2,1); overflow-y:auto; }
@keyframes slideIn{ from{ transform:translateX(-100%);} to{ transform:none; } }
.drawer-link{ font-family:var(--serif); font-size:1.5rem; color:var(--ink); padding:13px 0; border-bottom:1px solid var(--line); cursor:pointer; transition:.2s; }
.drawer-link:hover{ color:var(--gold-deep); padding-left:6px; }

/* Bottom nav */
.bottom-nav{ position:fixed; left:0; right:0; bottom:0; z-index:200; height:64px; background:rgba(250,247,240,.96); backdrop-filter:blur(10px); border-top:1px solid var(--line); display:flex; }
@media(min-width:900px){ .bottom-nav{ display:none; } }
.bn-item{ flex:1; background:none; border:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:3px; color:var(--muted); transition:.2s; }
.bn-item span{ font-size:.6rem; letter-spacing:.04em; }
.bn-item.active{ color:var(--gold-deep); }

/* Footer */
.footer-grid{ display:grid; grid-template-columns:1fr; gap:38px; }
@media(min-width:680px){ .footer-grid{ grid-template-columns:1.4fr 1fr 1fr 1fr; gap:30px; } }
.foot-col h4{ font-family:var(--serif); color:var(--on-dark); font-size:1.05rem; margin-bottom:16px; }
.foot-col a{ display:block; color:var(--on-dark-muted); font-size:.82rem; font-weight:300; padding:6px 0; cursor:pointer; transition:.2s; }
.foot-col a:hover{ color:var(--gold); }
.foot-soc{ width:38px; height:38px; border:1px solid #4a4234; border-radius:50%; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:.2s; }
.foot-soc:hover{ border-color:var(--gold); color:var(--gold); }
.footer-bottom{ display:flex; flex-direction:column; gap:10px; }
@media(min-width:680px){ .footer-bottom{ flex-direction:row; justify-content:space-between; align-items:center; } }

/* Search overlay */
.search-overlay{ position:fixed; inset:0; z-index:400; background:rgba(33,28,22,.5); display:flex; justify-content:center; align-items:flex-start; padding-top:14vh; animation:fadeIn .2s; }
.search-box{ width:min(92vw,620px); background:var(--cream); border-radius:var(--radius-lg); padding:20px; animation:fadeUp .3s; }
.search-input-row{ display:flex; align-items:center; gap:12px; border-bottom:1px solid var(--line-2); padding-bottom:14px; }
.search-input-row input{ border:0; font-size:1.15rem; font-family:var(--serif); padding:4px 0; background:none; }
.search-input-row input:focus{ box-shadow:none; }

/* ============ INSIGHT ============ */
.insight-hero{ display:grid; grid-template-columns:1fr; gap:0; border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; margin-top:36px; cursor:pointer; background:var(--paper); }
@media(min-width:820px){ .insight-hero{ grid-template-columns:1.1fr 1fr; } }
.insight-hero-img{ aspect-ratio:16/10; }
@media(min-width:820px){ .insight-hero-img{ aspect-ratio:auto; height:100%; min-height:320px; } }
.insight-hero-copy{ padding:34px 32px; display:flex; flex-direction:column; justify-content:center; }
.cat-tabs{ display:flex; gap:8px; overflow-x:auto; padding-bottom:4px; }
.cat-tab{ background:none; border:1px solid var(--line-2); border-radius:100px; padding:9px 18px; font-size:.78rem; color:var(--text); white-space:nowrap; transition:.2s; }
.cat-tab:hover{ border-color:var(--gold); }
.cat-tab.active{ background:var(--ink); color:var(--cream); border-color:var(--ink); }

/* ============ HOME ============ */
.c-gold{ color:var(--gold); }
.hero-sub{ color:var(--on-dark-muted); }

/* HERO (split editorial) */
.hero2{ background:var(--cream); position:relative; overflow:hidden; }
.hero2-grid{ display:grid; grid-template-columns:1fr; gap:36px; align-items:center; padding:40px 0 64px; }
@media(min-width:920px){ .hero2-grid{ grid-template-columns:1fr 1fr; gap:40px; min-height:calc(94vh - var(--nav-h)); padding:24px 0 56px; } }
.pill-eyebrow{ display:inline-block; font-size:.62rem; letter-spacing:.24em; text-transform:uppercase; color:var(--gold-deep); font-weight:600; padding:7px 15px; border:1px solid var(--gold-soft); border-radius:100px; margin-bottom:22px; }
.hero2 h1{ font-size:clamp(2.6rem,7vw,4.4rem); line-height:1.02; letter-spacing:-.5px; }
.hero2-sub{ color:var(--muted); font-weight:300; font-size:1.05rem; max-width:430px; margin:22px 0 30px; }
.hero2-cta{ display:flex; gap:14px; flex-wrap:wrap; }
.social-proof{ display:flex; align-items:center; gap:16px; margin-top:34px; }
.avatar-stack{ display:flex; }
.avatar-stack .avatar{ margin-left:-12px; }
.avatar-stack .avatar:first-child{ margin-left:0; }

.hero2-visual{ position:relative; }
.hero2-photo{ position:relative; aspect-ratio:4/5; border-radius:18px; overflow:hidden; }
@media(min-width:920px){ .hero2-photo{ aspect-ratio:5/6; } }
.hero2-photo .ph{ border-radius:18px; }
.hero2-bottle{ position:absolute; bottom:-18px; left:50%; transform:translateX(-50%); filter:drop-shadow(0 14px 26px rgba(120,90,30,.18)); }
.stats-card{ position:absolute; top:24%; right:-8px; width:210px; background:var(--paper); border:1px solid var(--line); border-radius:14px; padding:18px 18px 14px; box-shadow:0 18px 44px rgba(60,45,20,.12); }
@media(max-width:919px){ .stats-card{ right:0; width:190px; top:14%; } }
.stat-row{ display:flex; justify-content:space-between; align-items:center; padding:7px 0; font-size:.82rem; border-bottom:1px solid var(--line); }
.stat-row:last-of-type{ border-bottom:0; }
.stat-val{ font-family:var(--serif); color:var(--gold-deep); font-size:1.02rem; }
.stat-foot{ font-size:.6rem; color:var(--muted); margin-top:10px; line-height:1.4; }

/* VALUE STRIP */
.value-strip{ display:grid; grid-template-columns:repeat(2,1fr); gap:24px 0; border:1px solid var(--line); border-radius:var(--radius-lg); background:var(--paper); padding:26px 10px; }
@media(min-width:820px){ .value-strip{ grid-template-columns:repeat(4,1fr); } }
.value-item{ display:flex; align-items:center; gap:13px; padding:6px 22px; position:relative; }
@media(min-width:820px){ .value-item:not(:first-child)::before{ content:""; position:absolute; left:0; top:6px; bottom:6px; width:1px; background:var(--line); } }
.value-ic{ width:40px; height:40px; border-radius:50%; background:var(--cream-deep); display:flex; align-items:center; justify-content:center; color:var(--gold-deep); flex-shrink:0; }
.value-title{ font-weight:600; font-size:.82rem; color:var(--ink); }
.value-text{ font-size:.74rem; color:var(--muted); font-weight:300; margin-top:2px; }

/* ABOUT BAND */
.about-band-wrap{ background:var(--cream); }
.about-band{ display:grid; grid-template-columns:1fr; gap:32px; align-items:center; }
@media(min-width:820px){ .about-band{ grid-template-columns:1fr 1fr; gap:54px; } }
.about-img{ position:relative; aspect-ratio:5/4; border-radius:16px; overflow:hidden; }
.about-img .ph{ border-radius:16px; }
.about-copy h2{ margin:8px 0 16px; }
.btn-pill{ display:inline-flex; align-items:center; gap:9px; margin-top:24px; padding:13px 24px; border-radius:100px; border:1px solid var(--line-2); background:var(--paper); color:var(--ink); font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; font-weight:600; transition:.2s; }
.btn-pill:hover{ border-color:var(--gold); color:var(--gold-deep); }
.btn-pill.gold{ background:var(--gold); border-color:var(--gold); color:var(--ink); }
.btn-pill.gold:hover{ background:var(--gold-deep); border-color:var(--gold-deep); color:#fff; }

/* FEATURED COLLECTION (compact) */
.feat-head{ display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:30px; flex-wrap:wrap; gap:14px; }
.feat-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
@media(min-width:760px){ .feat-grid{ grid-template-columns:repeat(4,1fr); } }
.fcard{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; display:flex; flex-direction:column; transition:border-color .25s; }
.fcard:hover{ border-color:var(--gold-soft); }
.fcard-media{ position:relative; cursor:pointer; }
.fcard-body{ padding:16px; display:flex; flex-direction:column; gap:4px; flex:1; }
.fcard-name{ font-family:var(--serif); font-size:1.05rem; line-height:1.2; cursor:pointer; }
.fcard-sub{ font-size:.76rem; color:var(--muted); font-weight:300; }
.fcard-foot{ display:flex; align-items:center; justify-content:space-between; margin-top:auto; padding-top:12px; }
.fcard-price{ font-weight:500; font-size:.96rem; }
.add-round{ width:38px; height:38px; border-radius:50%; background:var(--ink); color:var(--cream); border:0; display:flex; align-items:center; justify-content:center; transition:.2s; flex-shrink:0; }
.add-round:hover{ background:var(--gold-deep); }
.add-round.added{ background:var(--emerald); }

/* ROUTINE BAND */
.routine-band{ display:grid; grid-template-columns:1fr; background:var(--dark); border-radius:var(--radius-lg); overflow:hidden; position:relative; }
@media(min-width:820px){ .routine-band{ grid-template-columns:1.05fr .95fr; } }
.routine-copy{ padding:42px 36px; position:relative; z-index:1; }
.routine-checks{ list-style:none; padding:0; margin:22px 0 28px; display:flex; flex-direction:column; gap:13px; }
.routine-checks li{ display:flex; align-items:center; gap:12px; color:var(--on-dark); font-size:.9rem; font-weight:300; }
.rc-ic{ width:22px; height:22px; border-radius:50%; background:var(--gold); color:var(--ink); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.routine-visual{ position:relative; min-height:280px; }
.routine-visual .ph{ background:repeating-linear-gradient(45deg, rgba(255,255,255,.05) 0 10px, rgba(255,255,255,0) 10px 20px), #2c2620; color:#8a8068; }

.testi-grid{ display:grid; grid-template-columns:1fr; gap:18px; }
@media(min-width:600px){ .testi-grid{ grid-template-columns:repeat(2,1fr); } }
@media(min-width:1000px){ .testi-grid{ grid-template-columns:repeat(4,1fr); } }
.testi-card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius-lg); padding:24px 22px; }

.ba-grid{ display:grid; grid-template-columns:1fr; gap:24px; max-width:840px; margin:0 auto; }
@media(min-width:680px){ .ba-grid{ grid-template-columns:repeat(2,1fr); } }
.ba-card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius-lg); padding:16px; }
.ba-images{ display:grid; grid-template-columns:repeat(3,1fr); gap:8px; }
.ba-frame .ph{ border-radius:3px; }

.ugc-strip{ display:grid; grid-template-columns:repeat(3,1fr); gap:4px; }
@media(min-width:760px){ .ugc-strip{ grid-template-columns:repeat(6,1fr); } }
.ugc-tile{ position:relative; aspect-ratio:1/1; overflow:hidden; cursor:pointer; }
.ugc-tile:hover .ugc-user{ opacity:1; }
.ugc-user{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; gap:6px; background:rgba(33,28,22,.55); color:var(--on-dark); font-size:.7rem; opacity:0; transition:.25s; }

/* ============ ARTICLE CARD ============ */
.article-card{ display:flex; flex-direction:column; cursor:pointer; }
.article-card .ph{ aspect-ratio:4/3; border-radius:var(--radius-lg); margin-bottom:16px; transition:.3s; }
.article-card:hover .ph{ opacity:.85; }
.article-card .acat{ font-size:.62rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-deep); font-weight:500; }
.article-card h3{ font-size:1.18rem; margin:10px 0 8px; line-height:1.25; transition:.2s; }
.article-card:hover h3{ color:var(--gold-deep); }
.article-card .aexc{ color:var(--muted); font-size:.85rem; font-weight:300; }
.article-card .aread{ font-size:.72rem; color:var(--muted); margin-top:10px; letter-spacing:.04em; }

/* ============ PAGE HEAD / CRUMB ============ */
.page-head{ padding:46px 0 30px; border-bottom:1px solid var(--line); }
.page-head .eyebrow{ margin-bottom:10px; }
.page-head h1{ margin-bottom:10px; }
.crumb{ display:flex; align-items:center; gap:6px; font-size:.76rem; color:var(--muted); }
.crumb a{ cursor:pointer; }
.crumb a:hover{ color:var(--gold-deep); }
.crumb svg{ opacity:.5; }
.field-lab{ font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); font-weight:500; }

/* ============ SHOP ============ */
.shop-layout{ display:grid; grid-template-columns:1fr; gap:32px; padding-top:36px; padding-bottom:80px; }
@media(min-width:900px){ .shop-layout{ grid-template-columns:228px 1fr; gap:44px; } }
.shop-aside{ display:none; }
@media(min-width:900px){ .shop-aside{ display:block; position:sticky; top:84px; align-self:start; } }
.filter-block{ margin-bottom:26px; }
.filter-block h4{ font-family:var(--sans); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink); font-weight:600; margin-bottom:14px; }
.check{ display:flex; align-items:center; gap:10px; padding:7px 0; cursor:pointer; font-size:.88rem; color:var(--text); }
.check input{ display:none; }
.check .box{ width:17px; height:17px; border:1px solid var(--line-2); border-radius:3px; flex-shrink:0; position:relative; transition:.2s; }
.check input:checked + .box{ background:var(--gold); border-color:var(--gold); }
.check input:checked + .box::after{ content:""; position:absolute; left:5px; top:1px; width:4px; height:9px; border:solid var(--ink); border-width:0 1.6px 1.6px 0; transform:rotate(45deg); }
.range{ -webkit-appearance:none; appearance:none; width:100%; height:3px; background:var(--line-2); border-radius:3px; }
.range::-webkit-slider-thumb{ -webkit-appearance:none; width:18px; height:18px; border-radius:50%; background:var(--gold); cursor:pointer; border:2px solid var(--cream); box-shadow:0 0 0 1px var(--gold); }
.range::-moz-range-thumb{ width:16px; height:16px; border-radius:50%; background:var(--gold); cursor:pointer; border:0; }
.shop-toolbar{ display:flex; align-items:center; gap:14px; margin-bottom:24px; }
.sort-select{ margin-left:auto; display:flex; align-items:center; gap:10px; }
.sort-select select{ width:auto; padding:8px 28px 8px 12px; font-size:.84rem; }
.filter-toggle{ display:inline-flex; }
@media(min-width:900px){ .filter-toggle{ display:none; } }
.t-count{ background:var(--gold); color:var(--ink); border-radius:9px; min-width:17px; height:17px; font-size:.6rem; display:inline-flex; align-items:center; justify-content:center; padding:0 4px; }
.filter-sheet{ width:100%; background:var(--cream); border-radius:14px 14px 0 0; padding:22px 22px 30px; max-height:85vh; overflow-y:auto; animation:sheetUp .3s cubic-bezier(.2,.8,.2,1); }
@keyframes sheetUp{ from{ transform:translateY(100%);} to{ transform:none; } }

/* ============ PDP ============ */
.pdp-grid{ display:grid; grid-template-columns:1fr; gap:32px; padding-top:24px; }
@media(min-width:860px){ .pdp-grid{ grid-template-columns:1fr 1fr; gap:54px; padding-top:32px; } }
.pdp-main{ position:relative; border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; }
.pdp-thumbs{ display:flex; gap:10px; margin-top:12px; }
.pdp-thumb{ width:68px; height:68px; border:1px solid var(--line); border-radius:4px; overflow:hidden; padding:0; background:var(--paper); transition:.2s; }
.pdp-thumb.active{ border-color:var(--gold); }
@media(min-width:860px){ .pdp-info{ position:sticky; top:84px; align-self:start; } }
.pdp-price{ font-family:var(--serif); font-size:2rem; color:var(--ink); }
.pdp-price .strike{ font-family:var(--sans); font-size:1rem; color:var(--muted); text-decoration:line-through; margin-left:12px; }
.variant-row{ display:flex; gap:10px; flex-wrap:wrap; margin-top:8px; }
.variant{ flex:1; min-width:130px; text-align:left; background:var(--paper); border:1px solid var(--line-2); border-radius:var(--radius); padding:12px 14px; display:flex; flex-direction:column; gap:4px; transition:.2s; }
.variant.active{ border-color:var(--gold); background:var(--gold-soft); }
.variant .vprice{ font-size:.82rem; color:var(--muted); }
.btn.wished{ border-color:#e7c2bd; color:#b5483f; }

.ing-wrap{ display:flex; flex-wrap:wrap; gap:8px; }
.ing-chip{ position:relative; font-size:.74rem; padding:7px 13px; border:1px solid var(--gold-soft); border-radius:100px; color:var(--gold-deep); cursor:help; transition:.2s; }
.ing-chip:hover{ background:var(--gold-soft); }
.ing-tip{ position:absolute; bottom:calc(100% + 10px); left:50%; transform:translateX(-50%); width:max-content; max-width:240px; background:var(--ink); color:var(--cream); font-size:.76rem; line-height:1.45; padding:10px 13px; border-radius:6px; z-index:20; box-shadow:0 8px 24px rgba(0,0,0,.18); pointer-events:none; }
.ing-tip::after{ content:""; position:absolute; top:100%; left:50%; transform:translateX(-50%); border:6px solid transparent; border-top-color:var(--ink); }
.bpom{ display:flex; align-items:center; gap:14px; margin-top:24px; padding:14px 18px; background:var(--emerald-wash); border:1px solid #cfe3db; border-radius:var(--radius-lg); }
.bpom-ic{ color:var(--emerald); }

.tabs{ display:flex; gap:4px; border-bottom:1px solid var(--line); overflow-x:auto; }
.tab{ background:none; border:0; padding:14px 18px; font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; font-weight:500; color:var(--muted); border-bottom:2px solid transparent; margin-bottom:-1px; white-space:nowrap; transition:.2s; }
.tab.active{ color:var(--ink); border-color:var(--gold); }
.tab-body{ padding:30px 0; max-width:760px; }
.prose p{ color:var(--text); }
.benefit-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:12px; margin-top:20px; }
@media(min-width:600px){ .benefit-grid{ grid-template-columns:repeat(3,1fr); } }
.benefit{ display:flex; align-items:center; gap:9px; font-size:.86rem; }
.howto{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:18px; }
.howto li{ display:flex; gap:16px; align-items:flex-start; }
.howto-num{ width:30px; height:30px; flex-shrink:0; border:1px solid var(--gold); border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:var(--serif); color:var(--gold-deep); font-size:.9rem; }
.ing-list{ display:flex; flex-direction:column; gap:18px; }
.ing-list-row{ display:flex; gap:14px; }
.ing-dot{ width:8px; height:8px; border-radius:50%; background:var(--gold); margin-top:7px; flex-shrink:0; }

.timeline{ display:flex; flex-direction:column; gap:0; max-width:620px; margin:0 auto; }
.tl-step{ display:flex; gap:20px; }
.tl-marker{ display:flex; flex-direction:column; align-items:center; }
.tl-dot{ width:16px; height:16px; border-radius:50%; background:var(--gold); border:3px solid var(--cream-deep); box-shadow:0 0 0 1px var(--gold); flex-shrink:0; }
.tl-line{ width:1px; flex:1; background:var(--gold); opacity:.4; margin:4px 0; }
.tl-content{ padding-bottom:30px; }
.tl-range{ font-family:var(--serif); font-size:1.2rem; color:var(--ink); margin-bottom:6px; }

.reviews{ display:grid; grid-template-columns:1fr; gap:32px; }
@media(min-width:760px){ .reviews{ grid-template-columns:240px 1fr; } }
.rev-summary{ display:flex; flex-direction:column; gap:18px; }
.rev-score{ text-align:center; padding:24px; background:var(--cream-deep); border-radius:var(--radius-lg); }
.rev-num{ font-family:var(--serif); font-size:3rem; color:var(--ink); line-height:1; margin-bottom:8px; }
.rating-bars{ display:flex; flex-direction:column; gap:7px; }
.rb-row{ display:flex; align-items:center; gap:10px; font-size:.74rem; color:var(--muted); }
.rb-label{ width:24px; }
.rb-track{ flex:1; height:6px; background:var(--line); border-radius:3px; overflow:hidden; }
.rb-fill{ display:block; height:100%; background:var(--gold); }
.rb-pct{ width:34px; text-align:right; }
.rev-list{ display:flex; flex-direction:column; gap:18px; }
.rev-card{ border:1px solid var(--line); border-radius:var(--radius-lg); padding:20px; background:var(--paper); }

/* ============ ACCOUNT ============ */
.acc-layout{ display:grid; grid-template-columns:1fr; gap:30px; padding-top:34px; padding-bottom:80px; }
@media(min-width:860px){ .acc-layout{ grid-template-columns:230px 1fr; gap:44px; } }
.acc-nav{ display:flex; gap:6px; overflow-x:auto; }
@media(min-width:860px){ .acc-nav{ flex-direction:column; position:sticky; top:84px; } }
.acc-link{ display:flex; align-items:center; gap:11px; padding:12px 14px; border:0; background:none; color:var(--text); font-size:.86rem; border-radius:var(--radius); text-align:left; white-space:nowrap; transition:.2s; }
.acc-link:hover{ background:var(--cream-deep); }
.acc-link.active{ background:var(--ink); color:var(--cream); }
.acc-link.active svg{ color:var(--gold); }
.acc-h{ font-size:1.6rem; margin-bottom:22px; }
.acc-card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius-lg); padding:24px; }
.info-grid{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.info-grid > div > div:last-child{ font-size:.95rem; margin-top:4px; }
.order-head{ display:flex; justify-content:space-between; align-items:center; cursor:pointer; }
.status{ font-size:.66rem; letter-spacing:.08em; text-transform:uppercase; font-weight:600; padding:5px 11px; border-radius:100px; }
.st-proc{ background:#F3E7C9; color:#8a6a16; }
.st-ship{ background:var(--emerald-wash); color:var(--emerald); }
.st-done{ background:#E7E3DA; color:var(--warm-gray,#6B6B68); }
.order-detail{ margin-top:18px; border-top:1px solid var(--line); padding-top:16px; }
.order-item{ display:flex; align-items:center; gap:14px; padding:8px 0; }
.addr-card .link-gold{ cursor:pointer; }
.loyalty-hero{ background:var(--dark); color:var(--on-dark); border-radius:var(--radius-lg); padding:30px; position:relative; overflow:hidden; }
.loy-track{ height:8px; background:rgba(255,255,255,.12); border-radius:4px; overflow:hidden; }
.loy-fill{ display:block; height:100%; background:linear-gradient(90deg,var(--gold-deep),var(--gold)); }
.tier-badge{ display:inline-flex; align-items:center; gap:6px; font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; font-weight:600; padding:5px 12px; border-radius:100px; margin-top:4px; }
.tier-gold{ background:var(--gold-soft); color:var(--gold-deep); }
.tier-emerald{ background:var(--emerald); color:#EAD9A6; }
.redeem-grid{ display:grid; grid-template-columns:1fr; gap:12px; }
@media(min-width:560px){ .redeem-grid{ grid-template-columns:1fr 1fr; } }
.redeem{ display:flex; justify-content:space-between; align-items:center; gap:12px; padding:18px 20px; }
.set-row{ display:flex; justify-content:space-between; align-items:center; padding:14px 0; border-bottom:1px solid var(--line); font-size:.92rem; }
.set-row:last-child{ border-bottom:0; }
.switch{ width:44px; height:24px; border-radius:12px; background:var(--line-2); border:0; position:relative; transition:.2s; }
.switch.on{ background:var(--gold); }
.switch .knob{ position:absolute; top:2px; left:2px; width:20px; height:20px; border-radius:50%; background:#fff; transition:.2s; }
.switch.on .knob{ left:22px; }
.form-2{ display:grid; grid-template-columns:1fr; gap:0 16px; }
@media(min-width:560px){ .form-2{ grid-template-columns:1fr 1fr; } }
.form-3{ display:grid; grid-template-columns:1fr; gap:0 16px; }
@media(min-width:560px){ .form-3{ grid-template-columns:1fr 1fr 1fr; } }

/* ============ CART / CHECKOUT ============ */
.cart-layout{ display:grid; grid-template-columns:1fr; gap:32px; padding-top:34px; padding-bottom:80px; }
@media(min-width:860px){ .cart-layout{ grid-template-columns:1fr 340px; gap:44px; align-items:start; } }
.cart-row{ display:flex; gap:16px; padding:18px 0; border-bottom:1px solid var(--line); }
.cart-thumb{ width:92px; height:92px; border-radius:6px; overflow:hidden; flex-shrink:0; cursor:pointer; border:1px solid var(--line); }
.cart-info{ flex:1; }
.cart-del{ background:none; border:0; color:var(--muted); padding:4px; transition:.2s; }
.cart-del:hover{ color:#b5483f; }
.cart-summary{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius-lg); padding:26px; }
@media(min-width:860px){ .cart-summary{ position:sticky; top:84px; } }
.sum-row{ display:flex; justify-content:space-between; align-items:center; padding:7px 0; font-size:.92rem; }
.sum-row.total{ font-family:var(--serif); font-size:1.3rem; color:var(--ink); padding-top:4px; }
.promo-row{ display:flex; gap:8px; margin-top:14px; }
.promo-row input{ flex:1; }
.cart-empty-ic{ width:74px; height:74px; border-radius:50%; border:1px solid var(--gold-soft); display:flex; align-items:center; justify-content:center; color:var(--gold-deep); }

.stepper{ display:flex; align-items:center; padding:30px 0 10px; max-width:560px; }
.step{ display:flex; align-items:center; flex:1; color:var(--muted); }
.step:last-child{ flex:0; }
.step-num{ width:30px; height:30px; border-radius:50%; border:1px solid var(--line-2); display:flex; align-items:center; justify-content:center; font-size:.82rem; font-weight:500; flex-shrink:0; transition:.2s; }
.step-label{ font-size:.78rem; margin-left:10px; white-space:nowrap; }
.step-bar{ flex:1; height:1px; background:var(--line-2); margin:0 14px; }
.step.active .step-num{ background:var(--gold); border-color:var(--gold); color:var(--ink); }
.step.active .step-label{ color:var(--ink); }
.step.done .step-num{ background:var(--emerald); border-color:var(--emerald); color:#EAD9A6; }
.checkout-layout{ display:grid; grid-template-columns:1fr; gap:32px; padding-top:24px; padding-bottom:80px; }
@media(min-width:860px){ .checkout-layout{ grid-template-columns:1fr 320px; gap:40px; align-items:start; } }
.opt-list{ display:flex; flex-direction:column; gap:10px; }
.opt{ display:flex; align-items:center; gap:14px; padding:14px 16px; border:1px solid var(--line-2); border-radius:var(--radius); cursor:pointer; transition:.2s; }
.opt.active{ border-color:var(--gold); background:var(--gold-soft); }
.opt input{ display:none; }
.opt-radio{ width:18px; height:18px; border-radius:50%; border:1px solid var(--line-2); flex-shrink:0; position:relative; }
.opt.active .opt-radio{ border-color:var(--gold-deep); }
.opt.active .opt-radio::after{ content:""; position:absolute; inset:3px; border-radius:50%; background:var(--gold-deep); }
.opt-ic{ color:var(--gold-deep); display:flex; }
.pay-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:10px; }
@media(min-width:560px){ .pay-grid{ grid-template-columns:repeat(4,1fr); } }
.pay-opt{ position:relative; padding:14px 10px; border:1px solid var(--line-2); border-radius:var(--radius); background:var(--paper); font-size:.84rem; transition:.2s; }
.pay-opt.active{ border-color:var(--gold); background:var(--gold-soft); }
.pay-check{ position:absolute; top:6px; right:6px; color:var(--gold-deep); }
.review-block{ margin-bottom:16px; }
.confirm-check{ width:84px; height:84px; border-radius:50%; background:var(--emerald); color:#EAD9A6; display:inline-flex; align-items:center; justify-content:center; }
.contact-layout{ display:grid; grid-template-columns:1fr; gap:32px; }
@media(min-width:760px){ .contact-layout{ grid-template-columns:1.2fr 1fr; gap:44px; } }
.contact-list{ display:flex; flex-direction:column; gap:16px; margin-top:24px; }
.contact-list > div{ font-size:.95rem; }

/* anim helpers */
.fade-up{ animation:fadeUp .6s ease; }
@keyframes fadeUp{ from{ transform:translateY(14px);} to{ transform:none; } }
@media(prefers-reduced-motion:reduce){ *{ animation:none!important; transition:none!important; } }
