/* =========================================================
   STICKY FINGERS ICE CREAM — style.css
   A design-forward, single-page brand experience.
   Built by OptiPath.
   ========================================================= */

/* ----------  TOKENS  ---------- */
:root{
  --pink:#E91E8B;
  --pink-light:#FF6FB5;
  --pink-dark:#C2156F;
  --blue:#3FA9F5;
  --blue-light:#7CC6FF;
  --blue-dark:#1E7FC8;
  --red:#E63946;
  --yellow:#FFD23F;
  --cream:#FFF8F0;
  --cream-deep:#FBEEDD;
  --ink:#221b2c;
  --ink-soft:#473b53;
  --night:#1b1430;
  --night-2:#241a3e;
  --white:#ffffff;

  --ff-display:'Lilita One', 'Arial Black', system-ui, sans-serif;
  --ff-body:'Nunito', 'Segoe UI', system-ui, sans-serif;
  --ff-fun:'Fredoka', 'Nunito', system-ui, sans-serif;
  --ff-hand:'Caveat', 'Segoe Print', cursive;

  --wrap:1240px;
  --pad:clamp(20px, 5vw, 64px);
  --radius:26px;
  --radius-lg:40px;

  --shadow-sm:0 6px 18px rgba(34,17,44,.10);
  --shadow-md:0 18px 40px rgba(34,17,44,.16);
  --shadow-lg:0 40px 90px rgba(34,17,44,.24);
  --shadow-pink:0 22px 50px rgba(233,30,139,.34);
  --shadow-blue:0 22px 50px rgba(63,169,245,.32);

  --ease-out:cubic-bezier(.16,1,.3,1);
  --ease-back:cubic-bezier(.34,1.56,.64,1);
}

/* ----------  RESET / BASE  ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{
  -webkit-text-size-adjust:100%;
  scroll-behavior:smooth;
}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;animation-delay:0ms!important;transition-delay:0ms!important;scroll-behavior:auto!important}
}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto !important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:hidden}

body{
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  font-size:clamp(16px,1.05vw,18px);
  font-weight:600;
  overflow-x:clip;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body.is-loading{overflow:hidden;height:100vh}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
input,select,textarea{font:inherit}
ul,ol{list-style:none}
::selection{background:var(--pink);color:#fff}
:focus-visible{outline:3px solid var(--blue);outline-offset:3px;border-radius:6px}

.visually-hidden,.book__form .visually-hidden{
  position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0;
}

/* ----------  LAYOUT HELPERS  ---------- */
.section__wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--pad)}
section{position:relative}
section[id],main[id],[id]{scroll-margin-top:clamp(76px,10vh,96px)}
.section__head{text-align:center;max-width:760px;margin:0 auto clamp(40px,6vw,72px)}
.section__head--book{margin-bottom:clamp(28px,4vw,44px)}

.kicker{
  display:inline-block;font-family:var(--ff-fun);font-weight:700;
  font-size:.82rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--pink);background:rgba(233,30,139,.10);
  padding:.5em 1.1em;border-radius:999px;margin-bottom:1.1rem;
}
.kicker--light{color:#fff;background:rgba(255,255,255,.16)}

.h-display{
  font-family:var(--ff-display);font-weight:400;line-height:.98;
  letter-spacing:-.01em;color:var(--ink);
  font-size:clamp(2.4rem,6.2vw,4.8rem);
  text-wrap:balance;
}
.h-display--light{color:#fff}
.tx-pink{color:var(--pink)}
.tx-blue{color:var(--blue)}
.tx-yellow{color:var(--yellow);text-shadow:0 4px 0 rgba(0,0,0,.08)}

.section__sub{
  margin-top:1.1rem;font-family:var(--ff-fun);font-weight:500;
  font-size:clamp(1.05rem,1.7vw,1.4rem);color:var(--ink-soft);
}
.section__sub--light{color:rgba(255,255,255,.86)}
.lede{font-size:clamp(1.05rem,1.5vw,1.25rem);color:var(--ink-soft);margin:1.2rem 0}
.kicker.kicker--light + .h-display--light{margin-top:0}

/* ----------  REVEALS  ---------- */
.reveal-up{opacity:0;transform:translateY(46px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.reveal-up.is-in{opacity:1;transform:none}
.reveal-clip{clip-path:inset(0 0 100% 0);transition:clip-path 1.1s var(--ease-out)}
.reveal-clip.is-in{clip-path:inset(0 0 0 0)}
.stat.is-in,.event-tile.is-in,.step.is-in,.gtile.is-in{transition-delay:var(--d,0s)}
@media (prefers-reduced-motion: reduce){
  .reveal-up,.reveal-clip{opacity:1!important;transform:none!important;clip-path:none!important;transition:none!important}
  .hero__title .word{opacity:1!important;transform:none!important}
  .hero__photo-frame{opacity:1!important;transform:rotate(-1.4deg)!important}
  .word--drip::after{transform:scaleY(1)!important}.word--drip::before{height:.34em!important}
}

/* =========================================================
   PRELOADER
   ========================================================= */
.loader{
  position:fixed;inset:0;z-index:9999;display:grid;place-items:center;
  background:linear-gradient(150deg,var(--pink-light),var(--pink) 45%,var(--blue) 110%);
  transition:opacity .7s ease,visibility .7s ease;
}
.loader.is-done{opacity:0;visibility:hidden;pointer-events:none}
.loader__inner{display:flex;flex-direction:column;align-items:center;gap:22px;text-align:center}
.loader__cone{width:118px;height:auto;overflow:visible;animation:coneWobble 1.4s var(--ease-back) infinite}
.loader__cone .loader__drip{transform-origin:86px 70px;animation:dripStretch 1.4s ease-in-out infinite}
.loader__bar{width:min(60vw,220px);height:10px;border-radius:999px;background:rgba(255,255,255,.28);overflow:hidden}
.loader__fill{display:block;height:100%;width:0;border-radius:999px;background:#fff;box-shadow:0 0 16px rgba(255,255,255,.7);transition:width .2s linear}
.loader__text{font-family:var(--ff-fun);font-weight:600;color:#fff;letter-spacing:.04em;font-size:1rem}
@keyframes coneWobble{0%,100%{transform:rotate(-7deg) translateY(0)}50%{transform:rotate(7deg) translateY(-8px)}}
@keyframes dripStretch{0%,100%{transform:scaleY(1)}50%{transform:scaleY(1.6)}}

/* =========================================================
   CUSTOM CURSOR (desktop, fine pointers)
   ========================================================= */
.cursor,.cursor-dot{position:fixed;top:0;left:0;pointer-events:none;z-index:9000;will-change:transform;opacity:0;transition:opacity .3s}
.cursor{width:40px;height:48px;margin:-30px 0 0 -20px;transform-origin:50% 70%}
.cursor__cone{width:100%;height:100%;filter:drop-shadow(0 4px 6px rgba(34,17,44,.25))}
.cursor-dot{width:8px;height:8px;margin:-4px 0 0 -4px;border-radius:50%;background:var(--pink);mix-blend-mode:multiply}
body.cursor-ready .cursor,body.cursor-ready .cursor-dot{opacity:1}
body.cursor-grow .cursor{transform:scale(1.55) rotate(-12deg)}
body.cursor-grow .cursor-dot{opacity:0}
body.cursor-hidden .cursor,body.cursor-hidden .cursor-dot{opacity:0!important}
@media (hover:none),(pointer:coarse){.cursor,.cursor-dot{display:none!important}}
body.cursor-ready{cursor:none}
body.cursor-ready a,body.cursor-ready button,body.cursor-ready input,body.cursor-ready select,body.cursor-ready textarea,body.cursor-ready label{cursor:none}

/* =========================================================
   SCROLL PROGRESS
   ========================================================= */
.scroll-progress{position:fixed;top:0;left:0;right:0;height:5px;z-index:1200;background:transparent}
.scroll-progress span{display:block;height:100%;width:0%;background:linear-gradient(90deg,var(--pink),var(--yellow),var(--blue));box-shadow:0 0 14px rgba(233,30,139,.4)}

/* =========================================================
   NAV
   ========================================================= */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;transition:background .4s ease,box-shadow .4s ease,padding .4s ease;padding:14px 0}
.nav__inner{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--pad);display:flex;align-items:center;gap:clamp(14px,3vw,40px)}
.nav.is-solid{background:rgba(255,248,240,.82);backdrop-filter:blur(16px) saturate(1.3);-webkit-backdrop-filter:blur(16px) saturate(1.3);box-shadow:0 6px 28px rgba(34,17,44,.10);padding:8px 0}
.nav.is-hidden{transform:translateY(-110%)}
.nav{transition:background .4s ease,box-shadow .4s ease,padding .4s ease,transform .45s var(--ease-out)}

.brand{display:flex;align-items:center;margin-right:auto;transform-origin:left center}
.brand picture{display:contents}
.brand__logo{height:clamp(44px,5vw,56px);width:auto;display:block;transition:transform .5s var(--ease-back),height .4s ease;transform-origin:left center;filter:drop-shadow(0 4px 10px rgba(34,17,44,.14))}
.nav.is-solid .brand__logo{height:clamp(40px,4.6vw,48px)}
.brand:hover .brand__logo{transform:rotate(-3deg) scale(1.05)}
.brand--footer{display:inline-block;background:#fff;border-radius:22px;padding:14px 22px;box-shadow:var(--shadow-md);transition:transform .5s var(--ease-back),box-shadow .4s ease}
.brand--footer:hover{transform:rotate(-2deg) scale(1.03);box-shadow:var(--shadow-lg)}
.brand__logo--footer{height:clamp(58px,8vw,76px);filter:none}

.nav__links{display:flex;gap:clamp(14px,2vw,30px);align-items:center}
.nav__link{position:relative;font-family:var(--ff-fun);font-weight:600;font-size:1rem;color:var(--ink);padding:6px 2px}
.nav__link::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:3px;border-radius:3px;background:var(--pink);transition:right .35s var(--ease-out)}
.nav__link:hover{color:var(--pink)}
.nav__link:hover::after,.nav__link.is-active::after{right:0}
.nav__link.is-active{color:var(--pink)}

.nav__burger{display:none;width:46px;height:46px;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:5px;background:rgba(34,17,44,.07);backdrop-filter:blur(8px)}
.nav__burger span{width:22px;height:3px;border-radius:3px;background:var(--ink);transition:transform .35s var(--ease-back),opacity .25s,background .25s}
.nav.is-solid .nav__burger{background:rgba(233,30,139,.12)}
.nav.menu-open .nav__burger{background:rgba(255,255,255,.2)}
.nav.menu-open .nav__burger span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav.menu-open .nav__burger span:nth-child(2){opacity:0}
.nav.menu-open .nav__burger span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
.nav.menu-open .nav__burger span{background:#fff}
.nav.menu-open{background:transparent;box-shadow:none}

/* ----------  BUTTONS  ---------- */
.btn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  font-family:var(--ff-fun);font-weight:700;font-size:1.02rem;letter-spacing:.01em;
  padding:.86em 1.5em;border-radius:999px;line-height:1;white-space:nowrap;
  transition:transform .35s var(--ease-back),box-shadow .35s var(--ease-out),background .3s,color .3s;
  overflow:visible;isolation:isolate;
}
.btn .btn__label{position:relative;z-index:2}
.btn:active{transform:scale(.96)}
.btn--lg{font-size:1.15rem;padding:1.05em 1.9em}
.btn--book{background:var(--pink);color:#fff;box-shadow:var(--shadow-pink)}
.btn--book:hover{transform:translateY(-3px) scale(1.04) rotate(-1deg);box-shadow:0 26px 56px rgba(233,30,139,.42)}
.btn--primary{background:var(--pink);color:#fff;box-shadow:var(--shadow-pink)}
.btn--primary:hover{transform:translateY(-4px) scale(1.04);box-shadow:0 30px 64px rgba(233,30,139,.45)}
.btn--ghost{background:transparent;color:var(--blue);border:3px solid var(--blue)}
.btn--ghost:hover{background:var(--blue);color:#fff;transform:translateY(-4px) scale(1.03);box-shadow:var(--shadow-blue)}
.nav:not(.is-solid):not(.menu-open) .btn--ghost{}
.btn__arrow{width:1.1em;height:1.1em;transition:transform .35s var(--ease-back)}
.btn--ghost:hover .btn__arrow{transform:translateY(4px)}

/* drip under primary buttons */
.btn__drip{position:absolute;left:0;right:0;bottom:-2px;height:0;z-index:0;pointer-events:none}
.btn__drip::before,.btn__drip::after{content:"";position:absolute;top:-12px;background:inherit;border-radius:0 0 60% 60%}
.btn--primary .btn__drip,.btn--book .btn__drip{background:var(--pink)}
.btn__drip::before{left:24%;width:16px;height:0}
.btn__drip::after{left:64%;width:22px;height:0}
.btn:hover .btn__drip::before{transition:height .4s var(--ease-out);height:16px}
.btn:hover .btn__drip::after{transition:height .45s .05s var(--ease-out);height:24px}

/* sprinkle burst on hover */
.btn__sprinkles{position:absolute;inset:0;pointer-events:none;z-index:1}
.btn__sprinkles i{position:absolute;top:50%;left:50%;width:5px;height:13px;border-radius:3px;opacity:0;transform:translate(-50%,-50%)}
.btn__sprinkles i:nth-child(1){background:var(--yellow)}
.btn__sprinkles i:nth-child(2){background:var(--blue)}
.btn__sprinkles i:nth-child(3){background:#fff}
.btn__sprinkles i:nth-child(4){background:var(--yellow)}
.btn__sprinkles i:nth-child(5){background:var(--blue-light)}
.btn__sprinkles i:nth-child(6){background:#fff}
.btn__sprinkles i:nth-child(7){background:var(--yellow)}
.btn__sprinkles i:nth-child(8){background:var(--blue)}
.btn:hover .btn__sprinkles i,.btn.is-pop .btn__sprinkles i{animation:sprinklePop .6s var(--ease-out) forwards}
.btn .btn__sprinkles i:nth-child(1){--tx:-70px;--ty:-34px;--r:40deg}
.btn .btn__sprinkles i:nth-child(2){--tx:64px;--ty:-40px;--r:-30deg}
.btn .btn__sprinkles i:nth-child(3){--tx:-92px;--ty:8px;--r:80deg}
.btn .btn__sprinkles i:nth-child(4){--tx:96px;--ty:14px;--r:-66deg}
.btn .btn__sprinkles i:nth-child(5){--tx:-44px;--ty:38px;--r:20deg}
.btn .btn__sprinkles i:nth-child(6){--tx:50px;--ty:42px;--r:-12deg}
.btn .btn__sprinkles i:nth-child(7){--tx:-14px;--ty:-46px;--r:120deg}
.btn .btn__sprinkles i:nth-child(8){--tx:18px;--ty:46px;--r:-100deg}
@keyframes sprinklePop{
  0%{opacity:0;transform:translate(-50%,-50%) rotate(0) scale(.4)}
  18%{opacity:1}
  100%{opacity:0;transform:translate(calc(-50% + var(--tx)),calc(-50% + var(--ty))) rotate(var(--r)) scale(1)}
}
@media (prefers-reduced-motion: reduce){
  .btn__sprinkles,.btn__drip{display:none}
  .btn:hover{transform:translateY(-3px)}
}

/* =========================================================
   MOBILE MENU
   ========================================================= */
.mobile-menu{position:fixed;inset:0;z-index:990;visibility:hidden;pointer-events:none}
.mobile-menu.is-open{visibility:visible;pointer-events:auto}
.mobile-menu__bg{position:absolute;inset:0;background:linear-gradient(155deg,var(--pink) 0%,var(--pink-dark) 48%,var(--blue) 130%);clip-path:circle(0% at calc(100% - 44px) 44px);transition:clip-path .7s var(--ease-out)}
.mobile-menu.is-open .mobile-menu__bg{clip-path:circle(150% at calc(100% - 44px) 44px)}
.mobile-menu__nav{position:relative;height:100%;display:flex;flex-direction:column;justify-content:center;gap:clamp(8px,2.4vh,18px);padding:0 var(--pad)}
.mobile-menu__link{display:flex;align-items:baseline;gap:14px;font-family:var(--ff-display);font-size:clamp(2rem,9vw,3.4rem);color:#fff;opacity:0;transform:translateX(40px);transition:opacity .5s,transform .5s}
.mobile-menu__link span{font-family:var(--ff-fun);font-weight:700;font-size:.34em;opacity:.7;letter-spacing:.1em}
.mobile-menu.is-open .mobile-menu__link{opacity:1;transform:none}
.mobile-menu.is-open .mobile-menu__link:nth-child(1){transition-delay:.18s}
.mobile-menu.is-open .mobile-menu__link:nth-child(2){transition-delay:.25s}
.mobile-menu.is-open .mobile-menu__link:nth-child(3){transition-delay:.32s}
.mobile-menu.is-open .mobile-menu__link:nth-child(4){transition-delay:.39s}
.mobile-menu.is-open .mobile-menu__link:nth-child(5){transition-delay:.46s}
.mobile-menu.is-open .mobile-menu__link:nth-child(6){transition-delay:.53s}
.mobile-menu__link--cta{color:var(--yellow)}
.mobile-menu__link:active{transform:scale(.97)}
.mobile-menu__foot{position:absolute;left:var(--pad);right:var(--pad);bottom:calc(28px + env(safe-area-inset-bottom));display:flex;justify-content:space-between;align-items:center;color:rgba(255,255,255,.9);font-family:var(--ff-fun);font-weight:600;font-size:.9rem;opacity:0;transition:opacity .5s .6s}
.mobile-menu.is-open .mobile-menu__foot{opacity:1}
.mobile-menu__social{display:flex;gap:10px}
.mobile-menu__social a{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.18);font-weight:800;letter-spacing:.02em}

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;min-height:100vh;min-height:100svh;overflow:hidden;
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(118px,16vh,164px) 0 clamp(50px,9vh,96px);
  background:linear-gradient(168deg,#FFE3F0 0%,#FFDCEE 20%,#FBE9F4 42%,#E8F4FF 76%,#DBEEFF 100%);
}
.hero__inner{position:relative;z-index:2;max-width:var(--wrap);margin-inline:auto;padding-inline:var(--pad);width:100%;display:grid;grid-template-columns:1.06fr .94fr;gap:clamp(28px,4.6vw,76px);align-items:center}
.hero__bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.blob{position:absolute;border-radius:46% 54% 60% 40% / 50% 44% 56% 50%;filter:blur(56px);opacity:.6;will-change:transform}
.blob--1{width:50vw;height:50vw;left:-14vw;top:-14vw;background:radial-gradient(circle at 35% 35%,#FF8FC6,#E91E8B);animation:blobFloat 16s ease-in-out infinite}
.blob--2{width:44vw;height:44vw;right:-16vw;top:2vw;background:radial-gradient(circle at 60% 40%,#9BD2FF,#3FA9F5);animation:blobFloat 20s ease-in-out infinite reverse}
.blob--3{width:38vw;height:38vw;left:28vw;bottom:-22vw;background:radial-gradient(circle at 50% 30%,#FFE39B,#FFD23F);opacity:.45;animation:blobFloat 24s ease-in-out infinite}
@keyframes blobFloat{0%,100%{transform:translate(0,0) rotate(0) scale(1)}33%{transform:translate(4vw,-3vw) rotate(40deg) scale(1.08)}66%{transform:translate(-3vw,3vw) rotate(-30deg) scale(.96)}}
.hero__grain{position:absolute;inset:-50%;opacity:.06;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='0.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");pointer-events:none;mix-blend-mode:overlay}

.floaties{position:absolute;inset:0;z-index:1;pointer-events:none}
.floaty{position:absolute;width:clamp(40px,5vw,68px);height:auto;filter:drop-shadow(0 14px 18px rgba(34,17,44,.16));will-change:transform;animation:floatDrift 9s ease-in-out infinite}
.floaty--pop1{left:7%;top:22%;animation-duration:11s}
.floaty--cone1{right:9%;top:16%;width:clamp(46px,5.5vw,76px);animation-duration:8.5s;animation-delay:-2s}
.floaty--pop2{right:6%;bottom:30%;animation-duration:13s;animation-delay:-4s}
.floaty--sand{left:11%;bottom:34%;width:clamp(54px,6vw,90px);animation-duration:10s;animation-delay:-1s}
.floaty--cone2{left:42%;top:8%;width:clamp(38px,4.4vw,58px);animation-duration:12s;animation-delay:-3s;opacity:.92}
.floaty--star{right:34%;bottom:38%;width:clamp(26px,3vw,42px);animation:floatDrift 7s ease-in-out infinite,spinSlow 14s linear infinite}
@keyframes floatDrift{0%,100%{transform:translateY(0) rotate(-6deg)}50%{transform:translateY(-26px) rotate(8deg)}}
@keyframes spinSlow{to{transform:rotate(360deg)}}

.sprinkle-canvas{position:absolute;inset:0;z-index:1;pointer-events:none}

.hero__content{position:relative;z-index:3;min-width:0}
.hero__eyebrow{font-family:var(--ff-fun);font-weight:600;color:var(--pink-dark);background:rgba(255,255,255,.55);backdrop-filter:blur(6px);display:inline-block;padding:.55em 1.1em;border-radius:999px;font-size:.92rem;margin-bottom:1.3rem;box-shadow:var(--shadow-sm)}
.hero__title{font-family:var(--ff-display);font-weight:400;line-height:.94;letter-spacing:-.012em;color:var(--ink);font-size:clamp(2.4rem,5vw,4.2rem);text-shadow:0 4px 0 rgba(255,255,255,.55);text-wrap:balance}
.hero__title .line{display:block;overflow:hidden;padding-bottom:.06em}
.hero__title .word{display:inline-block;transform:translateY(110%);opacity:0;will-change:transform}
.is-loaded .hero__title .word{transform:translateY(0);opacity:1;transition:transform 1s var(--ease-out),opacity 1s var(--ease-out)}
.hero__title .line:nth-child(1) .word:nth-child(1){transition-delay:.05s}
.hero__title .line:nth-child(1) .word:nth-child(2){transition-delay:.13s}
.hero__title .line:nth-child(1) .word:nth-child(3){transition-delay:.21s}
.hero__title .line:nth-child(2) .word:nth-child(1){transition-delay:.29s}
.hero__title .line:nth-child(2) .word:nth-child(2){transition-delay:.37s}
.hero__title .line:nth-child(3) .word:nth-child(1){transition-delay:.45s}
.hero__title .line:nth-child(3) .word:nth-child(2){transition-delay:.53s}
.hero__title .line:nth-child(3) .word:nth-child(3){transition-delay:.61s}
.word--pink{color:var(--pink)}
.word--drip{color:var(--blue);position:relative}
.word--drip::after{content:"";position:absolute;left:8%;right:8%;bottom:-.06em;height:.16em;background:var(--blue);border-radius:0 0 50% 50%;transform:scaleY(0);transform-origin:top;transition:transform .6s .9s var(--ease-back)}
.is-loaded .word--drip::after{transform:scaleY(1)}
.word--drip::before{content:"";position:absolute;width:.16em;height:0;background:var(--blue);left:30%;bottom:-.06em;border-radius:0 0 60% 60%;transition:height .5s 1.3s var(--ease-out)}
.is-loaded .word--drip::before{height:.34em}

.hero__sub{max-width:42ch;margin:1.4rem 0 1.9rem;font-family:var(--ff-fun);font-weight:500;font-size:clamp(1.05rem,1.5vw,1.32rem);color:var(--ink-soft)}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px}

.hero__showcase{position:relative;z-index:2;min-width:0;display:flex;justify-content:center;pointer-events:none}
.hero__photo-frame{position:relative;width:100%;background:#fff;border-radius:clamp(18px,1.6vw,28px);padding:clamp(7px,.9vw,13px);box-shadow:0 38px 80px rgba(34,17,44,.26),0 0 0 1px rgba(0,0,0,.04) inset;transform:rotate(-1.5deg) translateY(64px);opacity:0;transition:opacity 1s .55s var(--ease-out),transform 1.1s .55s var(--ease-out);will-change:transform}
.is-loaded .hero__photo-frame{opacity:1;transform:rotate(-1.5deg) translateY(0)}
.hero__photo{display:block;width:100%;height:auto;aspect-ratio:1365/1024;object-fit:cover;border-radius:clamp(12px,1.2vw,20px)}
.hero__photo-tag{position:absolute;right:clamp(-12px,-.6vw,-4px);top:clamp(-22px,-2vw,-14px);background:var(--pink);color:#fff;font-family:var(--ff-hand);font-weight:700;font-size:clamp(1.05rem,1.5vw,1.4rem);padding:.3em .95em;border-radius:999px;box-shadow:var(--shadow-md);transform:rotate(7deg);white-space:nowrap;animation:wobble 5s ease-in-out infinite}

/* truck illustrations — still used by the Fleet cards */
.fleet-truck{background-repeat:no-repeat;background-position:center;background-size:contain;filter:drop-shadow(0 18px 24px rgba(34,17,44,.2))}
.fleet-truck--a{background-image:url("truck-pink.svg")}
.fleet-truck--b{background-image:url("truck-blue.svg")}
.fleet-truck--c{background-image:url("truck-duo.svg")}

/* =========================================================
   MARQUEE
   ========================================================= */
.marquee{background:var(--ink);color:var(--cream);overflow:hidden;padding:14px 0;transform:rotate(-1.4deg) scale(1.04);margin:-6px 0 0}
.marquee__track{display:flex;align-items:center;gap:0;white-space:nowrap;width:max-content;animation:marquee 26s linear infinite;font-family:var(--ff-display);font-size:clamp(1.1rem,2.4vw,1.8rem);letter-spacing:.02em}
.marquee__track span{padding:0 .55em;color:var(--cream)}
.marquee__track span:nth-child(4n+1){color:var(--pink-light)}
.marquee__track span:nth-child(4n+3){color:var(--blue-light)}
.marquee__track b{color:var(--yellow);font-size:1.2em;line-height:0}
.marquee:hover .marquee__track{animation-play-state:paused}
@keyframes marquee{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion: reduce){.marquee__track{animation:none}}

/* =========================================================
   ABOUT
   ========================================================= */
.about{background:var(--cream);padding:clamp(80px,12vw,150px) 0;position:relative}
.about__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,6vw,84px);align-items:center}
.about__text h2{margin:.2rem 0 0}
.about__text p{max-width:52ch}
.stats{display:flex;flex-wrap:wrap;gap:clamp(20px,4vw,48px);margin-top:2.4rem}
.stat{display:flex;flex-direction:column;gap:4px}
.stat__num{font-family:var(--ff-display);font-size:clamp(2.6rem,5vw,4rem);line-height:1;color:var(--pink)}
.stat:nth-child(2) .stat__num{color:var(--blue)}
.stat:nth-child(3) .stat__num{color:var(--pink-dark)}
.stat__num--word{font-size:clamp(1.6rem,3.4vw,2.6rem);line-height:1.04}
.stat__label{font-family:var(--ff-fun);font-weight:600;color:var(--ink-soft);font-size:.98rem;letter-spacing:.02em}

.about__visual{position:relative}
.about__photo{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:linear-gradient(155deg,#FFE7F3,#FFDBED 38%,#E6F4FF);box-shadow:var(--shadow-lg);padding:clamp(16px,3.2vw,34px);aspect-ratio:4/3.6}
.about__photo::before{content:"";position:absolute;inset:0;z-index:1;background-image:radial-gradient(circle,rgba(255,255,255,.7) 2px,transparent 2.5px);background-size:26px 26px;opacity:.4;mix-blend-mode:overlay;pointer-events:none}
.about__photo-img{position:relative;z-index:2;display:block;width:100%;height:100%;object-fit:cover;border-radius:clamp(14px,1.6vw,22px);box-shadow:0 16px 38px rgba(34,17,44,.2)}
.about__sticker{position:absolute;z-index:3;font-family:var(--ff-hand);font-weight:700;background:#fff;color:var(--pink);padding:.4em 1em;border-radius:999px;box-shadow:var(--shadow-sm);font-size:clamp(1rem,1.6vw,1.3rem);white-space:nowrap}
.about__sticker--1{top:9%;left:6%;transform:rotate(-9deg);color:var(--pink)}
.about__sticker--2{bottom:11%;right:5%;transform:rotate(7deg);color:var(--blue);animation:wobble 4.5s ease-in-out infinite}
@keyframes wobble{0%,100%{transform:rotate(7deg)}50%{transform:rotate(-4deg) translateY(-4px)}}

/* =========================================================
   THE FLEET (dark showcase)
   ========================================================= */
.fleet{background:radial-gradient(120% 80% at 50% 0%,var(--night-2),var(--night) 70%);color:#fff;padding:clamp(80px,12vw,150px) 0 clamp(90px,14vw,170px);overflow:hidden}
.fleet .section__head{position:relative;z-index:2}
.fleet::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.06) 1.5px,transparent 2px);background-size:30px 30px;opacity:.5}
.fleet__cards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,30px);max-width:var(--wrap);margin-inline:auto;padding-inline:var(--pad);position:relative;z-index:2}
.truck-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;padding:clamp(20px,2.6vw,30px);min-height:clamp(340px,42vw,460px);display:flex;flex-direction:column;justify-content:flex-end;transition:transform .5s var(--ease-back),box-shadow .5s var(--ease-out);will-change:transform}
.truck-card--pink{background:linear-gradient(160deg,#FF8FC6,#E91E8B)}
.truck-card--blue{background:linear-gradient(160deg,#86C9FF,#2F95E0)}
.truck-card--duo{background:linear-gradient(160deg,#FF8FC6 0%,#E91E8B 46%,#3FA9F5 100%)}
.truck-card::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.5) 2px,transparent 2.4px);background-size:24px 24px;opacity:.16;transition:opacity .5s}
.truck-card__media{position:absolute;left:-6%;right:-6%;top:5%;bottom:33%;display:flex;align-items:center;justify-content:center;transform:translateY(var(--parY,0px))}
.truck-card__truck{width:100%;height:100%;background-position:center;transition:transform .6s var(--ease-out)}
.truck-card__shine{position:absolute;inset:0;background:linear-gradient(115deg,transparent 35%,rgba(255,255,255,.45) 50%,transparent 65%);transform:translateX(-120%);transition:transform .9s var(--ease-out)}
.truck-card__body{position:relative;z-index:2;color:#fff}
.truck-card__tag{font-family:var(--ff-fun);font-weight:700;letter-spacing:.2em;text-transform:uppercase;font-size:.78rem;opacity:.85}
.truck-card__name{font-family:var(--ff-display);font-size:clamp(1.7rem,2.6vw,2.4rem);line-height:1;margin:.3rem 0 .4rem;text-shadow:0 4px 0 rgba(0,0,0,.12)}
.truck-card__desc{font-family:var(--ff-fun);font-weight:500;font-size:1.02rem}
.truck-card:hover{transform:translateY(-16px) scale(1.025) rotate(-.6deg);box-shadow:var(--shadow-lg)}
.truck-card:hover .truck-card__truck{transform:scale(1.1) translateY(-6px)}
.truck-card:hover .truck-card__shine{transform:translateX(120%)}
.truck-card:hover::before{opacity:.3}
.truck-card--blue:hover{transform:translateY(-16px) scale(1.025) rotate(.6deg)}

/* =========================================================
   EVENTS
   ========================================================= */
.events{background:var(--cream);padding:clamp(80px,12vw,150px) 0}
.events__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.8vw,22px)}
.event-tile{position:relative;border-radius:26px;padding:clamp(20px,2.4vw,30px);min-height:clamp(190px,15vw,250px);display:flex;flex-direction:column;justify-content:flex-end;gap:.3rem;overflow:hidden;transition:transform .4s var(--ease-back),box-shadow .4s var(--ease-out),background-color .4s;will-change:transform}
.event-tile h3{font-family:var(--ff-display);font-size:clamp(1.15rem,1.6vw,1.5rem);line-height:1.02}
.event-tile p{font-family:var(--ff-fun);font-weight:500;font-size:.92rem;opacity:.9}
.event-tile__icon{position:absolute;top:clamp(14px,2vw,22px);left:clamp(16px,2vw,24px);width:clamp(46px,4.6vw,64px);height:clamp(46px,4.6vw,64px)}
.event-tile__icon svg{width:100%;height:100%;transition:transform .5s var(--ease-back)}
.event-tile--pink{background:#FFE2F1;color:var(--pink-dark)}
.event-tile--pink .event-tile__icon{color:var(--pink)}
.event-tile--blue{background:#E1F2FF;color:var(--blue-dark)}
.event-tile--blue .event-tile__icon{color:var(--blue)}
.event-tile--cream{background:var(--cream-deep);color:#9A6B2C}
.event-tile--cream .event-tile__icon{color:#E0A23A}
.event-tile::after{content:"";position:absolute;inset:0;background-image:radial-gradient(circle,currentColor 1.6px,transparent 2px);background-size:22px 22px;opacity:.07}
.event-tile:hover{transform:translateY(-12px) scale(1.03);box-shadow:var(--shadow-md)}
.event-tile--pink:hover{background:var(--pink);color:#fff}
.event-tile--pink:hover .event-tile__icon,.event-tile--blue:hover .event-tile__icon,.event-tile--cream:hover .event-tile__icon{color:#fff}
.event-tile--blue:hover{background:var(--blue);color:#fff}
.event-tile--cream:hover{background:var(--yellow);color:#7a4d12}
.event-tile--cream:hover .event-tile__icon{color:#7a4d12}
.event-tile:hover .event-tile__icon svg{transform:rotate(-12deg) scale(1.16)}

/* =========================================================
   HOW IT WORKS
   ========================================================= */
.how{background:radial-gradient(120% 90% at 50% 10%,var(--night-2),var(--night) 75%);color:#fff;padding:clamp(80px,12vw,150px) 0;overflow:hidden}
.how::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.05) 1.5px,transparent 2px);background-size:34px 34px}
.how__steps{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,4vw,56px);max-width:980px;margin:0 auto}
.how__line{position:absolute;left:8%;right:8%;top:54px;height:4px;border-radius:4px;background:rgba(255,255,255,.12);overflow:hidden}
.how__line span{display:block;height:100%;width:0%;background:linear-gradient(90deg,var(--pink),var(--yellow),var(--blue));border-radius:4px}
.step{position:relative;text-align:center;padding-top:8px}
.step__num{font-family:var(--ff-display);font-size:clamp(3.4rem,7vw,5.6rem);line-height:.9;display:inline-block;background:linear-gradient(160deg,var(--pink-light),var(--pink));-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:none;filter:drop-shadow(0 8px 20px rgba(233,30,139,.4))}
.step:nth-child(3) .step__num{background:linear-gradient(160deg,var(--yellow),#F5A623);-webkit-background-clip:text;background-clip:text;color:transparent}
.step:nth-child(4) .step__num{background:linear-gradient(160deg,var(--blue-light),var(--blue));-webkit-background-clip:text;background-clip:text;color:transparent}
.step__title{font-family:var(--ff-display);font-size:clamp(1.4rem,2.4vw,2rem);margin:.4rem 0 .5rem}
.step__desc{font-family:var(--ff-fun);font-weight:500;color:rgba(255,255,255,.8);max-width:24ch;margin-inline:auto}
.step__emoji{position:absolute;top:-6px;right:18%;font-size:clamp(1.6rem,3vw,2.4rem);transform:rotate(10deg);filter:drop-shadow(0 6px 10px rgba(0,0,0,.3))}
.how__cta{text-align:center;margin-top:clamp(40px,6vw,64px)}

/* =========================================================
   GALLERY
   ========================================================= */
.gallery{background:var(--cream);padding:clamp(80px,12vw,150px) 0}
.gallery__grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:clamp(150px,15vw,210px);gap:clamp(12px,1.6vw,20px);grid-auto-flow:row dense}
.gtile{position:relative;border-radius:24px;overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .5s var(--ease-back),box-shadow .5s var(--ease-out);will-change:transform}
.gtile--tall{grid-row:span 2}
.gtile--wide{grid-column:span 2}
.gtile__art{position:absolute;inset:0;transition:transform .7s var(--ease-out)}
img.gtile__art{width:100%;height:100%;object-fit:cover}
.gtile__art::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.55) 1.6px,transparent 2px);background-size:20px 20px;opacity:.4;mix-blend-mode:soft-light}
.gtile__art::after{position:absolute;inset:0;display:grid;place-items:center;font-size:clamp(3rem,7vw,5.4rem);filter:drop-shadow(0 8px 14px rgba(0,0,0,.18))}
.gtile figcaption{position:absolute;left:0;right:0;bottom:0;padding:1.4em 1em .9em;font-family:var(--ff-hand);font-weight:700;font-size:clamp(1rem,1.5vw,1.3rem);color:#fff;background:linear-gradient(0deg,rgba(20,10,30,.55),transparent);transform:translateY(20%);opacity:0;transition:opacity .4s,transform .4s var(--ease-out)}
.gtile:hover{transform:translateY(-8px) scale(1.02);box-shadow:var(--shadow-lg);z-index:2}
.gtile:hover .gtile__art{transform:scale(1.12)}
.gtile:hover figcaption{opacity:1;transform:none}
/* art compositions */
.gart-truck-park{background:linear-gradient(165deg,#9BD2FF,#3FA9F5 60%,#7BC47A 60.1%)}
.gart-truck-park::after{content:"\1F69A"}
.gart-pops{background:linear-gradient(155deg,#FFB3D7,#E91E8B)}
.gart-pops::after{content:"🍡"}
.gart-balloons{background:linear-gradient(155deg,#FFE39B,#FFC34D)}
.gart-balloons::after{content:"🎈"}
.gart-lineup{background:linear-gradient(120deg,#FF8FC6,#E91E8B 38%,#3FA9F5 100%)}
.gart-lineup::after{content:"🍦🍦🍦";letter-spacing:-.1em}
.gart-drumstick{background:linear-gradient(155deg,#FFDCA8,#E0A23A)}
.gart-drumstick::after{content:"🍦"}
.gart-blue-event{background:linear-gradient(165deg,#A9DBFF,#1E7FC8)}
.gart-blue-event::after{content:"🍨"}
.gart-sandwich{background:linear-gradient(155deg,#E7CFA7,#9A6B2C)}
.gart-sandwich::after{content:"🍪"}
.gart-confetti{background:linear-gradient(135deg,#FFB3D7,#FFD23F 50%,#7CC6FF)}
.gart-confetti::after{content:"🎉"}
.gallery__note{text-align:center;margin-top:clamp(28px,4vw,44px);font-family:var(--ff-fun);font-weight:600;color:var(--ink-soft)}
.gallery__note a{color:var(--pink);text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px}

/* =========================================================
   BOOKING
   ========================================================= */
.book{position:relative;overflow:hidden;padding:clamp(80px,12vw,150px) 0 clamp(90px,12vw,150px);background:linear-gradient(150deg,#FF6FB5 0%,#E91E8B 40%,#3FA9F5 110%);color:#fff}
.book__bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.book__bg .blob{opacity:.4;mix-blend-mode:overlay}
.blob--b1{width:50vw;height:50vw;left:-16vw;bottom:-20vw;background:radial-gradient(circle at 40% 40%,#fff,#FFD23F);animation:blobFloat 22s ease-in-out infinite}
.blob--b2{width:40vw;height:40vw;right:-14vw;top:-16vw;background:radial-gradient(circle at 60% 40%,#fff,#7CC6FF);animation:blobFloat 18s ease-in-out infinite reverse}
.confetti-canvas{position:absolute;inset:0;z-index:5;pointer-events:none}
.book__wrap{position:relative;z-index:2}
.section__head--book .kicker--light{}

.book__form{max-width:720px;margin:0 auto;background:rgba(255,255,255,.96);backdrop-filter:blur(10px);border-radius:var(--radius-lg);padding:clamp(24px,4.6vw,52px);box-shadow:var(--shadow-lg);color:var(--ink)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(14px,2.2vw,22px)}
.field-row>*{min-width:0}
.field{position:relative;margin-bottom:clamp(16px,2.4vw,24px);min-width:0}
.field input,.field select,.field textarea{
  width:100%;padding:1.4em 1.1em .7em;border:2.5px solid #EADFEC;border-radius:18px;background:#FFF8FC;
  font-family:var(--ff-fun);font-weight:600;font-size:1.02rem;color:var(--ink);
  transition:border-color .3s,box-shadow .3s,transform .3s var(--ease-out),background .3s;outline:none;
}
.field textarea{resize:vertical;min-height:120px}
.field select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23E91E8B' stroke-width='3' stroke-linecap='round'%3E%3Cpath d='M3 6l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1.1em center;padding-right:2.6em}
.field input::placeholder,.field textarea::placeholder{color:transparent}
.field label{position:absolute;left:1.15em;top:1.05em;font-family:var(--ff-fun);font-weight:600;color:#9B8AA0;pointer-events:none;transition:transform .25s var(--ease-out),color .25s,font-size .25s;transform-origin:left}
.field label i{color:var(--pink);font-style:normal}
.field label em{font-style:normal;opacity:.65;font-size:.9em}
.field input:focus,.field select:focus,.field textarea:focus,
.field input:not(:placeholder-shown),.field textarea:not(:placeholder-shown),
.field.is-filled select{border-color:var(--pink);background:#fff;box-shadow:0 0 0 5px rgba(233,30,139,.12)}
.field input:focus,.field select:focus,.field textarea:focus{transform:translateY(-2px)}
.field input:focus + label,.field select:focus + label,.field textarea:focus + label,
.field input:not(:placeholder-shown) + label,.field textarea:not(:placeholder-shown) + label,
.field.is-filled select + label,
.field input[type="date"] + label,.field input[type="time"] + label{
  transform:translateY(-.75em) scale(.74);color:var(--pink)
}
.field__bar{position:absolute;left:18px;right:18px;bottom:0;height:3px;background:var(--pink);border-radius:3px;transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease-out)}
.field input:focus ~ .field__bar,.field select:focus ~ .field__bar,.field textarea:focus ~ .field__bar{transform:scaleX(1)}
.field.has-error input,.field.has-error select,.field.has-error textarea{border-color:var(--red);box-shadow:0 0 0 5px rgba(230,57,70,.14);animation:shakeX .4s}
@keyframes shakeX{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-7px)}40%,80%{transform:translateX(7px)}}

.field--radio{border:none;padding:0}
.field--radio legend{font-family:var(--ff-fun);font-weight:600;color:#9B8AA0;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;margin:0 0 .5em 2px}
.radio-pills{display:flex;gap:8px;flex-wrap:wrap}
.radio-pills label{position:relative;cursor:pointer}
.radio-pills input{position:absolute;opacity:0;inset:0}
.radio-pills span{display:inline-flex;align-items:center;justify-content:center;padding:.65em 1em;border:2.5px solid #EADFEC;border-radius:14px;background:#FFF8FC;font-family:var(--ff-fun);font-weight:700;font-size:.96rem;color:var(--ink-soft);transition:all .25s var(--ease-back)}
.radio-pills input:hover + span{border-color:var(--pink-light)}
.radio-pills input:checked + span{background:var(--pink);border-color:var(--pink);color:#fff;transform:translateY(-2px) scale(1.04);box-shadow:0 8px 20px rgba(233,30,139,.3)}
.radio-pills input:focus-visible + span{outline:3px solid var(--blue);outline-offset:2px}

.btn--submit{width:100%;margin-top:1rem;font-size:1.2rem;padding:1.15em 1.6em;background:var(--pink);color:#fff;box-shadow:var(--shadow-pink)}
.btn--submit:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 30px 64px rgba(233,30,139,.45)}
.btn--submit.is-loading{pointer-events:none;opacity:.85}
.btn--submit.is-loading .btn__label::after{content:"";display:inline-block;width:1em;height:1em;margin-left:.5em;border:3px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spinSlow .7s linear infinite;vertical-align:-.15em}
.book__alt{text-align:center;margin-top:1.4rem;font-family:var(--ff-fun);font-weight:600;color:var(--ink-soft)}
.book__alt a{color:var(--pink);text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px}
.book__err{text-align:center;margin-top:1rem;color:var(--red);font-weight:700;font-family:var(--ff-fun)}

.book__success{max-width:620px;margin:0 auto;text-align:center;background:rgba(255,255,255,.97);border-radius:var(--radius-lg);padding:clamp(36px,6vw,64px);box-shadow:var(--shadow-lg);color:var(--ink)}
.book__success[hidden]{display:none}
.book__success-cone{width:clamp(90px,12vw,130px);margin:0 auto 1.2rem;animation:coneWobble 1.8s var(--ease-back) infinite}
.book__success-cone svg{overflow:visible}
.book__success h3{font-family:var(--ff-display);font-size:clamp(1.8rem,3.4vw,2.6rem);color:var(--pink);margin-bottom:.5rem}
.book__success p{font-family:var(--ff-fun);font-weight:500;color:var(--ink-soft);max-width:36ch;margin:0 auto 1.6rem}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{position:relative;background:var(--pink);color:#fff;padding-top:0}
.footer__drip{line-height:0}
.footer__drip svg{width:100%;height:clamp(36px,5vw,60px);display:block;transform:translateY(-1px)}
.footer__inner{display:grid;grid-template-columns:1.4fr .8fr 1fr;gap:clamp(28px,5vw,64px);padding-top:clamp(40px,7vw,80px);padding-bottom:clamp(36px,6vw,64px)}
.footer__col h4{font-family:var(--ff-display);font-size:1.2rem;margin-bottom:.9rem;color:var(--yellow)}
.brand--footer{margin-bottom:1rem}
.footer__tag{font-family:var(--ff-hand);font-weight:700;font-size:1.4rem;margin-bottom:.6rem}
.footer__loc{font-family:var(--ff-fun);font-weight:500;font-size:.96rem;color:rgba(255,255,255,.86);max-width:42ch}
.footer__col--links a{display:block;font-family:var(--ff-fun);font-weight:600;padding:.32em 0;width:fit-content;position:relative}
.footer__col--links a::after{content:"";position:absolute;left:0;right:100%;bottom:.18em;height:2px;background:var(--yellow);transition:right .3s var(--ease-out)}
.footer__col--links a:hover::after{right:0}
.footer__col--links a:hover{color:var(--yellow)}
.footer__email,.footer__phone{display:block;font-family:var(--ff-fun);font-weight:700;margin-bottom:.5rem;word-break:break-word}
.footer__email:hover{color:var(--yellow)}
.footer__phone{opacity:.75;cursor:default}
.footer__social{display:flex;gap:12px;margin-top:1rem}
.footer__social a{width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.16);display:grid;place-items:center;transition:transform .4s var(--ease-back),background .3s,color .3s}
.footer__social a svg{width:24px;height:24px}
.footer__social a:hover{transform:rotate(-12deg) scale(1.16);background:#fff;color:var(--pink)}
.footer__social a:nth-child(2):hover{transform:rotate(12deg) scale(1.16);color:var(--blue)}
.footer__bar{border-top:1px solid rgba(255,255,255,.2);padding:1.2rem var(--pad);max-width:none}
.footer__bar{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;font-family:var(--ff-fun);font-weight:600;font-size:.88rem;color:rgba(255,255,255,.88);max-width:var(--wrap);margin-inline:auto}
.footer__byline a{text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px}
.footer__byline a:hover{color:var(--yellow)}
.heart{display:inline-block;animation:beat 1.4s ease-in-out infinite}
@keyframes beat{0%,100%{transform:scale(1)}25%{transform:scale(1.25)}40%{transform:scale(1)}}

/* ----------  BACK TO TOP  ---------- */
.to-top{position:fixed;right:clamp(16px,3vw,30px);bottom:clamp(16px,3vw,30px);z-index:900;width:54px;height:54px;border-radius:50%;background:var(--pink);color:#fff;display:grid;place-items:center;box-shadow:var(--shadow-pink);opacity:0;transform:translateY(20px) scale(.8);pointer-events:none;transition:opacity .4s,transform .4s var(--ease-back),background .3s}
.to-top svg{width:24px;height:24px}
.to-top.is-visible{opacity:1;transform:none;pointer-events:auto}
.to-top:hover{transform:translateY(-4px) scale(1.08) rotate(-8deg);background:var(--pink-dark)}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1080px){
  .events__grid{grid-template-columns:repeat(2,1fr)}
  .gallery__grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:900px){
  .nav__links,.nav .btn--book{display:none}
  .nav__burger{display:flex}
  .hero{padding:clamp(96px,13vh,124px) 0 clamp(40px,7vh,76px)}
  .hero__inner{grid-template-columns:1fr;gap:clamp(28px,5vw,46px)}
  .hero__showcase{max-width:600px;margin-inline:auto;width:100%}
  .hero__sub{max-width:50ch}
  .about__grid{grid-template-columns:1fr;gap:48px}
  .about__visual{order:-1;max-width:560px;margin-inline:auto;width:100%}
  .fleet__cards{grid-template-columns:1fr;max-width:520px}
  .truck-card{min-height:380px}
  .how__steps{grid-template-columns:1fr;gap:40px;max-width:460px}
  .how__line{display:none}
  .step__emoji{right:30%}
  .footer__inner{grid-template-columns:1fr 1fr}
  .footer__col--brand{grid-column:1/-1}
}
@media (max-width:680px){
  :root{--radius-lg:30px}
  .hero{padding:clamp(84px,11vh,108px) 0 clamp(34px,6vh,60px)}
  .hero__sub{margin:1.1rem 0 1.6rem}
  .hero__photo-frame,.is-loaded .hero__photo-frame{transform:rotate(-1.2deg) translateY(0)}
  .hero__photo-tag{font-size:1rem;right:4px;top:-13px}
  .nav__inner{gap:10px}
  .events__grid{grid-template-columns:1fr 1fr;gap:12px}
  .event-tile{min-height:170px}
  .gallery__grid{grid-template-columns:1fr 1fr;grid-auto-rows:clamp(130px,40vw,170px)}
  .gtile--tall{grid-row:auto}
  .gtile--wide{grid-column:span 2}
  .field-row{grid-template-columns:1fr;gap:0}
  .footer__inner{grid-template-columns:1fr}
  .footer__bar{justify-content:center;text-align:center}
  .marquee{transform:rotate(-2deg) scale(1.06)}
}
@media (max-width:430px){
  .events__grid{grid-template-columns:1fr}
  .hero__title{font-size:clamp(2.2rem,10.5vw,3rem)}
  .h-display{font-size:clamp(2.1rem,9vw,3rem)}
}

/* Hover-capable refinements only on devices that actually hover */
@media (hover:none){
  .btn:hover,.truck-card:hover,.event-tile:hover,.gtile:hover{transform:none}
  .truck-card:active{transform:scale(.99)}
  .gtile figcaption{opacity:1;transform:none;background:linear-gradient(0deg,rgba(20,10,30,.5),transparent)}
}
