/* ═══════════════════════════════════════════
   ECOLAURA · Ultra-modern motion-design build
   ═══════════════════════════════════════════ */

:root {
  --sage-deep:  #3f6b4c;
  --sage:       #5e8f6a;
  --sage-mid:   #7fae88;
  --sage-soft:  #a8cbac;
  --sage-pale:  #d4e6d4;
  --sage-ghost: #eef5ed;

  --brown-deep: #5c4129;
  --brown:      #8a6440;
  --brown-soft: #c2a079;
  --brown-pale: #e7d6bf;
  --brown-ghost:#f6ede0;

  --cream:      #f6f2ea;
  --cream-deep: #efe8db;
  --ink:        #221b12;
  --ink-soft:   #574936;
  --ink-mute:   #9b8b76;
  --white:      #fffdf9;

  --font-serif: 'Cormorant Garamond', Georgia, serif;
  --font-sans:  'Jost', system-ui, sans-serif;

  --ease: cubic-bezier(.22,1,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
  --maxw: 1280px;
}

* , *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; overflow-x:hidden; }

body {
  font-family: var(--font-sans);
  background: var(--cream);
  color: var(--ink);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  cursor: none;
}
@media (hover:none){ body{cursor:auto;} }

a { color:inherit; text-decoration:none; }
img { display:block; max-width:100%; }
::selection { background: var(--sage-soft); color: var(--ink); }

/* ─────────── LOADER ─────────── */
.loader{
  position:fixed; inset:0; z-index:9999;
  background: var(--cream);
  display:flex; align-items:center; justify-content:center;
  transition: opacity .8s var(--ease), visibility .8s;
}
.loader.done{ opacity:0; visibility:hidden; }
.loader-inner{ text-align:center; width:min(340px,70vw); }
.loader-mark{ width:48px; height:48px; margin:0 auto 16px; display:block;
  animation:leafPulse 1.8s var(--ease) infinite; }
@keyframes leafPulse{ 0%,100%{ transform:translateY(0) scale(1); } 50%{ transform:translateY(-6px) scale(1.06); } }
.loader-logo{
  font-family:var(--font-serif); font-weight:300;
  font-size:2.6rem; letter-spacing:6px; text-transform:uppercase;
  color:var(--sage-deep); margin-bottom:28px;
}
.loader-logo span{ font-style:italic; color:var(--brown); }
.loader-bar{
  height:2px; background:var(--cream-deep); border-radius:2px; overflow:hidden;
}
.loader-bar-fill{
  height:100%; width:0%;
  background:linear-gradient(90deg,var(--sage),var(--brown-soft));
  transition: width .2s linear;
}
.loader-pct{
  margin-top:14px; font-size:.7rem; letter-spacing:3px;
  color:var(--ink-mute); text-transform:uppercase;
}

/* ─────────── CURSOR ─────────── */
.cursor-dot{
  position:fixed; top:0; left:0; z-index:9000;
  width:12px; height:12px; border-radius:50%;
  background:var(--sage-deep); pointer-events:none;
  mix-blend-mode:multiply;
  transition: width .3s var(--ease), height .3s var(--ease),
              background .3s var(--ease), opacity .3s;
  will-change:transform;
}
.cursor-dot.hover{ width:26px; height:26px; background:rgba(94,143,106,.45); }
.cursor-dot.click{ width:8px; height:8px; background:var(--brown); }
@media (hover:none){ .cursor-dot{ display:none; } }

/* click ripple from cursor */
.click-burst{
  position:fixed; z-index:8900; pointer-events:none;
  width:14px; height:14px; border-radius:50%;
  border:2px solid var(--sage); transform:translate(-50%,-50%) scale(0);
  animation:clickBurst .55s var(--ease-out) forwards;
}
@keyframes clickBurst{
  0%{ transform:translate(-50%,-50%) scale(.2); opacity:.7; }
  100%{ transform:translate(-50%,-50%) scale(5); opacity:0; }
}

/* in-element ripple on buttons/cards */
.ripple{
  position:absolute; border-radius:50%; pointer-events:none;
  background:rgba(255,255,255,.5); transform:translate(-50%,-50%) scale(0);
  animation:rippleGrow .6s var(--ease-out) forwards;
}
.ripple.dark{ background:rgba(63,107,76,.18); }
@keyframes rippleGrow{
  to{ transform:translate(-50%,-50%) scale(1); opacity:0; }
}

/* ─────────── SCROLL PROGRESS ─────────── */
.scroll-progress{
  position:fixed; top:0; left:0; height:3px; width:100%;
  transform:scaleX(0); transform-origin:left; will-change:transform;
  z-index:8000;
  background:linear-gradient(90deg,var(--sage-deep),var(--brown-soft));
}

/* ─────────── BACKGROUND MESH ─────────── */
.bg-mesh{ position:fixed; inset:-40px; z-index:-2; overflow:hidden; background:var(--cream);
  will-change:transform; }
.blob{ position:absolute; border-radius:50%; filter:blur(70px); opacity:.5;
  will-change:transform; }
.blob-1{ width:46vw; height:46vw; background:var(--sage-pale); top:-8%; left:-8%;
  animation:float1 26s ease-in-out infinite; }
.blob-2{ width:42vw; height:42vw; background:var(--brown-pale); bottom:-12%; right:-8%;
  animation:float2 30s ease-in-out infinite; }
.blob-3{ width:32vw; height:32vw; background:var(--sage-ghost); top:42%; left:50%;
  animation:float3 34s ease-in-out infinite; }
@keyframes float1{ 0%,100%{transform:translate(0,0) scale(1);} 50%{transform:translate(6vw,5vh) scale(1.12);} }
@keyframes float2{ 0%,100%{transform:translate(0,0) scale(1);} 50%{transform:translate(-6vw,-4vh) scale(1.08);} }
@keyframes float3{ 0%,100%{transform:translate(-50%,0) scale(1);} 50%{transform:translate(-40%,-6vh) scale(1.15);} }
.grain{
  position:absolute; inset:0; opacity:.035; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ─────────── ANNOUNCE MARQUEE ─────────── */
.announce{ background:var(--sage-deep); overflow:hidden; padding:11px 0; }
.announce-track{
  display:flex; gap:48px; white-space:nowrap; width:max-content;
  animation:marquee 28s linear infinite;
}
.announce-track span{
  color:rgba(255,255,255,.92); font-size:.72rem; letter-spacing:2px;
  text-transform:uppercase; font-weight:500;
}
@keyframes marquee{ from{transform:translateX(0);} to{transform:translateX(-50%);} }

/* ─────────── NAV ─────────── */
#nav{
  position:sticky; top:0; z-index:500;
  background:rgba(246,242,234,.7); backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(63,107,76,.1);
  transition:padding .4s var(--ease), background .4s;
}
#nav.shrink{ background:rgba(246,242,234,.92); }
.nav-inner{
  max-width:var(--maxw); margin:0 auto; padding:0 32px; height:72px;
  display:grid; grid-template-columns:1fr auto 1fr; align-items:center;
}
.nav-links{ display:flex; gap:30px; list-style:none; }
.nav-right{ justify-content:flex-end; }
.nav-links a{
  font-size:.72rem; letter-spacing:1.6px; text-transform:uppercase;
  font-weight:500; color:var(--ink-soft); position:relative; padding:4px 0;
}
.nav-links a::after{
  content:''; position:absolute; left:0; bottom:0; height:1px; width:0;
  background:var(--sage); transition:width .4s var(--ease);
}
.nav-links a:hover::after{ width:100%; }
.nav-logo{
  display:flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--font-serif); font-weight:300;
  font-size:1.6rem; letter-spacing:5px; text-transform:uppercase;
  color:var(--sage-deep);
  text-shadow:0 0 22px rgba(63,107,76,.25);
}
.nav-logo span{ font-style:italic; color:var(--brown); }
.nav-logo-mark{ width:26px; height:26px; transition:transform .5s var(--ease); }
.nav-logo:hover .nav-logo-mark{ transform:rotate(-12deg) scale(1.1); }
.footer-logo-mark{ width:30px; height:30px; vertical-align:-6px; margin-right:8px; }
.nav-burger{ display:none; background:none; border:none; cursor:pointer;
  flex-direction:column; gap:5px; justify-self:end; }
.nav-burger span{ width:24px; height:2px; background:var(--ink); display:block;
  transition:.3s var(--ease); }
.nav-burger.open span:first-child{ transform:translateY(3.5px) rotate(45deg); }
.nav-burger.open span:last-child{ transform:translateY(-3.5px) rotate(-45deg); }

.mobile-menu{
  position:fixed; inset:72px 0 auto 0; z-index:480;
  background:var(--cream); border-bottom:1px solid var(--cream-deep);
  display:flex; flex-direction:column; padding:0 32px;
  max-height:0; overflow:hidden; transition:max-height .5s var(--ease);
}
.mobile-menu.open{ max-height:340px; }
.mobile-menu a{
  padding:18px 0; border-bottom:1px solid var(--cream-deep);
  font-family:var(--font-serif); font-size:1.4rem; color:var(--ink);
}

/* ─────────── REVEAL UTIL ─────────── */
.reveal-up{ opacity:0; transform:translateY(40px); transition:opacity .9s var(--ease-out), transform .9s var(--ease-out); }
.reveal-up.in{ opacity:1; transform:none; }

/* static preview mode for clean screenshots */
html.preview .loader{ display:none !important; }
html.preview .reveal-up{ opacity:1 !important; transform:none !important; }
html.preview .hero-title .word{ transform:none !important; }
html.preview .cursor-dot{ display:none !important; }

/* ─────────── HERO ─────────── */
.hero{
  position:relative; min-height:100vh;
  display:flex; flex-direction:column; justify-content:center;
  max-width:var(--maxw); margin:0 auto; padding:80px 32px 140px;
}
.hero-content{ max-width:900px; }
.hero-eyebrow{ margin-bottom:30px; }
.hero-eyebrow span{
  display:inline-flex; align-items:center; gap:10px;
  font-size:.72rem; letter-spacing:3px; text-transform:uppercase;
  color:var(--sage); font-weight:500;
  padding:8px 18px; border:1px solid var(--sage-soft); border-radius:30px;
  background:rgba(255,255,255,.4);
}
.hero-title{
  font-family:var(--font-serif); font-weight:700;
  font-size:clamp(3.2rem,9vw,7.5rem); line-height:.98; color:var(--ink);
  letter-spacing:-1.5px;
}
.hero-title .line{ display:block; overflow:hidden; }
.hero-title .word{ display:inline-block; transform:translateY(110%); }
.hero-title em{ font-style:italic; color:var(--sage-deep);
  text-shadow:0 0 40px rgba(63,107,76,.2); }
.hero-desc{
  margin:34px 0 44px; max-width:520px;
  font-size:1.05rem; font-weight:300; line-height:1.85; color:var(--ink-soft);
}
.hero-actions{ display:flex; align-items:center; gap:30px; flex-wrap:wrap; }

.btn-magnetic{
  display:inline-flex; align-items:center; gap:12px;
  padding:18px 40px; background:var(--sage-deep); color:var(--white);
  font-size:.74rem; letter-spacing:2px; text-transform:uppercase; font-weight:600;
  border-radius:40px; position:relative; overflow:hidden; cursor:none;
  transition:background .4s var(--ease), box-shadow .4s var(--ease), transform .2s var(--ease);
  will-change:transform;
}
.btn-magnetic span,.btn-magnetic svg{ position:relative; z-index:1; }
.btn-magnetic::before{
  content:''; position:absolute; inset:0; border-radius:40px;
  background:var(--brown-deep); transform:scale(0); opacity:0;
  transition:transform .5s var(--ease), opacity .4s;
}
.btn-magnetic:hover{ box-shadow:0 16px 40px rgba(63,107,76,.3); }
.btn-magnetic:hover::before{ transform:scale(1.5); opacity:1; }
.btn-magnetic svg{ transition:transform .4s var(--ease); }
.btn-magnetic:hover svg{ transform:translateX(5px); }
.btn-magnetic.light{ background:var(--white); color:var(--sage-deep); }
.btn-magnetic.light::before{ background:var(--sage-deep); }
.btn-magnetic.light:hover{ color:var(--white); }

.btn-text{
  font-size:.8rem; letter-spacing:1.5px; text-transform:uppercase;
  color:var(--ink-soft); font-weight:500; position:relative;
}
.btn-text::after{ content:''; position:absolute; left:0; bottom:-3px; height:1px; width:100%;
  background:var(--sage); transform:scaleX(0); transform-origin:left; transition:transform .4s var(--ease); }
.btn-text:hover::after{ transform:scaleX(1); }

/* hero decorative visual (fills the right-side white space) */
.hero-visual{
  position:absolute; top:50%; right:4%; transform:translateY(-50%);
  width:380px; height:380px; z-index:-1;
  display:flex; align-items:center; justify-content:center;
  pointer-events:none;
}
.hero-visual-disc{
  width:230px; height:230px; border-radius:50%;
  background:radial-gradient(circle at 35% 30%, #ffffff, var(--sage-ghost) 55%, var(--sage-pale));
  box-shadow:0 30px 80px rgba(63,107,76,.22), inset 0 0 60px rgba(255,255,255,.6);
  display:flex; align-items:center; justify-content:center;
  animation:bob 6s ease-in-out infinite;
}
.hero-visual-leaf{ width:104px; height:104px; filter:drop-shadow(0 10px 22px rgba(63,107,76,.3)); }
.hero-visual-ring{
  position:absolute; width:300px; height:300px; border-radius:50%;
  border:1px dashed rgba(63,107,76,.3); animation:spin 30s linear infinite;
}
.hero-visual-ring.ring-2{ width:380px; height:380px; border-color:rgba(196,168,130,.35);
  animation-duration:46s; animation-direction:reverse; }
.hero-visual-tag{
  position:absolute; bottom:34px; right:6px;
  background:var(--sage-deep); color:#fff; font-size:.66rem; font-weight:600;
  letter-spacing:1.6px; text-transform:uppercase; padding:9px 18px; border-radius:30px;
  box-shadow:0 10px 26px rgba(63,107,76,.3); animation:bob 6s ease-in-out .5s infinite;
}
@media (max-width:1100px){ .hero-visual{ right:-3%; opacity:.75; } }
@media (max-width:900px){ .hero-visual{ display:none; } }

.hero-marquee{
  position:absolute; bottom:60px; left:0; width:100%; overflow:hidden;
  border-top:1px solid rgba(63,107,76,.12); border-bottom:1px solid rgba(63,107,76,.12);
  padding:18px 0;
}
.hero-marquee-track{
  display:flex; gap:30px; align-items:center; width:max-content;
  animation:marquee 30s linear infinite;
}
.hero-marquee-track span{
  font-family:var(--font-serif); font-style:italic; font-size:1.8rem;
  color:var(--sage-deep); opacity:.5;
}
.hero-marquee-track i{ color:var(--brown-soft); font-style:normal; }

.hero-scroll-hint{
  position:absolute; right:32px; bottom:60px;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  font-size:.62rem; letter-spacing:2px; text-transform:uppercase; color:var(--ink-mute);
}
.scroll-line{ width:1px; height:46px; background:var(--sage-soft); position:relative; overflow:hidden; }
.scroll-line::after{ content:''; position:absolute; top:0; left:0; width:100%; height:50%;
  background:var(--sage-deep); animation:scrollDown 1.8s var(--ease) infinite; }
@keyframes scrollDown{ 0%{transform:translateY(-100%);} 100%{transform:translateY(200%);} }

/* ─────────── STATS ─────────── */
.stats{
  max-width:var(--maxw); margin:0 auto; padding:40px 32px 110px;
  display:grid; grid-template-columns:repeat(4,1fr); gap:24px;
}
.stat{ text-align:center; padding:30px 20px; border-left:1px solid rgba(63,107,76,.12); }
.stat:first-child{ border-left:none; }
.stat-num{
  font-family:var(--font-serif); font-weight:400; font-size:clamp(2.8rem,5vw,4rem);
  color:var(--sage-deep); line-height:1;
}
.stat-label{ margin-top:12px; font-size:.74rem; letter-spacing:1.5px;
  text-transform:uppercase; color:var(--ink-mute); }

/* ─────────── SECTION INTRO ─────────── */
.section-intro{ max-width:var(--maxw); margin:0 auto; padding:90px 32px 50px; text-align:center; }
.intro-tag{
  display:inline-block; font-size:.68rem; letter-spacing:3px; text-transform:uppercase;
  color:var(--brown); font-weight:600; margin-bottom:18px;
  padding:6px 16px; border-radius:20px; background:var(--brown-ghost);
}
.intro-title{
  font-family:var(--font-serif); font-weight:700; line-height:1.08;
  font-size:clamp(2.2rem,5.5vw,4rem); color:var(--ink); letter-spacing:-.5px;
}
.intro-title em{ font-style:italic; color:var(--sage-deep); }
.intro-text{ max-width:600px; margin:24px auto 0; font-size:1.02rem;
  font-weight:300; line-height:1.85; color:var(--ink-soft); }

/* ─────────── PRODUCT GRID ─────────── */
.grid-shop{
  max-width:var(--maxw); margin:0 auto; padding:30px 32px 100px;
  display:grid; grid-template-columns:repeat(2,1fr); gap:28px;
}
.product{
  position:relative;
  background:var(--white); border-radius:24px; overflow:hidden;
  border:1px solid rgba(63,107,76,.1); cursor:none;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
  transform-style:preserve-3d; will-change:transform;
}
.product:hover{ box-shadow:0 30px 70px rgba(63,107,76,.16); }
.product-wide{ grid-column:1 / -1; }
.product-wide .product-media{ height:340px; }

.product-media{
  position:relative; height:300px; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
}
.product-media.green{ background:linear-gradient(180deg,#f3f6ef,#d7e6d6); }
.product-media.brown{ background:linear-gradient(180deg,#f6efe6,#e7d6bd); }
.product-glow{
  position:absolute; width:220px; height:220px; border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.5),transparent 70%);
  filter:blur(24px); opacity:0; pointer-events:none;
  transition:opacity .6s var(--ease), transform .6s var(--ease);
}
.product:hover .product-glow{ opacity:.7; transform:scale(1.4); }
.product-emoji{
  font-size:5.5rem; position:relative; z-index:1;
  filter:drop-shadow(0 12px 30px rgba(63,107,76,.2));
  transition:transform .6s var(--ease);
}
.product:hover .product-emoji{ transform:scale(1.12) rotate(-6deg); }
.product-img{
  position:relative; z-index:1;
  width:100%; height:100%; object-fit:contain; object-position:center;
  transition:transform .7s var(--ease);
}
.product:hover .product-img{ transform:scale(1.05); }
.product-num{
  position:absolute; top:20px; left:24px; z-index:1;
  font-family:var(--font-serif); font-size:1rem; letter-spacing:2px;
  color:var(--sage-deep); opacity:.5;
}
.product-cta{
  position:absolute; bottom:0; left:0; width:100%; padding:16px;
  background:var(--sage-deep); color:var(--white);
  text-align:center; font-size:.72rem; letter-spacing:2px; text-transform:uppercase;
  font-weight:600; transform:translateY(100%); transition:transform .45s var(--ease);
}
.product:hover .product-cta{ transform:translateY(0); }
.product-info{ padding:28px 30px 32px; }
.product-cat{
  font-size:.66rem; letter-spacing:2.5px; text-transform:uppercase;
  color:var(--brown); font-weight:600; margin-bottom:10px;
}
.product-name{
  font-family:var(--font-serif); font-weight:600; font-size:1.75rem;
  color:var(--ink); margin-bottom:8px; line-height:1.1;
}
.product-tagline{ font-size:.92rem; font-weight:300; color:var(--ink-soft); line-height:1.6; }
.product-tags{ display:flex; gap:8px; flex-wrap:wrap; margin-top:18px; }
.product-tags span{
  font-size:.66rem; letter-spacing:.5px; text-transform:uppercase; font-weight:500;
  padding:6px 13px; border-radius:20px;
  background:var(--sage-ghost); color:var(--sage-deep); border:1px solid rgba(63,107,76,.12);
}

/* ─────────── STORY ─────────── */
.story{
  max-width:var(--maxw); margin:0 auto; padding:100px 32px;
  display:grid; grid-template-columns:1fr 1.1fr; gap:80px; align-items:center;
}
.story-visual{ display:flex; justify-content:center; }
.story-card{
  position:relative; width:340px; height:420px; border-radius:200px 200px 24px 24px;
  background:linear-gradient(160deg,var(--sage-pale),var(--brown-pale));
  display:flex; align-items:center; justify-content:center; overflow:hidden;
  box-shadow:0 30px 80px rgba(63,107,76,.2);
}
.story-emoji{ font-size:7rem; position:relative; z-index:2;
  filter:drop-shadow(0 10px 30px rgba(63,107,76,.25)); animation:bob 5s ease-in-out infinite; }
@keyframes bob{ 0%,100%{transform:translateY(0);} 50%{transform:translateY(-14px);} }
.story-orbit{ position:absolute; width:260px; height:260px; border:1px dashed rgba(255,255,255,.6);
  border-radius:50%; animation:spin 24s linear infinite; }
.story-orbit-2{ width:380px; height:380px; border-color:rgba(63,107,76,.2); animation-duration:36s; animation-direction:reverse; }
@keyframes spin{ to{transform:rotate(360deg);} }
.story-title{ font-family:var(--font-serif); font-weight:700; line-height:1.08;
  font-size:clamp(2rem,4vw,3.4rem); color:var(--ink); margin-bottom:24px; letter-spacing:-.5px; }
.story-title em{ font-style:italic; color:var(--sage-deep); }
.story-content p{ font-size:1.02rem; font-weight:300; line-height:1.85;
  color:var(--ink-soft); margin-bottom:18px; }
.story-pillars{ margin-top:34px; display:flex; flex-direction:column; gap:18px; }
.pillar{ display:flex; gap:16px; align-items:center; }
.pillar-ic{ font-size:1.6rem; width:54px; height:54px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; border-radius:50%;
  background:var(--white); box-shadow:0 8px 22px rgba(63,107,76,.12); }
.pillar strong{ display:block; font-size:1rem; color:var(--ink); margin-bottom:2px; }
.pillar span{ font-size:.86rem; font-weight:300; color:var(--ink-mute); }

/* ─────────── INGREDIENTS ─────────── */
.ingredients{ max-width:var(--maxw); margin:0 auto; padding:60px 32px 100px; }
.ing-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:30px; }
.ing-card{
  position:relative; overflow:hidden;
  background:var(--white); border-radius:20px; padding:36px 30px;
  border:1px solid rgba(63,107,76,.1); cursor:none;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
  transform-style:preserve-3d; will-change:transform;
}
.ing-card:hover{ box-shadow:0 24px 60px rgba(63,107,76,.14); }
.ing-ic{ font-size:2.6rem; display:block; margin-bottom:18px;
  filter:drop-shadow(0 6px 16px rgba(63,107,76,.18)); }
.ing-card h4{ font-family:var(--font-serif); font-weight:500; font-size:1.4rem;
  color:var(--ink); margin-bottom:10px; }
.ing-card p{ font-size:.9rem; font-weight:300; line-height:1.7; color:var(--ink-soft); }

/* ─────────── TESTIMONIALS ─────────── */
.testi{ overflow:hidden; padding:60px 0 100px;
  background:linear-gradient(180deg,transparent,var(--sage-ghost),transparent); }
.testi-track{ display:flex; gap:28px; width:max-content; padding:0 32px;
  animation:marquee 40s linear infinite; }
.testi:hover .testi-track{ animation-play-state:paused; }
.testi-card{
  width:380px; flex-shrink:0; background:var(--white); border-radius:20px;
  padding:36px 34px; border:1px solid rgba(63,107,76,.1);
  box-shadow:0 12px 40px rgba(63,107,76,.08);
}
.testi-stars{ color:var(--brown-soft); letter-spacing:3px; margin-bottom:18px; }
.testi-card blockquote{ font-family:var(--font-serif); font-style:italic;
  font-size:1.3rem; line-height:1.5; color:var(--ink); margin-bottom:18px; }
.testi-card figcaption{ font-size:.78rem; letter-spacing:1px; text-transform:uppercase;
  color:var(--ink-mute); font-weight:500; }

/* ─────────── FAQ ─────────── */
.faq{ max-width:880px; margin:0 auto; padding:40px 32px 100px; }
.faq-list{ margin-top:30px; display:flex; flex-direction:column; gap:14px; }
.faq-item{
  background:var(--white); border-radius:16px; border:1px solid rgba(63,107,76,.1);
  overflow:hidden; transition:box-shadow .4s var(--ease);
}
.faq-item[open]{ box-shadow:0 16px 40px rgba(63,107,76,.1); }
.faq-item summary{
  list-style:none; cursor:pointer; padding:24px 28px;
  font-family:var(--font-serif); font-size:1.35rem; color:var(--ink);
  display:flex; justify-content:space-between; align-items:center; gap:20px;
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{ content:'+'; font-size:1.6rem; color:var(--sage);
  transition:transform .4s var(--ease); flex-shrink:0; }
.faq-item[open] summary::after{ transform:rotate(45deg); }
.faq-item p{ padding:0 28px 26px; font-size:.96rem; font-weight:300;
  line-height:1.8; color:var(--ink-soft); }

/* ─────────── CTA FINAL ─────────── */
.cta-final{ padding:30px 32px 120px; }
.cta-inner{
  max-width:var(--maxw); margin:0 auto; border-radius:36px;
  background:linear-gradient(135deg,var(--sage-deep),var(--brown)); color:var(--white);
  padding:90px 40px; text-align:center; position:relative; overflow:hidden;
}
.cta-inner::before{ content:''; position:absolute; width:500px; height:500px;
  border-radius:50%; background:rgba(255,255,255,.06); top:-200px; left:-100px; }
.cta-inner::after{ content:''; position:absolute; width:400px; height:400px;
  border-radius:50%; background:rgba(255,255,255,.05); bottom:-200px; right:-80px; }
.cta-inner h2{ font-family:var(--font-serif); font-weight:700;
  font-size:clamp(2.2rem,5vw,3.8rem); line-height:1.08; margin-bottom:36px; position:relative; letter-spacing:-.5px; }
.cta-inner em{ font-style:italic; color:var(--sage-pale); }

/* ─────────── FOOTER ─────────── */
footer{ background:var(--ink); color:var(--white); padding:80px 32px 36px; }
.footer-top{ max-width:var(--maxw); margin:0 auto;
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:50px;
  padding-bottom:50px; border-bottom:1px solid rgba(255,255,255,.08); }
.footer-logo{ font-family:var(--font-serif); font-weight:300; font-size:1.9rem;
  letter-spacing:5px; text-transform:uppercase; color:var(--sage-pale); margin-bottom:18px;
  text-shadow:0 0 26px rgba(212,230,212,.2); }
.footer-logo span{ font-style:italic; color:var(--brown-soft); }
.footer-brand p{ font-size:.88rem; font-weight:300; line-height:1.8;
  color:rgba(255,255,255,.5); max-width:300px; }
.footer-col h5{ font-size:.68rem; letter-spacing:2.5px; text-transform:uppercase;
  color:rgba(255,255,255,.4); margin-bottom:18px; font-weight:600; }
.footer-col a{ display:block; font-size:.88rem; font-weight:300;
  color:rgba(255,255,255,.6); margin-bottom:11px; transition:color .3s, padding-left .3s; }
.footer-col a:hover{ color:var(--sage-pale); padding-left:6px; }
.footer-bottom{ max-width:var(--maxw); margin:28px auto 0;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px;
  font-size:.74rem; color:rgba(255,255,255,.3); }

/* ─────────── MODAL ─────────── */
.modal{ position:fixed; inset:0; z-index:7000; display:none; }
.modal.open{ display:block; }
.modal-backdrop{ position:absolute; inset:0; background:rgba(34,27,18,.55);
  backdrop-filter:blur(8px); opacity:0; transition:opacity .5s var(--ease); }
.modal.open .modal-backdrop{ opacity:1; }
.modal-panel{
  position:absolute; top:0; right:0; height:100%; width:min(640px,100%);
  background:var(--cream); overflow-y:auto;
  transform:translateX(100%); transition:transform .6s var(--ease);
  box-shadow:-30px 0 80px rgba(0,0,0,.2);
}
.modal.open .modal-panel{ transform:translateX(0); }
.modal-close{
  position:sticky; top:24px; float:right; margin:24px 24px 0 0; z-index:5;
  width:46px; height:46px; border-radius:50%; border:none; cursor:none;
  background:var(--white); color:var(--ink); font-size:1.1rem;
  box-shadow:0 8px 24px rgba(0,0,0,.12); transition:transform .3s var(--ease); }
.modal-close:hover{ transform:rotate(90deg); }
.modal-content{ padding:60px 56px 80px; }

.modal-hero{ display:flex; align-items:center; gap:20px; margin-bottom:8px; }
.modal-emoji{ font-size:3.4rem; }
.modal-cat{ font-size:.68rem; letter-spacing:2.5px; text-transform:uppercase;
  color:var(--brown); font-weight:600; }
.modal-title{ font-family:var(--font-serif); font-weight:700;
  font-size:2.4rem; line-height:1.05; color:var(--ink); margin:6px 0 4px; letter-spacing:-.5px; }
.modal-sub{ font-size:.95rem; font-weight:300; color:var(--ink-soft); margin-bottom:36px; }

.modal-section-label{ display:flex; align-items:center; gap:12px;
  font-size:.72rem; letter-spacing:2.5px; text-transform:uppercase;
  color:var(--sage-deep); font-weight:600; margin:36px 0 18px; }
.modal-section-label::after{ content:''; flex:1; height:1px; background:rgba(63,107,76,.15); }

.modal-ing{ list-style:none; display:flex; flex-direction:column; gap:2px; }
.modal-ing li{ display:flex; gap:12px; align-items:flex-start;
  font-size:.94rem; font-weight:300; line-height:1.6; color:var(--ink-soft);
  padding:11px 0; border-bottom:1px solid rgba(0,0,0,.05); }
.modal-ing li::before{ content:''; width:6px; height:6px; border-radius:50%;
  background:var(--sage-soft); margin-top:8px; flex-shrink:0; }
.modal-ing li.modal-ing-head{ font-family:var(--font-serif); font-weight:700;
  font-style:italic; font-size:1.05rem; color:var(--brown); letter-spacing:1px;
  border-bottom:none; padding:16px 0 4px; }
.modal-ing li.modal-ing-head::before{ display:none; }

.modal-steps{ display:flex; flex-direction:column; gap:18px; }
.modal-step{ display:flex; gap:18px; align-items:flex-start; }
.modal-step-num{ flex-shrink:0; width:34px; height:34px; border-radius:50%;
  background:var(--sage-deep); color:var(--white); display:flex; align-items:center;
  justify-content:center; font-family:var(--font-serif); font-size:.95rem; }
.modal-step p{ font-size:.94rem; font-weight:300; line-height:1.7; color:var(--ink-soft); padding-top:4px; }

.modal-note{ background:var(--brown-ghost); border-left:3px solid var(--brown-soft);
  border-radius:10px; padding:16px 20px; margin:18px 0; font-size:.88rem;
  font-style:italic; line-height:1.7; color:var(--ink-soft); }
.modal-usage{ margin-top:36px; padding:28px; border-radius:18px;
  background:linear-gradient(135deg,var(--sage-ghost),var(--brown-ghost));
  border:1px solid rgba(63,107,76,.12); }
.modal-usage strong{ display:flex; align-items:center; gap:8px;
  font-family:var(--font-serif); font-size:1.3rem; color:var(--sage-deep); margin-bottom:12px; }
.modal-usage p{ font-size:.94rem; font-weight:300; line-height:1.8; color:var(--ink-soft); }

/* ─────────── RESPONSIVE ─────────── */
@media (max-width:980px){
  .story{ grid-template-columns:1fr; gap:50px; }
  .ing-grid{ grid-template-columns:repeat(2,1fr); }
  .footer-top{ grid-template-columns:1fr 1fr; gap:36px; }
}

/* ── TABLET / LARGE PHONE ── */
@media (max-width:760px){
  .nav-links{ display:none; }
  .nav-burger{ display:flex; }
  .nav-inner{ grid-template-columns:auto 1fr; padding:0 20px; height:62px; }
  .nav-logo{ justify-self:start; justify-content:flex-start; font-size:1.35rem; letter-spacing:3px; }
  .nav-logo-mark{ width:22px; height:22px; }
  .mobile-menu{ top:62px; }

  .hero{ min-height:auto; padding:54px 22px 116px; }
  .hero-content{ max-width:100%; }
  .hero-title{ font-size:clamp(2.6rem,8.5vw,3.6rem); line-height:1.05; letter-spacing:-.5px; }
  .hero-sub{ font-size:clamp(1.4rem,5vw,1.9rem); margin-bottom:26px; }
  .hero-desc{ margin:24px 0 36px; max-width:100%; }
  .hero-marquee{ padding:14px 0; }
  .hero-marquee-track span{ font-size:1.3rem; }
  .hero-scroll-hint{ display:none; }

  .stats{ grid-template-columns:1fr 1fr; gap:0; padding:30px 22px 70px; }
  .stat{ padding:24px 14px; }
  .stat:nth-child(odd){ border-left:none; }

  .section-intro{ padding:64px 22px 36px; overflow:hidden; }
  .intro-title{ font-size:clamp(1.9rem,7vw,2.8rem); }
  .intro-text{ max-width:100%; }
  .hero-title, .intro-title, .story-title, .card-title, .cta-inner h2,
  .product-name, .modal-title{ overflow-wrap:break-word; }
  .grid-shop{ grid-template-columns:1fr; gap:20px; padding:20px 22px 70px; }
  .product-media{ height:270px; }
  .product-wide .product-media{ height:270px; }
  .product-info{ padding:24px 24px 28px; }

  .story{ padding:64px 22px; }
  .ing-grid{ grid-template-columns:1fr; }
  .ingredients{ padding:40px 22px 70px; }

  .testi-card{ width:min(80vw,340px); padding:30px 26px; }
  .testi-card blockquote{ font-size:1.15rem; }

  .faq{ padding:30px 22px 70px; }
  .faq-item summary{ font-size:1.15rem; padding:20px 22px; }
  .faq-item p{ padding:0 22px 22px; }

  .cta-final{ padding:20px 22px 80px; }
  .cta-inner{ padding:56px 24px; border-radius:28px; }

  footer{ padding:60px 22px 30px; }
  .modal-content{ padding:48px 24px 56px; }
  .modal-title{ font-size:2rem; }
}

/* ── PHONE ── */
@media (max-width:480px){
  .announce-track span{ font-size:.66rem; }
  .hero{ padding:48px 18px 110px; }
  .hero-eyebrow span{ font-size:.62rem; letter-spacing:1.5px; padding:7px 13px; }
  .hero-title{ font-size:clamp(2.3rem,10vw,3rem); line-height:1.07; letter-spacing:-.5px; }
  .hero-sub{ font-size:1.5rem; }
  .hero-desc{ font-size:.96rem; margin:22px 0 32px; }
  .hero-actions{ gap:18px; width:100%; }
  .btn-magnetic{ width:100%; justify-content:center; padding:17px 28px; }
  .hero-marquee-track span{ font-size:1.1rem; }

  .stats{ padding:24px 18px 60px; }
  .stat-num{ font-size:2.4rem; }
  .stat-label{ font-size:.66rem; }

  .section-intro{ padding:54px 18px 30px; }
  .intro-tag{ font-size:.64rem; }
  .grid-shop{ padding:14px 18px 60px; }
  .product-media{ height:240px; }
  .product-wide .product-media{ height:240px; }
  .product-name{ font-size:1.5rem; }

  .story{ padding:54px 18px; }
  .story-card{ width:min(260px,78vw); height:330px; }
  .story-emoji{ font-size:5.2rem; }
  .story-orbit{ width:210px; height:210px; }
  .story-orbit-2{ width:300px; height:300px; }

  .ingredients{ padding:34px 18px 60px; }
  .testi{ padding:40px 0 70px; }
  .testi-track{ padding:0 18px; gap:18px; }

  .faq{ padding:24px 18px 60px; }
  .cta-inner{ padding:48px 20px; }
  .cta-inner h2{ font-size:2rem; }

  .footer-top{ grid-template-columns:1fr; gap:30px; }
  .footer-bottom{ flex-direction:column; align-items:flex-start; gap:8px; }
  .modal-content{ padding:44px 20px 50px; }
  .modal-close{ margin:18px 18px 0 0; width:42px; height:42px; }
  .modal-title{ font-size:1.75rem; }
}

/* keep custom dot cursor off on touch, restore native */
@media (hover:none){ body{ cursor:auto; } .product, .ing-card, .btn-magnetic, a, button, summary{ cursor:pointer; } }

/* ── PERFORMANCE: lighten heavy effects on phones ── */
@media (max-width:760px){
  .blob{ animation:none !important; filter:blur(60px); }
  .grain{ display:none; }
  #nav{ backdrop-filter:none; -webkit-backdrop-filter:none; background:rgba(246,242,234,.97); }
  .cursor-dot{ display:none; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; }
  .reveal-up{ opacity:1; transform:none; }
  .hero-title .word{ transform:none; }
}
