/* cyrillic-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(assets/fonts/gf-0.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* vietnamese */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(assets/fonts/gf-1.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(assets/fonts/gf-2.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(assets/fonts/gf-3.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(assets/fonts/gf-0.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* vietnamese */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(assets/fonts/gf-1.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(assets/fonts/gf-2.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(assets/fonts/gf-3.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(assets/fonts/gf-0.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* vietnamese */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(assets/fonts/gf-1.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(assets/fonts/gf-2.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(assets/fonts/gf-3.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(assets/fonts/gf-0.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* vietnamese */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(assets/fonts/gf-1.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(assets/fonts/gf-2.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(assets/fonts/gf-3.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Young Serif';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(assets/fonts/gf-16.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Young Serif';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(assets/fonts/gf-17.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* ============================================================
   LAMPENGRÜN — shared stylesheet (multi-page, GitHub-Pages ready)
   Tokens locked to brand-direction-v3 (2026-05-30) · Light + Life
   ============================================================ */
:root{
  --sun-400:#F7B32B; --sun-300:#FFD27A; --amber-500:#F2901E; --ember-600:#E2611C;
  --life-500:#6FBF3B; --life-700:#2F8F46;
  --cream-50:#FBF7EE; --cream-100:#FCFAF5; --night-900:#16271C; --charcoal:#1E1F18;

  --ink:var(--charcoal); --ink-soft:#5b5c4f; --line:#e7e0d1; --line-strong:#d8cfba;

  --serif:"Young Serif",Georgia,"Times New Roman",serif;
  --sans:"Hanken Grotesk",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;

  --ease:cubic-bezier(.16,1,.3,1);
  --maxw:1240px;
  --btn-r:16px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);background:var(--cream-50);color:var(--ink);
  line-height:1.6;font-size:clamp(16px,1.05vw,18px);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
::selection{background:var(--sun-300);color:var(--night-900)}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(20px,5vw,64px)}
.serif{font-family:var(--serif);font-weight:400;letter-spacing:-.01em;line-height:1.04}
.center{text-align:center}

/* kicker */
.kicker{font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--life-700);display:inline-flex;align-items:center;gap:.6em}
.kicker::before{content:"";width:22px;height:1.5px;background:var(--life-500);display:inline-block}
.kicker.on-dark{color:var(--sun-300)} .kicker.on-dark::before{background:var(--sun-400)}
.kicker.center-k{justify-content:center}

/* buttons */
.btn{font-family:var(--sans);font-weight:600;font-size:.98rem;display:inline-flex;align-items:center;gap:.55em;cursor:pointer;border:none;padding:.92em 1.5em;border-radius:var(--btn-r);transition:transform .5s var(--ease),box-shadow .5s var(--ease),background .3s var(--ease);will-change:transform;text-align:center;justify-content:center}
.btn-sun{background:linear-gradient(135deg,var(--sun-400),var(--amber-500));color:#3a2708;box-shadow:0 1px 0 rgba(255,255,255,.4) inset,0 10px 28px -10px rgba(242,144,30,.65)}
.btn-sun:hover{box-shadow:0 1px 0 rgba(255,255,255,.5) inset,0 16px 38px -10px rgba(242,144,30,.8)}
.btn-sun:active{transform:scale(.97)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line-strong)}
.btn-ghost:hover{border-color:var(--life-700);color:var(--life-700)}
.btn-ghost.on-dark{color:#f4efe2;border-color:rgba(244,239,226,.4)}
.btn-ghost.on-dark:hover{border-color:var(--sun-400);color:var(--sun-300)}
.btn .arr{transition:transform .5s var(--ease)}
.btn:hover .arr{transform:translateX(3px)}
.btn-block{width:100%}

/* ============================================================ URGENCY / ANNOUNCE BAR */
.announce{background:var(--night-900);color:#f4efe2;font-size:.85rem;text-align:center;padding:9px 16px;display:flex;gap:14px;align-items:center;justify-content:center;flex-wrap:wrap}
.announce b{color:var(--sun-300);font-weight:600}
.announce .sep{opacity:.4}

/* ============================================================ NAV */
header.nav{position:sticky;top:0;z-index:60;transition:background .4s var(--ease),box-shadow .4s var(--ease),padding .4s var(--ease);padding-block:16px;background:rgba(251,247,238,.82);backdrop-filter:saturate(140%) blur(14px)}
header.nav.scrolled{box-shadow:0 1px 0 var(--line);padding-block:11px}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:.6em;font-family:var(--serif);font-size:1.4rem;letter-spacing:-.02em}
.brand img{width:34px;height:34px;border-radius:9px}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{font-size:.93rem;font-weight:500;color:var(--ink-soft);transition:color .3s;position:relative}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--ink)}
.nav-links a[aria-current="page"]::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--sun-400);border-radius:2px}
.nav-cta{display:flex;align-items:center;gap:14px}
.menu-btn{display:none;background:none;border:none;cursor:pointer;width:42px;height:42px;align-items:center;justify-content:center;border-radius:10px}
.menu-btn svg{width:24px;height:24px;stroke:var(--ink)}
/* mobile drawer */
.mobile-menu{position:fixed;inset:0;z-index:70;background:var(--cream-50);transform:translateX(100%);transition:transform .5s var(--ease);display:flex;flex-direction:column;padding:22px clamp(20px,5vw,40px)}
.mobile-menu.open{transform:none}
.mm-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}
.mobile-menu nav{display:flex;flex-direction:column;gap:6px}
.mobile-menu nav a{font-family:var(--serif);font-size:1.7rem;padding:.35em 0;border-bottom:1px solid var(--line)}
.mobile-menu .btn{margin-top:24px}
@media(max-width:980px){
  .nav-links{display:none}
  .nav-cta .btn-ghost{display:none}
  .menu-btn{display:flex}
}

/* ============================================================ HERO (home) */
.hero{position:relative;padding-top:clamp(90px,12vh,150px);padding-bottom:clamp(60px,8vh,110px);overflow:hidden}
.hero::before{content:"";position:absolute;top:-10%;right:-6%;width:60vw;height:60vw;max-width:760px;max-height:760px;background:radial-gradient(circle at center,rgba(247,179,43,.42),rgba(255,210,122,.18) 38%,transparent 66%);z-index:0;pointer-events:none;filter:blur(6px)}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,72px);align-items:center}
.hero h1{font-family:var(--serif);font-size:clamp(2rem,8.5vw,4.5rem);line-height:1.04;letter-spacing:-.02em;overflow-wrap:break-word}
.hero h1 .glow{color:var(--ember-600)}
.hero .sub{margin-top:1.4rem;font-size:clamp(1.05rem,1.5vw,1.28rem);color:var(--ink-soft);max-width:30ch}
.hero .cta-row{margin-top:2.2rem;display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero .meta{margin-top:1.6rem;display:flex;align-items:center;gap:.6em;font-size:.9rem;color:var(--ink-soft)}
.pulse{width:9px;height:9px;border-radius:50%;background:var(--life-500);position:relative}
.pulse::after{content:"";position:absolute;inset:0;border-radius:50%;background:var(--life-500);animation:pulse 2.4s var(--ease) infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.6}70%,100%{transform:scale(3.4);opacity:0}}
.hero-media{position:relative}
.hero-media .frame{position:relative;border-radius:26px;overflow:hidden;box-shadow:0 40px 90px -40px rgba(226,97,28,.45),0 8px 30px -12px rgba(30,31,24,.25);background:linear-gradient(160deg,#fff,var(--cream-100));aspect-ratio:4/5}
.hero-media .frame img{width:100%;height:100%;object-fit:cover}
.hero-media .float-card{position:absolute;left:-26px;bottom:34px;background:rgba(252,250,245,.86);backdrop-filter:blur(10px);border:1px solid var(--line);border-radius:16px;padding:14px 18px;display:flex;gap:12px;align-items:center;box-shadow:0 24px 48px -20px rgba(30,31,24,.3);animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
.float-card b{font-family:var(--serif);font-size:1.5rem;line-height:1}
.float-card .lab{font-size:.78rem;color:var(--ink-soft);line-height:1.25}
.float-card .leaf{width:38px;height:38px;border-radius:11px;background:linear-gradient(150deg,var(--life-500),var(--life-700));display:grid;place-items:center}
@media(max-width:840px){.hero-grid{grid-template-columns:1fr;gap:38px}.hero-media{order:-1;max-width:440px}.hero .sub{max-width:42ch}}

/* trust strip */
.trust{border-block:1px solid var(--line);background:var(--cream-100)}
.trust .wrap{display:flex;flex-wrap:wrap;gap:clamp(18px,5vw,56px);justify-content:space-between;padding-block:20px}
.trust span{font-size:.86rem;color:var(--ink-soft);display:flex;align-items:center;gap:.55em;font-weight:500}
.trust .dot{width:6px;height:6px;border-radius:50%;background:var(--sun-400)}

/* ============================================================ generic section */
section{position:relative}
.sec{padding-block:clamp(72px,11vh,130px)}
.sec-sm{padding-block:clamp(48px,7vh,80px)}
.sec-head{max-width:62ch}
.sec-head.center-h{margin-inline:auto;text-align:center}
.sec-head h2{font-family:var(--serif);font-size:clamp(2rem,4.2vw,3.3rem);margin-top:1rem;line-height:1.05}
.sec-head p{margin-top:1.1rem;color:var(--ink-soft);font-size:1.1rem;max-width:52ch}
.sec-head.center-h p{margin-inline:auto}
.tint{background:var(--cream-100)}

/* flow steps */
.flow{margin-top:clamp(40px,6vw,70px);display:grid;gap:2px;border:1px solid var(--line);border-radius:24px;overflow:hidden;background:var(--line)}
.flow .step{background:var(--cream-100);padding:clamp(26px,3.4vw,44px);display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:start;transition:background .4s var(--ease)}
.flow .step:hover{background:#fff}
.flow .num{font-family:var(--serif);font-size:2.4rem;color:var(--sun-400);line-height:1;width:64px}
.flow .step h3{font-size:1.35rem;font-family:var(--serif);margin-bottom:.4rem}
.flow .step p{color:var(--ink-soft);font-size:1rem;max-width:46ch}
@media(min-width:760px){.flow{grid-template-columns:1fr 1fr 1fr}}

/* night drench */
.night{background:var(--night-900);color:#f4efe2;position:relative;overflow:hidden}
.night::before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-55%);width:90vw;height:90vw;max-width:900px;max-height:900px;background:radial-gradient(circle,rgba(247,179,43,.22),rgba(226,97,28,.08) 40%,transparent 64%);pointer-events:none}
.night .wrap{position:relative;z-index:1}
.night-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(34px,6vw,80px);align-items:center}
.night h2{font-family:var(--serif);font-size:clamp(2.2rem,4.6vw,3.7rem);line-height:1.04}
.night h2 .gold{color:var(--sun-400)}
.night p{margin-top:1.3rem;color:#cdd6c4;font-size:1.12rem;max-width:42ch;line-height:1.7}
.night .quote{margin-top:2rem;font-family:var(--serif);font-size:1.5rem;color:var(--sun-300);line-height:1.3}
.night-media{position:relative;border-radius:22px;overflow:hidden;aspect-ratio:16/11;box-shadow:0 50px 120px -40px rgba(247,179,43,.4);border:1px solid rgba(247,179,43,.18)}
.night-media img{width:100%;height:100%;object-fit:cover}
@media(max-width:840px){.night-grid{grid-template-columns:1fr;gap:34px}}

/* zig */
.zig{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,6vw,84px);align-items:center}
.zig + .zig{margin-top:clamp(56px,8vw,110px)}
.zig.rev .zig-media{order:2}
.zig-media{border-radius:22px;overflow:hidden;aspect-ratio:5/4;box-shadow:0 36px 80px -40px rgba(30,31,24,.4);background:var(--cream-100)}
.zig-media img{width:100%;height:100%;object-fit:cover}
.zig h3{font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.4rem);margin-top:.9rem;line-height:1.08}
.zig p{margin-top:1rem;color:var(--ink-soft);font-size:1.06rem;max-width:46ch}
.spec-list{margin-top:1.6rem;display:grid;gap:0;border-top:1px solid var(--line)}
.spec-list div{display:flex;justify-content:space-between;gap:18px;padding:.85em 0;border-bottom:1px solid var(--line);font-size:.96rem}
.spec-list dt{color:var(--ink-soft)} .spec-list dd{font-weight:600;text-align:right}
@media(max-width:780px){.zig{grid-template-columns:1fr;gap:28px}.zig.rev .zig-media{order:0}}

/* feats */
.feats{margin-top:clamp(40px,6vw,64px);display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:clamp(20px,3vw,40px)}
.feat{padding-top:24px;border-top:2px solid var(--ink)}
.feat .ic{width:30px;height:30px;color:var(--life-700);margin-bottom:14px}
.feat h4{font-size:1.18rem;font-family:var(--serif);margin-bottom:.5rem}
.feat p{color:var(--ink-soft);font-size:.98rem}

/* ============================================================ PRICING */
.pricing{background:var(--cream-100);border-block:1px solid var(--line)}
.price-grid{margin-top:clamp(40px,6vw,60px);display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.price{background:var(--cream-50);border:1px solid var(--line);border-radius:22px;padding:30px 28px;display:flex;flex-direction:column;transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .4s var(--ease)}
.price:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(226,97,28,.4);border-color:var(--sun-400)}
.price.feature{background:linear-gradient(180deg,#fff,var(--cream-100));border-color:var(--sun-400);box-shadow:0 24px 60px -36px rgba(242,144,30,.55)}
.price .tier{font-family:var(--serif);font-size:1.5rem}
.price .who{color:var(--ink-soft);font-size:.92rem;margin-top:.2rem;margin-bottom:1.2rem}
.price .amt{font-family:var(--serif);font-size:2.8rem;line-height:1}
.price .amt small{font-size:1rem;color:var(--ink-soft);font-family:var(--sans);font-weight:500}
.price ul{list-style:none;margin:1.4rem 0;display:grid;gap:.7em}
.price li{font-size:.95rem;display:flex;gap:.6em;align-items:flex-start;color:var(--ink-soft)}
.price li svg{flex:none;margin-top:.2em;color:var(--life-700);width:16px;height:16px}
.price .btn{margin-top:auto;width:100%}
.badge{align-self:flex-start;font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#3a2708;background:var(--sun-300);padding:.3em .8em;border-radius:999px;margin-bottom:14px}
@media(max-width:820px){.price-grid{grid-template-columns:1fr;max-width:440px;margin-inline:auto}}

/* ============================================================ REVIEWS / SOCIAL PROOF */
.reviews{background:var(--cream-50)}
.reviews-head{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:32px}
.stars{display:inline-flex;gap:3px;color:var(--sun-400)}
.stars svg{width:18px;height:18px}
.rating-line{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.rating-line b{font-family:var(--serif);font-size:1.4rem}
.rating-line span{color:var(--ink-soft);font-size:.92rem}
.review-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}
.review-card{background:var(--cream-100);border:1px solid var(--line);border-radius:16px;padding:22px}
.review-card .top{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.review-card .nm{font-weight:600;font-size:.95rem}
.review-card .verified{font-size:.74rem;color:var(--life-700);display:inline-flex;align-items:center;gap:.3em;font-weight:600}
.review-card .qt{font-size:1rem;color:var(--ink);line-height:1.5}
.review-card .sku{font-size:.8rem;color:var(--ink-soft);font-style:italic;margin-top:8px}

/* ============================================================ LISTICLE / ADVERTORIAL */
.adv-hero{padding-top:clamp(40px,6vw,70px);padding-bottom:clamp(40px,6vw,64px);text-align:center}
.adv-hero h1{font-family:var(--serif);font-size:clamp(2.2rem,5vw,3.7rem);line-height:1.06;max-width:18ch;margin:1rem auto 0}
.adv-hero .lede{margin:1.3rem auto 0;max-width:54ch;font-size:1.15rem;color:var(--ink-soft)}
.adv-hero .lede b{color:var(--ink)}
.adv-badges{display:flex;gap:clamp(14px,3vw,32px);justify-content:center;flex-wrap:wrap;margin-top:1.8rem}
.adv-badges .b{display:flex;align-items:center;gap:.5em;font-size:.9rem;font-weight:500;color:var(--ink-soft)}
.adv-badges .b svg{width:18px;height:18px;color:var(--sun-400)}
.adv-hero-img{margin:clamp(28px,4vw,44px) auto 0;max-width:760px;border-radius:22px;overflow:hidden;box-shadow:0 36px 80px -40px rgba(226,97,28,.4)}

.reason{padding-block:clamp(40px,6vw,72px);border-top:1px solid var(--line)}
.reason-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,72px);align-items:center}
.reason.rev .reason-media{order:2}
.reason-media{border-radius:20px;overflow:hidden;aspect-ratio:4/3;box-shadow:0 30px 70px -42px rgba(30,31,24,.4);background:var(--cream-100)}
.reason-media img{width:100%;height:100%;object-fit:cover}
.reason .rn{font-family:var(--serif);font-size:1.1rem;color:#fff;background:linear-gradient(135deg,var(--sun-400),var(--amber-500));width:46px;height:46px;border-radius:13px;display:grid;place-items:center;margin-bottom:18px;box-shadow:0 10px 24px -10px rgba(242,144,30,.7)}
.reason h2{font-family:var(--serif);font-size:clamp(1.5rem,2.8vw,2.1rem);line-height:1.12}
.reason p{margin-top:1rem;color:var(--ink-soft);font-size:1.05rem;max-width:48ch}
.reason p b{color:var(--ink)}
.qa{margin-top:1.2rem;border-left:0;background:var(--cream-100);border:1px solid var(--line);border-radius:14px;padding:18px 20px}
.qa .q{font-weight:600;color:var(--ink)} .qa .a{color:var(--ink-soft);margin-top:.3em}
.reason .btn{margin-top:1.6rem}
@media(max-width:780px){.reason-grid{grid-template-columns:1fr;gap:26px}.reason.rev .reason-media{order:0}}

/* ============================================================ FAQ accordion */
.faq{max-width:780px;margin-inline:auto}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{list-style:none;cursor:pointer;padding:22px 0;display:flex;justify-content:space-between;gap:16px;align-items:center;font-family:var(--serif);font-size:1.18rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{flex:none;width:26px;height:26px;border-radius:50%;border:1.5px solid var(--line-strong);display:grid;place-items:center;transition:transform .4s var(--ease),background .3s,border-color .3s}
.faq summary .pm svg{width:14px;height:14px;stroke:var(--ink-soft)}
.faq details[open] summary .pm{background:var(--sun-400);border-color:var(--sun-400);transform:rotate(45deg)}
.faq .ans{padding:0 0 22px;color:var(--ink-soft);max-width:62ch;line-height:1.65}

/* ============================================================ CONTACT */
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin-top:32px}
.contact-card{background:var(--cream-100);border:1px solid var(--line);border-radius:18px;padding:26px;text-align:center}
.contact-card .ic{width:34px;height:34px;margin:0 auto 12px;color:var(--life-700)}
.contact-card h4{font-family:var(--serif);font-size:1.2rem;margin-bottom:.3em}
.contact-card p{color:var(--ink-soft);font-size:.92rem}
.contact-card a{color:var(--life-700);font-weight:600}

/* ============================================================ WAITLIST */
.waitlist{background:var(--night-900);color:#f4efe2;position:relative;overflow:hidden}
.waitlist::before{content:"";position:absolute;bottom:-40%;left:50%;transform:translateX(-50%);width:120vw;height:80vw;max-width:1100px;max-height:700px;background:radial-gradient(ellipse at center,rgba(247,179,43,.2),transparent 60%);pointer-events:none}
.waitlist .wrap{position:relative;z-index:1;text-align:center}
.waitlist h2{font-family:var(--serif);font-size:clamp(2.1rem,4.5vw,3.4rem);max-width:18ch;margin:1rem auto 0;line-height:1.06}
.waitlist h2 .gold{color:var(--sun-400)}
.waitlist p{margin:1.2rem auto 0;color:#cdd6c4;max-width:46ch;font-size:1.08rem}
.wl-form{margin:2.4rem auto 0;max-width:480px;display:flex;gap:10px}
.wl-form input{flex:1;background:rgba(255,255,255,.06);border:1px solid rgba(244,239,226,.22);color:#fff;padding:.95em 1.2em;border-radius:var(--btn-r);font-family:var(--sans);font-size:1rem;outline:none;transition:border-color .3s,background .3s}
.wl-form input::placeholder{color:#9fb0a0}
.wl-form input:focus{border-color:var(--sun-400);background:rgba(255,255,255,.1)}
.wl-form input.err{border-color:var(--ember-600)}
.wl-note{margin-top:1.1rem;font-size:.86rem;color:#9fb0a0;min-height:1.2em;transition:color .3s}
.wl-note.ok{color:var(--sun-300)} .wl-note.err{color:#f3a98e}
.wl-trust{margin-top:2.4rem;display:flex;gap:clamp(16px,4vw,40px);justify-content:center;flex-wrap:wrap;font-size:.85rem;color:#9fb0a0}
.wl-trust span{display:flex;align-items:center;gap:.5em}
@media(max-width:520px){.wl-form{flex-direction:column}}
/* waitlist -> beehiiv embed (lazy-load placeholder) */
.wl-embed{margin:2.4rem auto 0;max-width:480px;cursor:pointer}
.wl-embed-fake{display:flex;gap:10px}
.wl-embed-input{flex:1;display:flex;align-items:center;background:rgba(127,127,127,.08);border:1px solid rgba(127,127,127,.32);color:inherit;opacity:.55;padding:.95em 1.2em;border-radius:var(--btn-r);font-size:1rem}
.wl-embed .btn-sun{white-space:nowrap}
.wl-embed.loaded{cursor:default}
@media(max-width:520px){.wl-embed-fake{flex-direction:column}}
/* footer legal links */
.foot-legal{display:inline-flex;gap:.5em;flex-wrap:wrap}
.foot-legal a{color:inherit;opacity:.85;text-decoration:none}
.foot-legal a:hover{opacity:1;text-decoration:underline}

/* ============================================================ PRODUCT PAGE */
.pdp{padding-top:clamp(32px,4vw,56px)}
.pdp-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);align-items:start}
.pdp-gallery{display:grid;gap:14px;position:sticky;top:90px}
.pdp-main{border-radius:22px;overflow:hidden;aspect-ratio:4/5;background:var(--cream-100);box-shadow:0 36px 80px -44px rgba(226,97,28,.45)}
.pdp-main img{width:100%;height:100%;object-fit:cover}
.pdp-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.pdp-thumbs button{border:1px solid var(--line);border-radius:12px;overflow:hidden;aspect-ratio:1;background:var(--cream-100);cursor:pointer;padding:0;transition:border-color .3s}
.pdp-thumbs button.active{border-color:var(--sun-400)}
.pdp-thumbs img{width:100%;height:100%;object-fit:cover}
.pdp-info h1{font-family:var(--serif);font-size:clamp(2rem,3.6vw,2.9rem);line-height:1.05;margin-top:.6rem}
.pdp-info .price-now{font-family:var(--serif);font-size:2.2rem;margin-top:1rem;display:flex;align-items:baseline;gap:.5em}
.pdp-info .price-now small{font-size:.9rem;color:var(--ink-soft);font-family:var(--sans)}
.pdp-info .lead{margin-top:1rem;color:var(--ink-soft);font-size:1.08rem}
.variant{margin-top:1.6rem}
.variant .lab{font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:.6em}
.swatches{display:flex;gap:10px;flex-wrap:wrap}
.swatch{border:1.5px solid var(--line-strong);border-radius:12px;padding:.6em 1em;font-size:.92rem;font-weight:500;cursor:pointer;background:var(--cream-50);transition:border-color .3s,background .3s}
.swatch.active{border-color:var(--sun-400);background:#fff}
.pdp-cta{margin-top:1.8rem;display:flex;gap:12px;flex-wrap:wrap}
.pdp-incl{margin-top:2rem;border-top:1px solid var(--line);padding-top:1.4rem}
.pdp-incl h4{font-family:var(--serif);font-size:1.1rem;margin-bottom:.8em}
.pdp-incl ul{list-style:none;display:grid;gap:.6em}
.pdp-incl li{display:flex;gap:.6em;align-items:flex-start;font-size:.96rem;color:var(--ink-soft)}
.pdp-incl li svg{flex:none;margin-top:.25em;width:15px;height:15px;color:var(--life-700)}
@media(max-width:840px){.pdp-grid{grid-template-columns:1fr;gap:30px}.pdp-gallery{position:static}}

/* ============================================================ SHOP / COLLECTION */
.shop-hero{text-align:center;padding-top:clamp(40px,6vw,72px)}
.collection{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-top:clamp(36px,5vw,56px)}
.pcard{background:var(--cream-50);border:1px solid var(--line);border-radius:20px;overflow:hidden;display:flex;flex-direction:column;transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .4s}
.pcard:hover{transform:translateY(-6px);box-shadow:0 30px 60px -36px rgba(226,97,28,.4);border-color:var(--sun-400)}
.pcard .img{aspect-ratio:4/3;overflow:hidden;background:var(--cream-100)}
.pcard .img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.pcard:hover .img img{transform:scale(1.04)}
.pcard .body{padding:22px;display:flex;flex-direction:column;flex:1}
.pcard .tag{font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--life-700);margin-bottom:.5em}
.pcard h3{font-family:var(--serif);font-size:1.5rem}
.pcard .desc{color:var(--ink-soft);font-size:.95rem;margin-top:.4em;flex:1}
.pcard .foot{display:flex;align-items:center;justify-content:space-between;margin-top:1.2rem;gap:12px}
.pcard .pr{font-family:var(--serif);font-size:1.5rem}
.pcard .pr small{font-size:.8rem;color:var(--ink-soft);font-family:var(--sans)}

/* page header (subpages) */
.page-head{padding-top:clamp(40px,6vw,80px);padding-bottom:clamp(28px,4vw,44px)}
.breadcrumbs{font-size:.84rem;color:var(--ink-soft);display:flex;gap:.5em;align-items:center;margin-bottom:1rem}
.breadcrumbs a:hover{color:var(--life-700)}
.page-head h1{font-family:var(--serif);font-size:clamp(2.2rem,4.6vw,3.5rem);line-height:1.05;max-width:20ch}
.page-head .sub{margin-top:1rem;color:var(--ink-soft);font-size:1.12rem;max-width:54ch}

/* prose (story / blog post) */
.prose{max-width:68ch;margin-inline:auto}
.prose p{margin-top:1.2em;font-size:1.1rem;color:var(--ink);line-height:1.75}
.prose h2{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.2rem);margin-top:1.8em;line-height:1.1}
.prose h3{font-family:var(--serif);font-size:1.35rem;margin-top:1.4em}
.prose blockquote{margin:1.6em 0;padding-left:1.2em;border-left:2px solid var(--sun-400);font-family:var(--serif);font-size:1.4rem;line-height:1.3;color:var(--ink)}
.prose .figure{margin:1.8em 0;border-radius:18px;overflow:hidden}
.prose img{border-radius:18px}

/* blog index */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:26px;margin-top:clamp(36px,5vw,52px)}
.post-card{background:var(--cream-50);border:1px solid var(--line);border-radius:20px;overflow:hidden;display:flex;flex-direction:column;transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .4s}
.post-card:hover{transform:translateY(-5px);box-shadow:0 26px 56px -38px rgba(30,31,24,.4);border-color:var(--line-strong)}
.post-card .img{aspect-ratio:16/10;overflow:hidden;background:var(--cream-100)}
.post-card .img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.post-card:hover .img img{transform:scale(1.04)}
.post-card .body{padding:24px;display:flex;flex-direction:column;flex:1}
.post-card .cat{font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--life-700)}
.post-card h3{font-family:var(--serif);font-size:1.35rem;margin-top:.5em;line-height:1.15}
.post-card .ex{color:var(--ink-soft);font-size:.95rem;margin-top:.5em;flex:1}
.post-card .rd{margin-top:1rem;font-size:.85rem;font-weight:600;color:var(--ember-600);display:inline-flex;align-items:center;gap:.4em}

/* ============================================================ FOOTER */
footer.site{background:var(--cream-50);padding-block:clamp(48px,7vw,72px) 32px;border-top:1px solid var(--line)}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px}
.foot-brand .brand{margin-bottom:14px}
.foot-brand .tag{font-family:var(--serif);font-size:1.3rem;max-width:18ch;line-height:1.2}
.foot-col h5{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:14px}
.foot-col a{display:block;font-size:.95rem;color:var(--ink);padding:.3em 0;transition:color .3s}
.foot-col a:hover{color:var(--life-700)}
.foot-bottom{margin-top:clamp(40px,6vw,60px);padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:.84rem;color:var(--ink-soft)}
@media(max-width:780px){.foot-top{grid-template-columns:1fr 1fr}.foot-brand{grid-column:1/-1}}

/* ============================================================ STICKY MOBILE CTA */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:55;background:rgba(251,247,238,.92);backdrop-filter:blur(12px);border-top:1px solid var(--line);padding:10px clamp(16px,4vw,24px);display:none;gap:12px;align-items:center;justify-content:space-between;transform:translateY(110%);transition:transform .5s var(--ease)}
.sticky-cta.show{transform:none}
.sticky-cta .px{font-family:var(--serif);font-size:1.1rem}
.sticky-cta .px small{font-size:.8rem;color:var(--ink-soft);font-family:var(--sans);display:block}
@media(max-width:720px){.sticky-cta{display:flex}}

/* ============================================================ EXIT-INTENT POPUP */
.modal-overlay{position:fixed;inset:0;z-index:90;background:rgba(22,39,28,.55);backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:opacity .4s var(--ease),visibility .4s;display:grid;place-items:center;padding:18px}
.modal-overlay.open{opacity:1;visibility:visible}
.modal{background:var(--cream-50);border-radius:24px;overflow:hidden;max-width:880px;width:100%;display:grid;grid-template-columns:1.05fr .95fr;transform:translateY(16px) scale(.98);transition:transform .5s var(--ease);box-shadow:0 50px 120px -30px rgba(22,39,28,.6);max-height:94vh}
.modal-overlay.open .modal{transform:none}
.modal .left{padding:clamp(28px,4vw,46px);display:flex;flex-direction:column;justify-content:center;overflow-y:auto}
.modal .right{background:var(--cream-100);position:relative;min-height:240px}
.modal .right img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.modal .eyebrow{font-family:var(--serif);font-style:italic;font-size:1.05rem;color:var(--ember-600)}
.modal h3{font-family:var(--serif);font-size:clamp(1.8rem,3.4vw,2.6rem);line-height:1.04;margin-top:.2em}
.modal h3 .gold{color:var(--amber-500)}
.modal .ask{margin-top:1rem;color:var(--ink-soft);font-size:1rem}
.modal .opts{margin-top:1.2rem;display:grid;gap:10px}
.modal .opt{width:100%;text-align:left;background:#fff;border:1.5px solid var(--line);border-radius:14px;padding:.85em 1.1em;font-family:var(--sans);font-weight:600;font-size:1rem;cursor:pointer;transition:border-color .3s,background .3s,transform .2s var(--ease);color:var(--ink)}
.modal .opt:hover{border-color:var(--sun-400);transform:translateX(3px)}
.modal .decline{margin-top:14px;background:none;border:none;color:var(--ink-soft);font-size:.86rem;cursor:pointer;text-decoration:underline;text-underline-offset:3px;font-family:var(--sans)}
.modal .reward{display:none}
.modal.revealed .opts,.modal.revealed .ask{display:none}
.modal.revealed .reward{display:block}
.reward .wl-form{margin-top:1.4rem;max-width:none}
.reward .wl-form input{background:#fff;border:1px solid var(--line-strong);color:var(--ink)}
.reward .wl-form input::placeholder{color:var(--ink-soft)}
.reward .perk{margin-top:1rem;background:#fff;border:1px dashed var(--sun-400);border-radius:12px;padding:14px 16px;font-size:.92rem;color:var(--ink)}
.reward .perk b{color:var(--ember-600)}
.modal .close{position:absolute;top:14px;right:14px;z-index:3;width:38px;height:38px;border-radius:50%;border:none;background:rgba(252,250,245,.9);cursor:pointer;display:grid;place-items:center;box-shadow:0 4px 14px -6px rgba(30,31,24,.4)}
.modal .close svg{width:18px;height:18px;stroke:var(--ink)}
@media(max-width:680px){.modal{grid-template-columns:1fr}.modal .right{display:none}}

/* ============================================================ reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s} .reveal[data-d="2"]{transition-delay:.16s} .reveal[data-d="3"]{transition-delay:.24s}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .pulse::after,.float-card{animation:none}
  html{scroll-behavior:auto}
  .modal,.modal-overlay,.mobile-menu,.sticky-cta{transition:opacity .2s linear}
}
