/* ============================================================
   STRAWBERRY FIELDS APOTHECARY — "Moonlit Strawberry Fields"
   Palette sampled from the logo. Fraunces (display) + Satoshi (body).
   Base: deep wine-night. Hero: strawberry-red. Support: sage-green.
   ============================================================ */

:root{
  --ink:#0a0510;          /* deep wine-black */
  --wine:#1c0c16;
  --wine2:#2a1220;
  --wine3:#431d28;
  --berry:#da2b46;        /* HERO accent */
  --berry-bright:#ec3a56;
  --rose:#a3424d;         /* moonlight mid-tone */
  --rose-soft:#c98a93;
  --sage:#8fa66a;         /* leaf green */
  --sage-bright:#a7c07d;
  --mint:#d6e7be;
  --cream:#fff7f4;
  --cream-2:#f3e4de;
  --dim:rgba(255,247,244,.66);
  --dimmer:rgba(255,247,244,.42);
  --line:rgba(255,247,244,.12);
  --line-berry:rgba(218,43,70,.30);

  --font-d:"Fraunces",Georgia,"Times New Roman",serif;
  --font-b:"Satoshi",system-ui,-apple-system,sans-serif;

  --maxw:1240px;
  --pad:clamp(1.15rem,5vw,3.5rem);
  --r:18px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--font-b);
  background:var(--ink);
  color:var(--cream);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--berry);color:#fff}

/* ---- type scale ---- */
.display{font-family:var(--font-d);font-weight:600;line-height:.98;letter-spacing:-.015em}
h1,h2,h3{font-family:var(--font-d);font-weight:600;line-height:1.02;letter-spacing:-.01em}
.eyebrow{
  font-family:var(--font-b);font-weight:700;
  font-size:.74rem;letter-spacing:.34em;text-transform:uppercase;
  color:var(--rose-soft);
}
.serif-i{font-style:italic;font-weight:400}

/* ---- layout ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}
section{position:relative;padding-block:clamp(4.5rem,11vh,9rem)}
.section-head{max-width:44ch}
.section-head .eyebrow{margin-bottom:1rem;display:inline-block}
.section-head h2{font-size:clamp(2.1rem,6.2vw,4.2rem);margin-bottom:.6rem}
.section-head p{color:var(--dim);font-size:clamp(1rem,2.4vw,1.18rem);margin-top:1rem}

/* strawberry bullet */
.berry-dot{color:var(--berry)}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--font-b);font-weight:700;font-size:.94rem;letter-spacing:.01em;
  padding:.92em 1.5em;border-radius:100px;border:1px solid transparent;
  cursor:pointer;transition:transform .3s var(--ease),background .3s,box-shadow .3s,color .3s;
  will-change:transform;
}
.btn--berry{background:var(--berry);color:#fff;box-shadow:0 8px 30px -8px rgba(218,43,70,.6)}
.btn--berry:hover{background:var(--berry-bright);transform:translateY(-2px);box-shadow:0 14px 40px -8px rgba(218,43,70,.75)}
.btn--ghost{border-color:var(--line);color:var(--cream);background:rgba(255,247,244,.02)}
.btn--ghost:hover{border-color:var(--rose);background:rgba(255,247,244,.06);transform:translateY(-2px)}
.btn svg{width:1.05em;height:1.05em}

/* ============================================================
   AGE / COMPLIANCE GATE
   ============================================================ */
.agegate{
  position:fixed;inset:0;z-index:1000;height:100dvh;
  display:flex;align-items:center;justify-content:center;padding:1.5rem;
  background:
    radial-gradient(120% 90% at 70% 8%, rgba(163,66,77,.35), transparent 55%),
    linear-gradient(180deg,#140812,#0a0510 70%);
}
.agegate[hidden]{display:none}
.agegate__panel{
  max-width:440px;width:100%;text-align:center;
  background:linear-gradient(180deg,rgba(42,18,32,.9),rgba(20,8,18,.94));
  border:1px solid var(--line);border-radius:26px;
  padding:clamp(2rem,5vw,3rem);
  box-shadow:0 40px 120px -30px #000, inset 0 1px 0 rgba(255,255,255,.05);
  animation:rise .7s var(--ease) both;
}
.agegate__mark{width:104px;height:104px;margin:0 auto 1.4rem;border-radius:50%;
  box-shadow:0 0 0 1px var(--line-berry),0 14px 40px -12px rgba(218,43,70,.55)}
.agegate__panel h2{font-size:2rem;margin-bottom:.5rem}
.agegate__panel p{color:var(--dim);font-size:.96rem;margin-bottom:1.7rem}
.agegate__row{display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap}
.agegate__no{color:var(--dimmer);font-size:.8rem;margin-top:1.4rem;letter-spacing:.02em}
.agegate__legal{color:var(--dimmer);font-size:.72rem;margin-top:1rem;line-height:1.5}

/* ============================================================
   HEADER
   ============================================================ */
.hdr{
  position:fixed;top:0;left:0;right:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:.85rem var(--pad);
  transition:background .4s,backdrop-filter .4s,padding .4s,border-color .4s;
  border-bottom:1px solid transparent;
}
.hdr.scrolled{background:rgba(10,5,16,.72);backdrop-filter:blur(14px);border-bottom-color:var(--line);padding-block:.6rem}
.hdr__brand{display:flex;align-items:center;gap:.6rem;font-family:var(--font-d);font-weight:600;font-size:1.05rem}
.hdr__brand img{width:38px;height:38px;border-radius:50%}
.hdr__brand span{display:none}
@media(min-width:560px){.hdr__brand span{display:inline}}
.hdr__nav{display:none;gap:1.6rem;align-items:center}
.hdr__nav a{font-size:.86rem;font-weight:500;color:var(--dim);letter-spacing:.02em;transition:color .25s;position:relative}
.hdr__nav a:hover{color:var(--cream)}
@media(min-width:860px){.hdr__nav{display:flex}}

/* ============================================================
   HERO — moonlit night sky
   ============================================================ */
.hero{
  min-height:100svh;display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;padding-top:6rem;overflow:hidden;
  background:
    radial-gradient(90% 60% at 50% 120%, rgba(66,29,40,.5), transparent 60%),
    radial-gradient(70% 55% at 74% 10%, rgba(163,66,77,.42), transparent 55%),
    linear-gradient(180deg,#160a14 0%, #0d0713 46%, #0a0510 100%);
}
#sky{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none}
.moon{
  position:absolute;top:11%;right:14%;width:clamp(70px,11vw,140px);aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle at 38% 36%, #fff2f4, #e9b9c2 55%, #b06c78 100%);
  box-shadow:0 0 60px 18px rgba(233,185,194,.35),0 0 140px 50px rgba(163,66,77,.22);
  z-index:1;
}
.moon::after{content:"";position:absolute;inset:0;border-radius:50%;
  background:radial-gradient(circle at 70% 32%, transparent 60%, rgba(120,70,84,.5) 61% 66%, transparent 67%),
             radial-gradient(circle at 78% 60%, transparent 60%, rgba(120,70,84,.4) 61% 64%, transparent 65%)}
.hills{position:absolute;left:0;right:0;bottom:-1px;width:100%;z-index:1;opacity:.9}
.hero__inner{position:relative;z-index:2;max-width:960px;padding-inline:var(--pad)}
.hero__logo{width:clamp(84px,13vw,120px);height:auto;margin:0 auto 1.6rem;
  filter:drop-shadow(0 10px 34px rgba(218,43,70,.45));border-radius:50%}
.hero h1{
  font-size:clamp(2.9rem,9vw,6.4rem);line-height:.94;margin-bottom:1.1rem;
  text-shadow:0 4px 40px rgba(218,43,70,.25);
}
.hero h1 .ln{display:block}
.hero h1 em{font-style:italic;color:var(--rose-soft);font-weight:400}
.hero__sub{font-size:clamp(1.02rem,2.5vw,1.28rem);color:var(--dim);max-width:40ch;margin:0 auto 2rem}
.hero__cta{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}
.hero__note{margin-top:1.7rem;font-size:.76rem;letter-spacing:.22em;text-transform:uppercase;color:var(--dimmer)}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{border-block:1px solid var(--line);background:linear-gradient(90deg,var(--wine),var(--ink));padding-block:0;overflow:hidden}
.marquee__track{display:flex;gap:0;white-space:nowrap;will-change:transform;animation:scroll 34s linear infinite}
.marquee__track span{font-family:var(--font-d);font-size:clamp(1.3rem,3.4vw,2.1rem);padding:.85em .7em;color:var(--cream-2);display:inline-flex;align-items:center;gap:.7em}
.marquee__track b{color:var(--berry);font-weight:400;padding:0 .5em}
.marquee:hover .marquee__track{animation-play-state:paused}

/* ============================================================
   STORY (editorial split)
   ============================================================ */
.story .wrap{display:grid;gap:clamp(2rem,5vw,4rem);align-items:center;grid-template-columns:1fr}
@media(min-width:900px){.story .wrap{grid-template-columns:1.05fr .95fr}}
.story__body h2{font-size:clamp(2rem,5.2vw,3.4rem);margin:1rem 0 1.2rem}
.story__body p{color:var(--dim);font-size:1.06rem;margin-bottom:1.1rem;max-width:52ch}
.story__body strong{color:var(--cream);font-weight:600}
.ledger{list-style:none;margin-top:1.8rem;border-top:1px solid var(--line)}
.ledger li{display:flex;justify-content:space-between;gap:1rem;padding:.85rem 0;border-bottom:1px solid var(--line);font-size:.92rem}
.ledger li span:first-child{color:var(--dim)}
.ledger li span:last-child{color:var(--sage-bright);font-weight:600;text-align:right}
.story__media{position:relative}
.story__media img{width:100%;border-radius:var(--r);aspect-ratio:4/5;object-fit:cover;
  box-shadow:0 40px 90px -30px #000,0 0 0 1px var(--line)}
.story__media .moon-mini{position:absolute;top:-22px;right:-10px;width:64px;height:64px;border-radius:50%;
  background:radial-gradient(circle at 38% 36%, #fff2f4, #d3a3ad 60%, #a3424d);
  box-shadow:0 0 40px 8px rgba(163,66,77,.4);z-index:2}

/* ============================================================
   HARVEST GALLERY
   ============================================================ */
.harvest{background:linear-gradient(180deg,var(--ink),#120813 60%,var(--ink))}
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-top:2.6rem}
@media(min-width:720px){.gallery{grid-template-columns:repeat(4,1fr);gap:1rem}}
.gcard{position:relative;overflow:hidden;border-radius:14px;background:var(--wine);border:1px solid var(--line)}
.gcard img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease);aspect-ratio:1}
.gcard:hover img{transform:scale(1.06)}
.gcard--tall{grid-row:span 2}
.gcard--tall img{aspect-ratio:1/2}
.gcard__tag{position:absolute;left:.7rem;bottom:.6rem;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--cream);background:rgba(10,5,16,.55);backdrop-filter:blur(4px);padding:.3em .7em;border-radius:100px;border:1px solid var(--line)}
@media(min-width:720px){.gcard--wide{grid-column:span 2}.gcard--wide img{aspect-ratio:2/1}}

/* ============================================================
   WHAT WE CARRY (category index)
   ============================================================ */
.carry .wrap{display:grid;gap:clamp(2rem,5vw,3.5rem);grid-template-columns:1fr}
@media(min-width:900px){.carry .wrap{grid-template-columns:.8fr 1.2fr}}
.cats{list-style:none;border-top:1px solid var(--line)}
.cats li{display:grid;grid-template-columns:auto 1fr auto;gap:1rem;align-items:baseline;
  padding:1.15rem .2rem;border-bottom:1px solid var(--line);transition:padding .3s var(--ease),background .3s}
.cats li:hover{background:linear-gradient(90deg,rgba(218,43,70,.06),transparent);padding-left:1rem}
.cats .num{font-family:var(--font-d);color:var(--rose);font-size:.9rem;font-variant-numeric:tabular-nums}
.cats .nm{font-family:var(--font-d);font-size:clamp(1.3rem,3vw,1.9rem);font-weight:600}
.cats .sub{color:var(--dim);font-size:.85rem;text-align:right;max-width:26ch}
@media(max-width:560px){.cats li{grid-template-columns:auto 1fr}.cats .sub{display:none}}

/* ============================================================
   TWO STORES (centerpiece)
   ============================================================ */
.stores{background:
  radial-gradient(80% 50% at 20% 0%, rgba(163,66,77,.16), transparent 60%),
  linear-gradient(180deg,var(--ink),#130914)}
.stores__grid{display:grid;gap:1.4rem;grid-template-columns:1fr;margin-top:3rem}
@media(min-width:820px){.stores__grid{grid-template-columns:1fr 1fr}}
.shopcard{
  position:relative;overflow:hidden;border-radius:24px;padding:clamp(1.8rem,3.5vw,2.8rem);
  background:linear-gradient(165deg,rgba(42,18,32,.92),rgba(16,8,18,.96));
  border:1px solid var(--line);
  box-shadow:0 40px 100px -40px #000;
  display:flex;flex-direction:column;min-height:340px;
}
.shopcard::before{content:"";position:absolute;top:-40px;right:-40px;width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle at 40% 40%, rgba(233,185,194,.14),transparent 70%);pointer-events:none}
.shopcard__badge{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--berry);font-weight:700;margin-bottom:.7rem}
.shopcard h3{font-size:clamp(1.7rem,4vw,2.4rem);margin-bottom:.3rem}
.shopcard .tag{color:var(--rose-soft);font-style:italic;font-family:var(--font-d);margin-bottom:1.4rem}
.shopcard__meta{list-style:none;margin-bottom:1.6rem}
.shopcard__meta li{display:flex;gap:.7rem;align-items:flex-start;padding:.42rem 0;color:var(--dim);font-size:.95rem}
.shopcard__meta svg{width:1.05em;height:1.05em;flex:none;margin-top:.28em;color:var(--sage)}
.shopcard__meta a:hover{color:var(--cream)}
.shopcard__cta{margin-top:auto;display:flex;gap:.6rem;flex-wrap:wrap}
.shopcard__cta .btn{padding:.72em 1.15em;font-size:.86rem}

/* ============================================================
   THE VIBE
   ============================================================ */
.vibe .wrap{display:grid;gap:1.2rem;grid-template-columns:1fr}
@media(min-width:820px){.vibe .wrap{grid-template-columns:1.4fr 1fr;grid-auto-rows:1fr}}
.vibe__lead{position:relative;border-radius:22px;overflow:hidden;min-height:320px;border:1px solid var(--line)}
.vibe__lead img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.vibe__lead .cap{position:absolute;left:0;right:0;bottom:0;padding:1.6rem;
  background:linear-gradient(0deg,rgba(10,5,16,.9),transparent);z-index:2}
.vibe__lead .cap h3{font-size:clamp(1.5rem,3.4vw,2.2rem);margin-bottom:.35rem}
.vibe__lead .cap p{color:var(--dim);max-width:40ch;font-size:.95rem}
.vibe__side{display:grid;gap:1.2rem;grid-template-rows:auto 1fr}
.vibe__drink{border-radius:22px;overflow:hidden;position:relative;min-height:180px;border:1px solid var(--line)}
.vibe__drink img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.vibe__note{border-radius:22px;background:linear-gradient(160deg,rgba(143,166,106,.14),rgba(16,8,18,.9));
  border:1px solid var(--line);padding:1.6rem;display:flex;flex-direction:column;justify-content:center}
.vibe__note p{font-family:var(--font-d);font-size:1.2rem;line-height:1.35}
.vibe__note .sm{font-family:var(--font-b);color:var(--dim);font-size:.9rem;margin-top:.7rem}

/* ============================================================
   NEIGHBORS (reviews)
   ============================================================ */
.says__grid{display:grid;gap:1rem;grid-template-columns:1fr;margin-top:2.6rem}
@media(min-width:640px){.says__grid{grid-template-columns:1fr 1fr}}
@media(min-width:980px){.says__grid{grid-template-columns:repeat(3,1fr)}}
.quote{background:linear-gradient(165deg,rgba(42,18,32,.5),rgba(16,8,18,.7));border:1px solid var(--line);
  border-radius:18px;padding:1.6rem}
.quote__stars{color:var(--berry);letter-spacing:.15em;margin-bottom:.8rem;font-size:.9rem}
.quote p{font-family:var(--font-d);font-size:1.12rem;line-height:1.4;margin-bottom:1rem}
.quote cite{color:var(--rose-soft);font-style:normal;font-size:.85rem;font-weight:600;letter-spacing:.02em}
.quote--feat{grid-column:1/-1;text-align:center}
.quote--feat p{font-size:clamp(1.4rem,3.4vw,2rem);max-width:24ch;margin-inline:auto}

/* ============================================================
   DEALS
   ============================================================ */
.deals__grid{display:grid;gap:1rem;grid-template-columns:1fr;margin-top:2.6rem}
@media(min-width:640px){.deals__grid{grid-template-columns:1fr 1fr}}
@media(min-width:980px){.deals__grid{grid-template-columns:repeat(4,1fr)}}
.deal{border:1px solid var(--line);border-radius:18px;padding:1.5rem;position:relative;overflow:hidden;
  background:linear-gradient(165deg,rgba(42,18,32,.4),transparent)}
.deal .big{font-family:var(--font-d);font-size:2.4rem;color:var(--berry);line-height:1;margin-bottom:.5rem}
.deal h4{font-size:1.05rem;margin-bottom:.3rem}
.deal p{color:var(--dim);font-size:.88rem}

/* ============================================================
   VISIT (maps)
   ============================================================ */
.visit__grid{display:grid;gap:1.4rem;grid-template-columns:1fr;margin-top:2.6rem}
@media(min-width:820px){.visit__grid{grid-template-columns:1fr 1fr}}
.mapcard{border:1px solid var(--line);border-radius:20px;overflow:hidden;background:var(--wine)}
.mapcard iframe{width:100%;height:280px;border:0;display:block;filter:grayscale(.3) saturate(1.1)}
.mapcard__foot{padding:1.1rem 1.3rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.mapcard__foot b{font-family:var(--font-d);font-weight:600;font-size:1.05rem}
.mapcard__foot span{color:var(--dim);font-size:.85rem;display:block}

/* ============================================================
   FOOTER
   ============================================================ */
.ft{border-top:1px solid var(--line);background:linear-gradient(180deg,var(--ink),#120813);padding-block:clamp(3rem,7vh,5rem) 2rem}
.ft__top{display:grid;gap:2.5rem;grid-template-columns:1fr}
@media(min-width:760px){.ft__top{grid-template-columns:1.3fr 1fr 1fr}}
.ft__brand img{width:66px;border-radius:50%;margin-bottom:1rem}
.ft__brand p{color:var(--dim);font-size:.9rem;max-width:34ch}
.ft h5{font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;color:var(--rose-soft);margin-bottom:1rem}
.ft ul{list-style:none;display:grid;gap:.55rem}
.ft ul a,.ft ul li{color:var(--dim);font-size:.9rem}
.ft ul a:hover{color:var(--cream)}
.ft__legal{margin-top:3rem;padding-top:1.6rem;border-top:1px solid var(--line);color:var(--dimmer);font-size:.76rem;line-height:1.6;max-width:75ch}
.ft__legal .warn{color:var(--rose-soft);font-weight:600}
.ft__base{margin-top:1.4rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;color:var(--dimmer);font-size:.78rem}

/* ============================================================
   REVEAL (fail-visible: visible by default, JS enhances)
   ============================================================ */
.reveal{opacity:1;transform:none}
.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.js .reveal.in{opacity:1;transform:none}
.js .reveal.d1{transition-delay:.08s}
.js .reveal.d2{transition-delay:.16s}
.js .reveal.d3{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){.js .reveal{opacity:1!important;transform:none!important;transition:none}}

/* keyframes */
@keyframes scroll{to{transform:translateX(-50%)}}
@keyframes rise{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
@keyframes twinkle{50%{opacity:.35}}
