/* =====================================================
   Frontier Cannabis — vintage frontier badge theme, v2
   Charcoal on cream · tan accent · slab serif headings
   ===================================================== */
:root{
  --cream:#F2ECE0;
  --bg:#F4EFE4;
  --paper:#FBF8F1;
  --ink:#22201b;
  --ink-soft:#3a362d;
  --dark:#1b1915;
  --dark-2:#26231d;
  --tan:#B5824A;
  --tan-dark:#9c6c39;
  --tan-light:#caa869;
  --line:#e2d9c6;
  --muted:#6c665a;
  --radius:6px;
  --radius-lg:10px;
  --shadow:0 12px 32px rgba(34,32,27,.10);
  --shadow-lg:0 24px 60px rgba(34,32,27,.16);
  --ease:cubic-bezier(.22,.8,.3,1);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:84px;}
body{font-family:'Inter',sans-serif;color:var(--ink);line-height:1.65;-webkit-font-smoothing:antialiased;
  /* halftone print grain — vintage newspaper feel */
  background-color:var(--bg);
  background-image:radial-gradient(rgba(34,32,27,.05) 1px, transparent 1.4px);
  background-size:5px 5px;}
h3,h4,.btn,.logo__word{font-family:'Zilla Slab',serif;}
h1,h2{font-family:'Alfa Slab One',serif;font-weight:400;}
.eyebrow{font-family:'Rye',serif;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
::selection{background:var(--tan);color:#fff;}

.wrap{max-width:1180px;margin:0 auto;padding:0 28px;}
.wrap--narrow{max-width:760px;}

.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--cream);padding:10px 18px;z-index:2000;border-radius:0 0 8px 0;}
.skip-link:focus{left:0;}

:is(a,button,input):focus-visible{outline:3px solid var(--tan);outline-offset:2px;border-radius:4px;}

.eyebrow{display:inline-flex;align-items:center;gap:14px;text-transform:uppercase;letter-spacing:.14em;font-size:12px;font-weight:400;color:var(--muted);margin-bottom:16px;}
.eyebrow--tan{color:var(--tan-dark);}
.section__head .eyebrow::before,.section__head .eyebrow::after{content:"";width:38px;height:1px;background:currentColor;opacity:.5;}

/* ===== Scroll reveal ===== */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.reveal.in{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  .reveal{opacity:1;transform:none;transition:none;}
  .marquee__track{animation:none!important;}
  *{transition-duration:.01ms!important;animation-duration:.01ms!important;}
}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.09em;padding:13px 26px;border-radius:3px;border:2px solid transparent;cursor:pointer;transition:transform .18s var(--ease),background .18s,color .18s,box-shadow .18s;}
.btn:hover{transform:translateY(-2px);}
.btn:active{transform:translateY(0);}
.btn--lg{padding:17px 36px;font-size:15px;}
.btn--tan{background:var(--tan);color:#fff;box-shadow:0 6px 18px rgba(181,130,74,.35);}
.btn--tan:hover{background:var(--tan-dark);box-shadow:0 10px 24px rgba(181,130,74,.4);}
.btn--dark{background:var(--ink);color:var(--cream);}
.btn--dark:hover{background:var(--dark-2);}
.btn--outline{background:transparent;color:var(--ink);border-color:var(--ink);}
.btn--outline:hover{background:var(--ink);color:var(--cream);}
.btn--ghost{background:transparent;color:var(--muted);border-color:var(--line);}
.btn--ghost:hover{background:var(--cream);}

/* ===== Age gate ===== */
.agegate{position:fixed;inset:0;z-index:1000;background:rgba(27,25,21,.92);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:24px;}
.agegate[hidden]{display:none;}
.agegate__card{background:var(--bg);border-radius:10px;padding:48px 44px;max-width:450px;text-align:center;box-shadow:0 30px 80px rgba(0,0,0,.5);border:1px solid rgba(181,130,74,.25);outline:1px solid var(--line);outline-offset:-9px;}
.agegate__logo-img{width:120px;height:120px;border-radius:50%;object-fit:cover;margin:0 auto 22px;box-shadow:0 10px 28px rgba(0,0,0,.35);}
.agegate__card h2{font-size:28px;color:var(--ink);margin-bottom:10px;}
.agegate__card p{color:var(--muted);font-size:15px;}
.agegate__btns{display:flex;gap:12px;justify-content:center;margin:26px 0 18px;}
.agegate__fine{font-size:12px;color:var(--muted);}

/* ===== Header ===== */
.site-header{position:sticky;top:0;z-index:500;background:var(--bg);border-bottom:4px double var(--line);transition:box-shadow .25s;}
.site-header.scrolled{box-shadow:0 4px 24px rgba(34,32,27,.10);}
.header__inner{display:flex;align-items:center;justify-content:space-between;height:76px;}
.logo{display:flex;align-items:center;gap:12px;}
.logo img{width:46px;height:46px;border-radius:50%;object-fit:cover;}
.logo__word{display:flex;flex-direction:column;line-height:1;font-weight:700;font-size:19px;letter-spacing:.05em;color:var(--ink);text-transform:uppercase;}
.logo__word small{font-size:10px;letter-spacing:.28em;color:var(--tan-dark);font-weight:600;margin-top:4px;}
.nav{display:flex;align-items:center;gap:30px;}
.nav a{position:relative;font-size:14px;font-weight:500;color:var(--ink);transition:color .15s;}
.nav a:not(.nav__cta)::after{content:"";position:absolute;left:0;bottom:-6px;width:100%;height:2px;background:var(--tan);transform:scaleX(0);transform-origin:left;transition:transform .22s var(--ease);}
.nav a:not(.nav__cta):hover::after{transform:scaleX(1);}
.nav a:hover{color:var(--tan-dark);}
.nav__cta{background:var(--ink);color:var(--cream)!important;padding:10px 20px;border-radius:3px;font-weight:600;}
.nav__cta:hover{background:var(--tan-dark);}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px;}
.nav-toggle span{width:24px;height:2px;background:var(--ink);transition:.25s;}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-toggle.open span:nth-child(2){opacity:0;}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ===== Cinematic scroll hero (video scrub) ===== */
.vhero{position:relative;height:300vh;background:#16140f;}
.vhero__sticky{position:sticky;top:0;height:100vh;height:100svh;overflow:hidden;}
.vhero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
/* JS adds .will-fade on boot, then .is-ready when decodable — so the video is
   never hidden unless the fade code is actually running. */
.vhero__video.will-fade{opacity:0;transition:opacity .2s ease-out;}
.vhero__video.will-fade.is-ready{opacity:1;}
.vhero__scrim{position:absolute;inset:0;background:
  radial-gradient(ellipse at center, transparent 30%, rgba(22,20,15,.55) 100%),
  linear-gradient(180deg, rgba(22,20,15,.35), transparent 30%, transparent 70%, rgba(22,20,15,.75));}
.vhero__copy{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:0 24px;}
.vhero__kicker{font-size:13px;font-weight:600;letter-spacing:.34em;text-transform:uppercase;color:var(--tan);margin-bottom:20px;}
.vhero__copy h1{font-size:clamp(38px,5.6vw,72px);line-height:1.08;color:var(--cream);max-width:14ch;text-shadow:0 4px 30px rgba(0,0,0,.5);}
.vhero__copy h1 em{font-family:'Rye',serif;font-style:normal;font-size:.94em;color:var(--tan);display:inline-block;}
.vhero__hint{position:absolute;bottom:34px;left:0;right:0;font-size:11px;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:rgba(242,236,224,.55);animation:vhero-pulse 2.2s ease-in-out infinite;}
@keyframes vhero-pulse{0%,100%{opacity:.4}50%{opacity:1}}
@media (prefers-reduced-motion: reduce){
  .vhero{height:100vh;height:100svh;}
}

/* ===== Hero ===== */
.hero{position:relative;overflow:hidden;background:var(--cream);}
.hero__bg{position:absolute;inset:0;
  background:
    radial-gradient(110% 90% at 75% 10%, rgba(181,130,74,.18), transparent 55%),
    repeating-linear-gradient(0deg, rgba(34,32,27,.035) 0 1px, transparent 1px 28px),
    repeating-linear-gradient(90deg, rgba(34,32,27,.035) 0 1px, transparent 1px 28px);
  mask-image:radial-gradient(circle at 60% 35%,#000,transparent 90%);}
.hero__inner{position:relative;display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:48px;padding-top:64px;padding-bottom:84px;}
.hero h1,.hero__title{font-size:clamp(34px,4.8vw,58px);line-height:1.1;letter-spacing:.01em;color:var(--ink);text-shadow:3px 3px 0 rgba(181,130,74,.22);}
.hero h1 em,.hero__title em{font-family:'Rye',serif;font-style:normal;font-size:.94em;color:var(--tan-dark);display:inline-block;text-shadow:none;}
.hero__sub{font-size:19px;color:var(--ink-soft);max-width:540px;margin:22px 0 32px;}
.hero__btns{display:flex;gap:14px;flex-wrap:wrap;}
.hero__chips{list-style:none;display:flex;gap:12px;flex-wrap:wrap;margin-top:34px;}
.hero__chips li{font-size:12.5px;font-weight:600;color:var(--ink-soft);letter-spacing:.03em;background:var(--paper);border:1px dashed var(--tan);border-radius:4px;padding:7px 14px;}
.hero__art{display:flex;justify-content:center;}
.hero__badge{width:min(480px,100%);height:auto;mix-blend-mode:multiply;filter:drop-shadow(0 24px 40px rgba(34,32,27,.18));transition:transform .4s var(--ease);}
.hero__badge:hover{transform:rotate(-1.5deg) scale(1.015);}

/* ===== Page hero (inner pages) ===== */
.page-hero{position:relative;overflow:hidden;background:var(--cream);text-align:center;}
.page-hero__inner{position:relative;padding-top:72px;padding-bottom:72px;display:flex;flex-direction:column;align-items:center;}
.page-hero h1{font-size:clamp(32px,4.4vw,52px);line-height:1.12;letter-spacing:.01em;color:var(--ink);text-shadow:3px 3px 0 rgba(181,130,74,.22);}
.page-hero h1 em{font-family:'Rye',serif;font-style:normal;font-size:.94em;color:var(--tan-dark);display:inline-block;text-shadow:none;}
.page-hero__sub{font-size:18px;color:var(--ink-soft);max-width:580px;margin-top:20px;}

/* ===== Format rows (education) ===== */
.format-list{max-width:820px;margin:0 auto;}
.format-row{display:grid;grid-template-columns:220px 1fr;gap:26px;padding:26px 0;border-bottom:1px dotted rgba(242,236,224,.25);}
.format-row:last-child{border-bottom:none;}
.format-row h3{font-size:21px;color:var(--tan-light);}
.format-row p{color:#cfc8b8;font-size:15.5px;}

/* ===== Terpene cards (education) ===== */
.terp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.terp-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:30px 28px;outline:1px solid var(--line);outline-offset:-8px;transition:transform .22s var(--ease),box-shadow .22s var(--ease);}
.terp-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.terp-card h3{font-size:21px;color:var(--ink);margin-bottom:4px;}
.terp-card__aroma{display:block;font-family:'Zilla Slab';font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--tan-dark);margin-bottom:12px;}
.terp-card p{color:var(--muted);font-size:14.5px;}

/* ===== Numbered steps (education) ===== */
.steps{list-style:none;counter-reset:step;max-width:640px;margin:0 auto;}
.steps li{counter-increment:step;position:relative;padding:18px 0 18px 70px;border-bottom:1px dotted var(--line);font-size:16px;color:var(--ink-soft);}
.steps li:last-child{border-bottom:none;}
.steps li strong{color:var(--ink);}
.steps li::before{content:counter(step);position:absolute;left:0;top:14px;width:46px;height:46px;display:flex;align-items:center;justify-content:center;font-family:'Alfa Slab One';font-size:18px;color:var(--tan-dark);background:var(--paper);border:2px solid var(--tan);border-radius:50%;}

/* ===== Marquee ===== */
.marquee{background:var(--dark);color:var(--cream);overflow:hidden;border-block:4px double rgba(242,236,224,.3);}
.marquee__track{display:flex;gap:34px;align-items:center;white-space:nowrap;width:max-content;padding:15px 0;animation:marquee 28s linear infinite;}
.marquee__track span{font-family:'Zilla Slab';font-weight:600;font-size:14px;text-transform:uppercase;letter-spacing:.18em;}
.marquee__leaf{color:var(--tan-light);}
@keyframes marquee{to{transform:translateX(-50%);}}

/* ===== Sections ===== */
.section{padding:92px 0;}
.section--dark{background:var(--dark);color:var(--cream);}
.section--cream{background:var(--cream);}
.section__head{max-width:680px;margin:0 auto 48px;text-align:center;}
.section__head h2{font-size:clamp(26px,3.6vw,40px);line-height:1.12;color:var(--ink);letter-spacing:.01em;text-shadow:2px 2px 0 rgba(181,130,74,.18);}
.section--dark .section__head h2{color:var(--cream);text-shadow:3px 3px 0 rgba(0,0,0,.35);}
.section__head h2::after{content:"— ★ —";display:block;font-family:'Zilla Slab';font-size:14px;letter-spacing:.4em;color:var(--tan);margin-top:16px;text-shadow:none;}
.section__head p{color:var(--muted);font-size:17px;margin-top:14px;}
.section--dark .section__head p{color:#cfc8b8;}

/* ===== Menu ===== */
.menu-controls{display:flex;justify-content:space-between;align-items:center;gap:20px;margin-bottom:18px;flex-wrap:wrap;}
.search{display:flex;align-items:center;gap:10px;background:var(--paper);border:1px solid var(--line);border-radius:3px;padding:12px 19px;min-width:260px;flex:1;max-width:340px;color:var(--muted);transition:border-color .2s,box-shadow .2s;}
.search:focus-within{border-color:var(--tan);box-shadow:0 0 0 3px rgba(181,130,74,.15);}
.search input{border:none;outline:none;font-family:inherit;font-size:15px;width:100%;background:none;color:var(--ink);}
.filters{display:flex;gap:8px;flex-wrap:wrap;}
.chip{font-family:'Zilla Slab';font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:8px 15px;border-radius:3px;border:1px solid var(--line);background:var(--paper);color:var(--muted);cursor:pointer;transition:.18s;}
.chip:hover{border-color:var(--tan);color:var(--tan-dark);transform:translateY(-1px);}
.chip.is-active{background:var(--ink);border-color:var(--ink);color:var(--cream);}
.menu-count{font-size:13px;color:var(--muted);margin-bottom:18px;}

.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.product{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .22s var(--ease),box-shadow .22s var(--ease),border-color .22s;display:flex;flex-direction:column;opacity:0;transform:translateY(14px);animation:cardIn .5s var(--ease) forwards;}
.product:nth-child(2){animation-delay:.04s}.product:nth-child(3){animation-delay:.08s}.product:nth-child(4){animation-delay:.12s}
.product:nth-child(5){animation-delay:.16s}.product:nth-child(6){animation-delay:.2s}.product:nth-child(7){animation-delay:.24s}.product:nth-child(8){animation-delay:.28s}
@keyframes cardIn{to{opacity:1;transform:none;}}
.product:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:#d8cdb4;}
.product__thumb{height:180px;background:#ece4d2;border-bottom:1px solid var(--line);overflow:hidden;}
.product__thumb img{width:100%;height:100%;object-fit:cover;transition:transform .35s var(--ease);}
.product:hover .product__thumb img{transform:scale(1.05);}
.product__body{padding:16px 16px 18px;display:flex;flex-direction:column;gap:6px;flex:1;}
.product__cat{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--tan-dark);font-weight:700;}
.product__name{font-family:'Zilla Slab';font-weight:700;font-size:16.5px;color:var(--ink);line-height:1.2;}
.product__meta{font-size:13px;color:var(--muted);}
.product__potency{display:flex;gap:6px;flex-wrap:wrap;margin-top:2px;}
.product__potency span{font-size:11px;font-weight:600;background:var(--cream);border:1px solid var(--line);color:var(--ink-soft);padding:2px 8px;border-radius:3px;}
.product__foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:12px;}
.product__price{font-family:'Zilla Slab';font-weight:700;color:var(--ink);font-size:18px;}
.product__tag{font-size:11px;background:var(--tan);color:#fff;padding:3px 10px;border-radius:3px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;}
.menu-empty{text-align:center;color:var(--muted);padding:34px;font-size:16px;}
.menu-note{text-align:center;color:var(--muted);font-size:13px;font-style:italic;margin-top:28px;}

/* ===== Story ===== */
.story{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;}
.story__text h2{color:var(--cream);font-size:clamp(26px,3.4vw,38px);line-height:1.16;margin-bottom:18px;letter-spacing:.01em;text-shadow:3px 3px 0 rgba(0,0,0,.35);}
.story__text p{color:#cfc8b8;margin-bottom:16px;}
.story__text strong{color:var(--cream);}
.story__text .btn{margin-top:12px;}
.story__side{display:flex;flex-direction:column;gap:24px;align-items:center;}
.story__emblem{width:min(280px,70%);border-radius:50%;box-shadow:0 24px 60px rgba(0,0,0,.45);transition:transform .4s var(--ease);}
.story__emblem:hover{transform:rotate(2deg) scale(1.02);}
.story__card{background:var(--dark-2);border:1px solid rgba(242,236,224,.12);border-radius:var(--radius-lg);padding:36px 34px;position:relative;outline:1px solid rgba(242,236,224,.14);outline-offset:-8px;}
.story__card .quote{font-family:'Zilla Slab';font-size:70px;line-height:.6;color:var(--tan-light);}
.story__card p{font-size:19px;color:var(--cream);font-family:'Zilla Slab';font-weight:600;line-height:1.4;margin:14px 0 18px;}
.story__by{color:var(--tan-light);font-size:14px;font-weight:600;}

/* ===== Stats ===== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:72px;padding-top:48px;border-top:1px solid rgba(242,236,224,.12);}
.stats div{text-align:center;}
.stats strong{font-family:'Alfa Slab One';font-weight:400;font-size:38px;color:var(--tan-light);line-height:1;text-shadow:2px 2px 0 rgba(0,0,0,.4);}
.stats em{font-family:'Zilla Slab';font-style:normal;font-weight:700;font-size:20px;color:var(--tan-light);margin-left:4px;}
.stats span{display:block;font-size:13px;color:#c8c1b1;margin-top:8px;}

/* ===== Stores ===== */
.store-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.store-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:32px;transition:transform .22s var(--ease),box-shadow .22s var(--ease);outline:1px solid var(--line);outline-offset:-8px;}
.store-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);}
.store-card__top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px;}
.store-card h3{font-size:23px;font-weight:700;color:var(--ink);}
.store-status{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:4px 11px;border-radius:3px;background:var(--cream);border:1px solid var(--line);color:var(--muted);white-space:nowrap;}
.store-status.open{background:#e5eedd;color:#3e6b2f;}
.store-status.closed{background:#f3e3dc;color:#9c4a32;}
.store-card__addr{color:var(--muted);font-size:15px;margin-bottom:8px;}
.store-card__tel{display:inline-block;color:var(--tan-dark);font-weight:600;margin-bottom:16px;}
.store-card__tel:hover{text-decoration:underline;}
.hours{list-style:none;border-top:1px solid var(--line);padding-top:14px;margin-bottom:16px;}
.hours li{display:flex;justify-content:space-between;font-size:14px;color:var(--ink);padding:5px 0;border-bottom:1px dotted var(--line);}
.hours li:last-child{border-bottom:none;}
.hours li span:first-child{color:var(--muted);}
.store-card__link{font-family:'Zilla Slab';font-weight:700;font-size:14px;color:var(--ink);text-transform:uppercase;letter-spacing:.05em;transition:color .15s;}
.store-card__link:hover{color:var(--tan-dark);}

/* ===== Learn ===== */
.learn-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.learn-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:34px 30px;transition:transform .22s var(--ease),box-shadow .22s var(--ease);outline:1px solid var(--line);outline-offset:-8px;}
.learn-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);}
.learn-card__no{font-family:'Rye',serif;font-size:15px;color:var(--tan-dark);margin-bottom:14px;}
.learn-card__no::after{content:"";display:block;width:34px;height:1px;background:var(--tan);margin-top:10px;opacity:.6;}
.learn-card h3{font-size:20px;font-weight:700;color:var(--ink);margin-bottom:8px;}
.learn-card p{color:var(--muted);font-size:15px;}
.learn-cta{text-align:center;margin-top:36px;}
.learn-note{margin-top:18px;color:var(--muted);font-size:14px;font-style:italic;text-align:center;}

/* ===== Reviews ===== */
.review-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.review{background:var(--cream);border-radius:var(--radius);padding:30px 26px;border:1px solid var(--line);transition:transform .22s var(--ease);outline:1px solid var(--line);outline-offset:-7px;}
.review:hover{transform:translateY(-4px);}
.review .stars{color:var(--tan);font-size:16px;letter-spacing:2px;margin-bottom:12px;}
.review p{font-size:16px;color:var(--ink);font-style:italic;margin-bottom:14px;}
.review cite{font-style:normal;font-weight:700;color:var(--tan-dark);font-size:14px;}

/* ===== FAQ ===== */
.faq__item{border-bottom:1px solid var(--line);}
.faq__q{width:100%;background:none;border:none;text-align:left;font-family:'Zilla Slab';font-weight:700;font-size:18px;color:var(--ink);padding:22px 0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;transition:color .15s;}
.faq__q:hover{color:var(--tan-dark);}
.faq__icon{font-size:24px;color:var(--tan-dark);transition:transform .25s var(--ease);flex:0 0 auto;}
.faq__item.open .faq__icon{transform:rotate(45deg);}
.faq__a{max-height:0;overflow:hidden;transition:max-height .3s var(--ease);}
.faq__a p{padding:0 0 22px;color:var(--muted);font-size:16px;}

/* ===== Newsletter ===== */
.newsletter{background:var(--tan);color:#fff;position:relative;overflow:hidden;}
.newsletter::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg, rgba(255,255,255,.04) 0 2px, transparent 2px 18px);}
.newsletter__inner{position:relative;display:flex;align-items:center;justify-content:space-between;gap:30px;padding-top:54px;padding-bottom:54px;flex-wrap:wrap;}
.newsletter h2{font-size:27px;text-shadow:2px 2px 0 rgba(0,0,0,.18);}
.newsletter p{color:#fbeede;margin-top:6px;max-width:460px;}
.newsletter__form{display:flex;gap:10px;}
.newsletter__form input{padding:15px 19px;border:none;border-radius:3px;font-family:inherit;font-size:15px;min-width:250px;}
.newsletter__success{font-weight:600;font-size:16px;}

/* ===== Footer ===== */
.footer{background:var(--dark);color:var(--cream);padding:64px 0 0;}
.footer__inner{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:38px;padding-bottom:46px;}
.footer__logo{width:84px;height:84px;border-radius:50%;object-fit:cover;margin-bottom:16px;}
.footer__brand p{color:#aaa394;font-size:14px;max-width:280px;}
.footer__col h4{font-family:'Rye',serif;font-weight:400;font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--tan-light);margin-bottom:14px;}
.footer__col a{display:block;color:#cfc8b8;font-size:14px;padding:5px 0;transition:color .15s,transform .15s;}
.footer__col a:hover{color:var(--cream);transform:translateX(3px);}
.footer__legal{color:#aaa394;font-size:13px;line-height:1.6;}
.footer__bar{border-top:1px solid rgba(242,236,224,.12);}
.footer__bar-inner{display:flex;justify-content:space-between;padding:20px 28px;font-size:13px;color:#aaa394;flex-wrap:wrap;gap:8px;}

/* ===== Back to top ===== */
.to-top{position:fixed;right:24px;bottom:24px;width:46px;height:46px;border-radius:6px;border:1px solid rgba(242,236,224,.3);background:var(--ink);color:var(--cream);font-size:19px;cursor:pointer;opacity:0;pointer-events:none;transform:translateY(10px);transition:opacity .25s,transform .25s,background .2s;z-index:400;box-shadow:0 10px 26px rgba(0,0,0,.25);}
.to-top.show{opacity:1;pointer-events:auto;transform:none;}
.to-top:hover{background:var(--tan-dark);}

/* ===== Responsive ===== */
@media(max-width:980px){
  .hero__inner{grid-template-columns:1fr;text-align:center;padding-top:48px;}
  .hero__copy{display:flex;flex-direction:column;align-items:center;}
  .hero__btns{justify-content:center;width:100%;}
  .hero__chips{justify-content:center;}
  .hero__art{order:-1;}
  .hero__badge{width:min(340px,76%);}
  .product-grid,.review-grid{grid-template-columns:repeat(2,1fr);}
  .store-grid,.learn-grid{grid-template-columns:1fr;}
  .terp-grid{grid-template-columns:repeat(2,1fr);}
  .format-row{grid-template-columns:1fr;gap:6px;padding:22px 0;}
  .story{grid-template-columns:1fr;gap:36px;}
  .stats{grid-template-columns:repeat(2,1fr);gap:28px;}
  .footer__inner{grid-template-columns:1fr 1fr;}
}
@media(max-width:760px){
  .nav{position:fixed;top:76px;right:0;left:0;flex-direction:column;align-items:stretch;gap:0;background:var(--bg);border-bottom:1px solid var(--line);padding:8px 0;transform:translateY(-130%);transition:transform .3s var(--ease);box-shadow:0 12px 30px rgba(0,0,0,.1);}
  .nav.open{transform:translateY(0);}
  .nav a{padding:14px 28px;border-bottom:1px solid var(--line);}
  .nav a:not(.nav__cta)::after{display:none;}
  .nav__cta{margin:10px 28px;text-align:center;}
  .nav-toggle{display:flex;}
  .menu-controls{flex-direction:column;align-items:stretch;}
  .search{max-width:none;}
  .newsletter__inner{flex-direction:column;align-items:flex-start;}
  .newsletter__form{width:100%;}
  .newsletter__form input{flex:1;min-width:0;}
  .section{padding:72px 0;}
}
@media(max-width:560px){
  .product-grid,.review-grid,.terp-grid{grid-template-columns:1fr;}
  .stats{grid-template-columns:1fr 1fr;}
  .footer__inner{grid-template-columns:1fr;}
  .logo__word small{display:none;}
  .hero h1{font-size:clamp(32px,9vw,42px);}
  .agegate__btns{flex-direction:column;}
}
