/* =========================================================
   SIP STREET 7  —  Fresh Aussie Street Treats
   Design system & styles
   Palette pulled straight from the brand logos:
   forest green · strawberry red · lemon yellow · warm cream
   ========================================================= */

:root{
  /* Brand */
  --green:        #1a7a3e;
  --green-deep:   #0d5226;
  --green-dark:   #103a23;   /* dark forest panel from the product shot */
  --green-soft:   #d8ecdc;
  --red:          #e23b2e;
  --red-deep:     #c22a1f;
  --yellow:       #f5bf1f;
  --yellow-soft:  #ffe9a8;
  --orange:       #f48a2b;

  /* Neutrals */
  --cream:        #fbf4e6;
  --cream-2:      #fdf9ef;
  --paper:        #fffdf8;
  --ink:          #15281b;
  --muted:        #5d6f60;
  --line:         rgba(21,40,27,.12);

  /* Type */
  --display: "Fredoka", system-ui, sans-serif;
  --script:  "Caveat", cursive;
  --body:    "DM Sans", system-ui, sans-serif;

  /* Motion */
  --ease: cubic-bezier(.22,1,.36,1);
  --ease-back: cubic-bezier(.34,1.56,.64,1);

  /* Spacing rhythm */
  --section-pad: clamp(72px, 11vh, 150px);
  --radius: 28px;
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }

html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; overflow-x:clip; }
/* Lenis controls scroll when JS is on; this is the no-JS fallback */
html.lenis{ scroll-behavior:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto; }
.lenis.lenis-stopped{ overflow:hidden; }

body{
  font-family:var(--body);
  background:var(--cream);
  color:var(--ink);
  line-height:1.6;
  overflow-x:clip;
  -webkit-font-smoothing:antialiased;
  position:relative;
}

/* subtle film-grain texture for warmth/depth */
body::after{
  content:"";
  position:fixed; inset:0;
  pointer-events:none; z-index:9000;
  opacity:.035; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%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");
}

img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }
ul{ list-style:none; }

::selection{ background:var(--yellow); color:var(--green-dark); }

/* Scrollbar */
::-webkit-scrollbar{ width:11px; }
::-webkit-scrollbar-track{ background:var(--cream); }
::-webkit-scrollbar-thumb{ background:var(--green); border-radius:20px; border:3px solid var(--cream); }

/* ---------- Accessibility ---------- */
.skip-link{
  position:fixed; top:-60px; left:16px; z-index:9999;
  background:var(--green); color:#fff; padding:.7em 1.2em; border-radius:0 0 14px 14px;
  font-family:var(--display); font-weight:600; transition:top .3s var(--ease);
}
.skip-link:focus{ top:0; outline:3px solid var(--yellow); }
:focus-visible{ outline:3px solid var(--green); outline-offset:3px; border-radius:4px; }
.nav__links a:focus-visible, .btn:focus-visible{ outline-color:var(--yellow); }

/* ---------- Inline SVG icons ---------- */
.ic{ width:1.15em; height:1.15em; display:inline-block; vertical-align:-0.18em; flex:0 0 auto; }
.hero__est .ic{ color:var(--red); width:1.05em; height:1.05em; }
.btn .ic{ width:1.1em; height:1.1em; vertical-align:-0.16em; }
.value__ico{ color:var(--green); }
.value__ico .ic{ width:32px; height:32px; }
.value:hover .value__ico{ color:#fff; }
.visit__row .ico{ color:var(--yellow); display:flex; align-items:center; }
.visit__row .ico .ic{ width:24px; height:24px; }
.order__ico{ color:var(--green-deep); }
.order__ico .ic{ width:24px; height:24px; }
.socials a .ic{ width:20px; height:20px; }

/* ---------- Layout helpers ---------- */
.container{ width:min(1240px, 92vw); margin-inline:auto; }
section{ position:relative; }

.eyebrow{
  display:inline-flex; align-items:center; gap:.55em;
  font-family:var(--display); font-weight:600;
  font-size:.82rem; letter-spacing:.22em; text-transform:uppercase;
  color:var(--green);
}
.eyebrow::before{
  content:""; width:26px; height:2px; background:var(--red); border-radius:2px;
}
.eyebrow.center::before{ display:none; }

.section-head{ max-width:680px; }
.section-head h2{
  font-family:var(--display); font-weight:600;
  font-size:clamp(2.1rem, 5vw, 3.7rem);
  line-height:1.04; letter-spacing:-.02em; margin:.35em 0 .4em;
}
.section-head p{ color:var(--muted); font-size:1.08rem; max-width:52ch; }
.script{ font-family:var(--script); color:var(--red); font-weight:700; }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--green); --fg:#fff;
  display:inline-flex; align-items:center; gap:.6em;
  padding:.95em 1.6em; border-radius:100px;
  font-family:var(--display); font-weight:600; font-size:1rem;
  background:var(--bg); color:var(--fg);
  position:relative; overflow:hidden; isolation:isolate;
  transition:transform .4s var(--ease-back), box-shadow .4s var(--ease);
  box-shadow:0 10px 22px -10px rgba(13,82,38,.6);
  will-change:transform;
}
.btn span{ position:relative; z-index:2; display:inline-flex; align-items:center; gap:.5em; }
.btn::before{
  content:""; position:absolute; inset:0; z-index:1;
  background:var(--green-deep); transform:translateY(101%);
  transition:transform .45s var(--ease); border-radius:inherit;
}
.btn:hover{ transform:translateY(-3px); box-shadow:0 18px 30px -12px rgba(13,82,38,.65); }
.btn:hover::before{ transform:translateY(0); }
.btn:active{ transform:translateY(0) scale(.98); }
.btn .arrow{ transition:transform .4s var(--ease); }
.btn:hover .arrow{ transform:translate(4px,-4px); }

.btn.red{ --bg:var(--red); box-shadow:0 10px 22px -10px rgba(194,42,31,.6); }
.btn.red::before{ background:var(--red-deep); }
.btn.ghost{
  --bg:transparent; --fg:var(--ink);
  border:2px solid rgba(21,40,27,.22); box-shadow:none;
}
.btn.ghost::before{ background:var(--ink); }
.btn.ghost:hover{ --fg:var(--cream); color:var(--cream); border-color:var(--ink); }
.btn.yellow{ --bg:var(--yellow); --fg:var(--green-dark); box-shadow:0 10px 22px -10px rgba(245,191,31,.7); }
.btn.yellow::before{ background:#e7a800; }

/* ---------- Loader ---------- */
.loader{
  position:fixed; inset:0; z-index:9500;
  background:var(--green-dark);
  display:grid; place-items:center;
  transition:opacity .6s var(--ease), visibility .6s;
}
.loader.done{ opacity:0; visibility:hidden; }
.loader__inner{ text-align:center; color:var(--cream); }
.loader__cup{ font-size:64px; animation:bob 1s ease-in-out infinite; }
.loader__txt{
  font-family:var(--script); font-size:2rem; margin-top:.2em; color:var(--yellow);
}
.loader__bar{
  width:200px; height:5px; background:rgba(255,255,255,.18);
  border-radius:10px; margin:18px auto 0; overflow:hidden;
}
.loader__bar i{ display:block; height:100%; width:0; background:var(--yellow); border-radius:10px; }
@keyframes bob{ 50%{ transform:translateY(-12px) rotate(-6deg); } }

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px clamp(16px,4vw,46px);
  transition:background .4s var(--ease), padding .4s var(--ease), box-shadow .4s var(--ease);
}
.nav.scrolled{
  background:rgba(251,244,230,.82);
  backdrop-filter:blur(14px) saturate(1.2);
  padding-block:11px;
  box-shadow:0 8px 30px -18px rgba(13,82,38,.5);
}
.nav__logo{ display:flex; align-items:center; gap:.55em; }
.nav__logo img{
  height:42px; width:auto;
  transition:height .4s var(--ease);
}
.nav.scrolled .nav__logo img{ height:36px; }
.nav__links{
  display:flex; gap:6px; align-items:center;
  background:rgba(255,255,255,.55); border:1px solid var(--line);
  padding:6px; border-radius:100px; backdrop-filter:blur(6px);
}
.nav__links a{
  font-family:var(--display); font-weight:500; font-size:.96rem;
  padding:.5em 1.05em; border-radius:100px; position:relative;
  transition:color .3s var(--ease);
}
.nav__links a::before{
  content:""; position:absolute; inset:0; background:var(--green);
  border-radius:100px; transform:scale(.4); opacity:0;
  transition:transform .35s var(--ease-back), opacity .3s var(--ease); z-index:-1;
}
.nav__links a:hover{ color:#fff; }
.nav__links a:hover::before{ transform:scale(1); opacity:1; }
.nav__cta{ display:flex; align-items:center; gap:14px; }
.nav__burger{
  display:none; width:46px; height:46px; border-radius:50%;
  background:var(--green); position:relative;
}
.nav__burger span{
  position:absolute; left:50%; top:50%; translate:-50% -50%;
  width:20px; height:2px; background:#fff; border-radius:2px;
  transition:.35s var(--ease);
}
.nav__burger span:nth-child(1){ transform:translateY(-6px); }
.nav__burger span:nth-child(3){ transform:translateY(6px); }
.nav.open .nav__burger span:nth-child(1){ transform:rotate(45deg); }
.nav.open .nav__burger span:nth-child(2){ opacity:0; }
.nav.open .nav__burger span:nth-child(3){ transform:rotate(-45deg); }

/* Mobile drawer */
.drawer{
  position:fixed; inset:0; z-index:999;
  background:var(--green-dark); color:var(--cream);
  display:flex; flex-direction:column; justify-content:center; align-items:center; gap:8px;
  clip-path:circle(0% at calc(100% - 46px) 40px);
  transition:clip-path .6s var(--ease);
  pointer-events:none;
}
.nav.open ~ .drawer{ clip-path:circle(150% at calc(100% - 46px) 40px); pointer-events:auto; }
.drawer a{
  font-family:var(--display); font-weight:600; font-size:2rem;
  opacity:0; transform:translateY(20px); transition:.5s var(--ease);
}
.nav.open ~ .drawer a{ opacity:1; transform:none; }
.nav.open ~ .drawer a:nth-child(1){ transition-delay:.15s; }
.nav.open ~ .drawer a:nth-child(2){ transition-delay:.22s; }
.nav.open ~ .drawer a:nth-child(3){ transition-delay:.29s; }
.nav.open ~ .drawer a:nth-child(4){ transition-delay:.36s; }
.nav.open ~ .drawer a:nth-child(5){ transition-delay:.43s; }
.drawer .script{ color:var(--yellow); font-size:2.6rem; margin-bottom:.2em; }

/* =========================================================
   HERO
   ========================================================= */
.hero{
  min-height:100svh; padding-top:130px; padding-bottom:60px;
  display:flex; align-items:center; position:relative; overflow:hidden;
}
/* soft colour blobs */
.blob{ position:absolute; border-radius:50%; filter:blur(60px); opacity:.55; z-index:0; }
.blob.b1{ width:520px; height:520px; background:var(--green-soft); top:-120px; left:-120px; }
.blob.b2{ width:440px; height:440px; background:var(--yellow-soft); bottom:-160px; right:-80px; opacity:.6; }
.blob.b3{ width:300px; height:300px; background:#ffd5cf; top:40%; right:30%; opacity:.4; }

.hero__grid{
  position:relative; z-index:2;
  display:grid; grid-template-columns:1.05fr .95fr; gap:40px; align-items:center;
}
.hero__est{
  display:inline-flex; align-items:center; gap:.7em;
  font-family:var(--display); font-weight:500; font-size:.8rem;
  letter-spacing:.16em; text-transform:uppercase; color:var(--green-deep);
  background:rgba(255,255,255,.6); border:1px solid var(--line);
  padding:.5em 1em; border-radius:100px; margin-bottom:26px;
}
.hero__est b{ color:var(--red); }
.hero h1{
  font-family:var(--display); font-weight:600;
  font-size:clamp(2.9rem, 7.2vw, 6.4rem);
  line-height:.96; letter-spacing:-.03em;
}
.hero h1 .l{ display:block; overflow:hidden; }
.hero h1 .l > span{ display:block; }
.hero h1 .treat{ color:var(--green); }
.hero h1 .starts{ position:relative; }
.hero h1 em{
  font-family:var(--script); font-style:normal; color:var(--red);
  font-size:1.08em; font-weight:700;
}
.hero__sub{
  margin:26px 0 34px; font-size:1.15rem; color:var(--muted); max-width:46ch;
}
.hero__cta{ display:flex; gap:14px; flex-wrap:wrap; align-items:center; }
.hero__rating{ display:flex; align-items:center; gap:12px; margin-top:30px; }
.hero__rating .stars{ color:var(--yellow); font-size:1.1rem; letter-spacing:2px; }
.hero__rating small{ color:var(--muted); font-size:.9rem; }
.hero__rating b{ color:var(--ink); }

/* hero visual */
.hero__visual{ position:relative; aspect-ratio:1/1.08; }
.hero__product{
  position:absolute; inset:0; z-index:3;
  border-radius:40px; overflow:hidden;
  box-shadow:0 50px 90px -40px rgba(13,82,38,.6);
  transform:rotate(2deg);
}
.hero__product img{ width:100%; height:100%; object-fit:cover; }
.hero__badge{
  position:absolute; z-index:5; bottom:6%; left:-7%;
  width:128px; height:128px; border-radius:50%;
  background:var(--yellow); color:var(--green-dark);
  display:grid; place-items:center; text-align:center;
  font-family:var(--display); font-weight:600; line-height:1.05;
  box-shadow:0 20px 40px -16px rgba(245,191,31,.8);
  animation:spin 18s linear infinite;
}
.hero__badge span{ font-size:.78rem; }
.hero__badge b{ display:block; font-size:1.5rem; }
@keyframes spin{ to{ transform:rotate(360deg); } }

.hero__mascot{
  position:absolute; z-index:6; right:-6%; top:-7%;
  width:140px;
  animation:bob 2.6s ease-in-out infinite;
}

/* floating fruit */
.fruit{
  position:absolute; z-index:4; font-size:2.4rem;
  filter:drop-shadow(0 10px 14px rgba(0,0,0,.18));
  will-change:transform;
}
.fruit.f1{ top:4%;  left:-4%;  font-size:3rem; }
.fruit.f2{ top:64%; left:-9%; }
.fruit.f3{ bottom:-3%; right:18%; font-size:2.8rem; }
.fruit.f4{ top:-3%; right:34%; }
@keyframes floaty{ 50%{ transform:translateY(-18px) rotate(8deg); } }

.scroll-cue{
  position:absolute; left:50%; bottom:26px; translate:-50% 0; z-index:5;
  display:flex; flex-direction:column; align-items:center; gap:8px;
  font-family:var(--display); font-size:.72rem; letter-spacing:.2em;
  text-transform:uppercase; color:var(--muted);
}
.scroll-cue .mouse{
  width:24px; height:38px; border:2px solid var(--green); border-radius:14px; position:relative;
}
.scroll-cue .mouse::before{
  content:""; position:absolute; left:50%; top:7px; translate:-50% 0;
  width:4px; height:8px; background:var(--green); border-radius:4px;
  animation:wheel 1.5s ease-in-out infinite;
}
@keyframes wheel{ 50%{ transform:translate(-50%,10px); opacity:.3; } }

/* =========================================================
   MARQUEE
   ========================================================= */
.marquee-clip{ overflow:hidden; margin-block:40px; }
.marquee{
  background:var(--green); color:var(--cream);
  padding:18px 0; overflow:hidden; white-space:nowrap;
  border-block:3px solid var(--green-deep);
  transform:rotate(-1.4deg) scale(1.04);
}
.marquee__track{ display:inline-flex; gap:0; animation:scroll-x 26s linear infinite; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
.marquee span{
  font-family:var(--display); font-weight:600; font-size:1.5rem;
  letter-spacing:.01em; padding-inline:26px; display:inline-flex; align-items:center; gap:26px;
}
.marquee span::after{ content:"✦"; color:var(--yellow); font-size:1rem; }
@keyframes scroll-x{ to{ transform:translateX(-50%); } }

/* =========================================================
   ABOUT
   ========================================================= */
.about{ padding-block:var(--section-pad); }
.about__grid{ display:grid; grid-template-columns:.95fr 1.05fr; gap:clamp(30px,5vw,72px); align-items:center; }
.about__media{ position:relative; }
.about__media .img-main{
  border-radius:var(--radius); overflow:hidden; aspect-ratio:4/4.4;
  box-shadow:0 40px 70px -36px rgba(13,82,38,.5);
}
.about__media .img-main img{ width:100%; height:100%; object-fit:cover; }
.about__media .img-float{
  position:absolute; bottom:-34px; right:-22px; width:46%;
  border-radius:22px; overflow:hidden; border:6px solid var(--cream);
  box-shadow:0 30px 50px -26px rgba(0,0,0,.4); aspect-ratio:1/1;
}
.about__media .img-float img{ width:100%; height:100%; object-fit:cover; }
.about__media .leaf{
  position:absolute; top:-26px; left:-26px; font-size:3rem; rotate:-18deg;
}
.about p.lead{ font-size:1.18rem; color:var(--ink); margin:.4em 0 1em; font-weight:500; }
.about p{ color:var(--muted); margin-bottom:1em; }
.stats{ display:flex; gap:14px; margin-top:30px; flex-wrap:wrap; }
.stat{
  flex:1; min-width:130px; padding:20px 22px; border-radius:20px;
  background:var(--paper); border:1px solid var(--line);
}
.stat b{ font-family:var(--display); font-weight:600; font-size:2.2rem; color:var(--green); line-height:1; }
.stat span{ display:block; font-size:.86rem; color:var(--muted); margin-top:6px; }

/* =========================================================
   MENU
   ========================================================= */
.menu{ padding-block:var(--section-pad); }
.menu__top{ display:flex; justify-content:space-between; align-items:flex-end; gap:30px; flex-wrap:wrap; margin-bottom:54px; }
.menu__grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:26px;
}
.card{
  position:relative; background:var(--paper); border-radius:var(--radius);
  overflow:hidden; border:1px solid var(--line);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
  will-change:transform;
}
.card:hover{ transform:translateY(-10px); box-shadow:0 40px 60px -34px rgba(13,82,38,.55); }
.card__img{ position:relative; aspect-ratio:4/3.3; overflow:hidden; }
.card__img img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease), filter .6s var(--ease); }
.card:hover .card__img img{ transform:scale(1.09); }
.card__tag{
  position:absolute; top:14px; left:14px; z-index:2;
  font-family:var(--display); font-weight:600; font-size:.74rem;
  letter-spacing:.06em; text-transform:uppercase;
  padding:.45em .9em; border-radius:100px;
  background:var(--cream); color:var(--green-deep);
  box-shadow:0 6px 14px -8px rgba(0,0,0,.3);
}
.card__tag.veg{ background:var(--green); color:#fff; }
.card__tag.cold{ background:#cfe9ff; color:#0a5a8a; }
.card__tag.sweet{ background:var(--red); color:#fff; }
.card__body{ padding:22px 24px 26px; }
.card__body h3{
  font-family:var(--display); font-weight:600; font-size:1.5rem;
  display:flex; justify-content:space-between; align-items:baseline; gap:10px;
}
.card__price{ color:var(--red); font-size:1.2rem; white-space:nowrap; }
.card__body p{ color:var(--muted); font-size:.96rem; margin-top:8px; }
.card__order{
  margin-top:18px; display:inline-flex; align-items:center; gap:.5em;
  font-family:var(--display); font-weight:600; color:var(--green); font-size:.95rem;
}
.card__order .arrow{ transition:transform .35s var(--ease); }
.card:hover .card__order .arrow{ transform:translateX(5px); }

/* ---------- Coming-soon menu ---------- */
.card__tag.soon{ background:var(--green-dark); color:var(--yellow); }
.card--soon .card__body h3{ display:block; }
.card--more{
  border:none; color:var(--cream); overflow:hidden;
  background:linear-gradient(150deg, var(--green) 0%, var(--green-deep) 100%);
  position:relative;
}
.card--more::after{
  content:"🍫"; position:absolute; right:-14px; bottom:-18px; font-size:6rem; opacity:.14; rotate:-12deg;
}
.card--more__inner{
  position:relative; z-index:2; height:100%;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:12px; text-align:center; padding:38px 26px;
}
.card--more__emoji{ font-size:3rem; }
.card--more h3{ font-family:var(--display); font-weight:600; font-size:1.55rem; line-height:1.08; }
.card--more p{ color:rgba(251,244,230,.82); font-size:.96rem; max-width:26ch; }
.card--more__soon{
  margin-top:6px; font-family:var(--display); font-weight:600; font-size:.74rem;
  letter-spacing:.14em; text-transform:uppercase; background:var(--yellow); color:var(--green-dark);
  padding:.5em 1.1em; border-radius:100px;
}
.hero__soon{
  display:inline-flex; align-items:center; gap:.5em;
  font-family:var(--display); font-weight:600; font-size:.95rem; color:var(--green-deep);
  background:var(--yellow-soft); border:1px solid rgba(245,191,31,.5);
  padding:.5em 1.1em; border-radius:100px;
}

/* =========================================================
   SPOTLIGHT  (featured product, dark panel)
   ========================================================= */
.spotlight{
  background:var(--green-dark); color:var(--cream);
  padding-block:clamp(80px,12vh,160px); overflow:hidden; position:relative;
}
.spotlight::before{
  content:""; position:absolute; inset:0; opacity:.08; z-index:0;
  background:url("assets/img/pattern-oranges.jpg") center/420px; mix-blend-mode:screen;
}
.spotlight__grid{ position:relative; z-index:2; display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.spotlight__img{
  border-radius:var(--radius); overflow:hidden; aspect-ratio:4/5;
  box-shadow:0 50px 90px -40px rgba(0,0,0,.7); transform:rotate(-2deg);
}
.spotlight__img img{ width:100%; height:100%; object-fit:cover; }
.spotlight .eyebrow{ color:var(--yellow); }
.spotlight .eyebrow::before{ background:var(--yellow); }
.spotlight h2{
  font-family:var(--display); font-weight:600;
  font-size:clamp(2.4rem,5.6vw,4.6rem); line-height:1; letter-spacing:-.02em; margin:.3em 0;
}
.spotlight h2 .made{ color:var(--yellow); }
.spotlight h2 .cold{ color:#9fe3ff; }
.spotlight p{ color:rgba(251,244,230,.78); font-size:1.12rem; max-width:46ch; margin-bottom:30px; }
.spotlight__list{ display:flex; flex-direction:column; gap:14px; margin-bottom:34px; }
.spotlight__list li{ display:flex; align-items:center; gap:12px; font-size:1.04rem; }
.spotlight__list .dot{
  width:30px; height:30px; border-radius:50%; background:rgba(255,255,255,.1);
  display:grid; place-items:center; color:var(--yellow); flex:0 0 auto;
}

/* =========================================================
   VALUES
   ========================================================= */
.values{ padding-block:var(--section-pad); }
.values__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; margin-top:50px; }
.value{
  padding:34px 26px; border-radius:24px; background:var(--paper);
  border:1px solid var(--line); transition:transform .45s var(--ease), background .45s var(--ease);
}
.value:hover{ transform:translateY(-8px); background:var(--green); color:var(--cream); }
.value:hover p{ color:rgba(251,244,230,.8); }
.value:hover .value__ico{ background:rgba(255,255,255,.15); }
.value__ico{
  width:64px; height:64px; border-radius:20px; display:grid; place-items:center;
  font-size:1.9rem; background:var(--green-soft); margin-bottom:20px;
  transition:background .45s var(--ease);
}
.value h3{ font-family:var(--display); font-weight:600; font-size:1.3rem; margin-bottom:8px; }
.value p{ color:var(--muted); font-size:.95rem; transition:color .45s var(--ease); }

/* =========================================================
   TESTIMONIALS
   ========================================================= */
.reviews{ padding-block:var(--section-pad); background:var(--cream-2); }
.reviews__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:50px; }
.review{
  background:var(--paper); border:1px solid var(--line); border-radius:24px; padding:30px 28px;
  position:relative;
}
.review .stars{ color:var(--yellow); letter-spacing:2px; margin-bottom:14px; }
.review p{ font-size:1.05rem; margin-bottom:22px; }
.review__who{ display:flex; align-items:center; gap:12px; }
.review__ava{
  width:46px; height:46px; border-radius:50%; flex:0 0 auto;
  display:grid; place-items:center; font-family:var(--display); font-weight:600; color:#fff;
}
.review__who b{ font-family:var(--display); }
.review__who span{ display:block; font-size:.84rem; color:var(--muted); }
.review .quote{ position:absolute; top:18px; right:24px; font-family:var(--script); font-size:4rem; color:var(--green-soft); line-height:1; }

/* =========================================================
   GALLERY  (insta-style)
   ========================================================= */
.gallery{ padding-block:var(--section-pad); }
.gallery__head{ text-align:center; display:flex; flex-direction:column; align-items:center; margin-bottom:46px; }
.gallery__grid{
  display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:1fr; gap:14px;
}
.gallery__grid a{
  position:relative; overflow:hidden; border-radius:20px; aspect-ratio:1/1; display:block;
}
.gallery__grid a.tall{ grid-row:span 2; aspect-ratio:auto; }
.gallery__grid img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease); }
.gallery__grid a:hover img{ transform:scale(1.08); }
.gallery__grid a::after{
  content:"\1F4F7"; position:absolute; inset:0; display:grid; place-items:center;
  background:rgba(13,58,35,.55); color:#fff; font-size:1.6rem; opacity:0; transition:opacity .4s var(--ease);
}
.gallery__grid a:hover::after{ opacity:1; }

/* =========================================================
   VISIT
   ========================================================= */
.visit{ padding-block:var(--section-pad); }
.visit__grid{ display:grid; grid-template-columns:1fr 1fr; gap:46px; align-items:stretch; }
.visit__card{
  background:var(--green-dark); color:var(--cream); border-radius:var(--radius);
  padding:clamp(34px,4vw,54px); position:relative; overflow:hidden;
}
.visit__card .leaf{ position:absolute; right:-20px; bottom:-20px; font-size:8rem; opacity:.12; }
.visit__card h2{ font-family:var(--display); font-weight:600; font-size:clamp(2rem,4vw,3rem); line-height:1.02; margin-bottom:26px; }
.visit__row{ display:flex; gap:14px; padding:18px 0; border-top:1px solid rgba(255,255,255,.14); }
.visit__row:first-of-type{ border-top:none; }
.visit__row .ico{ font-size:1.4rem; flex:0 0 auto; }
.visit__row b{ font-family:var(--display); display:block; margin-bottom:2px; }
.visit__row span{ color:rgba(251,244,230,.74); font-size:.96rem; }
.visit__hours{ margin-top:26px; }
.visit__map{
  border-radius:var(--radius); overflow:hidden; min-height:380px; position:relative;
  background:linear-gradient(135deg, var(--green-soft), var(--yellow-soft));
}
.visit__map iframe{ width:100%; height:100%; min-height:380px; border:0; display:block; filter:saturate(1.05); }
.visit__map .pin{ font-size:3.4rem; animation:bob 2s ease-in-out infinite; }
.visit__map .pin-label{ font-family:var(--display); font-weight:600; color:var(--green-deep); margin-top:10px; font-size:1.2rem; }
.visit__map small{ color:var(--green-deep); opacity:.8; }
.visit__map .grid-lines{ position:absolute; inset:0; opacity:.4;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:40px 40px; }

/* =========================================================
   NEWSLETTER
   ========================================================= */
.newsletter{ padding-block:clamp(50px,7vh,90px); }
.reach-form-wrap{ max-width:720px; margin:0 auto; border-radius:var(--radius); overflow:hidden; }
.reach-form-wrap iframe, .reach-form-wrap > div{ max-width:100%; }
.newsletter__inner{
  background:var(--red); color:#fff; border-radius:var(--radius);
  padding:clamp(40px,5vw,70px); text-align:center; position:relative; overflow:hidden;
}
.newsletter__inner::before,.newsletter__inner::after{
  content:"🍓"; position:absolute; font-size:7rem; opacity:.18;
}
.newsletter__inner::before{ top:-20px; left:-10px; rotate:-20deg; }
.newsletter__inner::after{ content:"🍋"; bottom:-26px; right:-6px; rotate:18deg; }
.newsletter h2{ font-family:var(--display); font-weight:600; font-size:clamp(1.9rem,4vw,3rem); position:relative; }
.newsletter p{ max-width:46ch; margin:12px auto 28px; opacity:.92; position:relative; }
.newsletter form{ display:flex; gap:10px; max-width:480px; margin-inline:auto; position:relative; flex-wrap:wrap; justify-content:center; }
.newsletter input{
  flex:1; min-width:220px; padding:1em 1.3em; border-radius:100px; border:none;
  font-family:var(--body); font-size:1rem; background:#fff; color:var(--ink);
}
.newsletter input:focus{ outline:3px solid var(--yellow); }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{ background:var(--green-dark); color:var(--cream); padding-top:clamp(60px,8vh,100px); }
.footer__grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:40px; padding-bottom:50px; }
.footer__brand img{ width:120px; mix-blend-mode:lighten; margin-bottom:18px; }
.footer__brand .script{ color:var(--yellow); font-size:1.9rem; display:block; margin-bottom:10px; }
.footer__brand p{ color:rgba(251,244,230,.7); max-width:34ch; font-size:.96rem; }
.footer h4{ font-family:var(--display); font-weight:600; font-size:1.05rem; margin-bottom:18px; color:var(--yellow); }
.footer ul li{ margin-bottom:11px; }
.footer ul a{ color:rgba(251,244,230,.74); transition:color .3s var(--ease), padding-left .3s var(--ease); }
.footer ul a:hover{ color:#fff; padding-left:6px; }
.socials{ display:flex; gap:12px; }
.socials a{
  width:44px; height:44px; border-radius:50%; display:grid; place-items:center;
  background:rgba(255,255,255,.1); transition:background .35s var(--ease), transform .35s var(--ease-back);
}
.socials a:hover{ background:var(--yellow); color:var(--green-dark); transform:translateY(-4px); }
.footer__bottom{
  border-top:1px solid rgba(255,255,255,.14); padding:24px 0;
  display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap;
  font-size:.88rem; color:rgba(251,244,230,.6);
}
.footer__bottom a{ color:rgba(251,244,230,.8); }

/* =========================================================
   REVEAL ANIMATIONS  (driven by JS / IntersectionObserver)
   ========================================================= */
.js [data-reveal]{ opacity:0; transform:translateY(34px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.js [data-reveal="left"]{ transform:translateX(-44px); }
.js [data-reveal="right"]{ transform:translateX(44px); }
.js [data-reveal="zoom"]{ transform:scale(.9); }
.js [data-reveal].in{ opacity:1; transform:none; }
[data-delay="1"]{ transition-delay:.08s; }
[data-delay="2"]{ transition-delay:.16s; }
[data-delay="3"]{ transition-delay:.24s; }
[data-delay="4"]{ transition-delay:.32s; }
[data-delay="5"]{ transition-delay:.4s; }

/* split-line hero reveal */
.js .hero h1 .l > span{ transform:translateY(110%); transition:transform 1s var(--ease); }
.js .hero.in h1 .l > span{ transform:translateY(0); }
.js .hero.in h1 .l:nth-child(2) > span{ transition-delay:.1s; }
.js .hero.in h1 .l:nth-child(3) > span{ transition-delay:.2s; }
.js .hero [data-hero]{ opacity:0; transform:translateY(26px); transition:opacity .9s var(--ease) .3s, transform .9s var(--ease) .3s; }
.js .hero.in [data-hero]{ opacity:1; transform:none; }
.js .hero [data-hero="2"]{ transition-delay:.42s; }
.js .hero [data-hero="3"]{ transition-delay:.54s; }
.js .hero [data-hero="visual"]{ transition:opacity 1.1s var(--ease) .25s, transform 1.1s var(--ease) .25s; transform:translateY(40px) scale(.96); }
.js .hero.in [data-hero="visual"]{ transform:none; }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1080px){
  .menu__grid{ grid-template-columns:repeat(2,1fr); }
  .values__grid{ grid-template-columns:repeat(2,1fr); }
  .footer__grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:880px){
  .nav__links{ display:none; }
  .nav__cta .btn{ display:none; }
  .nav__burger{ display:block; }
  .hero__grid{ grid-template-columns:1fr; gap:50px; }
  .hero__visual{ max-width:440px; margin-inline:auto; width:100%; }
  .about__grid{ grid-template-columns:1fr; gap:60px; }
  .about__media{ max-width:460px; }
  .spotlight__grid{ grid-template-columns:1fr; gap:40px; }
  .reviews__grid{ grid-template-columns:1fr; }
  .gallery__grid{ grid-template-columns:repeat(2,1fr); }
  .visit__grid{ grid-template-columns:1fr; }
}
@media (max-width:560px){
  :root{ --radius:22px; }
  .menu__grid{ grid-template-columns:1fr; }
  .values__grid{ grid-template-columns:1fr; }
  .footer__grid{ grid-template-columns:1fr; }
  .stats{ flex-direction:column; }
  .marquee span{ font-size:1.2rem; }
  .hero__mascot{ width:96px; }
  .hero__badge{ width:100px; height:100px; }
}

/* =========================================================
   LEGAL PAGES (privacy / terms)
   ========================================================= */
.legal-nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px clamp(16px,4vw,46px); position:sticky; top:0; z-index:100;
  background:rgba(251,244,230,.9); backdrop-filter:blur(12px); border-bottom:1px solid var(--line);
}
.legal-nav img{ height:40px; }
.legal-nav a.back{ font-family:var(--display); font-weight:600; color:var(--green); }
.legal-hero{
  background:var(--green-dark); color:var(--cream);
  padding:clamp(70px,12vh,130px) 0 clamp(50px,8vh,80px); text-align:center;
}
.legal-hero .script{ color:var(--yellow); font-size:1.6rem; }
.legal-hero h1{ font-family:var(--display); font-weight:600; font-size:clamp(2.4rem,6vw,4rem); margin-top:.1em; }
.legal-hero p{ color:rgba(251,244,230,.7); margin-top:10px; }
.legal{ padding:clamp(50px,8vh,90px) 0 clamp(60px,10vh,110px); }
.legal .container{ width:min(820px,92vw); }
.legal h2{ font-family:var(--display); font-weight:600; font-size:1.6rem; color:var(--green-deep); margin:1.8em 0 .5em; }
.legal h2:first-of-type{ margin-top:0; }
.legal p, .legal li{ color:var(--ink); margin-bottom:1em; }
.legal ul{ list-style:disc; padding-left:1.3em; margin-bottom:1em; }
.legal a{ color:var(--green); text-decoration:underline; }
.legal .note{
  background:var(--yellow-soft); border:1px solid rgba(245,191,31,.5);
  padding:16px 20px; border-radius:16px; font-size:.92rem; color:var(--green-dark);
}
.legal .updated{ color:var(--muted); font-size:.92rem; }

/* =========================================================
   ORDER MODAL
   ========================================================= */
.order{
  position:fixed; inset:0; z-index:8000;
  display:grid; place-items:center; padding:20px;
  visibility:hidden; opacity:0; transition:opacity .35s var(--ease), visibility .35s;
}
.order.open{ visibility:visible; opacity:1; }
.order__backdrop{ position:absolute; inset:0; background:rgba(13,58,35,.55); backdrop-filter:blur(6px); }
.order__panel{
  position:relative; z-index:2; width:min(540px,100%);
  background:var(--cream-2); border-radius:var(--radius);
  padding:clamp(28px,4vw,44px); text-align:center;
  box-shadow:0 50px 90px -30px rgba(0,0,0,.5);
  transform:translateY(24px) scale(.96); opacity:0;
  transition:transform .45s var(--ease-back), opacity .4s var(--ease);
}
.order.open .order__panel{ transform:none; opacity:1; }
.order__x{
  position:absolute; top:16px; right:18px; width:40px; height:40px; border-radius:50%;
  background:rgba(21,40,27,.08); color:var(--ink); font-size:1.5rem; line-height:1;
  transition:background .3s var(--ease), transform .3s var(--ease);
}
.order__x:hover{ background:var(--red); color:#fff; transform:rotate(90deg); }
.order__panel h3{ font-family:var(--display); font-weight:600; font-size:1.9rem; margin:.3em 0 .2em; }
.order__sub{ color:var(--muted); margin-bottom:26px; }
.order__opts{ display:grid; gap:12px; }
.order__opt{
  display:flex; align-items:center; gap:16px; text-align:left;
  padding:16px 20px; border-radius:18px; background:var(--paper);
  border:1px solid var(--line); width:100%;
  transition:transform .35s var(--ease-back), border-color .3s var(--ease), background .3s var(--ease);
}
.order__opt:hover{ transform:translateY(-3px); border-color:var(--green); background:var(--green-soft); }
.order__ico{
  width:50px; height:50px; flex:0 0 auto; border-radius:14px; display:grid; place-items:center;
  font-size:1.5rem; background:var(--cream);
}
.order__opt b{ font-family:var(--display); font-weight:600; font-size:1.1rem; display:block; }
.order__opt small{ color:var(--muted); }
.order__note{ margin-top:22px; font-size:.82rem; color:var(--muted); }
.order__note code{ background:rgba(21,40,27,.08); padding:.1em .45em; border-radius:6px; font-size:.95em; }

/* =========================================================
   REDUCED MOTION
   ========================================================= */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; scroll-behavior:auto !important; }
  .js [data-reveal],.js .hero [data-hero],.js .hero h1 .l > span{ opacity:1 !important; transform:none !important; }
}
