/* ---------- Isla Tropical — Premium homepage styles ---------- */

:root{
  --cream:        #F4EAD2;
  --cream-soft:   #EFE0BD;
  --cream-deep:   #E8D7B8;
  --mango:        #FFC93C;
  --mango-deep:   #F0B520;
  --green:        #2E7D5B;
  --green-deep:   #0F3D2A;
  --ink:          #0A1F16;
  --blue:         #2DAAE1;
  --blue-deep:    #1B7FB6;
  --paper:        #FBF6E9;

  --font-display: "Caprasimo", "Bagel Fat One", Georgia, serif;
  --font-sans:    "Inter", -apple-system, BlinkMacSystemFont, "SF Pro Display", system-ui, sans-serif;

  --ease-out: cubic-bezier(.16,1,.3,1);
  --ease:     cubic-bezier(.65,.05,.36,1);

  --maxw: 1480px;
  --pad-x: clamp(24px, 5vw, 80px);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{
  font-family:var(--font-sans);
  font-weight:400;
  color:var(--ink);
  background:var(--cream);
  line-height:1.5;
  overflow-x:hidden;
  font-feature-settings:"ss01","cv11";
}
img,svg{display:block;max-width:100%}
picture{display:contents} /* keep <picture> layout-transparent; img keeps its box */
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
a{color:inherit;text-decoration:none}

/* Keyboard focus ring (brand) — only shows for keyboard users, not mouse clicks */
:focus-visible{outline:2px solid var(--green-deep);outline-offset:3px;border-radius:4px}
.experience :focus-visible,.foot :focus-visible,.ticker :focus-visible{outline-color:var(--mango)}

/* Visually-hidden (screen-reader only) */
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* Skip link — hidden until focused by keyboard */
.skip-link{
  position:absolute;left:50%;top:8px;transform:translate(-50%,-150%);
  z-index:100;background:var(--green-deep);color:var(--cream);
  padding:10px 18px;border-radius:999px;font-size:14px;font-weight:500;
  transition:transform .2s var(--ease-out);
}
.skip-link:focus{transform:translate(-50%,0)}

/* ---------- Utility ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad-x)}
.eyebrow{
  font-size:12px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:24px;height:1px;background:currentColor;display:inline-block;opacity:.6}
.display{
  font-family:var(--font-display);font-weight:400;line-height:.86;
  letter-spacing:-.01em;
}
.h-xl{font-size:clamp(64px, 13vw, 240px)}
.h-lg{font-size:clamp(48px, 8vw, 132px)}
.h-md{font-size:clamp(36px, 5.5vw, 88px)}
.h-sm{font-size:clamp(28px, 3.4vw, 56px)}
.lede{font-size:clamp(17px, 1.4vw, 22px);line-height:1.45;max-width:48ch;color:color-mix(in oklab, var(--ink) 78%, transparent)}
.copy{font-size:16px;line-height:1.6;max-width:54ch;color:color-mix(in oklab, var(--ink) 75%, transparent)}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:12px;
  padding:18px 28px;border-radius:999px;
  font-weight:500;font-size:15px;letter-spacing:.01em;
  background:var(--ink);color:var(--cream);
  transition:transform .5s var(--ease-out), background .3s ease, color .3s ease, box-shadow .5s var(--ease-out);
  will-change:transform;
  box-shadow:0 2px 0 rgba(0,0,0,0);
}
.btn:hover{transform:translateY(-2px);box-shadow:0 18px 40px -18px rgba(15,61,42,.45)}
.btn .arrow{
  width:22px;height:22px;border-radius:50%;background:var(--mango);color:var(--ink);
  display:grid;place-items:center;font-size:11px;transition:transform .5s var(--ease-out);
}
.btn:hover .arrow{transform:translateX(3px) rotate(-45deg)}
.btn--ghost{background:transparent;color:var(--ink);border:1px solid color-mix(in oklab, var(--ink) 22%, transparent)}
.btn--ghost:hover{background:var(--ink);color:var(--cream)}
.btn--mango{background:var(--mango);color:var(--ink)}
.btn--mango .arrow{background:var(--ink);color:var(--mango)}
.btn--cream{background:var(--cream);color:var(--ink)}
.btn--cream .arrow{background:var(--mango);color:var(--ink)}

/* ---------- Announcement ---------- */
.announce{
  background:var(--ink);color:var(--cream);
  font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;
  text-align:center;padding:10px 16px;
}
.announce span{opacity:.75;margin:0 18px}
.announce .accent{color:var(--mango);opacity:1}

/* ---------- Nav ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--pad-x);
  background:color-mix(in oklab, var(--cream) 78%, transparent);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid color-mix(in oklab, var(--ink) 8%, transparent);
}
.nav__logo{display:flex;align-items:center;gap:10px}
.nav__logo img{width:60px;height:60px;object-fit:contain}
.nav__logo b{font-family:var(--font-display);font-size:22px;color:var(--green-deep);letter-spacing:-.01em}
.nav__menu{display:flex;align-items:center;gap:36px}
.nav__menu a{font-size:14px;font-weight:500;letter-spacing:.01em;opacity:.78;transition:opacity .2s}
.nav__menu a:hover{opacity:1}
.nav__cart{display:flex;align-items:center;gap:14px}
.cart-pill{
  display:flex;align-items:center;gap:8px;
  padding:10px 14px 10px 16px;border-radius:999px;
  background:var(--ink);color:var(--cream);font-size:13px;font-weight:500;
}
.cart-pill .dot{
  width:18px;height:18px;border-radius:50%;background:var(--mango);color:var(--ink);
  display:grid;place-items:center;font-size:11px;font-weight:600;
}
.lang-switch{
  display:inline-flex;align-items:center;gap:3px;
  padding:5px;border-radius:999px;
  border:1px solid color-mix(in oklab,var(--ink) 18%, transparent);
  font-size:13px;font-weight:600;letter-spacing:.02em;
}
.lang-switch span{
  display:grid;place-items:center;min-width:26px;height:24px;padding:0 6px;
  border-radius:999px;color:color-mix(in oklab,var(--ink) 55%, transparent);
  transition:background .2s var(--ease-out), color .2s;
}
.lang-switch .lang-switch__sep{min-width:0;padding:0;opacity:.3;font-weight:400}
.lang-switch .is-active{
  background:var(--green-deep);color:var(--cream);
}
.lang-switch:hover span:not(.is-active):not(.lang-switch__sep){
  color:var(--ink);
}
.nav__toggle{
  display:none;width:44px;height:44px;border-radius:999px;
  align-items:center;justify-content:center;
  background:var(--ink);color:var(--cream);flex-shrink:0;
}
.nav__toggle span,.nav__toggle span::before,.nav__toggle span::after{
  display:block;width:18px;height:2px;border-radius:2px;background:var(--cream);
  transition:transform .3s var(--ease-out), background .2s;
}
.nav__toggle span{position:relative}
.nav__toggle span::before,.nav__toggle span::after{content:"";position:absolute;left:0}
.nav__toggle span::before{top:-6px}
.nav__toggle span::after{top:6px}
.nav.is-open .nav__toggle span{background:transparent}
.nav.is-open .nav__toggle span::before{transform:translateY(6px) rotate(45deg)}
.nav.is-open .nav__toggle span::after{transform:translateY(-6px) rotate(-45deg)}
@media (max-width: 840px){
  .nav__toggle{display:flex}
  .nav__menu{
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:0;
    padding:6px var(--pad-x) 22px;
    background:color-mix(in oklab, var(--cream) 96%, transparent);
    backdrop-filter:saturate(160%) blur(14px);
    -webkit-backdrop-filter:saturate(160%) blur(14px);
    border-bottom:1px solid color-mix(in oklab, var(--ink) 10%, transparent);
    transform:translateY(-10px);opacity:0;visibility:hidden;pointer-events:none;
    transition:opacity .3s var(--ease-out), transform .3s var(--ease-out), visibility .3s;
  }
  .nav.is-open .nav__menu{transform:none;opacity:1;visibility:visible;pointer-events:auto}
  .nav__menu a{
    font-size:17px;font-weight:500;padding:15px 2px;opacity:.9;
    border-bottom:1px solid color-mix(in oklab,var(--ink) 8%, transparent);
  }
  .nav__menu a:last-child{border-bottom:0}
}

/* ---------- Hero ---------- */
.hero{
  position:relative;overflow:hidden;
  padding: clamp(40px, 6vw, 90px) var(--pad-x) clamp(80px, 10vw, 140px);
  min-height: calc(100vh - 130px);
  min-height: calc(100dvh - 130px); /* dvh avoids iOS Safari URL-bar jump */
  display:grid;
}
.hero__bg{position:absolute;inset:0;pointer-events:none}
.blob{position:absolute;border-radius:50%;filter:blur(.3px);opacity:.92}
.blob--y1{
  width:62vw;height:62vw;left:-18vw;bottom:-22vw;
  background:radial-gradient(ellipse at 60% 40%, var(--mango) 0%, var(--mango-deep) 55%, transparent 75%);
  animation:floatX 22s ease-in-out infinite;
}
.blob--y2{
  width:38vw;height:38vw;right:-10vw;top:-12vw;
  background:radial-gradient(ellipse at 40% 50%, color-mix(in oklab, var(--mango) 78%, white) 0%, var(--mango) 65%, transparent 80%);
  opacity:.55;
  animation:floatY 26s ease-in-out infinite;
}
.blob--g{
  width:28vw;height:28vw;right:32%;bottom:-14vw;
  background:radial-gradient(ellipse at 50% 50%, color-mix(in oklab, var(--green) 70%, var(--cream)) 0%, transparent 70%);
  opacity:.35;
  animation:floatX 30s -10s ease-in-out infinite;
}
.grain{
  position:absolute;inset:0;pointer-events:none;mix-blend-mode:multiply;opacity:.07;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .9 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

.hero__inner{
  position:relative;z-index:2;
  display:grid;grid-template-columns: minmax(0,1fr) clamp(300px,34vw,460px);gap:48px;
  align-items:end;width:100%;
}
.hero__copy{padding-bottom:24px;min-width:0}
.hero__eyebrow{color:var(--green-deep);margin-bottom:28px}
.hero h1{
  color:var(--green-deep);
  font-size:clamp(52px, 9vw, 184px);
  margin-bottom:34px;
}
.hero h1 .line{display:block;overflow:hidden}
.hero h1 .line > span{display:block;transform:translateY(110%);animation:rise 1.1s var(--ease-out) forwards}
.hero h1 .line:nth-child(2) > span{animation-delay:.12s}
.hero h1 .line:nth-child(3) > span{animation-delay:.22s}
.hero h1 .accent{color:var(--mango);font-style:italic}

.hero__sub{
  display:flex;align-items:flex-start;justify-content:space-between;gap:48px;
  max-width:580px;
}
.hero__sub p{font-size:17px;line-height:1.5;color:color-mix(in oklab, var(--green-deep) 88%, transparent);max-width:36ch}
.hero__sub .badge{
  flex-shrink:0;text-align:right;font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:color-mix(in oklab, var(--green-deep) 85%, transparent);
}
.hero__sub .badge b{display:block;font-size:14px;letter-spacing:.06em;color:var(--green-deep);margin-bottom:4px}

.hero__ctas{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}

.hero__bag{
  position:relative;align-self:stretch;
  display:flex;align-items:center;justify-content:center;
  min-height:520px;
}
.hero__bag img{
  width:115%;max-width:none;height:auto;
  filter:drop-shadow(0 60px 80px rgba(15,61,42,.18)) drop-shadow(0 18px 24px rgba(15,61,42,.12));
  animation:bagFloat 7s ease-in-out infinite;
  will-change:transform;
}
.hero__tag{
  position:absolute;top:14%;right:0;
  display:flex;align-items:center;gap:14px;
  padding:12px 16px 12px 14px;border-radius:999px;
  background:var(--ink);color:var(--cream);
  font-size:13px;letter-spacing:.04em;
  z-index:2;
  animation:tagDrop 1.4s .6s var(--ease-out) backwards;
}
.hero__tag .d{width:8px;height:8px;border-radius:50%;background:var(--mango);box-shadow:0 0 0 4px color-mix(in oklab,var(--mango) 50%, transparent)}
.hero__price{
  position:absolute;left:-8%;bottom:8%;
  width:158px;height:158px;border-radius:50%;
  background:var(--green-deep);color:var(--cream);
  display:grid;place-items:center;text-align:center;
  font-family:var(--font-display);font-size:46px;line-height:.9;
  animation:pricePop 1s 1s var(--ease-out) backwards;
  z-index:3;
}
.hero__price small{display:block;font-family:var(--font-sans);font-size:10px;letter-spacing:.2em;text-transform:uppercase;font-weight:500;margin-top:4px;opacity:.7}

.scroll-cue{
  position:absolute;left:var(--pad-x);bottom:32px;z-index:3;
  display:flex;align-items:center;gap:14px;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:color-mix(in oklab, var(--green-deep) 88%, transparent);
}
.scroll-cue .line{position:relative;width:60px;height:1px;background:color-mix(in oklab,var(--green-deep) 30%, transparent);overflow:hidden}
.scroll-cue .line::after{content:"";position:absolute;inset:0;background:var(--green-deep);transform:translateX(-100%);animation:slide 2.4s var(--ease) infinite}

@media (max-width:980px){
  .hero__inner{grid-template-columns:1fr;gap:0}
  .hero__bag{min-height:440px;margin-top:20px}
  .hero__price{width:120px;height:120px;font-size:34px;left:0}
  .hero__sub{flex-direction:column;gap:18px}
}

/* ---------- Ticker ---------- */
.ticker{
  background:var(--green-deep);color:var(--cream);
  overflow:hidden;padding:22px 0;
  border-block:1px solid color-mix(in oklab,var(--ink) 60%, var(--green-deep));
}
.ticker__track{
  display:flex;gap:64px;width:max-content;
  animation:scroll 38s linear infinite;
  font-family:var(--font-display);font-size:48px;letter-spacing:.005em;
  white-space:nowrap;
}
.ticker__track span{display:inline-flex;align-items:center;gap:64px}
.ticker__track .dot{
  width:14px;height:14px;border-radius:50%;background:var(--mango);
  display:inline-block;
}
.ticker__track i{color:var(--mango);font-style:normal}

/* ---------- Section base ---------- */
section{position:relative}
.sec{padding:clamp(80px, 10vw, 160px) 0}
.sec--cream{background:var(--cream)}
.sec--paper{background:var(--paper)}
.sec--green{background:var(--green-deep);color:var(--cream)}
.sec--mango{background:var(--mango);color:var(--green-deep)}
.sec--blue{background:var(--blue);color:var(--cream)}

/* ---------- Story / split ---------- */
.story{
  display:grid;grid-template-columns: .9fr 1.1fr;gap:clamp(40px,7vw,120px);align-items:center;
}
.story__media{
  position:relative;aspect-ratio:4/5;border-radius:14px;overflow:hidden;
  background:linear-gradient(160deg, var(--green) 0%, var(--green-deep) 100%);
}
.story__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.story__copy h2{color:var(--green-deep);margin-bottom:28px}
.story__copy h2 em{color:var(--mango);font-style:italic;font-weight:400}
.story__copy .lede{margin-bottom:32px}
.story__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:48px;border-top:1px solid color-mix(in oklab,var(--ink) 15%, transparent);padding-top:36px}
.story__stats .stat b{font-family:var(--font-display);font-size:clamp(42px,4.5vw,72px);color:var(--green-deep);display:block;line-height:.9}
.story__stats .stat span{font-size:13px;letter-spacing:.06em;color:color-mix(in oklab,var(--ink) 60%, transparent);margin-top:8px;display:block}

@media (max-width:880px){
  .story{grid-template-columns:1fr}
  .story__media{aspect-ratio:5/4}
  .story__stats{grid-template-columns:repeat(3,1fr);gap:10px}
}

/* ---------- Section heading ---------- */
.sec-head{
  display:flex;align-items:flex-end;justify-content:space-between;gap:40px;
  margin-bottom:clamp(40px,5vw,80px);
}
.sec-head h2{max-width:14ch}
.sec-head .meta{
  text-align:right;font-size:13px;letter-spacing:.04em;line-height:1.55;
  max-width:36ch;opacity:.78;
}
.sec-head .meta b{display:block;font-size:11px;letter-spacing:.2em;text-transform:uppercase;margin-bottom:8px;opacity:.7}
@media (max-width:760px){
  .sec-head{flex-direction:column;align-items:flex-start}
  .sec-head .meta{text-align:left}
}

/* ---------- Product tag badge (used in feature stage) ---------- */
.product__tag{
  display:inline-flex;font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  padding:6px 10px;border-radius:999px;
  border:1px solid color-mix(in oklab, currentColor 25%, transparent);
}

/* ---------- Single product feature ---------- */
.feature{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,80px);align-items:center;
}
.feature__stage{
  position:relative;border-radius:20px;overflow:hidden;
  background:linear-gradient(165deg, var(--cream) 0%, var(--cream-deep) 100%);
  min-height:560px;display:flex;align-items:center;justify-content:center;
  isolation:isolate;
}
.feature__blob{
  position:absolute;width:80%;aspect-ratio:1;border-radius:50%;z-index:-1;
  background:radial-gradient(circle at 50% 45%, var(--mango) 0%, var(--mango-deep) 60%, transparent 75%);
  filter:blur(2px);opacity:.85;
  animation:floatY 18s ease-in-out infinite;
}
.feature__stage img{
  width:auto;height:84%;
  filter:drop-shadow(0 50px 60px rgba(15,61,42,.28));
  animation:bagFloat 7s ease-in-out infinite;
}
.feature__info h3{
  font-family:var(--font-display);font-weight:400;line-height:.9;
  font-size:clamp(48px,5.5vw,92px);color:var(--green-deep);
}
.spec{list-style:none;border-top:1px solid color-mix(in oklab,var(--ink) 14%, transparent)}
.spec li{
  display:flex;align-items:baseline;justify-content:space-between;gap:20px;
  padding:16px 0;border-bottom:1px solid color-mix(in oklab,var(--ink) 10%, transparent);
}
.spec li span{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:color-mix(in oklab,var(--ink) 55%, transparent);flex-shrink:0}
.spec li b{font-size:16px;font-weight:500;color:var(--green-deep);text-align:right}
.feature__chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:28px}
.feature__chips span{
  font-size:12px;letter-spacing:.04em;padding:8px 14px;border-radius:999px;
  background:color-mix(in oklab,var(--green-deep) 8%, transparent);
  color:var(--green-deep);
}
@media (max-width:860px){
  .feature{grid-template-columns:1fr;gap:32px}
  .feature__stage{min-height:420px}
}

/* ---------- Pure / Ingredients ---------- */
.pure{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
}
.pure__card{
  background:var(--paper);
  border:1px solid color-mix(in oklab,var(--ink) 8%, transparent);
  border-radius:18px;padding:36px 28px 32px;
  min-height:300px;
  display:flex;flex-direction:column;justify-content:space-between;
  transition:transform .5s var(--ease-out), background .3s, color .3s;
}
.pure__card:hover{transform:translateY(-4px);background:var(--green-deep);color:var(--cream)}
.pure__card:hover .pure__num{color:var(--mango)}
.pure__num{
  font-family:var(--font-display);font-size:18px;color:var(--green);letter-spacing:.04em;
  display:flex;align-items:center;gap:8px;
}
.pure__num::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--mango)}
.pure__card h4{font-family:var(--font-display);font-weight:400;font-size:clamp(28px,2.4vw,38px);line-height:.95;margin-top:auto;margin-bottom:12px}
.pure__card p{font-size:14px;line-height:1.55;opacity:.78}

@media (max-width:980px){.pure{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.pure{grid-template-columns:1fr}}

/* ---------- Caribbean experience ---------- */
.experience{
  background:var(--green-deep);color:var(--cream);
  padding:clamp(80px, 10vw, 160px) 0;
  overflow:hidden;position:relative;
}
.experience::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 50% at 10% 110%, color-mix(in oklab,var(--blue) 60%, transparent) 0%, transparent 70%),
    radial-gradient(ellipse 50% 40% at 90% 0%, color-mix(in oklab,var(--mango) 40%, transparent) 0%, transparent 70%);
  pointer-events:none;opacity:.7;
}
.exp__head{position:relative;z-index:2}
.exp__head h2{color:var(--cream)}
.exp__head h2 em{color:var(--mango);font-style:italic}
.exp__grid{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.4fr 1fr 1fr;grid-template-rows:auto auto;gap:18px;
  margin-top:clamp(40px,5vw,80px);
}
.exp__tile{
  position:relative;overflow:hidden;border-radius:16px;
  background:color-mix(in oklab,var(--ink) 50%, var(--green-deep));
  min-height:240px;
  transition:transform .6s var(--ease-out);
}
.exp__tile:hover{transform:translateY(-4px)}
.exp__tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.exp__tile .cap{
  position:absolute;left:20px;bottom:16px;z-index:2;
  font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--cream);
  padding:6px 12px;border-radius:999px;background:color-mix(in oklab, var(--ink) 60%, transparent);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
}
.exp__tile--big{grid-row:span 2;min-height:520px}
.exp__tile--type{
  background:var(--mango);color:var(--green-deep);
  display:flex;align-items:center;justify-content:center;text-align:center;padding:24px;
  font-family:var(--font-display);font-size:clamp(32px,3vw,52px);line-height:.95;
}
.exp__tile--quote{
  background:color-mix(in oklab,var(--cream) 12%, var(--green-deep));
  border:1px solid color-mix(in oklab,var(--cream) 18%, transparent);
  display:flex;flex-direction:column;justify-content:space-between;padding:28px;
  font-size:18px;line-height:1.5;
}
.exp__tile--quote .src{font-size:12px;letter-spacing:.16em;text-transform:uppercase;opacity:.7}

@media (max-width:880px){
  .exp__grid{grid-template-columns:1fr 1fr}
  .exp__tile--big{grid-row:auto;min-height:380px}
}

/* ---------- Billboard editorial moment ---------- */
.billboard{
  position:relative;overflow:hidden;
  padding:clamp(80px,10vw,160px) 0;
  background:var(--mango);
}
.billboard__wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.billboard__copy h2{color:var(--green-deep);max-width:14ch}
.billboard__copy p{color:color-mix(in oklab,var(--green-deep) 80%, transparent);margin-top:24px;font-size:18px;max-width:42ch}
@media (max-width:880px){.billboard__wrap{grid-template-columns:1fr}}

/* ---------- Retail facts ---------- */
.retail__facts{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;
}
.retail__fact{
  background:color-mix(in oklab, var(--cream) 70%, var(--mango));
  border-radius:16px;padding:28px 24px;
  display:flex;flex-direction:column;gap:10px;
  min-height:160px;justify-content:space-between;
}
.retail__fact b{
  font-family:var(--font-display);font-weight:400;line-height:.9;
  font-size:clamp(34px,3.4vw,52px);color:var(--green-deep);
}
.retail__fact span{font-size:13px;line-height:1.4;color:color-mix(in oklab,var(--green-deep) 78%, transparent)}
@media (max-width:520px){.retail__facts{grid-template-columns:1fr}}

/* ---------- Social ---------- */
.social-grid{
  display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:200px;gap:14px;
}
.social-grid .cell{
  position:relative;overflow:hidden;border-radius:14px;
  background:var(--cream-deep);
  transition:transform .5s var(--ease-out);
}
.social-grid .cell:hover{transform:scale(1.02)}
.social-grid .cell img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease-out)}
.social-grid .cell:hover img{transform:scale(1.06)}
.social-grid .cell .handle{
  position:absolute;left:14px;bottom:12px;z-index:2;color:var(--cream);
  font-size:12px;letter-spacing:.06em;
  background:color-mix(in oklab,var(--ink) 60%, transparent);
  padding:5px 10px;border-radius:999px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
}
.cell--span2{grid-column:span 2}
.cell--row2{grid-row:span 2}
.cell--mango{background:var(--mango);display:grid;place-items:center;padding:24px;text-align:center}
.cell--mango b{font-family:var(--font-display);font-size:clamp(28px,2.2vw,42px);color:var(--green-deep);line-height:.95}
.cell--mango span{font-size:11px;letter-spacing:.2em;text-transform:uppercase;margin-top:10px;display:block;color:var(--green-deep);opacity:.7}
.cell--green{background:var(--green-deep);display:grid;place-items:center;padding:24px;text-align:center}
.cell--green b{font-family:var(--font-display);font-size:clamp(28px,2.2vw,42px);color:var(--cream)}
.cell--green span{font-size:11px;letter-spacing:.2em;text-transform:uppercase;margin-top:10px;display:block;color:var(--mango)}

@media (max-width:980px){.social-grid{grid-template-columns:repeat(3,1fr);grid-auto-rows:160px}.cell--row2{grid-row:auto}}
@media (max-width:520px){.social-grid{grid-template-columns:repeat(2,1fr)}.cell--span2{grid-column:auto}}

/* ---------- Big CTA ---------- */
.cta{
  background:var(--mango);color:var(--green-deep);
  padding:clamp(100px,12vw,200px) var(--pad-x);
  text-align:center;position:relative;overflow:hidden;
}
.cta::before, .cta::after{
  content:"";position:absolute;border-radius:50%;
  background:color-mix(in oklab,var(--cream) 60%, var(--mango));
  pointer-events:none;
}
.cta::before{width:60vw;height:60vw;left:-22vw;top:-30vw}
.cta::after{width:48vw;height:48vw;right:-18vw;bottom:-22vw;background:color-mix(in oklab,var(--green-deep) 16%, var(--mango))}
.cta__inner{position:relative;z-index:2;max-width:1200px;margin:0 auto}
.cta .eyebrow{color:var(--green-deep);margin-bottom:24px}
.cta h2{font-size:clamp(64px,11vw,200px);line-height:.86;margin-bottom:36px}
.cta h2 em{font-style:italic;color:var(--green-deep)}
.cta h2 .out{
  -webkit-text-stroke:2px var(--green-deep);
  color:transparent;font-style:italic;
}
.cta__btns{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:18px}

/* ---------- Footer ---------- */
.foot{background:var(--ink);color:var(--cream);padding:80px var(--pad-x) 36px}
.foot__top{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;
  padding-bottom:60px;border-bottom:1px solid color-mix(in oklab,var(--cream) 14%, transparent);
}
.foot__brand img{width:62px;height:62px;margin-bottom:18px}
.foot__brand p{font-size:14px;line-height:1.55;opacity:.7;max-width:32ch}
.foot__col h5{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--mango);margin-bottom:18px}
.foot__col ul{list-style:none;display:grid;gap:10px}
.foot__col li a{font-size:14px;opacity:.82}
.foot__col li a:hover{opacity:1;color:var(--mango)}
.foot__bottom{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:26px;font-size:12px;opacity:.74;letter-spacing:.04em;flex-wrap:wrap;gap:12px;
}
.foot__bigtype{
  font-family:var(--font-display);font-size:clamp(80px,16vw,260px);line-height:.86;
  color:color-mix(in oklab,var(--cream) 10%, var(--ink));
  margin:50px 0 0;letter-spacing:-.005em;
  pointer-events:none;user-select:none;
}
@media (max-width:880px){.foot__top{grid-template-columns:1fr 1fr;gap:30px}}
@media (max-width:540px){.foot__top{grid-template-columns:1fr}}

/* ---------- Mobile polish (phones) ---------- */
@media (max-width:560px){
  /* Nav stays on one tidy line down to small phones */
  .nav{padding:13px var(--pad-x)}
  .nav__cart{gap:8px}
  .nav__logo img{width:52px;height:52px}
  .cart-pill{padding:9px 12px 9px 14px;font-size:12px}
  /* Hide language switch on phones; geo auto-detect handles language */
  .lang-switch{display:none}
  /* Announce bar wraps/stacks on phones — hide it */
  .announce{display:none}

  /* Headline no longer clips against the viewport edge */
  .hero h1{font-size:clamp(44px,14.5vw,80px);margin-bottom:24px}
  .hero{min-height:0;padding-bottom:clamp(56px,14vw,90px)}
  .hero__sub{max-width:none}
  .hero__bag{min-height:340px;margin-top:8px}
  .hero__bag img{width:88%}
  .hero__tag{font-size:11px;padding:9px 12px;top:8%}
  .hero__price{width:100px;height:100px;font-size:26px;bottom:2%}

  /* Ticker calmer, less overwhelming */
  .ticker{padding:16px 0}
  .ticker__track{font-size:32px;gap:40px}
  .ticker__track span{gap:40px}

  /* Spec rows wrap cleanly instead of colliding */
  .spec li{flex-wrap:wrap;gap:2px 16px}
  .spec li b{text-align:left}

  /* Tighter section rhythm so scrolling feels intentional */
  .sec{padding:clamp(64px,16vw,160px) 0}
}
@media (max-width:360px){
  /* Reclaim space on the smallest devices */
  .cart-pill .dot{display:none}
  .cart-pill{padding:9px 14px}
}

/* ---------- FAQ ---------- */
.faq{max-width:940px;margin:0 auto}
.faq__item{border-top:1px solid color-mix(in oklab,var(--ink) 14%, transparent)}
.faq__item:last-child{border-bottom:1px solid color-mix(in oklab,var(--ink) 14%, transparent)}
.faq__item summary{
  list-style:none;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:26px 0;
  font-size:clamp(18px,1.7vw,23px);font-weight:600;color:var(--green-deep);
}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{
  content:"+";flex-shrink:0;
  font-family:var(--font-display);font-weight:400;font-size:30px;line-height:1;color:var(--mango);
  transition:transform .3s var(--ease-out);
}
.faq__item[open] summary::after{transform:rotate(45deg)}
.faq__a{padding:0 0 28px;max-width:72ch}
.faq__a p{font-size:16px;line-height:1.6;color:color-mix(in oklab,var(--ink) 78%, transparent)}
.faq__a p + p{margin-top:12px}

/* ---------- Reveal animations ---------- */
/* Hidden state only applies when JS is available (html.js), so content stays
   visible if JS fails or is disabled. JS adds .is-in as elements scroll in. */
.reveal{transition:opacity .9s var(--ease-out), transform .9s var(--ease-out)}
.js .reveal{opacity:0;transform:translateY(28px)}
.reveal.is-in{opacity:1;transform:none}
.reveal-stagger > *{transition:opacity .8s var(--ease-out), transform .8s var(--ease-out)}
.js .reveal-stagger > *{opacity:0;transform:translateY(24px)}
.reveal-stagger.is-in > *{opacity:1;transform:none}
.reveal-stagger.is-in > *:nth-child(1){transition-delay:.0s}
.reveal-stagger.is-in > *:nth-child(2){transition-delay:.08s}
.reveal-stagger.is-in > *:nth-child(3){transition-delay:.16s}
.reveal-stagger.is-in > *:nth-child(4){transition-delay:.24s}
.reveal-stagger.is-in > *:nth-child(5){transition-delay:.32s}
.reveal-stagger.is-in > *:nth-child(6){transition-delay:.4s}

/* ---------- Keyframes ---------- */
@keyframes rise{from{transform:translateY(110%)}to{transform:translateY(0)}}
@keyframes bagFloat{0%,100%{transform:translateY(0) rotate(-1.5deg)}50%{transform:translateY(-22px) rotate(1.5deg)}}
@keyframes floatX{0%,100%{transform:translate(0,0)}50%{transform:translate(40px,-30px)}}
@keyframes floatY{0%,100%{transform:translate(0,0)}50%{transform:translate(-30px,40px)}}
@keyframes pricePop{from{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes tagDrop{from{transform:translateY(-14px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes scroll{to{transform:translateX(-50%)}}
@keyframes slide{0%{transform:translateX(-100%)}50%,100%{transform:translateX(100%)}}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
}
