/* ===================== NIGHT RIDERS — стили ===================== */
:root{
  --bg:#070b1c;
  --bg-2:#0d1330;
  --ink:#eef1ff;
  --muted:#9aa3cf;
  --neon:#7c5cff;       /* фиолетовый неон */
  --neon-2:#28e0c8;     /* бирюзовый неон */
  --neon-pink:#ff5fa2;
  --card:rgba(255,255,255,.04);
  --card-line:rgba(255,255,255,.10);
  --radius:18px;
  --shadow:0 20px 60px rgba(0,0,0,.45);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Manrope',system-ui,sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.55;
  overflow-x:hidden;
  position:relative;
}

/* ---------- Звёздное небо (фиксированный спокойный фон) ---------- */
.starfield{position:fixed;inset:0;z-index:-2;overflow:hidden;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(124,92,255,.22), transparent 60%),
    radial-gradient(900px 500px at 10% 10%, rgba(40,224,200,.10), transparent 60%),
    linear-gradient(180deg,#05071a 0%, #0a0f28 45%, #070b1c 100%);
}
/* ---------- Сцена парка (один раз, у низа страницы) ---------- */
.sky{position:absolute;left:0;bottom:0;width:100%;height:min(46vh,380px);
  z-index:-1;overflow:hidden;pointer-events:none}
.stars{position:absolute;inset:0;
  background-image:
    radial-gradient(1px 1px at 20% 30%, #fff, transparent),
    radial-gradient(1px 1px at 60% 70%, #cdd6ff, transparent),
    radial-gradient(1.5px 1.5px at 80% 20%, #fff, transparent),
    radial-gradient(1px 1px at 40% 80%, #e6ebff, transparent),
    radial-gradient(1px 1px at 90% 60%, #fff, transparent),
    radial-gradient(1px 1px at 33% 50%, #fff, transparent);
  background-repeat:repeat;background-size:600px 600px;
  animation:twinkle 6s ease-in-out infinite alternate;opacity:.8;
}
.stars--2{background-size:420px 420px;opacity:.45;animation-duration:9s}
@keyframes twinkle{from{opacity:.35}to{opacity:.9}}
/* Луна: контейнер-круг (клип тени затмения), живой диск + умбра */
.moon{position:absolute;top:8%;right:12%;width:120px;height:120px;border-radius:50%;
  overflow:hidden;isolation:isolate;
  filter:drop-shadow(0 0 30px rgba(180,190,255,.30));
  animation:moonDrift 17s ease-in-out infinite alternate}
.moon__disk{position:absolute;inset:0;width:100%;height:100%;display:block;border-radius:50%;
  object-fit:cover;filter:saturate(.94) brightness(1.02);
  animation:moonGlow 7s ease-in-out infinite}
/* Умбра затмения: тёмно-красный диск с мягким краем, проходит поперёк луны.
   multiply + isolate => темнит/краснит текстуру луны (эффект «кровавой луны»). */
.moon__umbra{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:50%;
  background:radial-gradient(circle at 50% 50%,
     #2a0c08 0 40%, #5a1b12 62%, rgba(90,28,18,.34) 78%, rgba(90,28,18,0) 92%);
  mix-blend-mode:multiply;will-change:transform,opacity;
  transform:translateX(-140%);opacity:0;
  animation:eclipse 26s ease-in-out infinite}
/* плавный фейд: тень мягко проявляется, наезжает до тотальной фазы и так же мягко уходит */
@keyframes eclipse{
  0%, 46% {transform:translateX(-140%);opacity:0}
  56%     {transform:translateX(-95%);opacity:.35}
  66%     {transform:translateX(-50%);opacity:.7}
  78%     {transform:translateX(0%);opacity:1}      /* тотальная фаза по центру */
  88%     {transform:translateX(50%);opacity:.7}
  95%     {transform:translateX(95%);opacity:.3}
  100%    {transform:translateX(140%);opacity:0}
}
@keyframes moonDrift{from{transform:translateY(0)}to{transform:translateY(-12px)}}
@keyframes moonGlow{0%,100%{filter:saturate(.94) brightness(1.0)}50%{filter:saturate(1) brightness(1.08)}}
@media (prefers-reduced-motion:reduce){
  .moon,.moon__disk{animation:none}
  .moon__umbra{animation:none;opacity:0}
}
.fog-layer{position:absolute;bottom:0;left:0;right:0;height:40%;
  background:linear-gradient(180deg,transparent, rgba(124,92,255,.10));
  filter:blur(8px)}

/* Силуэт сказочного парка */
.skyline{position:absolute;bottom:0;left:0;width:100%;height:100%}
.skyline__fill path{fill:#05071a;stroke:rgba(124,92,255,.35);stroke-width:1.2}
.ferris line{stroke:rgba(40,224,200,.55);stroke-width:1.4;fill:none}
.ferris__rim{fill:none;stroke:rgba(40,224,200,.65);stroke-width:1.8;
  filter:drop-shadow(0 0 6px rgba(40,224,200,.5))}
.ferris__rim--thin{stroke-width:1;stroke:rgba(40,224,200,.4);filter:none}
.ferris__base{fill:rgba(124,92,255,.5)}
.ferris__hub{fill:var(--neon-2);filter:drop-shadow(0 0 6px rgba(40,224,200,.9))}
.ferris__gondola{fill:var(--neon-pink);stroke:rgba(255,255,255,.5);stroke-width:.5;
  filter:drop-shadow(0 0 6px rgba(255,95,162,.8))}
.ferris__cabs .ferris__gondola:nth-child(even){fill:#ffd36e;filter:drop-shadow(0 0 6px rgba(255,211,110,.8))}
.ferris__wheel{transform-origin:0px -118px;animation:wheel 36s linear infinite}
@keyframes wheel{to{transform:rotate(360deg)}}

/* Американская горка */
.coaster__rail{fill:none;stroke:rgba(255,95,162,.7);stroke-width:2.2;stroke-linecap:round;
  filter:drop-shadow(0 0 6px rgba(255,95,162,.55))}
.coaster__supports line{stroke:rgba(124,92,255,.5);stroke-width:1.3}
.coaster__car rect{fill:#ffd36e;filter:drop-shadow(0 0 5px rgba(255,211,110,.85))}
.coaster__car circle{fill:#0a0a1a;stroke:rgba(255,255,255,.6);stroke-width:.6}

/* Гирлянда огней */
.garland__wire{fill:none;stroke:rgba(255,255,255,.18);stroke-width:1}
.bulb{animation:bulbTwinkle 3s ease-in-out infinite}
.bulb--0{fill:#ffd36e;filter:drop-shadow(0 0 5px rgba(255,211,110,.9))}
.bulb--1{fill:#ff5fa2;filter:drop-shadow(0 0 5px rgba(255,95,162,.9));animation-delay:.5s}
.bulb--2{fill:#28e0c8;filter:drop-shadow(0 0 5px rgba(40,224,200,.9));animation-delay:1s}
.bulb--3{fill:#7c5cff;filter:drop-shadow(0 0 5px rgba(124,92,255,.9));animation-delay:1.5s}
@keyframes bulbTwinkle{0%,100%{opacity:.45}50%{opacity:1}}

/* Аттракцион-вышка */
.tower__mast{stroke:rgba(124,92,255,.5);stroke-width:1.6}
.tower__rung{stroke:rgba(124,92,255,.3);stroke-width:1.1}
.tower__top{fill:rgba(40,224,200,.18);stroke:rgba(40,224,200,.6);stroke-width:1}
.tower__star{fill:#ffd36e;filter:drop-shadow(0 0 6px rgba(255,211,110,.9));animation:bulbTwinkle 2s ease-in-out infinite}
.tower__car rect{fill:var(--neon-2);filter:drop-shadow(0 0 7px rgba(40,224,200,.85))}
.tower__car circle{fill:#06210f}
.tower__car{animation:drop 6.5s cubic-bezier(.5,0,.7,1) infinite}
@keyframes drop{
  0%{transform:translateY(0)}
  38%{transform:translateY(-150px)}
  48%{transform:translateY(-150px)}
  55%{transform:translateY(-6px)}
  62%{transform:translateY(-26px)}
  69%{transform:translateY(0)}
  100%{transform:translateY(0)}
}

/* Прожекторные лучи из парка */
.beams{position:absolute;inset:0;z-index:-1;overflow:hidden;pointer-events:none}
.beam{position:absolute;bottom:-6%;left:50%;width:130px;height:130%;
  transform-origin:50% 100%;filter:blur(12px);mix-blend-mode:screen;opacity:.5;
  border-radius:50% 50% 0 0}
.beam--1{background:linear-gradient(to top, rgba(124,92,255,.5), transparent 72%);animation:sweepA 11s ease-in-out infinite alternate}
.beam--2{background:linear-gradient(to top, rgba(40,224,200,.45), transparent 72%);animation:sweepB 9s ease-in-out infinite alternate}
.beam--3{background:linear-gradient(to top, rgba(255,95,162,.45), transparent 72%);animation:sweepC 13s ease-in-out infinite alternate}
@keyframes sweepA{from{transform:translateX(-50%) rotate(-30deg)}to{transform:translateX(-50%) rotate(-6deg)}}
@keyframes sweepB{from{transform:translateX(-50%) rotate(10deg)}to{transform:translateX(-50%) rotate(-14deg)}}
@keyframes sweepC{from{transform:translateX(-50%) rotate(28deg)}to{transform:translateX(-50%) rotate(4deg)}}

/* Падающие звёзды */
.shooting-star{position:absolute;top:14%;left:60%;width:120px;height:1.5px;
  background:linear-gradient(90deg,#fff,transparent);border-radius:999px;
  opacity:0;transform:rotate(-22deg);
  box-shadow:0 0 8px 1px rgba(255,255,255,.6);
  animation:shoot 5s ease-in .6s infinite}
.shooting-star--2{top:26%;left:30%;width:90px;animation-delay:2s;animation-duration:6s}
.shooting-star--3{top:9%;left:82%;width:110px;animation-delay:3.4s;animation-duration:5.5s}
.shooting-star--4{top:40%;left:14%;width:80px;animation-delay:1.2s;animation-duration:6.5s}
.shooting-star--5{top:20%;left:48%;width:130px;animation-delay:4.3s;animation-duration:5s}
@keyframes shoot{
  0%{opacity:0;transform:translate(0,0) rotate(-22deg)}
  6%{opacity:1}
  16%{opacity:0;transform:translate(-260px,120px) rotate(-22deg)}
  100%{opacity:0}
}

/* ---------- Экраны ---------- */
.screen{display:none;min-height:100vh}
.screen--active{display:block}
.screen--thanks{place-items:center}
body.show-thanks #screen-landing{display:none}
body.show-thanks #screen-thanks{display:grid}

/* ---------- Топбар ---------- */
.topbar{position:fixed;top:0;left:0;right:0;z-index:10;display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(16px,5vw,64px);
  background:linear-gradient(180deg, rgba(7,11,28,.85), transparent);
  backdrop-filter:blur(6px)}
.brand{display:inline-flex;gap:10px;align-items:center;text-decoration:none;
  font-family:'Unbounded',sans-serif;letter-spacing:.06em;font-size:14px}
.brand__logo{height:clamp(30px,3.4vw,42px);width:auto;display:block;
  filter:drop-shadow(0 1px 10px rgba(62,189,230,.35));transition:filter .25s, transform .25s}
.brand:hover .brand__logo{filter:drop-shadow(0 1px 16px rgba(62,189,230,.6));transform:translateY(-1px)}
.brand__dot{color:var(--neon-2)}
.brand__sub{color:var(--muted);font-weight:400}
.topbar__actions{display:flex;align-items:center;gap:clamp(10px,2vw,22px)}
.topbar__phone{display:inline-flex;align-items:center;gap:7px;text-decoration:none;
  font-weight:700;font-size:15px;color:#fff;white-space:nowrap;
  text-shadow:0 1px 8px rgba(7,11,28,.8);transition:color .2s}
.topbar__phone .ico{width:17px;height:17px;color:var(--neon-2)}
.topbar__phone:hover{color:#a78bff}

/* ---------- Кнопки ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:'Manrope',sans-serif;font-weight:700;font-size:15px;
  padding:14px 26px;border-radius:999px;border:1px solid transparent;cursor:pointer;
  text-decoration:none;transition:transform .15s ease, box-shadow .25s ease, background .2s}
.btn:active{transform:translateY(1px)}
.btn--sm{padding:9px 18px;font-size:13px}
.btn--block{width:100%}
.btn--primary{color:#fff;
  background:linear-gradient(135deg,#9a7bff 0%, #6c44e8 100%);
  box-shadow:0 0 0 0 rgba(124,92,255,.6), 0 10px 30px rgba(124,92,255,.4)}
.btn--primary:hover{box-shadow:0 0 26px 4px rgba(124,92,255,.6), 0 10px 30px rgba(124,92,255,.45);transform:translateY(-1px)}
.btn--ghost{color:var(--ink);border-color:var(--card-line);background:var(--card)}
.btn--ghost:hover{border-color:var(--neon);color:#fff}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100vh;min-height:100svh;
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  padding:96px clamp(16px,5vw,64px) 80px;text-align:center;overflow:hidden}
/* Фоновое видео hero */
.hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;
  pointer-events:none;
  -webkit-mask-image:linear-gradient(180deg,#000 88%,transparent);mask-image:linear-gradient(180deg,#000 88%,transparent)}
/* Затемняющий слой поверх видео — чтобы текст читался */
.hero__bg{position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:linear-gradient(180deg, rgba(7,11,28,.45) 0%, rgba(7,11,28,.22) 38%, rgba(7,11,28,.90) 100%)}
/* содержимое держим в центральной колонке, фон — на всю ширину */
.hero > :not(.hero__bg):not(.moon):not(.hero__video){position:relative;max-width:1000px;margin-left:auto;margin-right:auto}
/* луна — декоративный элемент только в hero, за текстом */
.hero .moon{z-index:0;top:6%;right:6%;width:92px;height:92px}
.hero__eyebrow{display:inline-block;align-self:center;
  color:#d3c4ff;letter-spacing:.16em;text-transform:uppercase;font-size:12px;font-weight:700;margin-bottom:18px;
  padding:9px 18px;border-radius:999px;
  background:rgba(10,13,30,.55);border:1px solid rgba(167,139,255,.5);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  box-shadow:0 0 18px rgba(124,92,255,.25), inset 0 0 12px rgba(124,92,255,.12)}
.hero__title{font-family:'Unbounded',sans-serif;font-weight:800;line-height:.92;
  font-size:clamp(56px,14vw,150px);letter-spacing:-.02em;
  text-shadow:0 0 30px rgba(124,92,255,.55)}
.hero__title span{display:block;font-family:'Anton',sans-serif;font-weight:400;
  letter-spacing:.03em;-webkit-text-stroke:0;
  background:linear-gradient(135deg,#bda7ff 0%, #6c44e8 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 22px rgba(124,92,255,.55))}
/* Русское дублирование названия (по закону о госязыке) */
.hero__ru{margin-top:8px;color:#d3c4ff;font-weight:600;
  font-size:clamp(13px,1.8vw,18px);letter-spacing:.42em;text-transform:uppercase;
  text-shadow:0 1px 10px rgba(7,11,28,.8)}
.hero__lead{max-width:640px;margin:24px auto 0;color:#eaedff;font-size:clamp(16px,2.2vw,20px);
  text-shadow:0 1px 2px rgba(7,11,28,.7), 0 4px 24px rgba(7,11,28,.85)}
.hero__lead strong{color:#fff;font-weight:700;white-space:nowrap}
.hero__cta{display:flex;gap:18px;align-items:center;justify-content:center;flex-wrap:wrap;margin-top:34px}
.hero__hint{color:#c2c9ef;font-size:14px;text-shadow:0 1px 8px rgba(7,11,28,.8)}
.hero__marquee{list-style:none;display:flex;gap:14px;flex-wrap:wrap;justify-content:center;
  margin-top:40px;color:#fff;font-size:clamp(15px,1.8vw,19px);font-weight:600}
.hero__marquee li{display:inline-flex;align-items:center;gap:8px;
  padding:13px 24px;border:1px solid rgba(167,139,255,.4);border-radius:999px;
  background:rgba(10,13,30,.5);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  box-shadow:0 4px 18px rgba(7,11,28,.35)}

/* ---------- Секции общее ---------- */
.section-title{font-family:'Unbounded',sans-serif;font-weight:600;text-align:center;
  font-size:clamp(26px,4vw,40px);letter-spacing:-.01em}
.section-title--left{text-align:left}
.section-sub{text-align:center;color:#b6bdea;margin-top:8px}
.section-sub--left{text-align:left}

/* ---------- Как попасть ---------- */
.how{max-width:1100px;margin:0 auto;padding:60px clamp(16px,5vw,64px)}
.how__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-top:34px}
.how__step{background:var(--card);border:1px solid var(--card-line);border-radius:var(--radius);padding:26px;position:relative;overflow:hidden}
.how__step::before{content:"";position:absolute;inset:0;background:radial-gradient(400px 120px at 0 0, rgba(124,92,255,.18), transparent 70%)}
.how__num{font-family:'Unbounded',sans-serif;color:#a78bff;font-size:13px;letter-spacing:.1em}
.how__step h3{margin:12px 0 8px;font-size:19px}
.how__step p{color:var(--muted);font-size:15px;position:relative}

/* ---------- Календарь дат ---------- */
/* ---------- Галерея-слайдер ---------- */
.gallery{max-width:1180px;margin:0 auto;padding:40px clamp(16px,5vw,64px)}
.slider{position:relative;max-width:1180px;margin:34px auto 0}
.slider__viewport{overflow:hidden;padding:10px 0}
.slider__track{display:flex;gap:20px;will-change:transform;
  transition:transform .6s cubic-bezier(.55,0,.2,1)}
.slide{position:relative;flex:0 0 66%;aspect-ratio:16/9;border-radius:20px;overflow:hidden;
  border:1px solid var(--card-line);box-shadow:0 18px 40px rgba(0,0,0,.35);
  opacity:.4;transform:scale(.9);transition:opacity .5s, transform .5s;cursor:pointer}
.slide.is-active{opacity:1;transform:scale(1);box-shadow:0 24px 60px rgba(124,92,255,.3);
  border-color:rgba(124,92,255,.5)}
.slide img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(1.05)}
.slide figcaption{position:absolute;left:0;right:0;bottom:0;padding:48px 26px 20px;
  font-family:'Unbounded',sans-serif;font-weight:600;color:#fff;
  font-size:clamp(15px,2.2vw,22px);text-shadow:0 2px 12px rgba(0,0,0,.6);
  opacity:0;transition:opacity .45s;
  background:linear-gradient(180deg,transparent,rgba(7,11,28,.88))}
.slide.is-active figcaption{opacity:1}
/* стрелки */
.slider__arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;
  width:48px;height:48px;border-radius:50%;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:26px;line-height:1;color:#fff;
  background:rgba(7,11,28,.55);border:1px solid var(--card-line);backdrop-filter:blur(6px);
  transition:background .2s, border-color .2s, transform .2s}
.slider__arrow:hover{background:rgba(124,92,255,.55);border-color:var(--neon);transform:translateY(-50%) scale(1.08)}
.slider__arrow--prev{left:14px}
.slider__arrow--next{right:14px}
/* точки */
.slider__dots{display:flex;gap:9px;justify-content:center;margin-top:18px;flex-wrap:wrap}
.slider__dot{width:9px;height:9px;border-radius:50%;cursor:pointer;border:none;padding:0;
  background:rgba(255,255,255,.25);transition:background .25s, transform .25s, width .25s}
.slider__dot:hover{background:rgba(255,255,255,.5)}
.slider__dot.is-active{background:linear-gradient(135deg,#9a7bff,#6c44e8);width:26px;border-radius:999px}

/* Фото в карточке даты */
.date-card__media{margin:-22px -18px 0;height:120px;overflow:hidden;position:relative}
.date-card__media img{width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .4s ease;filter:saturate(1.05) brightness(.92)}
.date-card:hover .date-card__media img{transform:scale(1.06)}
.date-card__media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 40%, var(--bg))}

.dates{max-width:1180px;margin:0 auto;padding:50px clamp(16px,5vw,64px)}
.dates__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:36px;align-items:stretch}
.date-card{position:relative;background:var(--card);border:1px solid var(--card-line);
  border-radius:var(--radius);padding:22px 18px;transition:transform .18s, border-color .2s, box-shadow .25s;
  display:flex;flex-direction:column;gap:14px;overflow:hidden;min-height:100%}
.date-card::after{content:"";position:absolute;inset:0;opacity:0;transition:opacity .25s;pointer-events:none;
  background:radial-gradient(300px 150px at 50% 0, rgba(124,92,255,.25), transparent 70%)}
.date-card:hover{transform:translateY(-4px);border-color:var(--neon);box-shadow:0 18px 40px rgba(124,92,255,.25)}
.date-card:hover::after{opacity:1}
.date-card.is-selected{border-color:var(--neon);box-shadow:0 0 0 2px rgba(124,92,255,.45), 0 18px 40px rgba(124,92,255,.25)}
.date-card__top{display:flex;flex-direction:column;gap:4px;padding-right:80px}
.date-card__weekday{color:#a78bff;font-size:12px;text-transform:uppercase;letter-spacing:.1em;font-weight:700;white-space:nowrap}
.date-card__time{color:var(--muted);font-size:13px;white-space:nowrap}
.date-card__date{font-family:'Unbounded',sans-serif;font-size:40px;line-height:1;font-weight:800}
.date-card__date small{font-size:16px;font-weight:400;color:var(--muted);margin-left:6px;font-family:'Manrope',sans-serif}
/* Погодная плашка — неоновая, с анимированной иконкой статуса */
.date-card__weather{display:grid;grid-template-columns:auto 1fr;align-items:center;
  gap:8px 12px;padding:12px 14px;border-radius:14px;position:relative;overflow:hidden;
  background:linear-gradient(180deg,rgba(124,92,255,.12),rgba(255,255,255,.03));
  border:1px solid rgba(124,92,255,.24)}
.wx__icon{width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;
  color:var(--neon-2);filter:drop-shadow(0 0 7px rgba(40,224,200,.6));transition:opacity .3s}
.wx__icon svg{width:40px;height:40px;overflow:visible}
.wx__icon.is-loading{opacity:.45}
.wx__main{min-width:0}
.wx__temp{font-weight:800;font-size:19px;line-height:1;font-family:'Unbounded',sans-serif;
  font-variant-numeric:tabular-nums}
.wx__text{font-size:12.5px;color:var(--muted);margin-top:4px;line-height:1.25}
.wx__prec{grid-column:1 / -1;display:flex;align-items:center;gap:7px;
  font-size:12px;color:#9fe6db;font-variant-numeric:tabular-nums;
  padding-top:9px;margin-top:2px;border-top:1px solid rgba(255,255,255,.09)}
.wx__prec .wx__drop{width:14px;height:14px;color:var(--neon-2);flex:none}
.wx__prec b{color:#cfeee9;font-weight:700}
.wx__prec .wx__muted{color:var(--muted);margin-left:auto;font-size:11px;letter-spacing:.02em}
/* --- анимации погодных иконок --- */
@keyframes wxPulse{0%,100%{opacity:.82}50%{opacity:1}}
@keyframes wxTwinkle{0%,100%{opacity:.2;transform:scale(.6)}50%{opacity:1;transform:scale(1)}}
@keyframes wxDriftX{0%,100%{transform:translateX(-1.4px)}50%{transform:translateX(1.8px)}}
@keyframes wxFog{0%,100%{transform:translateX(-2px)}50%{transform:translateX(2px)}}
@keyframes wxRain{0%{transform:translateY(-3px);opacity:0}25%{opacity:1}100%{transform:translateY(8px);opacity:0}}
.wx-disk{animation:wxPulse 3.5s ease-in-out infinite;transform-origin:center}
.wx-tw{animation:wxTwinkle 2.4s ease-in-out infinite;transform-box:fill-box;transform-origin:center}
.wx-cloud{animation:wxDriftX 4s ease-in-out infinite}
.wx-fog{animation:wxFog 3s ease-in-out infinite}
.wx-drop{animation:wxRain 1.2s linear infinite}
@media (prefers-reduced-motion:reduce){
  .wx-disk,.wx-tw,.wx-cloud,.wx-fog,.wx-drop{animation:none}
}
.date-card__price{display:flex;align-items:baseline;justify-content:space-between;
  margin-top:auto;padding-top:12px;border-top:1px solid var(--card-line);
  color:var(--muted);font-size:14px}
.date-card__price strong{color:#fff;font-family:'Unbounded',sans-serif;font-weight:600;font-size:19px}
.date-card__cta{margin-top:14px}
.badge{position:absolute;top:14px;right:14px;font-size:11px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;padding:5px 10px;border-radius:999px;z-index:2}
.badge--open{background:rgba(124,92,255,.18);color:#bcaaff;border:1px solid rgba(124,92,255,.5)}
.badge--soldout{background:rgba(255,95,162,.15);color:var(--neon-pink);border:1px solid rgba(255,95,162,.4)}
.date-card.is-soldout{opacity:.6;cursor:not-allowed}
.date-card.is-soldout:hover{transform:none;border-color:var(--card-line);box-shadow:none}

/* ---------- Лид-форма ---------- */
.lead{max-width:560px;margin:30px auto;padding:40px clamp(16px,5vw,40px)}
.lead__card{background:linear-gradient(180deg, rgba(124,92,255,.10), rgba(255,255,255,.03));
  border:1px solid var(--card-line);border-radius:24px;padding:clamp(24px,5vw,40px);box-shadow:var(--shadow)}
.field{margin-top:18px;display:flex;flex-direction:column;gap:7px}
.field label{font-size:13px;color:var(--muted);font-weight:500}
.field input,.field select{font-family:inherit;font-size:16px;color:var(--ink);
  background:rgba(0,0,0,.25);border:1px solid var(--card-line);border-radius:12px;padding:14px 16px;
  transition:border-color .2s, box-shadow .2s}
.field input::placeholder{color:#6c75a6}
.field input:focus,.field select:focus{outline:none;border-color:var(--neon);box-shadow:0 0 0 3px rgba(124,92,255,.22)}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%239aa3cf' viewBox='0 0 16 16'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
.field input.invalid,.field select.invalid{border-color:var(--neon-pink);box-shadow:0 0 0 3px rgba(255,95,162,.15)}
.consent{display:flex;gap:10px;align-items:flex-start;margin-top:20px;font-size:13px;color:var(--muted);cursor:pointer}
.consent input{margin-top:3px;accent-color:var(--neon)}
.consent a{color:#a78bff;text-decoration:underline;text-underline-offset:2px}
.consent a:hover{color:#fff}
#submit-btn{margin-top:24px}
.form-error{color:var(--neon-pink);font-size:14px;margin-top:14px;min-height:1em;text-align:center}

/* ---------- Footer + неоновый эквалайзер ---------- */
.footer{position:relative;z-index:1;text-align:center;padding:46px 16px 52px;
  color:var(--muted);font-size:13px}
/* лёгкая подложка, чтобы текст читался над сценой парка */
.footer::before{content:"";position:absolute;left:50%;top:0;transform:translateX(-50%);
  width:min(620px,94%);height:100%;z-index:-1;pointer-events:none;
  background:radial-gradient(62% 72% at 50% 38%, rgba(7,11,28,.72), transparent 76%)}
.sky--off{display:none!important}
/* Эквалайзер — на всю ширину экрана (full-bleed) */
.eq{display:flex;align-items:flex-end;justify-content:center;gap:5px;
  height:58px;width:100vw;margin-left:calc(50% - 50vw);margin-bottom:26px;padding:0 14px}
.eq__bar{flex:1 1 0;max-width:16px;min-width:3px;height:100%;border-radius:6px;transform-origin:bottom;
  background:linear-gradient(180deg,var(--neon-2) 0%,var(--neon) 56%,var(--neon-pink) 100%);
  box-shadow:0 0 8px rgba(124,92,255,.55), 0 0 2px rgba(40,224,200,.6);
  animation:eqBounce var(--eq-dur,1.1s) ease-in-out var(--eq-delay,0s) infinite}
@keyframes eqBounce{0%,100%{transform:scaleY(var(--eq-min,.2))}50%{transform:scaleY(1)}}
.footer__line{font-size:13.5px;color:var(--ink);opacity:.92}
.footer__line span{color:var(--muted)}
.footer__muted{opacity:.66;margin-top:9px;font-size:12.5px}
.footer__muted a{color:#a78bff;text-decoration:none;white-space:nowrap}
.footer__muted a:hover{color:#fff;text-decoration:underline}
@media (prefers-reduced-motion:reduce){.eq__bar{animation:none;transform:scaleY(.55)}}

/* ---------- Спасибо ---------- */
.thanks{max-width:560px;text-align:center;padding:60px clamp(20px,6vw,40px)}
.thanks__icon{display:inline-flex;color:#cdd4ff;filter:drop-shadow(0 0 24px rgba(170,180,255,.6));animation:float 4s ease-in-out infinite}
.thanks__icon svg{width:64px;height:64px;fill:none;stroke:currentColor}
.thanks__line{display:flex;gap:10px;align-items:flex-start}
.thanks__line .ico{width:20px;height:20px;flex:none;margin-top:3px;color:var(--neon-2)}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.thanks__title{font-family:'Unbounded',sans-serif;font-weight:800;font-size:clamp(28px,6vw,46px);margin-top:18px;
  text-shadow:0 0 30px rgba(124,92,255,.55)}
.thanks__lead{color:var(--ink);font-size:18px;margin-top:14px}
.thanks__card{margin-top:26px;background:var(--card);border:1px solid var(--card-line);border-radius:var(--radius);
  padding:24px;text-align:left}
.thanks__card p{margin:0}
.thanks__muted{color:var(--muted);font-size:14px;margin-top:10px!important}
.thanks__summary{margin:22px 0;display:grid;gap:8px;text-align:left;background:rgba(0,0,0,.2);
  border:1px dashed var(--card-line);border-radius:12px;padding:18px;font-size:14px}
.thanks__summary .row{display:flex;justify-content:space-between;gap:16px}
.thanks__summary .row span:first-child{color:var(--muted)}
.thanks .btn{margin-top:14px}

/* ---------- Загрузка кнопки ---------- */
.btn.is-loading{pointer-events:none;opacity:.75}
.btn.is-loading::after{content:"";width:16px;height:16px;border:2px solid rgba(10,10,26,.4);
  border-top-color:#0a0a1a;border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ============================================================
   SVG-ИКОНКИ (outline, currentColor) — заменяют все эмодзи
   ============================================================ */
.icon-sprite{position:absolute;width:0;height:0;overflow:hidden}
.ico{width:1.15em;height:1.15em;flex:none;display:inline-block;vertical-align:-0.18em;
  fill:none;stroke:currentColor;color:inherit}
.hero__eyebrow{display:inline-flex;align-items:center;gap:9px}
.hero__eyebrow .ico{width:15px;height:15px;color:#b9a3ff}
.hero__marquee li .ico{width:20px;height:20px;color:var(--neon-2)}
.hero__marquee li span{line-height:1}

/* ============================================================
   ЗАПРЕТ ВЫДЕЛЕНИЯ ТЕКСТА (поля формы — исключение)
   ============================================================ */
body{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;
  -webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}
input,textarea,select,[contenteditable="true"]{
  -webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}

/* ============================================================
   ТИПОГРАФИКА — тонкая настройка (kerning, лигатуры, перенос строк,
   таблично-выровненные цифры, флюидный ритм)
   ============================================================ */
html{-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;font-kerning:normal;
  font-feature-settings:"kern" 1,"liga" 1,"calt" 1;
  font-variant-ligatures:common-ligatures contextual;
  letter-spacing:.002em;
}
/* Балансировка заголовков и «красивый» перенос абзацев */
.hero__title,.section-title,.thanks__title,.how__step h3,.slide figcaption{
  text-wrap:balance;font-kerning:normal}
.hero__lead,.section-sub,.how__step p,.thanks__lead,.thanks__card p{text-wrap:pretty}
/* Цифры — табличные, чтобы даты/цены/телефон не «прыгали» */
.date-card__date,.date-card__price,.topbar__phone,.thanks__summary,.how__num{
  font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1,"kern" 1}

/* HERO: усиленная дисплейная типографика */
.hero__title{font-weight:800;line-height:.88;letter-spacing:-.035em;
  font-size:clamp(58px,14.5vw,164px)}
.hero__title span{letter-spacing:.015em;line-height:.92;margin-top:.04em}
.hero__eyebrow{font-size:11.5px;letter-spacing:.18em}
.hero__ru{letter-spacing:.46em}
.hero__lead{font-size:clamp(16px,1.4vw,20px);line-height:1.6;
  max-width:46ch;margin-left:auto;margin-right:auto;text-wrap:pretty}

/* Заголовки секций — крупнее, плотнее, с воздухом */
.section-title{font-weight:700;line-height:1.04;letter-spacing:-.02em;
  font-size:clamp(28px,4.2vw,46px)}
.section-sub{font-size:clamp(15px,1.2vw,17px);line-height:1.55;
  max-width:52ch;margin-left:auto;margin-right:auto}
.section-sub--left{margin-left:0}
.how__step h3{font-family:'Unbounded',sans-serif;font-weight:600;letter-spacing:-.01em;
  font-size:clamp(18px,1.6vw,21px);line-height:1.2}
.how__num{font-weight:600;letter-spacing:.14em}
.date-card__date{letter-spacing:-.02em}
.thanks__lead{font-size:clamp(17px,1.4vw,19px);line-height:1.6}

@media (max-width:920px){
  .dates__grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:600px){
  .moon{width:80px;height:80px;top:6%;right:8%}
  .hero__marquee{gap:12px}
  .dates__grid{grid-template-columns:1fr}
  .sky{height:min(34vh,280px)}
  .slider__arrow{width:38px;height:38px;font-size:20px}
  .slider__arrow--prev{left:8px}
  .slider__arrow--next{right:8px}
  .slide{flex-basis:84%}
  .slider__track{gap:12px}
  /* компактная шапка: оставляем логотип и телефон, даём запас чтобы телефон не уезжал */
  .brand__dot,.brand__sub{display:none}
  .topbar__actions .btn{display:none}
  .topbar{padding:12px 14px;gap:10px}
  .brand{min-width:0;flex:0 1 auto}
  .brand__logo{height:26px}
  .topbar__actions{flex:0 0 auto}
  .topbar__phone{font-size:13px;gap:6px}
  .topbar__phone .ico{width:15px;height:15px}

  /* облегчаем hero: меньше отступы и компактнее плашки-маркеры */
  .hero{padding-top:76px;padding-bottom:56px}
  .hero__eyebrow{margin-bottom:14px}
  .hero__lead{margin-top:16px}
  .hero__cta{margin-top:26px}
  .hero__marquee{gap:8px;margin-top:24px;font-size:13px}
  .hero__marquee li{padding:9px 14px;gap:6px}
  .hero__marquee .ico{width:15px;height:15px}
}
