/* ============ SO STONED — calm energy ============ */
:root{
  --black:#000000;
  --ink:#070807;
  --char:#101210;
  --panel:#141714;
  --line:rgba(80,222,55,.10);
  --line-soft:rgba(255,255,255,.07);
  --fog:#8b938a;
  --smoke:#cdd4cb;
  --white:#eef2ec;
  --green:#33e02d;
  --green-soft:#26b81a;
  --green-deep:#07160a;
  --warm:#f5c23a;
  --ease:cubic-bezier(.16,1,.3,1);
  --pad:clamp(20px,5vw,84px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--black);
  color:var(--white);
  font-family:"Play",system-ui,sans-serif;
  font-weight:400;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  /* clip (not hidden): contains horizontal overflow WITHOUT making <body> a
     scroll container — otherwise Safari breaks position:sticky on the hero stage
     (overflow-x:hidden forces overflow-y:auto, so the hero scrub never pins). */
  overflow-x:clip;
  cursor:default;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--green);color:#000}

/* radioactive scrollbar */
::-webkit-scrollbar{width:9px}
::-webkit-scrollbar-track{background:var(--ink)}
::-webkit-scrollbar-thumb{background:var(--green-deep);border-radius:0}
::-webkit-scrollbar-thumb:hover{background:var(--green-soft)}

/* ---------- shared type ---------- */
.eyebrow{
  font-family:"Play",sans-serif;
  font-size:clamp(11px,1vw,13px);
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--green);
  display:inline-block;
}
.eyebrow--warm{color:var(--warm)}
.m-br{display:none}

h1,h2,h3{
  font-family:"Anton",sans-serif;
  font-weight:400;
  text-transform:uppercase;
  line-height:.86;
  letter-spacing:-.01em;
}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(34px);
  transition:opacity 1s var(--ease) var(--d,0s),transform 1s var(--ease) var(--d,0s);
  will-change:opacity,transform}
.reveal.in{opacity:1;transform:none}

/* ---------- grain ---------- */
.grain{
  position:fixed;inset:-50%;z-index:9000;pointer-events:none;opacity:.05;
  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='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 6s steps(6) infinite;
}
@keyframes grain{
  0%{transform:translate(0,0)}20%{transform:translate(-6%,4%)}40%{transform:translate(4%,-6%)}
  60%{transform:translate(-4%,2%)}80%{transform:translate(6%,-2%)}100%{transform:translate(0,0)}
}

/* ---------- cursor glow ---------- */
.cursor-glow{
  position:fixed;top:0;left:0;width:520px;height:520px;z-index:1;pointer-events:none;
  margin:-260px 0 0 -260px;border-radius:50%;
  background:radial-gradient(circle,rgba(51,224,45,.10),transparent 62%);
  transform:translate3d(-1000px,-1000px,0);transition:opacity .4s;mix-blend-mode:screen;
}
@media(hover:none){.cursor-glow{display:none}}

/* ---------- loader ---------- */
.loader{
  position:fixed;inset:0;z-index:9999;background:var(--black);overflow:hidden;
  display:grid;place-items:center;transition:opacity .8s var(--ease),visibility .8s;
}
.loader.done{opacity:0;visibility:hidden;pointer-events:none;display:none}
/* repeat-visit / reduced-motion: hide before first paint so the loader never flashes */
html.skip-loader .loader{display:none}
/* glitch-wipe (signal-cut) exit */
.loader.off{animation:loaderOff .62s cubic-bezier(.7,0,.2,1) forwards}
@keyframes loaderOff{
  0%{clip-path:inset(0 0 0 0);opacity:1;filter:none;transform:translateX(0)}
  18%{filter:contrast(1.5) brightness(1.4) saturate(1.3);transform:translateX(-4px)}
  24%{transform:translateX(5px)}
  30%{transform:translateX(0);filter:none}
  62%{clip-path:inset(0 0 0 0);opacity:1}
  100%{clip-path:inset(50% 0 50% 0);opacity:0;filter:brightness(1.6)}
}
.loader__glow{
  position:absolute;top:50%;left:50%;width:min(86vw,680px);aspect-ratio:1;
  transform:translate(-50%,-50%);pointer-events:none;
  background:radial-gradient(circle,rgba(51,224,45,.12),transparent 60%);filter:blur(24px);
  animation:logopulse 5s ease-in-out infinite;
}
@keyframes logopulse{0%,100%{opacity:.05}50%{opacity:.12}}
.loader__inner{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center}
/* small rotating can above the boot terminal */
.loader__can{
  width:clamp(170px,44vw,230px);height:auto;display:block;margin:0 auto 6px;
  -webkit-mask:radial-gradient(64% 66% at 50% 46%,#000 26%,transparent 86%);
  mask:radial-gradient(64% 66% at 50% 46%,#000 26%,transparent 86%);
}
.loader__term{
  font-family:"Play",sans-serif;font-size:clamp(13px,1.5vw,16px);
  color:var(--green);letter-spacing:.04em;line-height:1.9;text-shadow:0 0 18px rgba(51,224,45,.4);
  white-space:pre;text-align:left;
  /* fixed box so the lines fill top-down instead of re-centering / jumping */
  width:min(80vw,300px);min-height:9.5em;
}
/* preload progress — segmented cell blocks */
.loader__cells{display:flex;gap:3px;width:min(80vw,300px);margin-top:18px}
.loader__cells i{
  flex:1;height:11px;background:rgba(51,224,45,.10);
  border:1px solid rgba(51,224,45,.16);
  transition:background .18s var(--ease),box-shadow .18s var(--ease),border-color .18s var(--ease);
}
.loader__cells i.on{background:var(--green);border-color:var(--green);box-shadow:0 0 9px rgba(51,224,45,.75)}
.loader__pct{margin-top:12px;font-family:"Play",sans-serif;font-size:11px;letter-spacing:.34em;color:var(--fog)}
/* glitch "power-on" finale */
.loader__term.boom{animation:bootBoom .5s steps(1) 2}
@keyframes bootBoom{
  0%{text-shadow:0 0 18px rgba(51,224,45,.4);transform:translate(0,0)}
  15%{text-shadow:-3px 0 rgba(255,46,136,.9),3px 0 rgba(24,216,255,.9),0 0 30px rgba(51,224,45,.8);transform:translate(-2px,1px) skewX(-3deg)}
  30%{text-shadow:3px 0 rgba(255,46,136,.85),-3px 0 rgba(24,216,255,.85);transform:translate(2px,-1px) skewX(3deg)}
  50%{transform:translate(0,0);text-shadow:0 0 42px rgba(51,224,45,1)}
  100%{text-shadow:0 0 18px rgba(51,224,45,.4);transform:translate(0,0)}
}
.loader__logo.boom{animation:logoBoom .5s ease-out 1 forwards}
@keyframes logoBoom{0%{opacity:.1}40%{opacity:.55}100%{opacity:.12}}

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--pad);
  transition:background .5s var(--ease),backdrop-filter .5s,padding .5s var(--ease),border-color .5s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(5,6,5,.72);backdrop-filter:blur(14px);
  padding-top:13px;padding-bottom:13px;border-color:var(--line-soft);
}
.nav__brand img{height:22px;width:auto;
  filter:brightness(0) saturate(100%) invert(82%) sepia(64%) saturate(1352%) hue-rotate(36deg) brightness(112%) contrast(108%);}
.nav__links{display:flex;gap:clamp(16px,2.4vw,40px)}
.nav__links a{
  font-family:"Play",sans-serif;font-weight:700;font-size:14px;letter-spacing:.14em;
  color:var(--smoke);position:relative;padding:4px 0;transition:color .3s;
}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--green);transition:width .35s var(--ease)}
.nav__links a:hover{color:var(--green)}
.nav__links a:hover::after{width:100%}
.nav__right{display:flex;align-items:center;gap:12px}
/* language switcher (CZ / EN) */
.lang{display:inline-flex;align-items:center;gap:7px;font-family:"Play",sans-serif;font-size:12px;letter-spacing:.12em;font-weight:700}
.lang__btn{background:none;border:0;padding:4px 2px;cursor:pointer;color:var(--fog);letter-spacing:.12em;font:inherit;transition:color .25s var(--ease)}
.lang__btn:hover{color:var(--smoke)}
.lang__btn.is-active{color:var(--green)}
.lang__sep{color:var(--line);font-weight:400}
.nav__burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:40px;padding:0 11px;background:transparent;border:1px solid var(--line-soft);cursor:pointer;transition:.3s}
.nav__burger span{display:block;height:2px;width:100%;background:var(--white);transition:transform .3s var(--ease),opacity .2s}
.nav__burger:hover{border-color:var(--green)}
.nav__burger:hover span{background:var(--green)}
.nav__burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__burger.open span:nth-child(2){opacity:0}
.nav__burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav__cart{
  font-family:"Play",sans-serif;font-size:12px;letter-spacing:.18em;
  color:var(--white);background:transparent;border:1px solid var(--line-soft);
  padding:9px 16px;cursor:pointer;display:flex;gap:8px;align-items:center;transition:.3s;
}
.nav__cart:hover{border-color:var(--green);color:var(--green)}
.nav__cart-icon{width:17px;height:17px;display:block;flex:0 0 auto}
.nav__cart:hover .nav__cart-icon{animation:cartNudge .5s var(--ease)}
@keyframes cartNudge{30%{transform:translateY(-2px) rotate(-6deg)}60%{transform:translateY(0) rotate(3deg)}100%{transform:none}}
.nav__cart-count{
  background:var(--green);color:#000;font-weight:700;min-width:18px;height:18px;
  display:grid;place-items:center;border-radius:50%;font-size:11px;transition:transform .3s var(--ease);
}
.nav__cart-count.pop{transform:scale(1.5)}

/* ---------- buttons ---------- */
.btn{
  font-family:"Play",sans-serif;font-weight:700;font-size:13px;letter-spacing:.1em;text-transform:uppercase;
  padding:15px 26px;display:inline-flex;align-items:center;gap:10px;cursor:pointer;
  border:1px solid var(--green);transition:.35s var(--ease);
}
.btn--solid{background:var(--green);color:#000;font-weight:700}
.btn--solid:hover{background:#5cee48;box-shadow:0 0 34px rgba(51,224,45,.45);transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--white);border-color:var(--line-soft)}
.btn--ghost:hover{border-color:var(--green);color:var(--green)}
.btn--full{width:100%;justify-content:center}

/* hero CTA — equal width, larger, more polished */
.hero__cta{gap:16px;margin-top:42px;max-width:560px}
.hero__cta .btn{
  flex:1 1 0;min-width:208px;justify-content:center;
  font-size:14px;letter-spacing:.13em;padding:20px 28px;
  position:relative;overflow:hidden;z-index:0;
}
.hero__cta .btn::after{
  content:"→";font-size:15px;line-height:1;
  transition:transform .35s var(--ease);
}
.hero__cta .btn:hover::after{transform:translateX(5px)}
/* solid: brighter, lifts higher, stronger glow */
.hero__cta .btn--solid:hover{
  background:#5cee48;box-shadow:0 12px 40px rgba(51,224,45,.5);transform:translateY(-3px);
}
/* ghost: green sweeps in from the left on hover, text flips to black */
.hero__cta .btn--ghost{color:var(--white);border-color:var(--line-soft)}
.hero__cta .btn--ghost::before{
  content:"";position:absolute;inset:0;background:var(--green);
  transform:translateX(-101%);transition:transform .42s var(--ease);z-index:-1;
}
.hero__cta .btn--ghost:hover{color:#000;border-color:var(--green)}
.hero__cta .btn--ghost:hover::before{transform:translateX(0)}

/* =================== HERO =================== */
.hero{
  position:relative;min-height:100svh;
}
.hero__sticky{
  position:relative;min-height:100svh;height:100svh;
  display:flex;align-items:center;
  padding:0 var(--pad);overflow:hidden;
}
/* scroll-scrub mode: tall section + pinned stage */
.hero--scrub{height:175vh;min-height:0}
.hero--scrub .hero__sticky{position:sticky;top:0}
.hero__media{position:absolute;inset:0;z-index:0;overflow:hidden;background:#000}
.hero__video{
  position:absolute;inset:0;z-index:0;
  width:100%;height:100%;object-fit:cover;object-position:center;
  will-change:opacity;transition:opacity .3s ease;
}
.hero__canvas{
  position:absolute;inset:0;z-index:1;
  width:100%;height:100%;display:block;
  opacity:0;will-change:opacity;transition:opacity .3s ease;
}
.hero__veil{z-index:2}
.hero__veil{
  position:absolute;inset:0;
  background:
    linear-gradient(90deg,rgba(0,0,0,.92) 0%,rgba(0,0,0,.7) 32%,rgba(0,0,0,.24) 62%,rgba(0,0,0,.28) 100%),
    linear-gradient(0deg,rgba(0,0,0,.85) 0%,transparent 34%),
    radial-gradient(120% 90% at 50% 40%,transparent 55%,rgba(0,0,0,.6) 100%);
}
/* ---------- hero animated vector FX (scattered geometric shapes) ---------- */
.hero__fx{position:absolute;inset:0;z-index:3;pointer-events:none;color:var(--green);overflow:hidden}
.fx-shape{
  position:absolute;display:block;
  width:var(--s,15px);height:var(--s,15px);opacity:var(--o,.2);
  animation:fxFloat var(--dur,10s) ease-in-out infinite;animation-delay:var(--delay,0s);
}
.fx-shape svg{
  width:100%;height:100%;display:block;
  transform-box:fill-box;transform-origin:center;
  animation:fxSpin var(--spin,44s) linear infinite;animation-delay:var(--delay,0s);
}
/* motion variants (element) */
.fx-shape--drift{animation-name:fxDrift}
.fx-shape--orbit{animation-name:fxOrbit;animation-timing-function:linear}
.fx-shape--bob{animation-name:fxBob}
.fx-shape--twinkle{animation-name:fxTwinkle}
/* spin direction (svg) */
.fx-shape--rev svg{animation-direction:reverse}
/* energy tracing the outline (stroke draw) */
.fx-shape--draw svg path,.fx-shape--draw svg rect{
  stroke-dasharray:72;
  animation:fxDraw var(--dur,10s) ease-in-out infinite;animation-delay:var(--delay,0s);
  filter:drop-shadow(0 0 4px rgba(51,224,45,.55));
}
@keyframes fxFloat{0%,100%{transform:translateY(-9px)}50%{transform:translateY(11px)}}
@keyframes fxDrift{0%,100%{transform:translate(-7px,6px)}50%{transform:translate(8px,-8px)}}
@keyframes fxOrbit{0%,100%{transform:translate(0,0)}25%{transform:translate(11px,-6px)}50%{transform:translate(0,-13px)}75%{transform:translate(-11px,-6px)}}
@keyframes fxBob{0%,100%{transform:translateY(-7px);opacity:calc(var(--o,.2)*.55)}50%{transform:translateY(9px);opacity:var(--o,.2)}}
@keyframes fxTwinkle{0%,100%{transform:scale(.78);opacity:calc(var(--o,.2)*.4)}50%{transform:scale(1.18);opacity:var(--o,.2)}}
@keyframes fxSpin{to{transform:rotate(360deg)}}
@keyframes fxDraw{0%{stroke-dashoffset:72}50%{stroke-dashoffset:0}100%{stroke-dashoffset:-72}}

.hero__aside{
  position:absolute;right:clamp(12px,2.4vw,30px);top:50%;transform:translateY(-50%);
  z-index:3;display:flex;flex-direction:column;align-items:center;gap:16px;pointer-events:none;
}
.hero__aside-text{
  writing-mode:vertical-rl;font-family:"Play",sans-serif;font-size:12px;
  letter-spacing:.52em;text-transform:uppercase;color:var(--white);opacity:.92;
  text-shadow:0 0 14px rgba(0,0,0,.55);
}
.hero__aside-line{
  width:1px;height:clamp(42px,9vh,96px);
  background:linear-gradient(var(--green),rgba(51,224,45,0));
}
.hero__aside-dot{
  width:5px;height:5px;border-radius:50%;background:var(--green);
  box-shadow:0 0 12px var(--green);animation:hudPulse 2.6s ease-in-out infinite;
}
.hero__status{
  position:absolute;left:clamp(14px,3vw,46px);bottom:34px;z-index:4;
  display:flex;align-items:center;gap:9px;
  font-family:"Play",sans-serif;font-size:11px;letter-spacing:.28em;
  text-transform:uppercase;color:var(--fog);opacity:.72;
}
.hero__status i{
  width:7px;height:7px;border-radius:50%;background:var(--green);
  box-shadow:0 0 12px var(--green);animation:hudPulse 2.6s ease-in-out infinite;
}
@keyframes hudPulse{0%,100%{opacity:.4;transform:scale(.8)}50%{opacity:1;transform:scale(1.18)}}
.hero__copy{position:relative;z-index:4;max-width:min(60vw,760px);padding-left:clamp(14px,3vw,46px)}
.hero__title{
  font-size:clamp(64px,15vw,230px);margin:18px 0 0 -4px;color:var(--white);
  text-shadow:0 6px 50px rgba(0,0,0,.6);
}
.hero__title span{display:block}
.hero__title span.hero__title-accent{display:inline-block}
/* ENERGY — glitch effect: the word sits clean & solid green most of the time,
   then bursts into a quick RGB-split + sliced-offset glitch with speed lines
   shooting across. Reads as raw energy, not a soft glow. Bursts are short and
   spaced out so it never looks like a permanently broken/dirty letterform. */
.hero__title-accent{
  position:relative;display:inline-block;
  color:var(--green);
  text-shadow:0 0 26px rgba(51,224,45,.4);
  animation:energyGlitch 4.6s steps(1) infinite;
}
.hero__title-accent::before,
.hero__title-accent::after{
  content:attr(data-text);
  position:absolute;left:0;top:0;width:100%;height:100%;
  pointer-events:none;text-shadow:none;opacity:0;
  mix-blend-mode:screen;
}
.hero__title-accent::before{color:#18d8ff;animation:energyGhostA 4.6s steps(1) infinite}
.hero__title-accent::after{color:#ff2e88;animation:energyGhostB 4.6s steps(1) infinite}

/* chromatic shimmer on the solid word during the bursts */
@keyframes energyGlitch{
  0%,7%,12%,52%,57%,100%{transform:translate3d(0,0,0);text-shadow:0 0 26px rgba(51,224,45,.4)}
  8%{transform:translate3d(-2px,1px,0);text-shadow:-3px 0 rgba(24,216,255,.85),3px 0 rgba(255,46,136,.85),0 0 30px rgba(51,224,45,.6)}
  9%{transform:translate3d(2px,-1px,0);text-shadow:3px 0 rgba(24,216,255,.8),-3px 0 rgba(255,46,136,.8),0 0 30px rgba(51,224,45,.6)}
  10%{transform:translate3d(-1px,0,0);text-shadow:-2px 0 rgba(24,216,255,.7),2px 0 rgba(255,46,136,.7),0 0 30px rgba(51,224,45,.6)}
  53%{transform:translate3d(2px,-1px,0);text-shadow:-4px 0 rgba(24,216,255,.9),4px 0 rgba(255,46,136,.9),0 0 34px rgba(51,224,45,.7)}
  54%{transform:translate3d(-2px,1px,0);text-shadow:4px 0 rgba(24,216,255,.85),-4px 0 rgba(255,46,136,.85),0 0 34px rgba(51,224,45,.7)}
}
/* cyan ghost slice — only visible mid-burst */
@keyframes energyGhostA{
  0%,7%,11%,52%,56%,100%{opacity:0}
  8%{opacity:.9;transform:translate3d(-4px,0,0);clip-path:inset(8% 0 68% 0)}
  9%{opacity:.85;transform:translate3d(4px,0,0);clip-path:inset(66% 0 8% 0)}
  10%{opacity:.8;transform:translate3d(-3px,0,0);clip-path:inset(40% 0 38% 0)}
  53%{opacity:.9;transform:translate3d(-5px,0,0);clip-path:inset(16% 0 58% 0)}
  54%{opacity:.85;transform:translate3d(3px,0,0);clip-path:inset(56% 0 14% 0)}
}
/* magenta ghost slice — offset the other way */
@keyframes energyGhostB{
  0%,7%,11%,52%,56%,100%{opacity:0}
  8%{opacity:.9;transform:translate3d(4px,0,0);clip-path:inset(58% 0 18% 0)}
  9%{opacity:.85;transform:translate3d(-4px,0,0);clip-path:inset(14% 0 60% 0)}
  10%{opacity:.8;transform:translate3d(3px,0,0);clip-path:inset(44% 0 34% 0)}
  53%{opacity:.9;transform:translate3d(5px,0,0);clip-path:inset(62% 0 12% 0)}
  54%{opacity:.85;transform:translate3d(-3px,0,0);clip-path:inset(20% 0 54% 0)}
}
/* speed lines shooting across the word during the same bursts */
.hero__energy-lines{
  position:absolute;left:-4%;top:0;width:108%;height:100%;
  pointer-events:none;mix-blend-mode:screen;opacity:0;
  background:repeating-linear-gradient(94deg,
    transparent 0 13px, rgba(140,255,180,.6) 13px 14px, transparent 14px 16px);
  background-size:80px 100%;
  -webkit-mask:linear-gradient(90deg,transparent,#000 18%,#000 82%,transparent);
          mask:linear-gradient(90deg,transparent,#000 18%,#000 82%,transparent);
  animation:energyStreak 4.6s steps(1) infinite;
}
@keyframes energyStreak{
  0%,7%,11%,52%,56%,100%{opacity:0}
  8%{opacity:.85;background-position:0 0}
  9%{opacity:.5;background-position:-46px 0}
  10%{opacity:.75;background-position:-20px 0}
  53%{opacity:.8;background-position:10px 0}
  54%{opacity:.45;background-position:-40px 0}
}
.hero__sub{
  margin-top:26px;font-size:clamp(17px,1.7vw,24px);color:var(--smoke);font-weight:300;max-width:34ch;
}
.hero__cta{display:flex;gap:14px;margin-top:38px;flex-wrap:wrap}
@keyframes float{0%,100%{transform:translateY(-12px) rotate(-1deg)}50%{transform:translateY(18px) rotate(1.5deg)}}
.hero__scroll{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:4;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  font-family:"Play",sans-serif;font-size:10px;letter-spacing:.4em;color:var(--fog);
}
.hero__scroll i{width:1px;height:46px;background:linear-gradient(var(--green),transparent);position:relative;overflow:hidden}
.hero__scroll i::after{content:"";position:absolute;top:0;left:0;width:100%;height:40%;background:var(--green);animation:scrolldot 1.8s var(--ease) infinite}
@keyframes scrolldot{0%{transform:translateY(-100%)}100%{transform:translateY(250%)}}

/* =================== MARQUEE =================== */
.marquee{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--green-deep);overflow:hidden;padding:16px 0;
}
.marquee__track{display:flex;gap:30px;white-space:nowrap;width:max-content;animation:marq 26s linear infinite}
.marquee__track span{font-family:"Anton",sans-serif;font-size:clamp(20px,2.6vw,34px);letter-spacing:.02em;color:var(--green);text-transform:uppercase}
.marquee__track b{color:var(--green-soft);font-size:22px;align-self:center}
@keyframes marq{to{transform:translateX(-50%)}}

/* tour marquee — roadshow stops */
.marquee--tour{background:var(--green-deep)}
.marquee--tour .marquee__track{gap:24px;animation-duration:70s}
.marquee--tour:hover .marquee__track{animation-play-state:paused}
/* NOTE: these must out-specify `.marquee__track span` (0,1,1) above, hence the
   `.marquee__track` prefix — otherwise tour stops fall back to big green Anton
   (green-on-green = nearly invisible, oversized items = broken-looking scroll). */
.marquee__track .tour__stop{
  font-family:"Play",sans-serif;font-size:clamp(12px,1.25vw,15px);font-weight:400;
  letter-spacing:.07em;text-transform:uppercase;color:var(--smoke);
}
.marquee__track .tour__stop b{color:var(--white);font-weight:700;margin-right:9px}
.marquee__track .tour__cta{
  font-family:"Anton",sans-serif;font-size:clamp(15px,1.7vw,21px);
  letter-spacing:.03em;text-transform:uppercase;color:var(--green);
}
.marquee--tour .marquee__track i{
  color:var(--green-soft);font-style:normal;font-size:10px;align-self:center;opacity:.8;
}

/* =================== SOUTĚŽ / ROADSHOW =================== */
.contest{
  position:relative;overflow:hidden;
  padding:clamp(70px,11vh,150px) var(--pad);
  background:radial-gradient(120% 80% at 82% 0%,rgba(51,224,45,.07),transparent 58%),var(--ink);
  border-bottom:1px solid var(--line);
}
.contest__grain{
  position:absolute;inset:0;pointer-events:none;opacity:.6;
  background-image:radial-gradient(rgba(51,224,45,.07) 1px,transparent 1px);
  background-size:26px 26px;
  -webkit-mask:radial-gradient(80% 72% at 50% 28%,#000,transparent 82%);
          mask:radial-gradient(80% 72% at 50% 28%,#000,transparent 82%);
}
.contest__head{
  position:relative;max-width:1120px;margin:0 auto;
  display:grid;grid-template-columns:1.55fr .85fr;gap:clamp(28px,5vw,64px);align-items:center;
}
.contest__title{
  font-size:clamp(48px,9vw,134px);line-height:.95;color:var(--white);
  letter-spacing:-.01em;margin-top:clamp(22px,3vw,40px);
}
.contest__sep{display:inline}
/* roadshow selfie — framed like a UGC IG post */
.contest__photo{position:relative;justify-self:center;width:100%;max-width:380px}
.contest__photo-card{
  position:relative;background:#0d0f0d;border:1px solid var(--line-soft);
  padding:11px 11px 0;transform:rotate(-2.6deg);
  box-shadow:0 32px 64px -22px rgba(0,0,0,.75);
  transition:transform .45s var(--ease),border-color .45s var(--ease),box-shadow .45s var(--ease);
}
.contest__photo-card:hover{
  transform:rotate(0) translateY(-4px);border-color:var(--green);
  box-shadow:0 34px 72px -20px rgba(51,224,45,.28);
}
.contest__photo-card img{display:block;width:100%;height:auto}
.contest__photo-cap{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:13px 4px}
.contest__photo-tag{font-family:"Play",sans-serif;font-weight:700;font-size:13px;letter-spacing:.03em;color:var(--green)}
.contest__photo-loc{font-family:"Play",sans-serif;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--fog)}
.contest__photo-pin{
  position:absolute;top:-14px;right:-10px;z-index:3;transform:rotate(4deg);
  font-family:"Play",sans-serif;font-weight:700;font-size:11px;letter-spacing:.06em;text-transform:uppercase;
  color:#000;background:var(--green);padding:6px 11px;box-shadow:0 0 18px rgba(51,224,45,.5);
}
@media (max-width:880px){
  .contest__head{grid-template-columns:1fr;gap:36px}
  .contest__photo{max-width:330px;margin-top:6px}
}
.contest__title em{font-style:normal;color:var(--green);text-shadow:0 0 60px rgba(51,224,45,.4)}
.contest__lede{
  margin-top:26px;max-width:56ch;font-size:clamp(16px,1.5vw,20px);
  color:var(--smoke);font-weight:300;
}
.contest__lede strong{color:var(--green);font-weight:700}

/* steps */
.steps{
  position:relative;list-style:none;max-width:1120px;
  margin:clamp(40px,6vh,72px) auto 0;
  display:grid;grid-template-columns:repeat(4,1fr);gap:30px;
}
.ig-link{color:var(--green);border-bottom:1px solid rgba(51,224,45,.4);font-weight:700}
.ig-link:hover{border-color:var(--green)}
.contest__btns{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.btn__ig{width:18px;height:18px;display:block;flex:0 0 auto}
.chaos__cta{margin-top:clamp(28px,4vh,46px)}
@media (max-width:1000px){
  .steps{grid-template-columns:repeat(2,1fr)}
  .step:not(:last-child)::after{display:none}
}

/* next stop — nearest upcoming roadshow date (live HUD banner) */
.next-stop{
  position:relative;overflow:hidden;isolation:isolate;
  max-width:1120px;margin:clamp(28px,4vh,46px) auto 0;
  display:flex;align-items:center;flex-wrap:wrap;gap:12px 26px;
  padding:18px 24px;border:1px solid var(--line);
  background:
    radial-gradient(rgba(51,224,45,.05) 1px,transparent 1px) 0 0/22px 22px,
    linear-gradient(110deg,rgba(51,224,45,.10),rgba(51,224,45,.02) 42%,transparent);
  transition:border-color .4s var(--ease),box-shadow .4s var(--ease);
}
.next-stop:hover{border-color:var(--green);box-shadow:0 0 36px -10px rgba(51,224,45,.5)}
/* glowing left accent bar */
.next-stop::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;z-index:2;
  background:var(--green);box-shadow:0 0 16px rgba(51,224,45,.7);
}
/* radar scan sweep */
.next-stop::after{
  content:"";position:absolute;top:0;bottom:0;left:-180px;width:160px;z-index:-1;pointer-events:none;
  background:linear-gradient(90deg,transparent,rgba(51,224,45,.12),transparent);
  animation:scanSweep 5s linear infinite;
}
@keyframes scanSweep{0%{left:-180px}100%{left:100%}}
.next-stop__live{display:flex;align-items:center;gap:9px;font-family:"Play",sans-serif;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--green)}
.next-stop__live i{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 12px var(--green);animation:hudPulse 2.4s ease-in-out infinite}
.next-stop__date{font-family:"Anton",sans-serif;font-size:clamp(22px,2.6vw,36px);color:var(--white);line-height:1;text-shadow:0 0 30px rgba(51,224,45,.25)}
.next-stop__place{flex:1;min-width:160px;font-size:clamp(13px,1.2vw,16px);color:var(--smoke);text-transform:uppercase;letter-spacing:.04em}
.next-stop__count{
  font-family:"Play",sans-serif;font-weight:700;font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  color:#000;background:var(--green);padding:7px 13px;white-space:nowrap;
  animation:chipPulse 2.8s ease-in-out infinite;
}
.next-stop__count:empty{display:none}
@keyframes chipPulse{0%,100%{box-shadow:0 0 0 0 rgba(51,224,45,0)}50%{box-shadow:0 0 20px 0 rgba(51,224,45,.55)}}
.step{
  position:relative;
  padding:clamp(22px,2.2vw,30px) clamp(18px,1.8vw,24px);
  background:var(--panel);border:1px solid var(--line-soft);
  transition:transform .45s var(--ease),border-color .45s var(--ease),background .45s var(--ease);
}
/* growing top accent line */
.step::before{
  content:"";position:absolute;top:0;left:0;height:2px;width:100%;z-index:2;
  background:linear-gradient(90deg,var(--green),rgba(51,224,45,0));
  transform:scaleX(0);transform-origin:left;transition:transform .55s var(--ease);
}
.step:hover::before{transform:scaleX(1)}
/* connector arrow — the path between steps (horizontal on desktop) */
.step:not(:last-child)::after{
  content:"→";position:absolute;z-index:3;
  top:clamp(40px,4.2vw,56px);right:-20px;
  font-family:"Play",sans-serif;font-weight:700;font-size:19px;color:var(--green);
  text-shadow:0 0 10px rgba(51,224,45,.55);
  animation:pathPulse 2.2s ease-in-out infinite;
}
.step:nth-child(2)::after{animation-delay:.35s}
.step:nth-child(3)::after{animation-delay:.7s}
.step:hover{transform:translateY(-5px);border-color:var(--green);background:#12150f}
.step__num{
  font-family:"Anton",sans-serif;font-size:clamp(30px,3.6vw,52px);color:var(--green);
  display:block;line-height:1;transition:text-shadow .45s var(--ease);
}
.step:hover .step__num{text-shadow:0 0 26px rgba(51,224,45,.55)}
.step p{margin-top:14px;color:var(--smoke);font-size:clamp(14px,1.2vw,16px);font-weight:300}
.step strong{color:var(--white);font-weight:700}
@keyframes pathPulse{0%,100%{opacity:.4}50%{opacity:1}}

/* prizes — featured 1st place + stacked runners-up */
.prizes{
  position:relative;max-width:1120px;margin:clamp(48px,7vh,90px) auto 0;
  display:grid;grid-template-columns:1.35fr 1fr;grid-auto-rows:1fr;gap:clamp(14px,1.6vw,22px);
}
.prize{
  position:relative;display:flex;flex-direction:column;overflow:hidden;
  background:var(--panel);border:1px solid var(--line-soft);transition:.4s var(--ease);
}
.prize--1{grid-row:span 2}
.prize:hover{border-color:var(--green);transform:translateY(-3px)}
.prize__rank{
  position:absolute;top:12px;left:16px;z-index:2;
  font-family:"Anton",sans-serif;font-size:clamp(28px,3vw,46px);color:var(--white);opacity:.16;line-height:1;
}
.prize__media{
  position:relative;flex:1;min-height:clamp(150px,22vh,220px);display:grid;place-items:center;
  background:radial-gradient(80% 80% at 50% 38%,rgba(51,224,45,.10),transparent 70%),#0b0d0b;color:var(--green);
}
.prize--1 .prize__media{min-height:clamp(220px,40vh,430px)}
.prize__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.prize__icon{width:clamp(46px,6vw,86px);height:auto;opacity:.5}
.prize__soon{
  position:absolute;bottom:12px;left:0;right:0;text-align:center;
  font-family:"Play",sans-serif;font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--fog);opacity:.55;
}
.prize__info{padding:clamp(16px,1.6vw,22px);border-top:1px solid var(--line-soft)}
.prize__place{font-family:"Play",sans-serif;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--green)}
.prize__name{font-family:"Anton",sans-serif;font-size:clamp(22px,2.4vw,38px);color:var(--white);margin-top:6px;line-height:.95}
.prize--1 .prize__name{font-size:clamp(30px,3.6vw,56px)}
.prize__desc{margin-top:8px;color:var(--smoke);font-size:clamp(13px,1.1vw,15px);font-weight:300}

/* more prizes + footer */
.contest__more{
  max-width:1120px;margin:clamp(26px,4vh,40px) auto 0;text-align:center;
  color:var(--fog);font-size:clamp(13px,1.2vw,16px);
}
.contest__more strong{color:var(--smoke);font-weight:700}
.contest__foot{
  max-width:1120px;margin:clamp(30px,5vh,56px) auto 0;
  display:flex;flex-direction:column;align-items:center;gap:18px;text-align:center;
}
.contest__fine{font-size:11px;color:var(--fog);letter-spacing:.04em;max-width:62ch;line-height:1.7}
.contest__fine a{color:var(--green);border-bottom:1px solid rgba(51,224,45,.3)}
.contest__fine a:hover{border-color:var(--green)}

@media (max-width:760px){
  /* steps as clean rows: green number square left, text beside */
  .steps{display:flex;flex-direction:column;gap:12px}
  .step{display:flex;align-items:center;gap:16px;padding:16px 18px}
  .step::before{display:none}
  .step:not(:last-child)::after{display:none}
  .step__num{
    flex:0 0 auto;width:52px;height:52px;display:grid;place-items:center;
    background:var(--green);color:#000;-webkit-text-stroke:0;text-shadow:none;
    font-size:24px;animation:none;
  }
  .step p{margin-top:0}
  .prizes{grid-template-columns:1fr}
  .prize--1{grid-row:auto}
  .prize--1 .prize__media{min-height:clamp(180px,32vh,260px)}
}

/* rules link (in fine print) */
.rules-link{
  background:none;border:none;padding:0;font:inherit;cursor:pointer;
  color:var(--green);border-bottom:1px solid rgba(51,224,45,.3);
}
.rules-link:hover{border-color:var(--green)}

/* =================== RULES MODAL =================== */
.modal{
  position:fixed;inset:0;z-index:300;display:grid;place-items:center;
  padding:clamp(16px,4vw,48px);
  opacity:0;visibility:hidden;transition:opacity .3s var(--ease),visibility .3s;
}
.modal.open{opacity:1;visibility:visible}
.modal__scrim{position:absolute;inset:0;background:rgba(0,0,0,.8);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.modal__panel{
  position:relative;z-index:1;width:min(720px,100%);max-height:86vh;
  display:flex;flex-direction:column;overflow:hidden;
  background:var(--char);border:1px solid var(--line);box-shadow:0 30px 90px rgba(0,0,0,.6);
  transform:translateY(16px) scale(.985);transition:transform .35s var(--ease);
}
.modal.open .modal__panel{transform:none}
.modal__top{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 22px;border-bottom:1px solid var(--line-soft);flex:0 0 auto;
  font-family:"Play",sans-serif;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--green);
}
.modal__close{background:none;border:none;color:var(--white);font-size:26px;line-height:1;cursor:pointer;transition:.2s}
.modal__close:hover{color:var(--green)}
.modal__body{overflow-y:auto;padding:clamp(20px,3vw,34px);color:var(--smoke)}
.modal__title{font-family:"Anton",sans-serif;font-size:clamp(20px,2.4vw,30px);color:var(--white);line-height:1.08;margin-bottom:20px}
.modal__body h4{font-family:"Play",sans-serif;font-weight:700;font-size:13px;letter-spacing:.05em;text-transform:uppercase;color:var(--green);margin:20px 0 6px}
.modal__body p{font-size:14px;font-weight:300;line-height:1.65;margin-bottom:8px}
.modal__body ul{margin:6px 0 10px;padding-left:18px}
.modal__body li{font-size:14px;font-weight:300;line-height:1.6;margin-bottom:5px}
.modal__body strong{color:var(--white);font-weight:700}

/* product detail modal */
.pmodal__panel{width:min(720px,100%);max-height:90vh}
.pmodal__panel .modal__close{
  position:absolute;top:12px;right:14px;z-index:5;
  width:36px;height:36px;display:grid;place-items:center;line-height:1;
  background:rgba(5,6,5,.55);border:1px solid var(--line);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
}
.pmodal__media{flex:0 0 auto;height:clamp(240px,34vh,330px);background:radial-gradient(70% 80% at 50% 46%,rgba(51,224,45,.14),transparent 70%),#0a0c0a;display:grid;place-items:center;overflow:hidden;border-bottom:1px solid var(--line-soft)}
.pmodal__media img{width:100%;height:100%;object-fit:cover;object-position:center}
.pmodal__media.contain img{width:auto;height:auto;max-width:78%;max-height:82%;object-fit:contain}
.pmodal__info{flex:1;min-width:0;overflow-y:auto;padding:clamp(24px,3vw,40px)}
.pmodal__pack{font-family:"Play",sans-serif;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--green)}
.pmodal__name{font-family:"Anton",sans-serif;font-size:clamp(28px,3vw,46px);color:var(--white);margin-top:6px;line-height:1}
.pmodal__desc{margin-top:12px;color:var(--smoke);font-weight:300;font-size:15px;line-height:1.6}
.pmodal__buy{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin:22px 0;padding-bottom:24px;border-bottom:1px solid var(--line-soft)}
.pmodal__price{font-family:"Anton",sans-serif;font-size:clamp(28px,3vw,42px);color:var(--white);margin-right:auto}
.pmodal__qty{display:flex;align-items:center;gap:12px;border:1px solid var(--line-soft);padding:6px 10px}
.pmodal__qty button{width:26px;height:26px;border:1px solid var(--line-soft);background:none;color:var(--white);cursor:pointer;font-size:16px;line-height:1;transition:.25s}
.pmodal__qty button:hover{border-color:var(--green);color:var(--green)}
.pmodal__qty span{font-family:"Play",sans-serif;font-weight:700;font-size:14px;min-width:20px;text-align:center}
.pmodal__buy #pmAdd{flex:1 1 auto;min-width:180px;justify-content:center}
.pmodal__spec h4{font-family:"Play",sans-serif;font-weight:700;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--green);margin:20px 0 8px}
.pmodal__spec h4 small{color:var(--fog);font-weight:400;letter-spacing:.04em;text-transform:none;font-size:11px}
.pmodal__spec p{font-size:13px;line-height:1.65;color:var(--smoke);font-weight:300}
.pmodal__nutri{width:100%;border-collapse:collapse;font-size:13px;margin-top:2px}
.pmodal__nutri th{text-align:left;font-weight:400;color:var(--smoke);padding:7px 12px 7px 0;border-bottom:1px solid var(--line-soft);vertical-align:top}
.pmodal__nutri th span{display:block;color:var(--fog);font-size:11px}
.pmodal__nutri td{text-align:right;color:var(--white);font-family:"Play",sans-serif;font-weight:700;padding:7px 0;border-bottom:1px solid var(--line-soft);white-space:nowrap}
.pmodal__legal{margin-top:16px;font-size:11px;line-height:1.7;color:var(--fog)}
.pmodal__legal strong{color:var(--smoke);font-weight:700}
@media (max-width:680px){
  .pmodal__panel{flex-direction:column;max-height:92vh}
  .pmodal__media{flex:0 0 auto;height:220px}
}

/* =================== CALM-IN-CHAOS BANNER =================== */
.cityband{
  position:relative;width:100%;height:clamp(300px,48vh,580px);
  overflow:hidden;background:#000;
}
.cityband img,
.cityband video{
  width:100%;height:100%;object-fit:cover;object-position:center 45%;display:block;
}
.cityband img{animation:cityDrift 32s ease-in-out infinite alternate}
.cityband::after{content:"";position:absolute;left:0;right:0;bottom:0;height:120px;pointer-events:none;z-index:1;background:linear-gradient(transparent,var(--black))}
@keyframes cityDrift{from{transform:scale(1)}to{transform:scale(1.07)}}

/* =================== CHAOS VS CALM =================== */
.chaos{
  position:relative;overflow:hidden;text-align:center;z-index:1;
  margin-top:clamp(-150px,-13vh,-90px);
  padding:clamp(34px,5vh,72px) var(--pad) clamp(80px,13vh,160px);
  display:flex;flex-direction:column;align-items:center;
  min-height:62svh;
}
.chaos__bg{
  position:absolute;inset:0;background:#000 url("assets/chaos.webp") center/cover no-repeat;
  opacity:.62;will-change:transform;
}
.chaos__noise{position:absolute;inset:0;background:radial-gradient(circle at 70% 50%,transparent,rgba(5,6,5,.9) 75%)}
/* fade the chaos backgrounds in from the top so the heading sits over the video */
.chaos__bg,.chaos__noise{
  -webkit-mask:linear-gradient(to bottom,transparent 0,#000 220px);
          mask:linear-gradient(to bottom,transparent 0,#000 220px);
}
.chaos__inner{position:relative;z-index:2;padding:0 var(--pad)}
.chaos__head{font-size:clamp(46px,9.5vw,134px);line-height:1.04;letter-spacing:-.01em;color:var(--white)}
.chaos__head span{color:var(--green);text-shadow:0 0 70px rgba(51,224,45,.45)}
.chaos__sub{font-family:"Anton",sans-serif;font-size:clamp(22px,3.4vw,46px);line-height:1.12;color:var(--smoke);margin:18px 0 0}
.chaos__lede{margin-top:22px;font-family:"Play",sans-serif;font-size:clamp(13px,1.3vw,16px);letter-spacing:.06em;color:var(--fog);line-height:1.8}
.chaos__lede strong{color:var(--green);font-weight:700}

/* =================== CALM ENERGY =================== */
.calm{
  position:relative;
  padding:clamp(80px,12vh,170px) var(--pad);
  max-width:1340px;margin:0 auto;transform:translateX(-1.6vw);
  display:grid;grid-template-columns:1.32fr .68fr;gap:clamp(28px,4.5vw,72px);align-items:center;
}
/* can visual with soft green aura */
.calm__content{position:relative;z-index:1}
.calm__visual{position:relative;z-index:1;justify-self:start;width:100%;max-width:860px}
.calm__visual::before{display:none}
.calm__visual img,.calm__visual video{
  position:relative;z-index:1;width:100%;height:auto;display:block;
  transform:translateY(clamp(40px,7vh,110px));
  -webkit-mask:
    radial-gradient(56% 80% at 50% 43%,#000 26%,transparent 100%),
    linear-gradient(to bottom,#000 42%,transparent 84%);
  -webkit-mask-composite:source-in;
  mask:
    radial-gradient(56% 80% at 50% 43%,#000 26%,transparent 100%),
    linear-gradient(to bottom,#000 42%,transparent 84%);
  mask-composite:intersect;
}
.calm__title{
  font-family:"Anton",sans-serif;font-size:clamp(32px,4.2vw,60px);line-height:1.08;
  letter-spacing:-.01em;color:var(--white);margin-top:16px;
}
.calm__title em{
  font-style:normal;color:var(--green);position:relative;display:inline-block;
  text-shadow:0 0 60px rgba(51,224,45,.4);
}
.calm__title em::after{
  content:"";position:absolute;left:0;right:0;bottom:-.08em;height:3px;
  background:linear-gradient(90deg,transparent,var(--green),transparent);
  background-repeat:no-repeat;background-size:50% 100%;
  filter:drop-shadow(0 0 7px rgba(51,224,45,.7));
  animation:ruleSweep 3.8s linear infinite;
}
@keyframes ruleSweep{
  0%{background-position:-140% 0;opacity:0}
  14%{opacity:1}
  58%{opacity:1}
  72%{background-position:240% 0;opacity:0}
  100%{background-position:240% 0;opacity:0}
}
.calm__lede{margin-top:22px;font-size:clamp(16px,1.4vw,20px);color:var(--smoke);max-width:46ch;font-weight:300}
/* benefits as a clean list */
.calm__list{list-style:none;margin-top:clamp(30px,4vh,50px);display:flex;flex-direction:column}
.calm__item{
  position:relative;
  display:flex;gap:clamp(16px,1.6vw,26px);align-items:center;
  padding:clamp(16px,1.8vw,22px) 0;border-top:1px solid var(--line-soft);
  transition:padding-left .4s var(--ease),background .4s var(--ease);
}
.calm__item:last-child{border-bottom:1px solid var(--line-soft)}
.calm__item::after{
  content:"→";position:absolute;right:4px;top:50%;
  transform:translateY(-50%) translateX(-8px);
  color:var(--green);opacity:0;transition:opacity .4s var(--ease),transform .4s var(--ease);
}
.calm__item:hover{
  padding-left:14px;
  background:linear-gradient(90deg,rgba(51,224,45,.06),transparent 70%);
}
.calm__item:hover::after{opacity:.85;transform:translateY(-50%) translateX(0)}
.calm__num{
  font-family:"Anton",sans-serif;font-size:clamp(36px,3.6vw,56px);line-height:1;
  flex:0 0 auto;min-width:1.4em;
  color:transparent;-webkit-text-stroke:1.2px var(--green-soft);
  transition:color .4s var(--ease),text-shadow .4s var(--ease),-webkit-text-stroke-color .4s var(--ease);
  animation:numGlitch 5.5s steps(1) infinite;
}
.calm__item:nth-child(2) .calm__num{animation-delay:-1.9s}
.calm__item:nth-child(3) .calm__num{animation-delay:-3.7s}
.calm__item:hover .calm__num{
  color:var(--green);-webkit-text-stroke-color:var(--green);text-shadow:0 0 26px rgba(51,224,45,.5);
}
@keyframes numGlitch{
  0%,89%,100%{transform:translate(0,0) skewX(0deg);opacity:1}
  90%{transform:translate(-1px,.5px) skewX(-3deg);opacity:.6}
  92%{transform:translate(1px,-.5px) skewX(3deg);opacity:1}
  94%{transform:translate(-.5px,0) skewX(0deg);opacity:.85}
}
.calm__item h3{font-family:"Anton",sans-serif;font-size:clamp(20px,1.9vw,30px);color:var(--white);letter-spacing:.01em;line-height:1}
.calm__item p{margin-top:7px;color:var(--fog);font-size:clamp(13px,1.1vw,15px);font-weight:300}
@media (max-width:860px){
  .calm{grid-template-columns:1fr;gap:clamp(30px,5vh,48px);transform:none}
  .calm__visual{max-width:300px;justify-self:center;transform:none}
  .calm__visual video,.calm__visual img{transform:none}
}

/* =================== CULTURE =================== */
.culture{
  position:relative;max-width:1340px;margin:0 auto;transform:translateX(-1.6vw);
  display:grid;grid-template-columns:1fr 1.05fr;align-items:center;
  gap:clamp(28px,4.5vw,76px);
  padding:clamp(28px,5vh,70px) var(--pad) clamp(64px,10vh,130px);
}
/* tall, full-bleed, framed image */
.culture__img{position:relative;overflow:hidden;height:clamp(460px,76vh,800px)}
.culture__img img{width:100%;height:100%;object-fit:cover;filter:saturate(.95) contrast(1.05);transform:scale(1.03);transition:transform 1.4s var(--ease)}
.culture__img:hover img{transform:scale(1.08)}
.culture__veil{position:absolute;inset:0;pointer-events:none;background:linear-gradient(90deg,transparent 58%,rgba(0,0,0,.45) 100%),linear-gradient(0deg,rgba(0,0,0,.5),transparent 42%)}
/* animated film/camera grain over the photo */
.culture__grain{
  position:absolute;inset:-40%;z-index:2;pointer-events:none;opacity:.16;
  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='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:120px 120px;
  animation:grainShift .5s steps(6) infinite;
}
@keyframes grainShift{
  0%{transform:translate(0,0)}
  16%{transform:translate(-7%,5%)}
  33%{transform:translate(5%,-6%)}
  50%{transform:translate(-5%,7%)}
  66%{transform:translate(7%,3%)}
  83%{transform:translate(-6%,-5%)}
  100%{transform:translate(0,0)}
}
/* CCTV scanlines + slow scan sweep */
.culture__scan{
  position:absolute;inset:0;z-index:2;pointer-events:none;overflow:hidden;opacity:.55;
  background:repeating-linear-gradient(0deg,rgba(0,0,0,.28) 0 1px,transparent 1px 3px);
}
.culture__scan::after{
  content:"";position:absolute;left:0;right:0;top:-16%;height:16%;
  background:linear-gradient(180deg,transparent,rgba(140,255,170,.07) 50%,transparent);
  animation:cctvScan 5.5s linear infinite;
}
@keyframes cctvScan{0%{top:-16%}100%{top:100%}}
.culture__rec{
  position:absolute;top:18px;right:18px;z-index:3;display:flex;align-items:center;gap:7px;
  font-family:"Play",sans-serif;font-size:10px;letter-spacing:.24em;color:var(--green);
  background:rgba(5,6,5,.5);padding:5px 10px;border:1px solid var(--line);
}
.culture__rec i{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);animation:recBlink 1.4s steps(1) infinite}
@keyframes recBlink{0%,49%{opacity:1}50%,100%{opacity:.15}}
.culture__img::before,.culture__img::after{content:"";position:absolute;width:28px;height:28px;border:2px solid var(--green);z-index:2;opacity:.85}
.culture__img::before{top:18px;left:18px;border-right:0;border-bottom:0}
.culture__img::after{bottom:18px;right:18px;border-left:0;border-top:0}
.culture__tag{
  position:absolute;left:18px;bottom:18px;z-index:3;display:flex;align-items:center;gap:8px;
  font-family:"Play",sans-serif;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--green);
  background:rgba(5,6,5,.62);padding:8px 13px;border:1px solid var(--line);
}
.culture__tag i{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 10px var(--green);animation:hudPulse 2.4s ease-in-out infinite}

.culture__copy{position:relative}
.culture__title{font-family:"Anton",sans-serif;font-size:clamp(34px,5vw,82px);line-height:1.16;letter-spacing:-.01em;margin:14px 0 0;color:var(--white)}
.culture__title em{font-style:normal;color:var(--green);text-shadow:0 0 60px rgba(51,224,45,.4)}
.culture__lede{margin-top:22px;font-size:clamp(16px,1.4vw,20px);color:var(--smoke);font-weight:300;max-width:42ch}
.culture__list{list-style:none;display:flex;flex-wrap:wrap;gap:10px;margin-top:clamp(26px,3.5vh,40px)}
.culture__list li{
  display:inline-flex;align-items:center;gap:9px;
  font-family:"Play",sans-serif;font-size:12px;letter-spacing:.1em;color:var(--smoke);
  border:1px solid var(--line-soft);padding:9px 15px 9px 12px;
  background:rgba(51,224,45,.03);transition:.3s var(--ease);
}
.culture__list li svg{width:16px;height:16px;color:var(--green);flex:0 0 auto;transition:.3s var(--ease)}
.culture__list li:hover{border-color:var(--green);color:var(--white);transform:translateY(-2px);background:rgba(51,224,45,.07)}
.culture__list li:hover svg{filter:drop-shadow(0 0 6px rgba(51,224,45,.65))}

/* =================== SHOP =================== */
.shop{padding:clamp(80px,12vh,160px) var(--pad)}
.shop__head{margin-bottom:clamp(40px,6vh,72px);max-width:1340px;margin-left:auto;margin-right:auto}
.shop__title{font-size:clamp(40px,7vw,104px);line-height:1.04;margin-top:16px;color:var(--white)}
.shop__green{color:var(--green);text-shadow:0 0 60px rgba(51,224,45,.4)}
.shop__lede{margin-top:18px;font-size:clamp(15px,1.4vw,19px);color:var(--smoke);font-weight:300;max-width:46ch}
.shop__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:1340px;margin:0 auto}
.product{
  border:1px solid var(--line-soft);background:linear-gradient(180deg,var(--ink),var(--black));
  display:flex;flex-direction:column;transition:.45s var(--ease);position:relative;overflow:hidden;cursor:pointer;
}
.product::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 30%,rgba(51,224,45,.10),transparent 60%);opacity:0;transition:opacity .5s}
.product:hover{border-color:var(--green);transform:translateY(-6px)}
.product:hover::before{opacity:1}
.product--feature{border-color:var(--line)}
.product__media{height:320px;display:grid;place-items:center;position:relative;z-index:2;overflow:hidden;background:#000}
.product__media img{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .6s var(--ease)}
.product:hover .product__media img{transform:scale(1.07)}
.product__badge{position:absolute;top:14px;right:14px;z-index:3;font-family:"Anton",sans-serif;font-size:26px;color:var(--green);text-shadow:0 0 20px rgba(51,224,45,.5)}
.product__body{padding:clamp(20px,2vw,30px);position:relative;z-index:2;border-top:1px solid var(--line-soft);flex:1;display:flex;flex-direction:column}
.product__flag{align-self:flex-start;font-family:"Play",sans-serif;font-size:10px;letter-spacing:.2em;color:#000;background:var(--green);padding:4px 9px;text-transform:uppercase}
.product__body h3{font-size:clamp(24px,2.4vw,34px);color:var(--white);margin-top:12px}
.product__body h3 small{font-size:.5em;color:var(--green);font-family:"Play",sans-serif;letter-spacing:.1em}
.product__note{font-family:"Play",sans-serif;font-size:12px;color:var(--fog);letter-spacing:.04em;margin-top:6px;text-transform:lowercase}
.product__row{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:24px}
.product__price{font-family:"Anton",sans-serif;font-size:clamp(24px,2.4vw,32px);color:var(--white)}
.product__detail{
  font-family:"Play",sans-serif;font-size:12px;letter-spacing:.16em;
  background:transparent;color:var(--green);border:1px solid var(--green);padding:11px 18px;cursor:pointer;transition:.3s;
}
.product:hover .product__detail{background:var(--green);color:#000}

/* =================== TROPICAL HAZE =================== */
.tropical{position:relative;min-height:100svh;display:grid;align-items:center;overflow:hidden}
.tropical__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;will-change:transform}
.tropical__veil{position:absolute;inset:0;background:linear-gradient(90deg,rgba(5,6,5,.92) 18%,rgba(5,6,5,.35) 60%,rgba(20,8,0,.4))}
.tropical__inner{position:relative;z-index:3;display:block;padding:0 var(--pad);width:100%}
.tropical__copy{max-width:620px}
.tropical__title{font-size:clamp(58px,12vw,170px);color:#fff;margin:16px 0 0;text-shadow:0 4px 40px rgba(0,0,0,.5)}
.tropical__soon{
  display:inline-flex;align-items:center;gap:13px;margin-top:18px;
  font-family:"Anton",sans-serif;font-size:clamp(22px,3vw,46px);letter-spacing:.14em;
  color:var(--warm);text-shadow:0 0 34px rgba(245,194,58,.45);
  animation:soonPulse 2.4s ease-in-out infinite;
}
.tropical__soon::before{
  content:"";width:11px;height:11px;border-radius:50%;background:var(--warm);
  box-shadow:0 0 14px var(--warm);animation:soonBlink 1.3s steps(1) infinite;
}
@keyframes soonPulse{0%,100%{text-shadow:0 0 22px rgba(245,194,58,.3)}50%{text-shadow:0 0 46px rgba(245,194,58,.75)}}
@keyframes soonBlink{0%,55%{opacity:1}56%,100%{opacity:.2}}
.tropical__lede{margin-top:26px;font-size:clamp(16px,1.6vw,21px);color:#e8ddcf;font-weight:300}
.tropical__hl{display:inline-block;margin-top:8px;color:var(--warm);font-weight:700}
.tropical__form{display:flex;margin-top:34px;max-width:440px;border:1px solid rgba(240,166,75,.35);background:rgba(5,6,5,.4);backdrop-filter:blur(6px)}
.tropical__form input{flex:1;background:transparent;border:0;outline:0;color:#fff;font-family:"Play",sans-serif;font-size:14px;padding:15px 18px}
.tropical__form input::placeholder{color:rgba(232,221,207,.5)}
.tropical__form button{background:var(--warm);color:#1a0d00;border:0;font-family:"Play",sans-serif;font-size:12px;letter-spacing:.16em;font-weight:700;padding:0 22px;cursor:pointer;transition:.3s}
.tropical__form button:hover{background:#ffbf66}
.tropical__msg{margin-top:14px;font-family:"Play",sans-serif;font-size:13px;color:var(--warm);min-height:18px}
.tropical__can{justify-self:center;animation:float 8s ease-in-out infinite}
.tropical__can img{width:min(34vw,420px);
  -webkit-mask-image:radial-gradient(ellipse 70% 74% at 50% 50%,#000 56%,transparent 82%);
  mask-image:radial-gradient(ellipse 70% 74% at 50% 50%,#000 56%,transparent 82%);}

/* =================== FOOTER =================== */
.footer{padding:clamp(60px,9vh,120px) var(--pad) 40px;border-top:1px solid var(--line)}
.footer__logo{
  display:block;width:min(760px,84vw);height:auto;margin:0 auto;
  animation:logoGlitch 2.8s steps(1) infinite;
}
@keyframes logoGlitch{
  0%,85%,100%{transform:translate(0,0);filter:drop-shadow(0 0 16px rgba(51,224,45,.3))}
  86%{transform:translate(-3px,1px) skewX(-2deg);filter:drop-shadow(-5px 0 rgba(255,46,136,.85)) drop-shadow(5px 0 rgba(24,216,255,.85))}
  88%{transform:translate(3px,-1px) skewX(2deg);filter:drop-shadow(5px 0 rgba(255,46,136,.8)) drop-shadow(-5px 0 rgba(24,216,255,.8))}
  90%{transform:translate(-2px,0);filter:drop-shadow(-3px 0 rgba(255,46,136,.7)) drop-shadow(3px 0 rgba(24,216,255,.7)) drop-shadow(0 0 22px rgba(51,224,45,.45))}
  92%{transform:translate(0,0);filter:drop-shadow(0 0 16px rgba(51,224,45,.3))}
}
.footer__tag{font-family:"Anton",sans-serif;font-size:clamp(20px,3vw,40px);color:var(--green);text-transform:uppercase;text-align:center;margin-top:16px}
.footer__contact{display:flex;justify-content:center;flex-wrap:wrap;gap:14px 30px;margin-top:26px}
.footer__link{display:inline-flex;align-items:center;gap:10px;font-family:"Play",sans-serif;font-size:14px;letter-spacing:.05em;color:var(--smoke);transition:color .25s var(--ease)}
.footer__link svg{width:20px;height:20px;color:var(--green);flex:0 0 auto;transition:filter .25s var(--ease)}
.footer__link:hover{color:var(--green)}
.footer__link:hover svg{filter:drop-shadow(0 0 7px rgba(51,224,45,.6))}
.footer__meta{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;font-family:"Play",sans-serif;font-size:12px;color:var(--fog);letter-spacing:.08em;margin-top:30px;padding-top:28px;border-top:1px solid var(--line-soft)}
.footer__fine{display:flex;justify-content:space-between;margin-top:40px;font-family:"Play",sans-serif;font-size:11px;color:var(--fog);letter-spacing:.1em}

/* =================== CART =================== */
.cart{position:fixed;inset:0;z-index:500;visibility:hidden;pointer-events:none}
.cart.open{visibility:visible;pointer-events:auto}
.cart__scrim{position:absolute;inset:0;background:rgba(0,0,0,.6);opacity:0;transition:opacity .5s;backdrop-filter:blur(2px)}
.cart.open .cart__scrim{opacity:1}
.cart__panel{
  position:absolute;top:0;right:0;height:100%;width:min(420px,90vw);
  background:var(--ink);border-left:1px solid var(--line);
  display:flex;flex-direction:column;transform:translateX(100%);transition:transform .55s var(--ease);
}
.cart.open .cart__panel{transform:none}
.cart__top{display:flex;justify-content:space-between;align-items:center;padding:24px var(--pad);border-bottom:1px solid var(--line-soft);font-family:"Play",sans-serif;letter-spacing:.2em;font-size:13px;color:var(--green)}
.cart__top button{background:none;border:0;color:var(--white);font-size:28px;line-height:1;cursor:pointer;transition:color .3s}
.cart__top button:hover{color:var(--green)}
.cart__items{flex:1;overflow-y:auto;padding:10px var(--pad)}
.cart__empty{font-family:"Play",sans-serif;font-size:13px;color:var(--fog);text-align:center;margin-top:50px;letter-spacing:.06em}
.cart__item{display:flex;align-items:center;gap:14px;padding:18px 0;border-bottom:1px solid var(--line-soft)}
.cart__item img{height:54px;width:auto;filter:drop-shadow(0 6px 14px rgba(0,0,0,.6))}
.cart__item-info{flex:1}
.cart__item-info b{font-family:"Play";font-weight:700;font-size:15px;color:var(--white);display:block}
.cart__item-info span{font-family:"Play",sans-serif;font-size:12px;color:var(--fog)}
.cart__qty{display:flex;align-items:center;gap:10px;margin-top:8px}
.cart__qty button{width:22px;height:22px;border:1px solid var(--line-soft);background:none;color:var(--white);cursor:pointer;font-size:14px;line-height:1;transition:.25s}
.cart__qty button:hover{border-color:var(--green);color:var(--green)}
.cart__qty span{font-family:"Play",sans-serif;font-size:13px;min-width:18px;text-align:center}
.cart__item-price{font-family:"Anton",sans-serif;font-size:18px;color:var(--green)}
.cart__foot{padding:20px var(--pad) 26px;border-top:1px solid var(--line)}
/* coupon */
.cart__coupon{display:flex;gap:8px;margin-bottom:6px}
.cart__coupon input{
  flex:1;min-width:0;background:var(--ink);border:1px solid var(--line-soft);color:var(--white);
  font-family:"Play",sans-serif;font-size:13px;letter-spacing:.06em;padding:11px 13px;
}
.cart__coupon input::placeholder{color:var(--fog);text-transform:uppercase;letter-spacing:.14em;font-size:11px}
.cart__coupon input:focus{outline:none;border-color:var(--green)}
.cart__coupon button{
  font-family:"Play",sans-serif;font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  background:transparent;color:var(--green);border:1px solid var(--green);padding:0 16px;cursor:pointer;transition:.25s;
}
.cart__coupon button:hover{background:var(--green);color:#000}
.cart__coupon-msg{font-family:"Play",sans-serif;font-size:11px;letter-spacing:.06em;margin:0 0 12px}
.cart__coupon-msg.is-ok{color:var(--green)}
.cart__coupon-msg.is-err{color:var(--warm)}
/* line items */
.cart__lines{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.cart__line{display:flex;justify-content:space-between;align-items:baseline;font-family:"Play",sans-serif;font-size:13px;color:var(--fog)}
.cart__line b{color:var(--smoke);font-weight:700}
.cart__line--disc b{color:var(--green)}
.cart__total{display:flex;justify-content:space-between;align-items:baseline;margin:0 0 18px;padding-top:14px;border-top:1px solid var(--line-soft);font-family:"Play",sans-serif;letter-spacing:.18em;font-size:13px;color:var(--fog)}
.cart__total b{font-family:"Anton",sans-serif;font-size:30px;color:var(--white);letter-spacing:0}
.cart__micro{text-align:center;margin-top:14px;font-family:"Play",sans-serif;font-size:11px;color:var(--fog);letter-spacing:.12em}

/* =================== RESPONSIVE =================== */
@media(max-width:900px){
  .hero{padding:0}
  .hero__sticky{align-items:stretch}
  .hero__copy{max-width:100%;padding:118px 0 32px;flex:1 1 100%;display:flex;flex-direction:column;justify-content:flex-end}
  .hero__title{font-size:clamp(80px,23vw,118px)}
  .hero__cta{flex-direction:column;max-width:100%;margin-top:30px}
  .m-br{display:inline}
  /* contest block — tighter to marquee, bigger title, split eyebrow (mobile only) */
  .contest{padding-top:clamp(28px,4vh,48px)}
  .contest__title{font-size:clamp(60px,15vw,96px)}
  .contest__sep{display:none}
  /* next stop: label/place left, date + count right-aligned */
  .next-stop{display:grid;grid-template-columns:1fr auto;gap:8px 14px;align-items:center}
  .next-stop__date{justify-self:end;text-align:right}
  .next-stop__count{justify-self:end}
  .next-stop__place{min-width:0}
  /* chaos block — bigger text + button on mobile */
  .chaos__inner{width:100%;padding-left:0;padding-right:0}
  .chaos__head{font-size:clamp(72px,18vw,96px)}
  .chaos__sub{font-size:clamp(30px,5.4vw,42px)}
  .chaos__lede{font-size:clamp(16px,4.4vw,19px);line-height:1.6}
  .chaos__cta{font-size:15px;letter-spacing:.12em;padding:21px 34px;width:100%;justify-content:center}
  .contest__btns{width:100%}
  .contest__btns .btn{width:100%;justify-content:center}
  .hero__cta .btn{min-width:0;width:100%;padding:26px 28px}
  /* show the can on mobile (it sits on the right of the video frame) */
  .hero__video{object-position:73% center}
  .hero__veil{background:
    linear-gradient(0deg,rgba(0,0,0,.92) 8%,rgba(0,0,0,.45) 55%,rgba(0,0,0,.6) 100%),
    radial-gradient(120% 80% at 50% 30%,transparent 50%,rgba(0,0,0,.55) 100%)}
  .hero__aside,.hero__scroll,.hero__status,.hero__fx{display:none}
  .calm{padding-top:clamp(20px,3vh,36px);gap:0}
  .calm__visual{max-width:none;width:calc(100% + 2*var(--pad));margin-left:calc(-1*var(--pad));margin-right:calc(-1*var(--pad))}
  .calm__content{margin-top:clamp(-150px,-24vw,-80px)}
  .calm__title{font-size:clamp(42px,11.5vw,60px)}
  .calm__num{font-size:clamp(54px,14vw,72px);min-width:1.5em}
  .calm__item{padding:clamp(20px,5vw,28px) 0;gap:18px}
  .calm__item h3{font-size:clamp(26px,7vw,34px)}
  .calm__item p{margin-top:9px;font-size:clamp(15px,4vw,17px)}
  .culture{grid-template-columns:1fr;padding-inline:var(--pad);transform:none}
  .culture__img{height:clamp(380px,60vh,560px);order:-1}
  .culture__title{font-size:clamp(46px,12.5vw,66px)}
  .culture__list{gap:12px}
  .culture__list li{font-size:15px;padding:13px 18px 13px 15px;gap:11px}
  .culture__list li svg{width:20px;height:20px}
  .shop__title{font-size:clamp(58px,15.5vw,104px)}
  .shop__green{display:block}
  .shop__grid{grid-template-columns:1fr}
  .tropical__inner{grid-template-columns:1fr}
  .tropical__can{display:none}
  /* mobile tropical: video as darkened full background, less empty space */
  .tropical{min-height:80svh}
  .tropical__bg{object-fit:cover;object-position:68% center}
  .tropical__title{font-size:clamp(70px,18vw,170px)}
  .tropical__soon{font-size:clamp(30px,7.5vw,46px)}
  .tropical__veil{background:linear-gradient(180deg,rgba(5,6,5,.72),rgba(5,6,5,.5) 45%,rgba(5,6,5,.92))}
  /* mobile nav: hamburger + fullscreen menu */
  /* backdrop-filter would create a containing block that traps the fixed menu overlay */
  .nav.scrolled{-webkit-backdrop-filter:none;backdrop-filter:none;background:rgba(5,6,5,.9)}
  .nav__burger{display:flex}
  .nav__cart-label{display:none}
  .nav__cart{padding:9px 12px}
  .nav__brand,.nav__right{position:relative;z-index:100}
  .nav__links{
    display:flex;position:fixed;inset:0;z-index:90;
    flex-direction:column;justify-content:center;align-items:center;gap:30px;
    background:rgba(5,6,5,.97);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);
    transform:translateY(-100%);transition:transform .45s var(--ease);
  }
  .nav__links.open{transform:translateY(0)}
  .nav__links a{font-size:26px;letter-spacing:.16em;color:var(--white)}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001s!important;transition-duration:.2s!important}
  .reveal{opacity:1;transform:none}
}
