/* ShopCoffee — shared storefront styles
   Brand: espresso black #0A0705 · cream #F7F1E6 · amber/crema #D8A24A · stone #B9B2A6
   Type: Playfair Display (headlines) · Inter (body) · JetBrains Mono (labels/UI) */
:root{
  --espresso:#0A0705; --espresso-2:#120D09; --panel:#171009; --line:rgba(216,162,74,.18);
  --amber:#D8A24A; --amber-soft:#D8A24A2e; --amber-2:#E6B45C;
  --cream:#F7F1E6; --cream-dim:#E7DECF; --stone:#B9B2A6; --stone-dim:rgba(185,178,166,.6);
  --maxw:1140px; --r:16px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Inter',-apple-system,system-ui,sans-serif;background:var(--espresso);color:var(--cream);
  -webkit-font-smoothing:antialiased;line-height:1.6;overflow-x:hidden;}
/* defensive: no image or video should ever break the layout horizontally */
img,video{max-width:100%;}
::selection{background:var(--amber);color:#1a1208;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
h1,h2,h3{font-family:'Playfair Display',Georgia,serif;line-height:1.08;font-weight:700;}
.serif{font-family:'Playfair Display',Georgia,serif;}
.mono{font-family:'JetBrains Mono',monospace;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 1.5rem;}
.amber{color:var(--amber);}
.eyebrow{font-family:'JetBrains Mono',monospace;font-size:.66rem;letter-spacing:.28em;text-indent:.28em;
  text-transform:uppercase;color:var(--amber);}
.muted{color:var(--stone);}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:'JetBrains Mono',monospace;font-size:.74rem;
  font-weight:500;letter-spacing:.16em;text-transform:uppercase;padding:.85rem 1.5rem;border-radius:999px;
  cursor:pointer;border:1px solid transparent;transition:filter .2s,transform .15s,background .2s,color .2s;white-space:nowrap;}
.btn:active{transform:scale(.97);}
.btn-primary{background:linear-gradient(180deg,var(--amber-2),var(--amber));color:#1a1208;}
.btn-primary:hover{filter:brightness(1.1);}
.btn-ghost{border-color:var(--amber);color:var(--amber);background:rgba(216,162,74,.06);}
.btn-ghost:hover{background:rgba(216,162,74,.16);}

/* ---- header ---- */
.site-head{position:sticky;top:0;z-index:50;backdrop-filter:blur(12px);
  background:rgba(10,7,5,.72);border-bottom:1px solid var(--line);}
.site-head .wrap{display:flex;align-items:center;justify-content:space-between;height:64px;}
.brand{font-family:'Playfair Display',serif;font-weight:900;font-size:1.5rem;letter-spacing:.01em;color:var(--cream);}
.brand span{color:var(--amber);}
.nav{display:flex;align-items:center;gap:1.9rem;}
.nav a{font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--cream-dim);transition:color .2s;}
.nav a:hover,.nav a.active{color:var(--amber);}
.nav .btn{padding:.6rem 1.15rem;}
.navtoggle{display:none;background:none;border:0;color:var(--cream);font-size:1.5rem;line-height:1;
  cursor:pointer;width:44px;height:44px;align-items:center;justify-content:center;margin-right:-.4rem;}
@media(max-width:760px){
  /* Full-width opaque dropdown glued to the header's bottom edge. Solid background so the
     hero/content never bleeds through; scrolls internally if the menu is taller than the viewport. */
  .nav{position:fixed;inset:64px 0 auto 0;flex-direction:column;gap:0;background:var(--espresso);
    border-bottom:1px solid var(--line);box-shadow:0 26px 48px rgba(0,0,0,.6);padding:.4rem 0 .9rem;
    max-height:calc(100vh - 64px);overflow-y:auto;transform:translateY(-135%);visibility:hidden;
    transition:transform .32s cubic-bezier(.4,0,.2,1),visibility 0s linear .32s;}
  .nav.open{transform:translateY(0);visibility:visible;transition:transform .32s cubic-bezier(.4,0,.2,1),visibility 0s;}
  .nav a{padding:1rem 1.5rem;width:100%;border-top:1px solid var(--line);}
  .nav .btn{margin:.9rem 1.5rem 0;justify-content:center;}
  .navtoggle{display:inline-flex;}
}

/* ---- hero ---- */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden;}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
  filter:brightness(.96) contrast(1.08) saturate(1.2);animation:kenburns 32s ease-in-out infinite alternate;}
@keyframes kenburns{from{transform:scale(1.04);}to{transform:scale(1.14);}}
/* lighter, directional scrim: keeps the left text legible while the video stays bright + visible,
   warm amber bloom for depth, soft bottom fade into the next section. */
.hero-overlay{position:absolute;inset:0;z-index:1;background:
  linear-gradient(90deg,rgba(10,7,5,.8) 0%,rgba(10,7,5,.42) 40%,rgba(10,7,5,.06) 72%,rgba(10,7,5,0) 100%),
  linear-gradient(0deg,rgba(10,7,5,.9) 0%,rgba(10,7,5,.12) 28%,rgba(10,7,5,0) 52%),
  radial-gradient(75% 60% at 72% 32%,rgba(216,162,74,.16),transparent 62%);}
.hero .wrap{position:relative;z-index:2;padding-top:4rem;padding-bottom:4rem;}
.hero .eyebrow{display:inline-block;margin-bottom:1rem;text-shadow:0 1px 12px rgba(0,0,0,.6);}
.hero h1{font-size:clamp(2.8rem,7.4vw,5.6rem);font-weight:900;max-width:14ch;letter-spacing:-.01em;
  background:linear-gradient(180deg,#FFF8EC,var(--cream) 55%,#C9A876 120%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  filter:drop-shadow(0 3px 22px rgba(0,0,0,.55));}
.hero p.lede{font-size:clamp(1rem,2.4vw,1.3rem);color:var(--cream);max-width:46ch;margin:1.3rem 0 2rem;
  text-shadow:0 1px 16px rgba(0,0,0,.7);}
.hero .cta-row{display:flex;gap:.9rem;flex-wrap:wrap;}
/* keep the ghost CTA legible wherever it lands over the bright bag in the video */
.hero .btn-ghost{background:rgba(10,7,5,.4);backdrop-filter:blur(4px);}
.hero .btn-ghost:hover{background:rgba(216,162,74,.2);}
/* scroll cue */
.scrolldown{position:absolute;left:50%;bottom:2rem;transform:translateX(-50%);z-index:2;
  font-family:'JetBrains Mono',monospace;font-size:.58rem;letter-spacing:.28em;text-indent:.28em;
  text-transform:uppercase;color:var(--stone);display:flex;flex-direction:column;align-items:center;gap:.5rem;
  opacity:0;animation:up 1.2s 1.4s ease forwards;}
.scrolldown::after{content:"";width:1px;height:34px;background:linear-gradient(var(--amber),transparent);
  animation:scrollpulse 2.2s ease-in-out infinite;}
@keyframes scrollpulse{0%,100%{opacity:.3;transform:scaleY(.6);}50%{opacity:1;transform:scaleY(1);}}

/* ---- How-it-works figure (homepage triptych above the step cards) ---- */
.hiw-figure{margin:0 auto 2.5rem;max-width:1140px;}
.hiw-figure img{width:100%;height:auto;display:block;border-radius:var(--r);
  box-shadow:0 30px 80px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.05);}

/* ---- product details grid (roast-date stamp + origin still-life under accent) ---- */
.details-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem;}
.details-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  display:flex;flex-direction:column;}
.details-card img{width:100%;aspect-ratio:3/4;object-fit:cover;display:block;}
.details-card figcaption{padding:1.2rem 1.3rem 1.4rem;color:var(--cream-dim);font-size:.92rem;line-height:1.55;}
.details-card figcaption strong{color:var(--cream);font-weight:500;display:block;margin-bottom:.3rem;
  font-family:'Playfair Display',serif;font-size:1.05rem;}
@media(max-width:760px){.details-grid{grid-template-columns:1fr;}.details-card img{aspect-ratio:4/3;}}

/* ---- product accent video (brewing method below main visual) ---- */
.accent-figure{max-width:560px;margin:0 auto;text-align:center;}
.accent-video{width:100%;max-width:420px;aspect-ratio:1/1;border-radius:18px;display:block;margin:0 auto;
  object-fit:cover;box-shadow:0 30px 70px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.06);}
.accent-figure figcaption{margin-top:1rem;color:var(--stone);font-size:.95rem;font-style:italic;font-family:'Playfair Display',serif;}

/* ---- homepage wide brand feature (three-bag stack hero strip) ---- */
.brand-feature{position:relative;padding:0;overflow:hidden;}
.brand-feature-img{width:100%;height:auto;display:block;}
.brand-feature .wrap{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;
  padding-bottom:2.5rem;pointer-events:none;}
.brand-feature .badge-text{font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--amber);background:rgba(10,7,5,.7);padding:.5rem .9rem;
  border:1px solid var(--amber);border-radius:999px;align-self:flex-start;backdrop-filter:blur(6px);}
@media(max-width:760px){.brand-feature .wrap{padding-bottom:1.2rem;}.brand-feature .badge-text{font-size:.6rem;}}

/* ---- Find Your Coffee quiz ---- */
.quiz{background:var(--panel);border:1px solid var(--line);border-radius:24px;padding:3rem 2.5rem;}
.quiz-progress{font-family:'JetBrains Mono',monospace;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--stone);margin-bottom:1.5rem;}
.quiz-bar{height:3px;background:rgba(216,162,74,.15);border-radius:2px;overflow:hidden;margin-top:.5rem;}
.quiz-bar-fill{height:100%;background:var(--amber);transition:width .35s ease;}
.quiz-q{font-size:clamp(1.6rem,3vw,2.2rem);line-height:1.2;margin:0 0 1.6rem;color:var(--cream);}
.quiz-options{display:flex;flex-direction:column;gap:.7rem;}
.quiz-opt{background:rgba(255,255,255,.04);border:1px solid var(--line);color:var(--cream);
  font-family:'Inter',sans-serif;font-size:1.02rem;text-align:left;padding:1.1rem 1.3rem;
  border-radius:14px;cursor:pointer;transition:border-color .2s,background .2s,transform .15s;}
.quiz-opt:hover{border-color:var(--amber);background:rgba(216,162,74,.06);}
.quiz-opt:active{transform:scale(.99);}
.quiz-result{text-align:center;}
.quiz-result-name{font-size:clamp(2rem,4.5vw,3rem);margin:.5rem 0;color:var(--cream);}
.quiz-result-roast{font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--stone);margin-bottom:1.5rem;}
.quiz-result-img{max-width:280px;margin:1.4rem auto;border-radius:14px;overflow:hidden;box-shadow:0 24px 56px rgba(0,0,0,.5);}
.quiz-result-img img{width:100%;height:auto;display:block;}
.quiz-result-desc{color:var(--cream-dim);max-width:50ch;margin:1.4rem auto;}
.quiz-result-cta{display:flex;justify-content:center;gap:.8rem;flex-wrap:wrap;margin-top:1.5rem;}
.quiz-restart{margin-top:2rem;font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;}
.quiz-restart a{color:var(--stone);text-decoration:none;border-bottom:1px solid transparent;transition:.2s;}
.quiz-restart a:hover{color:var(--amber);border-color:var(--amber);}
@media(max-width:560px){.quiz{padding:2rem 1.4rem;border-radius:18px;}}

/* ---- Article figure (triptych etc) ---- */
.article-figure{margin:1.5rem auto 2.5rem;max-width:880px;}
.article-figure img{width:100%;height:auto;display:block;border-radius:var(--r);
  box-shadow:0 24px 60px rgba(0,0,0,.45),0 0 0 1px rgba(255,255,255,.06);}
.article-figure figcaption{margin-top:.8rem;text-align:center;color:var(--stone);
  font-size:.86rem;font-style:italic;}

/* ---- About page split hero (text left, bag-in-hand right) ---- */
.about-hero{display:grid;grid-template-columns:1fr 1.1fr;gap:3rem;align-items:center;
  padding-top:3.5rem;padding-bottom:1.5rem;}
.about-hero-text h1{font-size:clamp(2.4rem,5.4vw,3.8rem);line-height:1.05;margin:.6rem 0;
  background:linear-gradient(180deg,#FFF8EC,var(--cream) 55%,#C9A876 120%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  filter:drop-shadow(0 3px 22px rgba(0,0,0,.35));}
.about-hero-text p{color:var(--cream-dim);max-width:50ch;margin-top:1rem;font-size:clamp(1rem,1.4vw,1.15rem);}
.about-hero-img{border-radius:var(--r);overflow:hidden;
  box-shadow:0 30px 70px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.06);}
.about-hero-img img{width:100%;height:auto;display:block;}
@media(max-width:880px){.about-hero{grid-template-columns:1fr;gap:2rem;}}

/* ---- freshness proof (homepage section: bag vs grocery shelf) ---- */
.proof{display:grid;grid-template-columns:1.05fr 1fr;gap:3rem;align-items:center;}
.proof-img{position:relative;border-radius:var(--r);overflow:hidden;
  box-shadow:0 30px 70px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.06);}
.proof-img img{width:100%;height:auto;display:block;}
.proof-text h2{font-size:clamp(1.6rem,3.2vw,2.4rem);line-height:1.15;margin:.6rem 0;
  background:linear-gradient(180deg,#FFF8EC,var(--cream) 65%,#C9A876 130%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.proof-text p{color:var(--cream-dim);max-width:48ch;margin-top:.7rem;}
.proof-text p.muted{color:var(--stone);font-size:.92rem;}
.proof-text .btn{margin-top:1.2rem;}
@media(max-width:880px){.proof{grid-template-columns:1fr;gap:2rem;}}

/* ---- offer band (homepage $9 first-bag) ---- */
.offer-band{padding:0;background:linear-gradient(90deg,#1b1109 0%,#2a1b0d 50%,#1b1109 100%);
  border-top:1px solid rgba(216,162,74,.35);border-bottom:1px solid rgba(216,162,74,.35);}
.offer-band .wrap{padding-top:2.4rem;padding-bottom:2.4rem;}
.offer{display:grid;grid-template-columns:1.6fr auto;gap:2rem;align-items:center;}
.offer-text h2{font-size:clamp(1.4rem,3vw,2rem);line-height:1.15;margin:.4rem 0;color:var(--cream);}
.offer-text p{color:var(--stone);max-width:60ch;}
.offer-eyebrow{display:inline-block;font-family:'JetBrains Mono',monospace;font-size:.66rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--amber);background:rgba(216,162,74,.15);border:1px solid var(--amber);
  border-radius:999px;padding:.3rem .8rem;}
.btn-lg{font-size:.86rem;padding:1.05rem 1.9rem;letter-spacing:.18em;}
@media(max-width:780px){
  .offer{grid-template-columns:1fr;text-align:left;}
  .offer .btn{justify-self:start;}
}

/* ---- sections ---- */
section{padding:5rem 0;}
.section-head{text-align:center;max-width:60ch;margin:0 auto 3rem;}
.section-head h2{font-size:clamp(1.8rem,4vw,2.8rem);margin:.6rem 0;}
.section-head p{color:var(--stone);}

/* value strip */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
.value-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:2rem 1.6rem;}
.value-card .ico{font-size:1.6rem;}
.value-card h3{font-size:1.15rem;margin:.9rem 0 .5rem;}
.value-card p{color:var(--stone);font-size:.92rem;}
@media(max-width:760px){.values{grid-template-columns:1fr;}}

/* ---- product grid ---- */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;}
@media(max-width:900px){.grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.grid{grid-template-columns:1fr;}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .25s,border-color .25s,box-shadow .25s;}
.card:hover{transform:translateY(-4px);border-color:rgba(216,162,74,.45);box-shadow:0 18px 40px rgba(0,0,0,.45);}
.card .thumb{position:relative;aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(78% 78% at 50% 34%,#3c2712 0%,#1a1008 56%,#0b0705 100%);overflow:hidden;}
.card .thumb-img{width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .6s cubic-bezier(.2,.7,.2,1);}
.card:hover .thumb-img{transform:scale(1.04);}
.card .badge{position:absolute;top:.8rem;left:.8rem;font-family:'JetBrains Mono',monospace;font-size:.58rem;
  letter-spacing:.14em;text-transform:uppercase;padding:.3rem .6rem;border-radius:999px;
  background:rgba(216,162,74,.16);border:1px solid var(--amber);color:var(--amber);}
.card .body{padding:1.3rem 1.3rem 1.5rem;display:flex;flex-direction:column;gap:.5rem;flex:1;}
.card h3{font-size:1.3rem;}
.card .roast{font-family:'JetBrains Mono',monospace;font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--stone);}
.card .desc{color:var(--stone);font-size:.9rem;flex:1;}
.card .foot{display:flex;align-items:center;justify-content:space-between;margin-top:.6rem;}
.card .price{font-size:1.15rem;font-weight:600;color:var(--cream);}
.card .price small{color:var(--stone);font-weight:400;font-size:.72rem;}
/* guide cards — no thumbnail, just text. Same card chrome. */
.guide-card{aspect-ratio:auto;}
.guide-card .body{padding:1.5rem 1.5rem 1.7rem;gap:.6rem;}
.guide-card h3{font-size:1.2rem;}
.guide-card .desc{margin-bottom:1rem;}
.guide-card .amber{font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;}
.guide-card.guide-soon{opacity:.62;pointer-events:none;}

/* coffee bag mockup (CSS, no stock photos) — colored bag body + cream label sticker, with a light
   ring + warm halo so even the dark roasts read clearly against the dark card. --bag set per product. */
.bag{width:50%;max-width:160px;aspect-ratio:5/7;border-radius:10px 10px 6px 6px;position:relative;
  background-color:var(--bag,#C68A3A);
  background-image:linear-gradient(180deg,rgba(255,255,255,.30),rgba(255,255,255,0) 34%,rgba(0,0,0,.32));
  box-shadow:0 20px 40px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.18),
    inset 0 0 24px rgba(0,0,0,.22),inset 0 2px 0 rgba(255,255,255,.28);}
.bag::before{content:"";position:absolute;top:-7px;left:16%;right:16%;height:11px;border-radius:3px;
  background:linear-gradient(rgba(255,255,255,.4),rgba(0,0,0,.35));box-shadow:0 2px 4px rgba(0,0,0,.45);}
.bag .label{position:absolute;left:13%;right:13%;top:29%;bottom:15%;border-radius:5px;
  background:linear-gradient(180deg,#FCF8EF,#EFE5D2);color:#1c130a;
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:.5rem;
  box-shadow:0 3px 8px rgba(0,0,0,.3),inset 0 0 0 1px rgba(0,0,0,.06);}
.bag .label .lbrand{font-family:'JetBrains Mono',monospace;font-size:.44rem;letter-spacing:.2em;text-transform:uppercase;color:#9A6A2E;}
.bag .label .lname{font-family:'Playfair Display',serif;font-weight:900;font-size:.95rem;line-height:1;margin:.28rem 0;color:#1c130a;}
.bag .label .lroast{font-family:'JetBrains Mono',monospace;font-size:.4rem;letter-spacing:.14em;text-transform:uppercase;color:#6b5640;}
.bag.big{max-width:320px;width:82%;}
.bag.big .lname{font-size:1.8rem;} .bag.big .lbrand{font-size:.62rem;} .bag.big .lroast{font-size:.56rem;}

/* ---- how it works ---- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;counter-reset:s;}
.step{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:2rem 1.6rem;position:relative;}
.step::before{counter-increment:s;content:"0" counter(s);font-family:'JetBrains Mono',monospace;
  font-size:1.6rem;color:var(--amber);opacity:.5;}
.step h3{font-size:1.15rem;margin:.7rem 0 .5rem;} .step p{color:var(--stone);font-size:.92rem;}
@media(max-width:760px){.steps{grid-template-columns:1fr;}}

/* ---- subscribe banner ---- */
.banner{background:linear-gradient(120deg,#1d130a,#0f0a06);border:1px solid var(--line);border-radius:24px;
  padding:3rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;}
.banner h2{font-size:clamp(1.6rem,3.5vw,2.4rem);max-width:18ch;}
.banner p{color:var(--stone);max-width:42ch;margin-top:.6rem;}
/* banner-video variant: text + CTA on left, portrait product video on right */
.banner.banner-video{display:grid;grid-template-columns:1.4fr 1fr;gap:2.8rem;align-items:center;}
.banner-content{display:flex;flex-direction:column;align-items:flex-start;gap:.6rem;}
.banner-content .btn{margin-top:1.4rem;}
.banner-video-wrap{position:relative;border-radius:16px;overflow:hidden;
  box-shadow:0 28px 60px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.08),inset 0 0 0 1px rgba(216,162,74,.18);
  aspect-ratio:448/672;max-width:300px;width:100%;justify-self:center;}
.banner-video-wrap video,.banner-video-wrap img{width:100%;height:100%;object-fit:cover;display:block;}
.banner-video-wrap::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(0,0,0,0) 70%,rgba(0,0,0,.3) 100%);}
@media(max-width:780px){
  .banner.banner-video{grid-template-columns:1fr;gap:1.6rem;text-align:center;}
  .banner-content{align-items:center;}
  .banner-video-wrap{max-width:240px;}
}

/* ---- waitlist ---- */
.waitlist{text-align:center;}
.field{display:flex;border:1px solid rgba(216,162,74,.4);border-radius:999px;background:rgba(255,255,255,.04);
  overflow:hidden;width:min(440px,92vw);margin:1.4rem auto 0;transition:border-color .3s,box-shadow .3s;}
.field:focus-within{border-color:var(--amber);box-shadow:0 0 0 4px var(--amber-soft);}
.field input{flex:1;background:transparent;border:0;outline:0;color:var(--cream);font-family:'Inter';font-size:.95rem;padding:.95rem 1.3rem;}
.field input::placeholder{color:var(--stone);}
.field button{border:0;background:linear-gradient(180deg,var(--amber-2),var(--amber));color:#1a1208;
  font-family:'JetBrains Mono',monospace;font-size:.72rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  padding:0 1.5rem;cursor:pointer;transition:filter .25s;white-space:nowrap;}
.field button:hover{filter:brightness(1.12);}
.msg{min-height:1.1rem;margin-top:.8rem;font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.06em;
  color:var(--amber);opacity:0;transition:opacity .4s;}.msg.show{opacity:1;}

/* ---- top notice strip — launch/waitlist (primary) + domain-for-sale (secondary, muted) ----
   Each anchor is a single nowrap unit so text can never overlap itself; the row wraps
   between the two anchors and stacks cleanly on mobile. */
.notice{background:linear-gradient(90deg,rgba(216,162,74,.13),rgba(216,162,74,.07));
  border-bottom:1px solid rgba(216,162,74,.26);
  display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:.45rem 1.4rem;
  font-family:'JetBrains Mono',monospace;font-size:.64rem;letter-spacing:.13em;text-transform:uppercase;
  padding:.6rem 1.2rem;line-height:1.4;text-align:center;}
.notice a{color:inherit;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;
  white-space:nowrap;transition:opacity .2s,color .2s;}
.notice a:hover{opacity:.85;}
.notice-launch{color:var(--cream-dim);font-weight:500;}
.notice-launch .notice-dot{width:6px;height:6px;border-radius:50%;background:var(--amber);flex:none;
  box-shadow:0 0 8px rgba(216,162,74,.85);animation:noticePulse 2.4s ease-in-out infinite;}
@keyframes noticePulse{0%,100%{opacity:.45;}50%{opacity:1;}}
.notice-launch .notice-arrow{color:var(--amber);}
.notice-launch:hover{color:var(--cream);}
.notice-sep{width:1px;height:13px;background:rgba(216,162,74,.3);flex:none;}
.notice-domain{color:var(--stone);}
.notice-domain strong{color:var(--amber);font-weight:600;letter-spacing:.03em;text-transform:none;
  font-family:'Playfair Display',serif;font-size:.86rem;}
.notice-domain:hover{color:var(--cream-dim);}
@media(max-width:740px){
  .notice{flex-direction:column;gap:.4rem;padding:.55rem 1rem;font-size:.6rem;}
  .notice-sep{display:none;}
}

/* ---- generic content (about/faq/product) ---- */
.page-hero{padding:4.5rem 0 1rem;text-align:center;}
.page-hero h1{font-size:clamp(2.2rem,5vw,3.4rem);}
.page-hero p{color:var(--stone);max-width:54ch;margin:1rem auto 0;}
.prose{max-width:70ch;margin:0 auto;}
.prose h2{font-size:1.5rem;margin:2.4rem 0 .8rem;} .prose h3{font-size:1.15rem;margin:1.6rem 0 .5rem;}
.prose p{color:var(--cream-dim);margin:.8rem 0;} .prose ul{color:var(--cream-dim);margin:.8rem 0 .8rem 1.2rem;}
.prose li{margin:.4rem 0;}
.faq-item{border-top:1px solid var(--line);padding:1.5rem 0;}
.faq-item h3{font-size:1.1rem;margin-bottom:.5rem;color:var(--cream);} .faq-item p{color:var(--stone);}

/* ---- product detail ---- */
.product{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;padding-top:2rem;}
@media(max-width:820px){.product{grid-template-columns:1fr;gap:2rem;}}
.product .visual{background:radial-gradient(70% 70% at 50% 36%,#3c2712,#180f08 58%,#0b0705);border:1px solid var(--line);
  border-radius:var(--r);aspect-ratio:1;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;}
.product .visual.has-video{padding:0;}
.product .product-video,.product .product-still{width:100%;height:100%;object-fit:cover;display:block;}
.product .visual.has-video::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(0,0,0,0) 70%,rgba(0,0,0,.35) 100%);}
.product .info h1{font-size:clamp(2rem,4.5vw,3rem);margin:.5rem 0;}
.product .info .price{font-size:1.6rem;font-weight:600;margin:.6rem 0;}
.product .info .price small{font-size:.8rem;color:var(--stone);font-weight:400;}
.product .opts{display:flex;gap:.6rem;flex-wrap:wrap;margin:1.2rem 0;}
.opt{font-family:'JetBrains Mono',monospace;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;
  border:1px solid var(--line);border-radius:999px;padding:.5rem .9rem;cursor:pointer;color:var(--cream-dim);transition:.2s;}
.opt.sel{border-color:var(--amber);color:var(--amber);background:rgba(216,162,74,.1);}
.tasting{display:flex;gap:.5rem;flex-wrap:wrap;margin:1.2rem 0;}
.tasting span{font-family:'JetBrains Mono',monospace;font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;
  background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:999px;padding:.4rem .8rem;color:var(--stone);}

/* ---- footer ---- */
.site-foot{border-top:1px solid var(--line);background:var(--espresso-2);padding:3.5rem 0 2rem;margin-top:2rem;}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem;}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr;gap:1.6rem;}}
.site-foot .brand{font-size:1.3rem;margin-bottom:.6rem;}
.site-foot p{color:var(--stone);font-size:.88rem;max-width:38ch;}
.foot-col h4{font-family:'JetBrains Mono',monospace;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--amber);margin-bottom:.9rem;}
.foot-col a{display:block;color:var(--cream-dim);font-size:.9rem;padding:.28rem 0;transition:color .2s;}
.foot-col a:hover{color:var(--amber);}
.foot-bot{border-top:1px solid var(--line);margin-top:2.5rem;padding-top:1.5rem;display:flex;
  justify-content:space-between;gap:1rem;flex-wrap:wrap;color:var(--stone-dim);
  font-family:'JetBrains Mono',monospace;font-size:.62rem;letter-spacing:.1em;}
/* tasteful "domain for sale" line — injected site-wide by site.js (bigger + brighter) */
.forsale{margin-top:1.8rem;padding:1rem 1.4rem;border:1px solid rgba(216,162,74,.38);border-radius:12px;
  background:rgba(216,162,74,.08);text-align:center;
  font-family:'JetBrains Mono',monospace;font-size:.82rem;letter-spacing:.05em;color:var(--cream-dim);}
.forsale strong{color:var(--amber);font-weight:600;}
.forsale a{color:var(--amber);margin-left:.5rem;font-weight:500;border-bottom:1px solid rgba(216,162,74,.55);transition:border-color .2s;}
.forsale a:hover{border-color:var(--amber);}

@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;}.hero-video{transform:scale(1.06);}}
