
/* ==========================================================
   wowpovod.ru — premium event landing
   build: 2026-05-22 · rev 2 (rebrand · galkin · weather · parallax)
   ========================================================== */

:root{
  --font-display:  'Bricolage Grotesque', -apple-system, BlinkMacSystemFont, "SF Pro Display", "Helvetica Neue", Arial, sans-serif;
  --font-accent:   'Onest', -apple-system, BlinkMacSystemFont, "SF Pro Display", "Helvetica Neue", Arial, sans-serif;
  --font-text:     'Inter', -apple-system, BlinkMacSystemFont, "SF Pro Text", "Helvetica Neue", Arial, sans-serif;
  --font-mono:     'JetBrains Mono', ui-monospace, "SF Mono", Menlo, Monaco, Consolas, monospace;

  /* golden ratio scale (φ ≈ 1.618, Fibonacci-based) */
  --s-0: 5px;
  --s-1: 8px;
  --s-2: 13px;
  --s-3: 21px;
  --s-4: 34px;
  --s-5: 55px;
  --s-6: 89px;
  --s-7: 144px;
  --s-8: 233px;
  --phi: 1.618;
  --marquee-h: 92px;

  --bg-0:#000;
  --bg-1:#06060a;
  --bg-2:#0d0d12;
  --bg-3:#16161d;

  --surface:rgba(255,255,255,.04);
  --surface-2:rgba(255,255,255,.07);
  --surface-3:rgba(255,255,255,.10);
  --stroke:rgba(255,255,255,.09);
  --stroke-2:rgba(255,255,255,.16);

  --text-0:#f6f6f8;
  --text-1:#d4d4d8;
  --text-2:#9e9ea6;
  --text-3:#6f6f78;

  /* brand */
  --cyan:#1ec8e6;
  --cyan-bright:#64e0ff;
  --blue:#0a84ff;
  --indigo:#5e5ce6;
  --purple:#bf5af2;
  --pink:#ff375f;
  --coral:#ff6b6b;
  --orange:#ff9f0a;
  --gold:#ffd60a;
  --green:#30d158;
  --mint:#63e6e2;

  --maxw:1280px;
  --gutter:24px;
  --section-pad:89px;   /* φ: s-6 ≈ 89, total between sections = 178px */
  --nav-h:68px;

  --ease-out:cubic-bezier(.16,1,.3,1);
  --ease-out-quart:cubic-bezier(.25,1,.5,1);
  --ease-spring:cubic-bezier(.34,1.4,.64,1);
  --ease-soft:cubic-bezier(.4,0,.2,1);
}

/* 4K monitors — section spacing follows φ (s-7=144, s-8=233) */
@media (min-width:2200px){
  :root{
    --maxw:1600px;
    --gutter:32px;
    --section-pad:144px;
    --nav-h:80px;
  }
  html{font-size:18px}
}
@media (min-width:3000px){
  :root{
    --maxw:2000px;
    --gutter:48px;
    --section-pad:233px;
    --nav-h:96px;
  }
  html{font-size:20px}
}

/* ==========================================================
   RESET
   ========================================================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{
  scroll-behavior:smooth;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  background:var(--bg-0);
  overflow-x:clip;
  scrollbar-color:#5e5ce6 rgba(255,255,255,.02);
  scrollbar-width:thin;
  -webkit-text-size-adjust:100%;
}
body{
  background:var(--bg-0);
  color:var(--text-0);
  font-family:var(--font-text);
  font-size:17px; line-height:1.55; letter-spacing:-.011em;
  overflow-x:clip; width:100%;
  font-feature-settings:"cv11","ss03","tnum","calt","case";
  font-optical-sizing:auto;
  position:relative;
  isolation:isolate;
  /* No text selection */
  -webkit-user-select:none;
  -moz-user-select:none;
  -ms-user-select:none;
  user-select:none;
  -webkit-touch-callout:none;
}
::selection{background:transparent;color:inherit}
img,svg,video{display:block;max-width:100%;-webkit-user-drag:none;user-select:none;pointer-events:none}
a,button{pointer-events:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
section[id]{scroll-margin-top:100px}

/* ==========================================================
   SCROLLBAR
   ========================================================== */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:rgba(255,255,255,.02)}
::-webkit-scrollbar-thumb{
  background:linear-gradient(180deg,#1ec8e6 0%,#5e5ce6 35%,#bf5af2 70%,#ff375f);
  border-radius:5px;border:2px solid #000;background-clip:padding-box;min-height:40px;
}
::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#64e0ff 0%,#bf5af2 50%,#ff375f);background-clip:padding-box}

/* ==========================================================
   CURSOR
   ========================================================== */
@media (hover:hover) and (pointer:fine){
  html{
    cursor: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='28' height='28' viewBox='0 0 28 28'><defs><linearGradient id='g' x1='0' y1='0' x2='1' y2='1'><stop offset='0%25' stop-color='%231ec8e6'/><stop offset='50%25' stop-color='%23bf5af2'/><stop offset='100%25' stop-color='%23ff375f'/></linearGradient><filter id='s' x='-50%25' y='-50%25' width='200%25' height='200%25'><feDropShadow dx='0' dy='1' stdDeviation='1.4' flood-color='black' flood-opacity='0.55'/></filter></defs><g transform='rotate(-22 14 14)'><path d='M14 3 L24 23 L14 18 L4 23 Z' fill='url(%23g)' stroke='white' stroke-width='1.1' stroke-linejoin='round' filter='url(%23s)'/></g></svg>") 10 4, auto;
  }
  a, button, .card, .niche, .venue, .level, .faq summary, .tab, .nav-link, .cta, .phone-cta, .magnetic{
    cursor: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='34' height='34' viewBox='0 0 34 34'><defs><linearGradient id='g' x1='0' y1='0' x2='1' y2='1'><stop offset='0%25' stop-color='%2364e0ff'/><stop offset='50%25' stop-color='%23bf5af2'/><stop offset='100%25' stop-color='%23ff375f'/></linearGradient><filter id='s' x='-50%25' y='-50%25' width='200%25' height='200%25'><feDropShadow dx='0' dy='2' stdDeviation='2.5' flood-color='%231ec8e6' flood-opacity='0.7'/></filter></defs><g transform='rotate(-22 17 17)'><path d='M17 3 L29 27 L17 21 L5 27 Z' fill='url(%23g)' stroke='white' stroke-width='1.4' stroke-linejoin='round' filter='url(%23s)'/></g></svg>") 12 4, pointer;
  }
}

/* ==========================================================
   LAYOUT
   ========================================================== */
.wrap{
  width:100%; max-width:var(--maxw); margin:0 auto;
  padding-left:max(var(--gutter), env(safe-area-inset-left));
  padding-right:max(var(--gutter), env(safe-area-inset-right));
  position:relative;
}
.section{padding:var(--section-pad) 0; position:relative; isolation:isolate}
.section--tight{padding:80px 0}

/* ==========================================================
   TYPOGRAPHY
   ========================================================== */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:760;letter-spacing:-.034em;line-height:1.02;font-style:normal}
h1{font-size:clamp(40px, 4.6vw, 78px);font-weight:800;letter-spacing:-.044em;line-height:.96;font-variation-settings:"opsz" 96}
h2{font-size:clamp(34px, 5.0vw, 78px);font-weight:740;letter-spacing:-.036em;line-height:.98;font-variation-settings:"opsz" 64}
h3{font-size:clamp(22px, 2.4vw, 36px);font-weight:680;letter-spacing:-.024em;line-height:1.1;font-variation-settings:"opsz" 32}
h4{font-size:19px;font-weight:620;letter-spacing:-.014em;line-height:1.18}

/* Onest accent — same sans-serif family principle (no serifs anywhere) */
.fr{
  font-family:var(--font-accent);
  font-weight:600;
  letter-spacing:-.022em;
  font-style:normal;
}

.lead{font-family:var(--font-display);font-size:clamp(18px,1.55vw,22px);font-weight:450;line-height:1.5;letter-spacing:-.012em;color:var(--text-1);max-width:62ch}
.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}
.num{font-family:var(--font-display);font-variant-numeric:tabular-nums;font-feature-settings:"tnum","ss01"}

.grad-text{background:linear-gradient(180deg,#fff 0%,#a9a9b0 130%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.ac-cyan{background:linear-gradient(120deg,#1ec8e6,#64e0ff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.ac-purple{background:linear-gradient(120deg,#bf5af2,#ff375f);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.ac-warm{background:linear-gradient(120deg,#ff9f0a,#ff375f);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.ac-rainbow{background:linear-gradient(120deg,#1ec8e6,#5e5ce6 35%,#bf5af2 60%,#ff375f);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}

/* ==========================================================
   EYEBROW (redesigned: line + mono number + label)
   ========================================================== */
.eyebrow{
  display:inline-flex;align-items:center;gap:16px;
  padding:6px 0;
  font-family:var(--font-text);
}
.eyebrow .line{
  width:42px;height:1.6px;flex-shrink:0;
  background:linear-gradient(90deg,#1ec8e6,#bf5af2,#ff375f);
  border-radius:2px;
  position:relative;
}
.eyebrow .line::after{
  content:"";position:absolute;right:-6px;top:50%;transform:translateY(-50%);
  width:8px;height:8px;border-radius:50%;
  background:#ff375f;box-shadow:0 0 0 4px rgba(255,55,95,.16),0 0 12px rgba(255,55,95,.6);
}
.eyebrow .n{
  font-family:var(--font-mono);font-size:12px;font-weight:500;color:var(--text-3);
  letter-spacing:.02em;
}
.eyebrow .l{
  font-family:var(--font-accent);font-weight:500;font-size:15px;color:var(--text-1);letter-spacing:-.005em;
  font-variation-settings:"opsz" 14;
}

/* ==========================================================
   NAV
   ========================================================== */
.nav{
  position:fixed;inset:0 0 auto 0;height:var(--nav-h);z-index:90;
  display:flex;align-items:center;
  background:linear-gradient(180deg, rgba(6,6,10,.78), rgba(6,6,10,.35) 80%, transparent);
  backdrop-filter: saturate(160%) blur(20px);
  -webkit-backdrop-filter: saturate(160%) blur(20px);
  transition: background .3s var(--ease-out), border-color .3s var(--ease-out);
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(6,6,10,.82);
  border-bottom-color:var(--stroke);
}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px;width:100%}
/* ---- nav logo (animated mark + wordmark) ---- */
.nav-logo{
  display:flex;align-items:center;gap:12px;flex-shrink:0;
  font-family:var(--font-display);font-weight:800;font-size:22px;letter-spacing:-.034em;color:#fff;
  position:relative;
}
.nav-logo svg.mark{width:36px;height:36px;flex-shrink:0;overflow:visible}
.nav-logo .mark-bg{transition: fill .4s var(--ease-out)}
.nav-logo .mark-star{
  transform-origin:50% 50%;
  transform-box:view-box;
  animation: starSpin 16s linear infinite;
  filter: drop-shadow(0 0 6px rgba(30,200,230,.35));
  transition: filter .45s var(--ease-out), animation-duration .45s var(--ease-out);
}
.nav-logo .mark-star path{transform-origin:50% 50%;transform-box:view-box}
@keyframes starSpin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes starPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
.nav-logo .mark-star path{animation: starPulse 4.2s ease-in-out infinite}
.nav-logo span{
  position:relative;display:inline-block;
  background:linear-gradient(120deg, #fff 0%, #f6f6f8 50%, #fff 100%);
  background-size:200% 100%;
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  transition: filter .4s var(--ease-out);
}
.nav-logo span::after{
  content:"wowpovod";position:absolute;inset:0;
  background:linear-gradient(120deg, #1ec8e6 0%, #bf5af2 50%, #ff375f 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  opacity:0;transition: opacity .4s var(--ease-out);
  pointer-events:none;
}
.nav-logo:hover .mark-star{animation-duration:3s;filter: drop-shadow(0 0 14px rgba(191,90,242,.7))}
.nav-logo:hover span::after{opacity:1}

/* ---- nav links (top-tier hover) ---- */
.nav-links{display:flex;align-items:center;gap:30px}
.nav-link{
  font-size:14px;color:var(--text-1);font-weight:500;letter-spacing:-.005em;
  position:relative;padding:8px 2px;
  font-family:var(--font-text);display:inline-block;
  transition: color .35s var(--ease-out), transform .4s var(--ease-spring);
}
.nav-link::before{
  content:"";position:absolute;left:50%;top:0;width:4px;height:4px;border-radius:50%;
  background:var(--cyan);
  box-shadow:0 0 10px var(--cyan), 0 0 4px #fff inset;
  transform:translate(-50%, -4px) scale(0);
  transition: transform .45s var(--ease-spring), opacity .35s var(--ease-out);
  opacity:0;
}
.nav-link::after{
  content:"";position:absolute;left:50%;right:50%;bottom:2px;height:1.6px;
  background:linear-gradient(90deg,#1ec8e6,#bf5af2,#ff375f);
  border-radius:2px;
  transition: left .45s var(--ease-out), right .45s var(--ease-out), opacity .35s var(--ease-out);
  opacity:0;
}
.nav-link:hover{color:#fff;transform:translateY(-1.5px)}
.nav-link:hover::after{left:0;right:0;opacity:1}
.nav-link:hover::before{transform:translate(-50%, -2px) scale(1);opacity:1}

/* ---- nav phone (no pulse · phone icon · ring waves · gradient border shimmer) ---- */
.nav-phone{
  display:inline-flex;align-items:center;gap:11px;
  padding:8px 20px 8px 8px;border-radius:999px;
  font-family:var(--font-mono);font-weight:500;font-size:14px;letter-spacing:.01em;
  background:linear-gradient(135deg, rgba(30,200,230,.14), rgba(191,90,242,.14));
  border:1px solid transparent;
  color:#fff;
  position:relative;overflow:hidden;isolation:isolate;
  transition: transform .35s var(--ease-spring), background .4s var(--ease-out), box-shadow .45s var(--ease-out);
}
.nav-phone::before{
  content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1.6px;
  background: linear-gradient(120deg, #1ec8e6 0%, #5e5ce6 25%, #bf5af2 50%, #ff375f 75%, #ff9f0a 100%);
  background-size: 280% 280%;
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  animation: phoneBorder 7s linear infinite;
  pointer-events:none;
}
@keyframes phoneBorder{
  0%{background-position:0% 50%}
  100%{background-position:200% 50%}
}
.nav-phone:hover{
  transform:translateY(-2px);
  background:linear-gradient(135deg, rgba(30,200,230,.22), rgba(191,90,242,.22));
  box-shadow: 0 14px 36px -10px rgba(30,200,230,.4), 0 8px 22px -10px rgba(191,90,242,.32);
}
.nav-phone .pico{
  position:relative;width:34px;height:34px;border-radius:50%;flex-shrink:0;
  display:grid;place-items:center;
  background:linear-gradient(135deg, rgba(30,200,230,.4), rgba(191,90,242,.4));
  border:1px solid rgba(255,255,255,.22);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.22), 0 4px 14px -4px rgba(30,200,230,.6);
  z-index:1;
}
.nav-phone .pico svg{
  width:15px;height:15px;color:#fff;
  animation: phoneShake 5s ease-in-out infinite;
  will-change: transform;
}
.nav-phone .pico::before, .nav-phone .pico::after{
  content:"";position:absolute;inset:0;border-radius:50%;
  border:1.4px solid var(--cyan);
  opacity:0;
  animation: phoneRing 2.6s var(--ease-out) infinite;
  pointer-events:none;
  z-index:-1;
}
.nav-phone .pico::after{
  animation-delay: 1.3s;
  border-color: var(--purple);
}
@keyframes phoneRing{
  0%{transform:scale(.8);opacity:.85}
  70%{opacity:0}
  100%{transform:scale(2.8);opacity:0}
}
.nav-phone:hover .pico::before, .nav-phone:hover .pico::after{animation-duration:1.5s}
.nav-phone:hover .pico svg{animation-duration:1.2s}
.nav-phone .phone-text{position:relative;z-index:1;font-variant-numeric:tabular-nums}

/* ==========================================================
   SCROLL PROGRESS BAR — under nav, gradient fill width = scroll %
   ========================================================== */
.scroll-progress{
  position:fixed;
  top: var(--nav-h);
  left:0;right:0;
  height:3px;
  z-index: 89;
  background:rgba(255,255,255,.04);
  pointer-events:none;
  overflow:hidden;
}
.scroll-progress-bar{
  height:100%;width:0%;
  background:linear-gradient(90deg, #1ec8e6 0%, #5e5ce6 35%, #bf5af2 65%, #ff375f 100%);
  box-shadow:
    0 0 12px rgba(30,200,230,.55),
    0 0 6px rgba(191,90,242,.4);
  border-radius:0 3px 3px 0;
  transition: width .08s linear;
  position:relative;
  overflow:hidden;
}
.scroll-progress-bar::after{
  /* travelling shimmer dot */
  content:"";position:absolute;
  top:0;bottom:0;right:0;width:30px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.85), transparent);
  filter:blur(2px);
  animation: progressShimmer 1.8s linear infinite;
}
@keyframes progressShimmer{
  0%   { transform: translateX(-40px); opacity: 0; }
  20%  { opacity: 1; }
  80%  { opacity: 1; }
  100% { transform: translateX(30px); opacity: 0; }
}

/* ==========================================================
   PARALLAX LAYERS (global background)
   ========================================================== */
.bg-mesh{
  position:fixed;inset:-10%;z-index:-2;pointer-events:none;
  background:
    radial-gradient(ellipse 50% 38% at 18% 22%, rgba(30,200,230,.20), transparent 60%),
    radial-gradient(ellipse 45% 35% at 82% 18%, rgba(191,90,242,.18), transparent 60%),
    radial-gradient(ellipse 55% 45% at 50% 88%, rgba(255,55,95,.14), transparent 60%),
    radial-gradient(ellipse 38% 30% at 10% 85%, rgba(255,159,10,.12), transparent 60%);
  filter:saturate(1.1);
  animation: meshDrift 28s ease-in-out infinite alternate;
  will-change:transform;
}
@keyframes meshDrift{
  0%{background-position:0% 0%, 100% 0%, 50% 100%, 0% 100%}
  100%{background-position:5% 3%, 95% -2%, 55% 95%, -2% 95%}
}
.bg-grid{
  position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.30;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: radial-gradient(circle at 50% 30%, #000 30%, transparent 80%);
  -webkit-mask-image: radial-gradient(circle at 50% 30%, #000 30%, transparent 80%);
}
.spotlight{
  position:fixed;inset:0;z-index:1;pointer-events:none;
  background: radial-gradient(280px 280px at var(--mx,50%) var(--my,50%), rgba(30,200,230,.10), transparent 70%);
  transition: opacity .4s var(--ease-out);
  mix-blend-mode: screen;
  opacity:0;
}
@media (hover:hover) and (pointer:fine){
  .spotlight{opacity:1}
}

/* ==========================================================
   HERO — fold-fit: nav + hero + marquee = 100vh
   spacing on Fibonacci/φ scale (s-1..s-7)
   ========================================================== */
.hero{
  padding: calc(var(--nav-h) + var(--s-3)) 0 var(--s-3);
  min-height: calc(100vh - var(--marquee-h));
  height: calc(100vh - var(--marquee-h));
  display:flex;align-items:center;
  position:relative;isolation:isolate;
  overflow:hidden;
}
.hero .wrap{max-width:1340px;width:100%}
.hero-grid{display:grid;grid-template-columns:1fr;gap:var(--s-3);align-items:center}

/* ---- looping iframe background (Rutube embed) ---- */
.hero-bg{
  position:absolute;inset:0;z-index:-3;overflow:hidden;pointer-events:none;
  background:#06060a;
}
/* fallback when iframe is removed (mobile / VPN-friendly) */
.hero-bg--no-video{
  background:
    radial-gradient(ellipse 70% 50% at 20% 20%, rgba(30,200,230,.32), transparent 60%),
    radial-gradient(ellipse 60% 50% at 80% 30%, rgba(94,92,230,.30), transparent 60%),
    radial-gradient(ellipse 70% 60% at 50% 90%, rgba(191,90,242,.28), transparent 65%),
    radial-gradient(ellipse 60% 55% at 90% 90%, rgba(255,55,95,.22), transparent 65%),
    linear-gradient(180deg, #0a0a14 0%, #14081e 60%, #0a0a14 100%);
  animation: heroBgDrift 24s ease-in-out infinite alternate;
}
@keyframes heroBgDrift{
  0%   { background-position: 0% 0%, 100% 0%, 50% 100%, 100% 100%, 0% 0%; }
  100% { background-position: 4% 2%, 96% -2%, 55% 95%, 95% 96%, 0% 0%; }
}
.hero-bg iframe{
  position:absolute;
  top:50%;left:50%;
  width: max(100%, 177.78vh);
  height: max(56.25vw, 100%);
  min-width:100%;min-height:100%;
  transform: translate(-50%, -50%) scale(1.06);
  border:0;
  pointer-events:none;
  filter: saturate(1.05) contrast(1.04);
}
/* veil: сильное затемнение, чтобы перебить яркость видео и держать текст читаемым */
.hero-veil{
  position:absolute;inset:0;z-index:-2;pointer-events:none;
  background:
    /* центральное затемнение — перекрывает Rutube play-кнопку и держит контраст для CTA */
    radial-gradient(circle 320px at 50% 50%, rgba(6,6,10,.85) 0%, rgba(6,6,10,.55) 60%, transparent 100%),
    /* верх → низ: общее затемнение */
    linear-gradient(180deg,
      rgba(6,6,10,.78) 0%,
      rgba(6,6,10,.58) 18%,
      rgba(6,6,10,.50) 50%,
      rgba(6,6,10,.72) 82%,
      rgba(6,6,10,.93) 100%),
    /* левая половина — приоритетная для текста, дополнительное затемнение */
    linear-gradient(90deg, rgba(6,6,10,.42) 0%, rgba(6,6,10,.10) 55%, rgba(6,6,10,0) 80%),
    /* лёгкая брендовая тонировка */
    radial-gradient(ellipse 80% 60% at 70% 30%, rgba(94,92,230,.10), transparent 70%);
}

.hero h1{margin-top:var(--s-3);margin-bottom:var(--s-3);max-width:18ch}
.hero h1 .reveal{display:inline-block;overflow:hidden;vertical-align:baseline;padding-bottom:.12em;margin-bottom:-.12em}
.hero h1 .word{
  display:inline-block;
  will-change:transform,opacity,filter;
  /* mouse parallax shift, set by JS */
  transform: translate3d(var(--mxw, 0px), var(--myw, 0px), 0);
  transition: transform .9s var(--ease-out);
}
.hero h1 .fr{
  display:inline-block;
  background:linear-gradient(120deg,#1ec8e6,#bf5af2 55%,#ff375f);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;
  font-family:var(--font-accent);font-weight:700;letter-spacing:-.034em;
  position:relative;
  filter: drop-shadow(0 4px 18px rgba(191,90,242,.32));
}

.hero-sub{
  font-size:clamp(16px,1.16vw,19px);
  color:var(--text-1);
  max-width:55ch;line-height:1.5;
  margin-bottom:var(--s-4);
  font-weight:430;font-family:var(--font-display);
}

.hero-cta-row{display:flex;flex-wrap:wrap;gap:var(--s-2);align-items:center}

/* ---- PRIMARY: phone-cta with multi-layer motion ---- */
.phone-cta{
  position:relative;display:inline-flex;align-items:center;gap:var(--s-2);
  padding:var(--s-3) var(--s-4) var(--s-3) var(--s-3);
  font-family:var(--font-mono);font-weight:500;font-size:clamp(20px, 1.8vw, 26px);letter-spacing:.015em;
  color:#fff;
  background:linear-gradient(135deg, #0e0e16 0%, #1a0d24 100%);
  border-radius:22px;
  overflow:hidden;isolation:isolate;
  transition: transform .35s var(--ease-spring), box-shadow .45s var(--ease-out);
  will-change:transform;
}
.phone-cta::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.8px;
  background: linear-gradient(120deg, #1ec8e6 0%, #5e5ce6 28%, #bf5af2 55%, #ff375f 82%, #ff9f0a 100%);
  background-size: 260% 260%;
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  animation: phoneBorder 7s linear infinite;
  pointer-events:none;
}
/* gradient sweep highlight that travels across button */
.phone-cta::after{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:
    radial-gradient(220px 220px at var(--cx,50%) var(--cy,50%), rgba(30,200,230,.34), transparent 70%),
    linear-gradient(105deg, transparent 30%, rgba(255,255,255,.10) 50%, transparent 70%);
  background-size: 100% 100%, 220% 100%;
  background-position: 0 0, -120% 0;
  opacity:.55;transition: opacity .35s var(--ease-out), background-position .9s var(--ease-out);
  pointer-events:none;mix-blend-mode:screen;
}
.phone-cta:hover{
  transform: translateY(-3px) scale(1.015);
  box-shadow:
    0 28px 70px -12px rgba(30,200,230,.42),
    0 14px 32px -10px rgba(191,90,242,.36),
    0 0 0 1px rgba(255,255,255,.05) inset;
}
.phone-cta:hover::after{opacity:1;background-position: 0 0, 120% 0}
.phone-cta .ico{
  position:relative;width:54px;height:54px;border-radius:16px;flex-shrink:0;
  display:grid;place-items:center;
  background:linear-gradient(135deg, rgba(30,200,230,.32), rgba(191,90,242,.32));
  border:1px solid rgba(255,255,255,.22);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18), 0 6px 18px -4px rgba(30,200,230,.55);
  isolation:isolate;
}
.phone-cta .ico svg{
  width:24px;height:24px;color:#fff;
  animation: phoneShake 5s ease-in-out infinite;
  will-change: transform;
}
.phone-cta .ico::before, .phone-cta .ico::after{
  content:"";position:absolute;inset:0;border-radius:inherit;
  border:1.6px solid var(--cyan);
  opacity:0;animation: ctaRing 2.6s var(--ease-out) infinite;
  pointer-events:none;z-index:-1;
}
.phone-cta .ico::after{animation-delay:1.3s;border-color:var(--purple)}
@keyframes ctaRing{
  0%{transform:scale(.78);opacity:.7}
  70%{opacity:0}
  100%{transform:scale(1.9);opacity:0}
}
.phone-cta:hover .ico svg{animation-duration:1.4s}
.phone-cta:hover .ico::before,
.phone-cta:hover .ico::after{animation-duration:1.6s}
@keyframes phoneShake{
  0%, 90%, 100%{transform:rotate(0deg)}
  92%{transform:rotate(-10deg)}94%{transform:rotate(10deg)}96%{transform:rotate(-7deg)}98%{transform:rotate(5deg)}
}
.phone-cta .label{display:flex;flex-direction:column;align-items:flex-start;gap:4px;line-height:1;min-width:0;position:relative;z-index:1}
.phone-cta .label small{font-family:var(--font-text);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-2);font-weight:500}
.phone-cta .num{font-family:var(--font-mono);font-weight:500;letter-spacing:.005em;white-space:nowrap}

/* ---- SECONDARY: liquid surface with gradient text + arrow slide ---- */
.cta-secondary{
  display:inline-flex;align-items:center;gap:var(--s-2);
  padding:var(--s-3) var(--s-4);border-radius:18px;
  font-family:var(--font-display);font-weight:580;font-size:15px;letter-spacing:-.005em;
  background:var(--surface);border:1px solid var(--stroke-2);color:var(--text-0);
  position:relative;overflow:hidden;isolation:isolate;
  transition: background .35s var(--ease-out), transform .35s var(--ease-spring), border-color .35s var(--ease-out), color .35s var(--ease-out);
}
.cta-secondary::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(120deg, rgba(30,200,230,.22), rgba(191,90,242,.22));
  opacity:0;transition: opacity .4s var(--ease-out);
  z-index:-1;
}
.cta-secondary::after{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.4px;
  background: linear-gradient(120deg, #1ec8e6, #bf5af2, #ff375f);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition: opacity .4s var(--ease-out);
  pointer-events:none;
}
.cta-secondary:hover{
  background:transparent;border-color:transparent;color:#fff;
  transform:translateY(-2px);
}
.cta-secondary:hover::before, .cta-secondary:hover::after{opacity:1}
.cta-secondary svg{
  width:14px;height:14px;
  transition: transform .45s var(--ease-spring);
}
.cta-secondary:hover svg{transform:translateX(4px)}

/* ---- USP cards: liquid-glass surfaces with icon + gradient number + hover lift ---- */
.hero-stats{
  display:grid;grid-template-columns:repeat(4, minmax(0,1fr));
  gap:var(--s-2);
  margin-top:var(--s-4);
}
.hero-stat{
  position:relative;
  padding:var(--s-2) var(--s-2) var(--s-2) calc(var(--s-2) + 2px);
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.015));
  border:1px solid var(--stroke);
  isolation:isolate;overflow:hidden;
  display:flex;align-items:center;gap:var(--s-2);
  min-width:0;
  transition: transform .4s var(--ease-spring), background .35s var(--ease-out), border-color .35s var(--ease-out);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.hero-stat::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.4px;
  background:linear-gradient(135deg, var(--c1, #1ec8e6), var(--c2, #bf5af2));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .35s var(--ease-out);
  pointer-events:none;
}
.hero-stat::after{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:radial-gradient(180px 100px at 80% 0%, color-mix(in srgb, var(--c1, #1ec8e6) 22%, transparent), transparent 65%);
  opacity:.6;pointer-events:none;z-index:-1;
}
.hero-stat:hover{
  transform:translateY(-3px);
  background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.025));
  border-color:transparent;
}
.hero-stat:hover::before{opacity:1}
.hero-stat .usp-ico{
  width:36px;height:36px;border-radius:12px;flex-shrink:0;
  display:grid;place-items:center;
  background:linear-gradient(135deg, color-mix(in srgb, var(--c1,#1ec8e6) 28%, transparent), color-mix(in srgb, var(--c2,#bf5af2) 28%, transparent));
  border:1px solid var(--stroke-2);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.12);
  transition: transform .5s var(--ease-spring);
}
.hero-stat .usp-ico svg{width:18px;height:18px;color:#fff}
.hero-stat:hover .usp-ico{transform:rotate(-8deg) scale(1.08)}
.hero-stat .usp-body{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}
.hero-stat .v{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(24px, 1.9vw, 32px);
  letter-spacing:-.034em;line-height:1;display:inline-flex;align-items:baseline;gap:5px;
  background:linear-gradient(135deg, var(--c1, #1ec8e6), var(--c2, #bf5af2));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;
  font-variation-settings:"opsz" 36;
}
.hero-stat .v .unit{
  font-family:var(--font-mono);font-size:10.5px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;
  color:var(--text-2);-webkit-text-fill-color:initial;background:none;
}
.hero-stat .l{
  font-size:11.5px;color:var(--text-2);font-weight:500;letter-spacing:.005em;
  display:block;font-family:var(--font-text);line-height:1.35;
}
.hero-stat .l b{color:var(--text-1);font-weight:600}

/* Hero parallax decoration: orbs */
.hero-orbs{position:absolute;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.orb{position:absolute;border-radius:50%;filter:blur(40px);opacity:.7;will-change:transform}
.orb.a{width:560px;height:560px;background:radial-gradient(circle,#1ec8e6,transparent 70%);top:-140px;right:-80px}
.orb.b{width:440px;height:440px;background:radial-gradient(circle,#bf5af2,transparent 70%);bottom:-80px;left:-120px}
.orb.c{width:320px;height:320px;background:radial-gradient(circle,#ff375f,transparent 70%);top:30%;right:8%;opacity:.45}

/* Hero floating chips (event icons in liquid-glass pills) */
.hero-chips{position:absolute;inset:0;pointer-events:none;z-index:-1}
.hero-chips .chip{
  position:absolute;width:60px;height:60px;border-radius:18px;
  background:linear-gradient(135deg, rgba(30,200,230,.13), rgba(191,90,242,.13));
  border:1px solid var(--stroke-2);
  display:grid;place-items:center;
  backdrop-filter:blur(10px);
  box-shadow: 0 12px 32px -10px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.08);
  will-change:transform;
  animation:chipFloat 10s ease-in-out infinite;
}
.hero-chips .chip svg{width:28px;height:28px;color:var(--text-0);opacity:.9}
.hero-chips .chip:nth-child(1){top:18%;left:6%;animation-delay:0s}
.hero-chips .chip:nth-child(2){top:64%;left:11%;animation-delay:-2s}
.hero-chips .chip:nth-child(3){top:22%;right:9%;animation-delay:-4s}
.hero-chips .chip:nth-child(4){top:72%;right:6%;animation-delay:-6s}
.hero-chips .chip:nth-child(5){top:46%;left:46%;animation-delay:-3s;opacity:.7}
@keyframes chipFloat{
  0%,100%{transform:translate3d(0,0,0) rotate(-3deg)}
  50%{transform:translate3d(0,-24px,0) rotate(3deg)}
}

/* ==========================================================
   MARQUEE
   ========================================================== */
.marquee{
  padding:22px 0;border-top:1px solid var(--stroke);border-bottom:1px solid var(--stroke);
  overflow:hidden;position:relative;
  background:linear-gradient(180deg, rgba(255,255,255,.02), transparent);
}
.marquee::before, .marquee::after{
  content:"";position:absolute;top:0;bottom:0;width:140px;z-index:1;pointer-events:none;
}
.marquee::before{left:0;background:linear-gradient(90deg, var(--bg-0), transparent)}
.marquee::after{right:0;background:linear-gradient(-90deg, var(--bg-0), transparent)}
.marquee-track{
  display:flex;gap:48px;animation: marqueeScroll 42s linear infinite;width:max-content;
}
.marquee-item{
  font-family:var(--font-display);font-weight:660;font-size:clamp(20px,2vw,32px);letter-spacing:-.024em;
  color:var(--text-1);display:inline-flex;align-items:center;gap:48px;white-space:nowrap;
}
.marquee-item .sep{width:10px;height:10px;border-radius:50%;background:linear-gradient(135deg,#1ec8e6,#bf5af2);flex-shrink:0}
@keyframes marqueeScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ==========================================================
   MANIFESTO
   ========================================================== */
.manifesto-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:64px}
.manif{
  padding:36px 32px;border-radius:24px;
  background:var(--surface);border:1px solid var(--stroke);
  position:relative;overflow:hidden;isolation:isolate;
  transition:transform .4s var(--ease-spring), border-color .35s var(--ease-out), background .35s var(--ease-out);
}
.manif::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.4px;
  background:linear-gradient(135deg, var(--c1,#1ec8e6), var(--c2,#bf5af2));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .35s var(--ease-out);
  pointer-events:none;
}
.manif:hover{transform:translateY(-4px);background:var(--surface-2);border-color:transparent}
.manif:hover::before{opacity:1}
.manif .x{
  font-family:var(--font-mono);font-weight:500;font-size:13px;
  color:var(--text-3);margin-bottom:18px;
  letter-spacing:.04em;
  text-decoration:line-through;text-decoration-color:rgba(255,107,107,.5);text-decoration-thickness:1.6px;
}
.manif .y{
  font-family:var(--font-display);font-weight:720;font-size:26px;letter-spacing:-.026em;line-height:1.15;
  margin-bottom:18px;
  font-variation-settings:"opsz" 28;
}
.manif .y .fr{font-family:var(--font-accent);font-weight:500;background:linear-gradient(120deg,#1ec8e6,#bf5af2);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;font-variation-settings:"opsz" 64}
.manif .why{font-size:15px;color:var(--text-2);line-height:1.55;font-family:var(--font-text)}

/* ==========================================================
   MANIFESTO EMAIL CTA — bright motion, paper-plane animation
   ========================================================== */
.email-cta-wrap{margin-top:var(--s-5);perspective:1400px}
.email-cta{
  display:block;width:100%;
  padding:var(--s-4) var(--s-5);
  border-radius:28px;
  background:linear-gradient(135deg, #0a0a14, #190b22);
  position:relative;overflow:hidden;isolation:isolate;
  transition: transform .45s var(--ease-spring), box-shadow .45s var(--ease-out);
  color:#fff;
  will-change:transform;
}
.email-cta::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:2px;
  background:linear-gradient(120deg, #1ec8e6 0%, #5e5ce6 22%, #bf5af2 50%, #ff375f 75%, #ff9f0a 100%);
  background-size:280% 280%;
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  animation: phoneBorder 6s linear infinite;
  pointer-events:none;z-index:2;
}
.email-cta::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(105deg, transparent 30%, rgba(255,255,255,.12) 50%, transparent 70%);
  background-size:220% 100%;background-position:-130% 0;
  transition: background-position 1.1s var(--ease-out), opacity .35s var(--ease-out);
  pointer-events:none;mix-blend-mode:screen;
  opacity:.55;z-index:1;
}
.email-cta:hover{
  transform:translateY(-5px) scale(1.005);
  box-shadow:
    0 40px 90px -20px rgba(30,200,230,.45),
    0 20px 50px -16px rgba(191,90,242,.40),
    inset 0 0 0 1px rgba(255,255,255,.05);
}
.email-cta:hover::after{background-position:120% 0;opacity:1}

.email-cta-content{
  display:grid;grid-template-columns:auto 1fr auto;gap:var(--s-4);
  align-items:center;position:relative;z-index:3;
}

/* envelope + paper plane */
.email-cta-ico{
  position:relative;width:68px;height:68px;border-radius:20px;flex-shrink:0;
  display:grid;place-items:center;
  background:linear-gradient(135deg, rgba(30,200,230,.32), rgba(191,90,242,.32));
  border:1px solid rgba(255,255,255,.22);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.20), 0 8px 24px -6px rgba(30,200,230,.55);
  isolation:isolate;overflow:visible;
  transition: transform .5s var(--ease-spring);
}
.email-cta:hover .email-cta-ico{transform:rotate(-6deg) scale(1.05)}
.email-cta-ico svg{position:absolute;color:#fff}
.email-cta-ico .env{width:30px;height:30px;animation: envWobble 4.5s ease-in-out infinite}
.email-cta-ico .plane{width:22px;height:22px;animation: planeFly 4.5s var(--ease-out) infinite}
@keyframes envWobble{
  0%, 70%, 100% {transform:rotate(0deg) scale(1)}
  78% {transform:rotate(-4deg) scale(.96)}
  86% {transform:rotate(3deg) scale(.98)}
  94% {transform:rotate(0deg) scale(1)}
}
@keyframes planeFly{
  0%  {transform: translate(-4px, 6px) rotate(-10deg); opacity:0}
  12% {opacity:1}
  45% {transform: translate(70px, -42px) rotate(8deg); opacity:1}
  55% {transform: translate(70px, -42px) rotate(8deg); opacity:0}
  60% {transform: translate(-4px, 6px) rotate(-10deg); opacity:0}
  100%{transform: translate(-4px, 6px) rotate(-10deg); opacity:0}
}

/* orbs bursting outward from ico position */
.email-cta-orbs{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:visible}
.email-cta-orbs i{
  position:absolute;width:10px;height:10px;border-radius:50%;
  background:radial-gradient(circle, var(--c, #1ec8e6), transparent 70%);
  opacity:0;
  animation: orbBurst 5s ease-out infinite;
  top: 50%; left: calc(var(--s-5) + 22px);
}
.email-cta-orbs i:nth-child(1){--c:#1ec8e6;animation-delay:0s}
.email-cta-orbs i:nth-child(2){--c:#bf5af2;animation-delay:1.2s}
.email-cta-orbs i:nth-child(3){--c:#ff375f;animation-delay:2.4s}
.email-cta-orbs i:nth-child(4){--c:#ff9f0a;animation-delay:3.6s}
@keyframes orbBurst{
  0%  {transform: translate(-50%, -50%) scale(.4); opacity:0}
  10% {opacity:.8}
  60% {transform: translate(calc(-50% + 95px), calc(-50% - 50px)) scale(1.4); opacity:.45}
  100%{transform: translate(calc(-50% + 130px), calc(-50% - 90px)) scale(.3); opacity:0}
}

.email-cta-text{display:flex;flex-direction:column;gap:6px;min-width:0}
.email-cta-text small{
  font-family:var(--font-text);font-size:13px;color:var(--text-2);
  font-weight:500;letter-spacing:.005em;
}
.email-cta-text b{
  font-family:var(--font-display);font-weight:740;font-size:clamp(22px, 2.0vw, 30px);
  letter-spacing:-.028em;line-height:1.1;
  background:linear-gradient(120deg, #fff 0%, #fff 55%, #64e0ff 90%, #bf5af2 110%);
  background-size:200% 100%;background-position:0% 0;
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  transition: background-position .9s var(--ease-out);
}
.email-cta:hover .email-cta-text b{background-position:100% 0}

.email-cta-arrow{
  display:inline-flex;align-items:center;gap:14px;
  padding:14px 22px;border-radius:14px;
  background:rgba(255,255,255,.05);border:1px solid var(--stroke-2);
  font-family:var(--font-mono);font-size:13.5px;color:var(--text-1);
  transition: background .35s var(--ease-out), border-color .35s var(--ease-out), transform .4s var(--ease-spring);
}
.email-cta-arrow svg{width:14px;height:14px;transition: transform .4s var(--ease-spring)}
.email-cta:hover .email-cta-arrow{
  background:rgba(255,255,255,.10);
  border-color:rgba(255,255,255,.32);
}
.email-cta:hover .email-cta-arrow svg{transform:translateX(6px)}

/* ==========================================================
   NICHES
   ========================================================== */
.tabs{display:inline-flex;padding:6px;gap:6px;border-radius:999px;background:var(--surface);border:1px solid var(--stroke);margin-top:40px;margin-bottom:48px}
.tab{
  padding:11px 24px;border-radius:999px;font-family:var(--font-display);font-weight:600;font-size:15px;letter-spacing:-.01em;color:var(--text-2);
  transition:color .25s var(--ease-out), background .35s var(--ease-out);position:relative;
}
.tab[aria-selected="true"]{color:#fff;background:linear-gradient(135deg, rgba(30,200,230,.22), rgba(191,90,242,.22));box-shadow:inset 0 0 0 1px var(--stroke-2)}
.tab:hover{color:#fff}
.tab .count{font-family:var(--font-mono);font-size:11.5px;color:var(--text-3);margin-left:10px;font-weight:500}

.niches{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.niche{
  position:relative;padding:26px 24px;border-radius:22px;
  background:linear-gradient(180deg, var(--surface), rgba(255,255,255,.015));
  border:1px solid var(--stroke);
  overflow:hidden;isolation:isolate;
  transition: transform .4s var(--ease-spring), border-color .35s var(--ease-out), background .35s var(--ease-out);
  transform-style:preserve-3d;
  min-height:200px;
  display:flex;flex-direction:column;justify-content:space-between;gap:16px;
}
.niche::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.4px;
  background:linear-gradient(135deg, var(--c1,#1ec8e6), var(--c2,#bf5af2));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .35s var(--ease-out);pointer-events:none;
}
.niche::after{
  content:"";position:absolute;inset:-1px;border-radius:inherit;
  background:radial-gradient(220px 220px at var(--mx,50%) var(--my,50%), color-mix(in srgb, var(--c1, #1ec8e6) 22%, transparent), transparent 70%);
  opacity:0;transition:opacity .35s var(--ease-out);
  pointer-events:none;mix-blend-mode:screen;
}
.niche:hover{transform:translateY(-3px) scale(1.005);background:var(--surface-2);border-color:transparent}
.niche:hover::before, .niche:hover::after{opacity:1}
.niche .glyph{
  width:52px;height:52px;border-radius:16px;display:grid;place-items:center;
  background:linear-gradient(135deg, color-mix(in srgb, var(--c1, #1ec8e6) 24%, transparent), color-mix(in srgb, var(--c2, #bf5af2) 24%, transparent));
  border:1px solid var(--stroke-2);transition: transform .5s var(--ease-spring);
}
.niche .glyph svg{width:26px;height:26px;color:#fff}
.niche:hover .glyph{transform:rotate(-8deg) scale(1.08)}
.niche .name{font-family:var(--font-display);font-weight:680;font-size:18px;letter-spacing:-.020em;line-height:1.18;color:#fff}
.niche .meta{font-size:13.5px;color:var(--text-2);font-family:var(--font-text);line-height:1.45}
.niche .meta b{color:var(--text-1);font-weight:600}

.tab-panel{display:none;animation:fadeUp .55s var(--ease-out) both}
.tab-panel[aria-current="true"]{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* ==========================================================
   VENUES
   ========================================================== */
.venues-wrap{margin-top:48px;position:relative}
.venues-rail{
  display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding:8px 0 32px;
  margin: 0 calc(-1 * max(var(--gutter), env(safe-area-inset-left)));
  padding-left:max(var(--gutter), env(safe-area-inset-left));
  padding-right:max(var(--gutter), env(safe-area-inset-right));
  scrollbar-width:thin;
  scroll-padding-left:max(var(--gutter), env(safe-area-inset-left));
}
.venue{
  flex:0 0 380px;scroll-snap-align:start;
  position:relative;padding:0;border-radius:26px;
  background:linear-gradient(170deg, var(--bg-2), var(--bg-1) 80%);
  border:1px solid var(--stroke);
  overflow:hidden;isolation:isolate;
  min-height:520px;
  display:flex;flex-direction:column;gap:0;
  transition: transform .45s var(--ease-spring), border-color .35s var(--ease-out), box-shadow .45s var(--ease-out);
  transform-style:preserve-3d;
}
.venue::before{
  content:"";position:absolute;inset:-2px;border-radius:inherit;
  background:radial-gradient(circle at 30% 0%, color-mix(in srgb, var(--c1, #1ec8e6) 30%, transparent), transparent 60%);
  opacity:.6;z-index:-1;pointer-events:none;
}
.venue::after{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.4px;
  background:linear-gradient(140deg, var(--c1, #1ec8e6), var(--c2, #bf5af2));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .35s var(--ease-out);pointer-events:none;
  z-index:2;
}
.venue:hover{
  transform:translateY(-6px) rotateX(2deg) rotateY(-2deg);
  border-color:transparent;
  box-shadow: 0 28px 60px -16px rgba(0,0,0,.5), 0 0 0 1px color-mix(in srgb, var(--c1, #1ec8e6) 35%, transparent);
}
.venue:hover::after{opacity:1}

/* photo header (16:9) */
.venue-img{
  position:relative;width:100%;aspect-ratio:16/9;
  overflow:hidden;flex-shrink:0;
  margin:0;background:#0d0d12;
}
.venue-img img{
  width:100%;height:100%;object-fit:cover;
  transition: transform .9s var(--ease-out), filter .9s var(--ease-out);
  filter:saturate(1.05) contrast(1.02);
}
.venue:hover .venue-img img{transform:scale(1.07);filter:saturate(1.18) contrast(1.06)}
.venue-img::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(6,6,10,.45) 0%, transparent 30%, transparent 55%, rgba(6,6,10,.55) 100%),
    radial-gradient(circle at 50% 100%, color-mix(in srgb, var(--c1, #1ec8e6) 22%, transparent), transparent 70%);
  pointer-events:none;
}
.venue-img .tag{
  position:absolute;top:14px;left:14px;z-index:1;
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;border-radius:999px;font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;
  background:rgba(6,6,10,.55);color:#fff;border:1px solid rgba(255,255,255,.16);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.venue-body{
  padding:24px 26px 26px;
  display:flex;flex-direction:column;gap:14px;flex:1;
}
.venue h3{font-family:var(--font-display);font-weight:740;font-size:24px;letter-spacing:-.026em;line-height:1.08}
.venue .desc{font-size:14px;color:var(--text-2);line-height:1.5;flex:1;font-family:var(--font-text)}
.venue .specs{display:grid;grid-template-columns:repeat(2,1fr);gap:10px 14px;font-size:13px;padding-top:16px;border-top:1px solid var(--stroke)}
.venue .specs div{display:flex;flex-direction:column;gap:2px}
.venue .specs .k{font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);font-family:var(--font-mono)}
.venue .specs .v{font-family:var(--font-display);font-weight:660;font-size:14.5px;color:#fff;letter-spacing:-.012em}

.rail-hint{
  display:inline-flex;align-items:center;gap:10px;
  margin-top:12px;
  padding:8px 16px;border-radius:999px;
  background:linear-gradient(135deg, rgba(30,200,230,.10), rgba(191,90,242,.10));
  border:1px solid var(--stroke-2);
  color:var(--text-1);font-size:13px;font-family:var(--font-mono);
  letter-spacing:.02em;
}
.rail-hint .swipe-ico{
  width:18px;height:18px;display:inline-grid;place-items:center;color:#fff;flex-shrink:0;
}
.rail-hint .swipe-ico svg{width:16px;height:16px}

/* mobile-only floating right-edge hint inside venues rail — hidden on desktop */
.rail-edge-hint{display:none}

/* ==========================================================
   VENUES — INLINE LEAD FORM
   ========================================================== */
.venues-lead{
  margin-top:var(--s-4);
  padding:var(--s-4) var(--s-4);
  border-radius:24px;
  background:linear-gradient(170deg, var(--bg-2), var(--bg-1));
  border:1px solid var(--stroke);
  position:relative;overflow:hidden;isolation:isolate;
}
.venues-lead::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.4px;
  background:linear-gradient(135deg, #1ec8e6, #5e5ce6, #bf5af2, #ff375f);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:.45;pointer-events:none;
}
.venues-lead::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 50% at 100% 0%, rgba(30,200,230,.12), transparent 60%),
    radial-gradient(ellipse 50% 50% at 0% 100%, rgba(191,90,242,.10), transparent 60%);
  pointer-events:none;z-index:-1;
}
.venues-lead-head{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:center;margin-bottom:var(--s-3)}
.venues-lead-icon{
  width:54px;height:54px;border-radius:18px;
  display:grid;place-items:center;
  background:linear-gradient(135deg, rgba(30,200,230,.32), rgba(191,90,242,.32));
  border:1px solid rgba(255,255,255,.22);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18);
  color:#fff;flex-shrink:0;
  animation: phoneShake 6s ease-in-out infinite;
}
.venues-lead-icon svg{width:24px;height:24px}
.venues-lead h3{
  font-family:var(--font-display);font-weight:740;
  font-size:clamp(20px, 2vw, 26px);letter-spacing:-.024em;line-height:1.15;
  margin-bottom:6px;
}
.venues-lead-sub{
  font-family:var(--font-text);font-size:14px;color:var(--text-2);line-height:1.5;
}
.venues-lead-fields{
  display:grid;grid-template-columns:1fr 1fr;gap:var(--s-2);margin-bottom:var(--s-3);
}
.venues-lead-submit-row{
  display:flex;flex-wrap:wrap;gap:var(--s-2);align-items:center;margin-bottom:var(--s-2);
}
.venues-lead-submit{
  cursor:pointer;
  font-family:var(--font-mono);font-weight:500;font-size:16px;letter-spacing:.01em;color:#fff;
  padding:var(--s-2) var(--s-3) var(--s-2) var(--s-2);
}
.venues-lead-submit .ico svg{color:#fff;width:20px;height:20px}
.venues-lead-submit:disabled{cursor:wait}
.venues-lead-submit.is-loading{pointer-events:none}
.venues-lead-submit.is-loading .ico svg{animation: planeFlyLoop .9s linear infinite}
.venues-lead-submit.is-loading::after{
  content:"";position:absolute;inset:0;
  background: linear-gradient(105deg, transparent 30%, rgba(255,255,255,.15) 50%, transparent 70%);
  background-size: 220% 100%;
  animation: loadingShimmer 1.1s linear infinite;
  pointer-events:none;mix-blend-mode:screen;border-radius:inherit;
}

/* ==========================================================
   PROCESS
   ========================================================== */
.steps{
  display:grid;grid-template-columns:repeat(5,1fr);gap:32px;margin-top:64px;position:relative;
}
.steps::before{
  content:"";position:absolute;left:0;right:0;top:34px;height:2px;
  background:linear-gradient(90deg,#1ec8e6,#5e5ce6,#bf5af2,#ff375f,#ff9f0a);
  opacity:.28;border-radius:2px;z-index:0;
}
.step{position:relative;z-index:1}
.step .n{
  width:68px;height:68px;border-radius:20px;display:grid;place-items:center;
  font-family:var(--font-display);font-weight:780;font-size:24px;
  background:linear-gradient(135deg, var(--bg-2), var(--bg-1));
  border:1px solid var(--stroke-2);position:relative;color:#fff;
  transition: transform .4s var(--ease-spring), box-shadow .4s var(--ease-out);
}
.step .n::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.5px;
  background:linear-gradient(135deg, var(--c1), var(--c2));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;
}
.step:hover .n{transform:translateY(-4px) scale(1.04);box-shadow: 0 16px 40px -10px color-mix(in srgb, var(--c1) 60%, transparent)}
.step h4{margin-top:22px;font-family:var(--font-display);font-weight:680;font-size:19px;letter-spacing:-.016em}
.step p{margin-top:10px;font-size:14.5px;color:var(--text-2);line-height:1.5;font-family:var(--font-text)}

/* ==========================================================
   ENHANCERS
   ========================================================== */
.enhancers{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:48px}
.enhancer{
  position:relative;padding:26px;border-radius:20px;
  background:var(--surface);border:1px solid var(--stroke);
  overflow:hidden;isolation:isolate;
  display:flex;flex-direction:column;gap:16px;min-height:180px;
  transition:transform .4s var(--ease-spring), background .35s var(--ease-out), border-color .35s var(--ease-out);
}
.enhancer::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.4px;
  background:linear-gradient(135deg, var(--c1, #1ec8e6), var(--c2, #bf5af2));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .35s var(--ease-out);pointer-events:none;
}
.enhancer:hover{transform:translateY(-3px);background:var(--surface-2);border-color:transparent}
.enhancer:hover::before{opacity:1}
.enhancer .ico{
  width:46px;height:46px;border-radius:14px;display:grid;place-items:center;
  background:linear-gradient(135deg, color-mix(in srgb, var(--c1, #1ec8e6) 24%, transparent), color-mix(in srgb, var(--c2, #bf5af2) 24%, transparent));
  border:1px solid var(--stroke-2);
  transition:transform .5s var(--ease-spring);
}
.enhancer .ico svg{width:24px;height:24px;color:#fff}
.enhancer:hover .ico{transform:rotate(8deg) scale(1.1)}
.enhancer h4{font-family:var(--font-display);font-weight:680;font-size:18px;letter-spacing:-.014em;line-height:1.18}
.enhancer p{font-size:13.5px;color:var(--text-2);line-height:1.5;font-family:var(--font-text)}

/* ==========================================================
   LEVELS
   ========================================================== */
.levels{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:48px;align-items:stretch}

.level{
  position:relative;
  padding:var(--s-4) var(--s-3) var(--s-3);
  border-radius:24px;
  overflow:hidden;
  isolation:isolate;
  background:linear-gradient(180deg, var(--bg-2), var(--bg-1));
  border:1px solid var(--stroke);
  display:flex;flex-direction:column;gap:var(--s-3);
  min-height:460px;
  transition:
    transform .5s var(--ease-spring),
    border-color .4s var(--ease-out),
    box-shadow .5s var(--ease-out);
  /* отключаем переносы внутри карточки — только для длинного example текста разрешим балансировку */
  hyphens: manual;
  word-break: normal;
}
.level .level-example, .level .price-sub{text-wrap: pretty}

/* base gradient border */
.level::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.4px;
  background:linear-gradient(180deg, var(--c1, #1ec8e6), var(--c2, #bf5af2));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:.55;pointer-events:none;
  transition: opacity .45s var(--ease-out);
  z-index:2;
}

/* decorative подложка (orb + dot pattern) — появляется вместе с карточкой */
.level-bg{
  position:absolute;inset:0;border-radius:inherit;
  overflow:hidden;pointer-events:none;
  opacity:0;
  transition: opacity 1.1s var(--ease-out) .2s;
  z-index:0;
}
.level.in .level-bg{opacity:1}
.level-orb{
  position:absolute;top:-70px;right:-70px;width:230px;height:230px;border-radius:50%;
  background:radial-gradient(circle, color-mix(in srgb, var(--c1, #1ec8e6) 38%, transparent), transparent 65%);
  filter:blur(32px);
  animation: levelOrbDrift 14s ease-in-out infinite alternate;
}
.level-orb--2{
  top:auto;right:auto;bottom:-90px;left:-50px;width:180px;height:180px;
  background:radial-gradient(circle, color-mix(in srgb, var(--c2, #bf5af2) 32%, transparent), transparent 65%);
  animation: levelOrbDrift 17s ease-in-out -3s infinite alternate-reverse;
}
@keyframes levelOrbDrift{
  0%{transform:translate(0,0) scale(1)}
  100%{transform:translate(-22px, 28px) scale(1.18)}
}
.level-pattern{
  position:absolute;inset:0;
  background-image:radial-gradient(circle 1.2px at 50% 50%, rgba(255,255,255,.06) 1.2px, transparent 1.6px);
  background-size:18px 18px;
  opacity:.45;
  mask-image: linear-gradient(180deg, rgba(0,0,0,.6) 0%, rgba(0,0,0,.2) 70%, transparent 100%);
  -webkit-mask-image: linear-gradient(180deg, rgba(0,0,0,.6) 0%, rgba(0,0,0,.2) 70%, transparent 100%);
}

/* содержимое поверх подложки */
.level > *:not(.level-bg):not(.level-tag-top){position:relative;z-index:1}

/* head: pill в верхнем-правом углу абсолютом, head-titles занимает всю ширину */
.level-head{
  position:relative;
  min-height:42px;
}
.head-titles{
  display:flex;flex-direction:column;gap:4px;
  padding-right:106px; /* место для pill справа */
}
.level .name{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(22px, 1.7vw, 26px);
  letter-spacing:-.030em;line-height:1.05;
  display:inline-flex;align-items:center;gap:8px;
  white-space: nowrap;        /* запрещаем перенос внутри слова */
  hyphens: manual;
}
.level .name .crown{
  width:20px;height:20px;
  color:transparent;
  background:linear-gradient(135deg, #ffd60a, #ff9f0a, #ff375f);
  -webkit-background-clip:text;background-clip:text;
  filter: drop-shadow(0 2px 6px rgba(255,159,10,.5));
  animation: crownFloat 2.8s ease-in-out infinite;
}
@keyframes crownFloat{
  0%,100%{transform:translateY(0) rotate(-3deg)}
  50%    {transform:translateY(-2px) rotate(3deg)}
}
.level .kicker{
  font-family:var(--font-text);font-weight:500;font-size:12.5px;
  color:var(--text-2);letter-spacing:.005em;line-height:1.2;
}
.level .pill{
  position:absolute;top:0;right:0;
  display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;
  font-family:var(--font-mono);font-size:10px;letter-spacing:.05em;text-transform:uppercase;
  background:linear-gradient(135deg, color-mix(in srgb, var(--c1) 22%, transparent), color-mix(in srgb, var(--c2) 22%, transparent));
  color:#fff;border:1px solid var(--stroke-2);
  white-space:nowrap;
  z-index:2;
}

/* типичный сценарий — короткое описание */
.level-example{
  font-family:var(--font-text);font-size:13.5px;color:var(--text-2);line-height:1.5;
  font-weight:400;letter-spacing:0;
  text-wrap: pretty;
  border-left: 2px solid color-mix(in srgb, var(--c1) 38%, transparent);
  padding-left:12px;
  margin:0;
}

/* anchor-цена: «от X ₽» + средний чек */
.level-price{
  position:relative;
  padding-bottom:var(--s-3);
}
.level-price::after{
  content:"";position:absolute;left:0;right:30%;bottom:0;height:1px;
  background:linear-gradient(90deg,
    color-mix(in srgb, var(--c1) 55%, transparent),
    color-mix(in srgb, var(--c2) 35%, transparent) 70%,
    transparent);
  opacity:.9;
}
.level-price .price-row{
  display:inline-flex;align-items:baseline;gap:6px;white-space:nowrap;
  font-family:var(--font-display);font-weight:800;
  line-height:1;
}
.level-price .prefix{
  font-family:var(--font-text);font-weight:520;font-size:14px;
  letter-spacing:.005em;color:var(--text-2);
  -webkit-text-fill-color:initial;background:none;
}
.level-price .price-num{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(30px, 2.8vw, 44px);
  letter-spacing:-.040em;
  font-variation-settings:"opsz" 64;
  background:linear-gradient(135deg, var(--c1, #1ec8e6), var(--c2, #bf5af2));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;
  filter: drop-shadow(0 4px 18px color-mix(in srgb, var(--c1) 30%, transparent));
}
.level-price .price-num--inquire{
  font-size:clamp(24px, 2.2vw, 34px);
  letter-spacing:-.032em;
}
.level-price .curr{
  font-family:var(--font-display);font-weight:680;
  font-size:clamp(20px, 1.7vw, 26px);
  letter-spacing:-.02em;
  color:var(--text-1);
  -webkit-text-fill-color:initial;background:none;
}
.level-price .price-sub{
  display:block;font-size:12.5px;font-weight:500;color:var(--text-3);margin-top:var(--s-1);
  letter-spacing:.005em;font-family:var(--font-text);line-height:1.4;
  text-wrap: balance;max-width:38ch;
}
.level-price .price-sub b{color:var(--text-1);font-weight:600;font-variant-numeric:tabular-nums}

/* features */
.level-features{
  list-style:none;display:flex;flex-direction:column;gap:11px;
  font-size:14px;color:var(--text-1);font-family:var(--font-text);
  flex:1;line-height:1.42;
}
.level-features li{
  display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:flex-start;
  text-wrap: pretty;
}
.level-features .check{
  flex-shrink:0;width:24px;height:24px;border-radius:50%;
  display:grid;place-items:center;
  background:linear-gradient(135deg,
    color-mix(in srgb, var(--c1) 25%, transparent),
    color-mix(in srgb, var(--c2) 25%, transparent));
  border:1px solid color-mix(in srgb, var(--c1) 45%, transparent);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.10);
  transition: transform .45s var(--ease-spring), background .4s var(--ease-out), box-shadow .4s var(--ease-out);
}
.level-features .check svg{
  width:11px;height:11px;color:#fff;
  filter: drop-shadow(0 1px 0 color-mix(in srgb, var(--c1) 50%, transparent));
}
.level:hover .level-features li:nth-child(1) .check{transform:scale(1.12)}
.level:hover .level-features li:nth-child(2) .check{transform:scale(1.12);transition-delay:.05s}
.level:hover .level-features li:nth-child(3) .check{transform:scale(1.12);transition-delay:.10s}
.level:hover .level-features li:nth-child(4) .check{transform:scale(1.12);transition-delay:.15s}
.level:hover .level-features .check{
  background:linear-gradient(135deg, var(--c1), var(--c2));
  box-shadow: 0 6px 20px -4px color-mix(in srgb, var(--c1) 60%, transparent);
}

/* per-card CTA */
.level-cta-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  margin-top:auto;
  padding:13px 18px;border-radius:14px;
  font-family:var(--font-display);font-weight:580;font-size:14px;letter-spacing:-.005em;
  background:rgba(255,255,255,.04);
  border:1px solid var(--stroke-2);
  color:#fff;
  text-align:center;
  position:relative;overflow:hidden;
  transition: background .4s var(--ease-out), transform .4s var(--ease-spring), border-color .4s var(--ease-out), box-shadow .4s var(--ease-out);
}
.level-cta-btn svg{width:12px;height:12px;transition: transform .45s var(--ease-spring)}
.level-cta-btn:hover{
  background:linear-gradient(135deg,
    color-mix(in srgb, var(--c1) 22%, transparent),
    color-mix(in srgb, var(--c2) 22%, transparent));
  border-color: color-mix(in srgb, var(--c1) 60%, transparent);
  transform:translateY(-2px);
  box-shadow:
    0 12px 30px -10px color-mix(in srgb, var(--c1) 50%, transparent),
    0 6px 16px -8px color-mix(in srgb, var(--c2) 40%, transparent);
}
.level-cta-btn:hover svg{transform:translateX(5px)}

/* hover на саму карточку */
.level:hover{
  transform:translateY(-6px);
  border-color:transparent;
  box-shadow:
    0 30px 60px -16px rgba(0,0,0,.5),
    0 0 0 1px color-mix(in srgb, var(--c1) 35%, transparent),
    0 0 40px -8px color-mix(in srgb, var(--c1) 25%, transparent);
}
.level:hover::before{opacity:1}

/* featured card — выделяется сильнее (выше специфичность чем .reveal-up.in) */
.level.featured,
.reveal-up.level.featured.in{
  transform:translateY(-10px) scale(1.018);
  z-index:1;
}
.level.featured::before{
  opacity:1;
  background:linear-gradient(180deg, #1ec8e6, #bf5af2 40%, #ff375f 80%, #ff9f0a);
  background-size:100% 250%;
  animation: featuredBorder 5s linear infinite;
}
@keyframes featuredBorder{
  0%  {background-position:0 0}
  100%{background-position:0 250%}
}
.level.featured:hover,
.reveal-up.level.featured.in:hover{
  transform:translateY(-14px) scale(1.022);
}
.level.featured .pill{
  background:linear-gradient(135deg, var(--c1), var(--c2));
  color:#fff;border-color:transparent;
  animation: pillPulse 2.6s ease-in-out infinite;
}
@keyframes pillPulse{
  0%,100%{box-shadow: 0 0 0 0 color-mix(in srgb, var(--c1) 30%, transparent)}
  50%    {box-shadow: 0 0 0 8px color-mix(in srgb, var(--c1) 0%, transparent)}
}
.level-cta-btn--featured{
  background:linear-gradient(135deg, var(--c1), var(--c2));
  border-color:transparent;color:#fff;
  box-shadow: 0 12px 30px -10px color-mix(in srgb, var(--c1) 55%, transparent);
}
.level-cta-btn--featured:hover{
  background:linear-gradient(135deg, var(--c1), var(--c2));
  filter: brightness(1.08);
  transform:translateY(-3px);
  box-shadow: 0 20px 45px -12px color-mix(in srgb, var(--c1) 60%, transparent);
}

/* ==========================================================
   FAQ
   ========================================================== */
.faq{margin-top:48px;max-width:980px}
.faq details{
  border:1px solid var(--stroke);background:var(--surface);border-radius:18px;
  padding:0;margin-bottom:12px;overflow:hidden;
  transition: background .3s var(--ease-out), border-color .3s var(--ease-out);
}
.faq details[open]{background:var(--surface-2);border-color:var(--stroke-2)}
.faq summary{
  list-style:none;padding:22px 24px;display:flex;justify-content:space-between;align-items:center;gap:18px;
  font-family:var(--font-display);font-weight:600;font-size:18px;letter-spacing:-.012em;line-height:1.3;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary .plus{
  width:30px;height:30px;border-radius:50%;flex-shrink:0;
  display:grid;place-items:center;border:1px solid var(--stroke-2);
  background:var(--surface);position:relative;
  transition:transform .35s var(--ease-spring), background .35s var(--ease-out);
}
.faq summary .plus::before, .faq summary .plus::after{content:"";position:absolute;background:#fff;border-radius:1px}
.faq summary .plus::before{width:11px;height:1.5px}
.faq summary .plus::after{width:1.5px;height:11px;transition:transform .3s var(--ease-out)}
.faq details[open] summary .plus{transform:rotate(45deg);background:linear-gradient(135deg, rgba(30,200,230,.3), rgba(191,90,242,.3))}
.faq .answer{padding:0 24px 24px 24px;color:var(--text-1);font-size:15px;line-height:1.55;font-family:var(--font-text)}
.faq .answer p + p{margin-top:10px}

/* ==========================================================
   CONTACT + WEATHER
   ========================================================== */
.contact{position:relative;padding:var(--s-6) 0 var(--s-5);overflow:hidden;isolation:isolate}
.contact::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(ellipse 60% 50% at 50% 50%, rgba(30,200,230,.16), transparent 60%),
    radial-gradient(ellipse 40% 40% at 80% 30%, rgba(191,90,242,.13), transparent 60%),
    radial-gradient(ellipse 40% 40% at 20% 80%, rgba(255,55,95,.11), transparent 60%);
}
.contact-inner{text-align:center;max-width:980px;margin:0 auto}
.contact h2{margin-bottom:20px}
.contact .sub{color:var(--text-1);font-size:clamp(17px,1.5vw,22px);max-width:62ch;margin:0 auto 60px;line-height:1.5;font-family:var(--font-display);font-weight:440}

.giant-phone{
  display:inline-flex;align-items:center;gap:24px;
  padding:32px 56px;border-radius:32px;
  font-family:var(--font-mono);font-weight:500;font-size:clamp(28px, 4.4vw, 60px);letter-spacing:.01em;line-height:1;color:#fff;
  background:linear-gradient(135deg, #0a0a14, #1a0b22);
  position:relative;overflow:hidden;isolation:isolate;
  transition: transform .4s var(--ease-spring), box-shadow .4s var(--ease-out);
}
.giant-phone::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:2px;
  background:linear-gradient(120deg,#1ec8e6 0%,#5e5ce6 30%,#bf5af2 60%,#ff375f 100%);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;
}
.giant-phone::after{
  content:"";position:absolute;inset:-1px;border-radius:inherit;
  background:radial-gradient(300px 300px at var(--cx,50%) var(--cy,50%), rgba(30,200,230,.4), transparent 70%);
  opacity:0;transition:opacity .35s var(--ease-out);pointer-events:none;mix-blend-mode:screen;
}
.giant-phone:hover{transform:translateY(-3px) scale(1.02);box-shadow: 0 30px 80px -10px rgba(30,200,230,.4), 0 16px 40px -8px rgba(191,90,242,.32)}
.giant-phone:hover::after{opacity:1}
.giant-phone .ico{
  width:88px;height:88px;border-radius:26px;display:grid;place-items:center;flex-shrink:0;
  background:linear-gradient(135deg, rgba(30,200,230,.28), rgba(191,90,242,.28));border:1px solid rgba(255,255,255,.22);
  animation: phoneShake 6s ease-in-out infinite;
}
.giant-phone .ico svg{width:38px;height:38px;color:#fff}

.work-strip{
  display:inline-flex;align-items:center;gap:24px;margin-top:32px;flex-wrap:wrap;justify-content:center;
}
.work-hours{
  display:inline-flex;align-items:center;gap:10px;padding:11px 20px;border-radius:999px;
  border:1px solid var(--stroke-2);background:var(--surface);
  font-size:13.5px;color:var(--text-1);font-family:var(--font-mono);
}
.work-hours .dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 5px rgba(48,209,88,.16), 0 0 12px rgba(48,209,88,.6);animation:pulseDot 2.2s var(--ease-out) infinite}

.weather{
  display:inline-flex;align-items:center;gap:14px;padding:10px 20px 10px 14px;border-radius:999px;
  border:1px solid var(--stroke-2);background:var(--surface);
  font-family:var(--font-mono);color:var(--text-1);
  min-width:230px;
}
.weather .w-ico{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg, rgba(30,200,230,.2), rgba(191,90,242,.2));border:1px solid var(--stroke-2);flex-shrink:0}
.weather .w-ico svg{width:18px;height:18px;color:#fff}
.weather .w-body{display:flex;flex-direction:column;gap:2px;align-items:flex-start;line-height:1.05;font-size:13.5px}
.weather .w-temp{font-family:var(--font-display);font-weight:660;font-size:20px;letter-spacing:-.018em;color:#fff;display:inline-flex;align-items:baseline;gap:4px}
.weather .w-temp .label{font-family:var(--font-mono);font-size:11px;color:var(--text-3);font-weight:500;letter-spacing:.06em;text-transform:uppercase}
.weather .w-text{font-size:12px;color:var(--text-2);letter-spacing:.005em;font-family:var(--font-text)}
.weather[data-state="loading"] .w-temp,.weather[data-state="loading"] .w-text{opacity:.3}

.contact-extras{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:24px}
.contact-extras .ce{
  display:inline-flex;align-items:center;gap:10px;padding:12px 22px;border-radius:999px;
  font-size:14px;color:var(--text-1);font-family:var(--font-display);font-weight:520;letter-spacing:-.005em;
  background:var(--surface);border:1px solid var(--stroke-2);
  transition:background .3s var(--ease-out), transform .3s var(--ease-spring), border-color .3s var(--ease-out);
}
.contact-extras .ce:hover{background:var(--surface-2);border-color:rgba(255,255,255,.28);transform:translateY(-1px)}
.contact-extras .ce svg{width:16px;height:16px;opacity:.7}

/* ==========================================================
   FOOTER
   ========================================================== */
.footer{padding:var(--s-6) 0 var(--s-5);border-top:1px solid var(--stroke);background:var(--bg-1);position:relative;isolation:isolate}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1.1fr;gap:48px}
.footer-brand .logo{display:flex;align-items:center;gap:12px;margin-bottom:22px;font-family:var(--font-display);font-weight:800;font-size:26px;letter-spacing:-.034em;color:#fff}
.footer-brand .logo svg.mark{width:34px;height:34px;flex-shrink:0}
.footer p, .footer a, .footer span, .footer dd, .footer dt, .footer li{font-size:13.5px;color:var(--text-2);line-height:1.55;font-family:var(--font-text)}
.footer a{color:var(--text-1)}
.footer a:hover{color:#fff}
.footer h5{font-family:var(--font-display);font-weight:680;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-1);margin-bottom:20px}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.footer dl{display:grid;grid-template-columns:auto 1fr;gap:8px 16px;font-size:12.5px}
.footer dl dt{color:var(--text-3);letter-spacing:.02em;font-family:var(--font-text)}
.footer dl dd{color:var(--text-1);font-family:var(--font-mono);font-size:12px;word-break:break-all}
.footer-bot{margin-top:48px;padding-top:30px;border-top:1px solid var(--stroke);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;font-size:12.5px;color:var(--text-3);font-family:var(--font-text)}

/* footer contacts — pill links (used on desktop AND mobile) */
.footer-contacts{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.footer-contacts a{
  display:inline-flex;align-items:center;gap:10px;
  padding:9px 16px;border-radius:999px;
  background:linear-gradient(135deg, rgba(30,200,230,.12), rgba(191,90,242,.12));
  border:1px solid var(--stroke-2);
  font-family:var(--font-mono);font-size:13.5px;color:#fff !important;
  letter-spacing:.005em;
  transition: background .35s var(--ease-out), border-color .35s var(--ease-out), transform .35s var(--ease-spring);
}
.footer-contacts a:hover{
  background:linear-gradient(135deg, rgba(30,200,230,.22), rgba(191,90,242,.22));
  border-color:rgba(255,255,255,.32);
  transform:translateY(-1px);
}
.footer-contacts svg{
  width:15px;height:15px;color:var(--cyan-bright);flex-shrink:0;
}
.footer-bot .made-with{display:inline-flex;align-items:center;gap:8px}
.footer-bot .made-with svg{width:14px;height:14px;color:var(--pink)}

/* ==========================================================
   ANIMATIONS / UTILS
   ========================================================== */
.reveal-up{opacity:0;transform:translateY(28px);filter:blur(8px);transition:opacity .9s var(--ease-out), transform .9s var(--ease-out), filter .9s var(--ease-out)}
.reveal-up.in{opacity:1;transform:none;filter:blur(0)}
.delay-1{transition-delay:.08s}.delay-2{transition-delay:.16s}.delay-3{transition-delay:.24s}.delay-4{transition-delay:.32s}.delay-5{transition-delay:.40s}
.delay-6{transition-delay:.48s}.delay-7{transition-delay:.56s}.delay-8{transition-delay:.64s}

.word{display:inline-block;will-change:transform,opacity,filter}
.word-inner{display:inline-block;opacity:0;transform:translateY(110%);filter:blur(8px);transition:opacity .9s var(--ease-out), transform .9s var(--ease-out), filter .8s var(--ease-out)}
.in .word-inner{opacity:1;transform:translate(0);filter:blur(0)}

.confetti{position:fixed;left:0;top:0;pointer-events:none;z-index:120}

/* Parallax helper */
[data-px]{will-change:transform;transform:translate3d(0,0,0)}

/* ==========================================================
   BRIEF FORM
   ========================================================== */
.brief{
  margin-top:var(--s-5);
  padding:var(--s-5) var(--s-5);
  border-radius:28px;
  background:linear-gradient(170deg, var(--bg-2), var(--bg-1));
  border:1px solid var(--stroke);
  position:relative;overflow:hidden;isolation:isolate;
}
.brief::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.4px;
  background:linear-gradient(135deg, #1ec8e6, #5e5ce6, #bf5af2, #ff375f);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:.45;pointer-events:none;
}
.brief::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 50% at 100% 0%, rgba(30,200,230,.12), transparent 60%),
    radial-gradient(ellipse 50% 50% at 0% 100%, rgba(191,90,242,.10), transparent 60%);
  pointer-events:none;z-index:-1;
}

.brief-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:var(--s-3) var(--s-3);
  position:relative;z-index:1;
}

.field{
  display:flex;flex-direction:column;gap:8px;
  position:relative;border:0;padding:0;margin:0;min-width:0;
}
.field--full{grid-column:1 / -1}
.field-label{
  font-family:var(--font-display);font-weight:580;font-size:13.5px;
  letter-spacing:.005em;color:var(--text-1);
}
.field-label i{font-style:normal;color:var(--pink);margin-left:4px;font-family:var(--font-mono);font-size:12px}

.field input,
.field select,
.field textarea{
  font-family:var(--font-text);font-size:15px;font-weight:450;color:#fff;letter-spacing:-.005em;
  background:rgba(255,255,255,.04);
  border:1.4px solid var(--stroke-2);
  border-radius:14px;
  padding:14px 16px;
  outline:none;
  transition: border-color .35s var(--ease-out), background .3s var(--ease-out), box-shadow .35s var(--ease-out);
  width:100%;
  font-feature-settings:"tnum","ss01";
}
.field input::placeholder,
.field textarea::placeholder{color:var(--text-3)}
.field input:focus,
.field select:focus,
.field textarea:focus{
  border-color: var(--cyan);
  background:rgba(255,255,255,.07);
  box-shadow: 0 0 0 4px rgba(30,200,230,.16), 0 6px 24px -8px rgba(30,200,230,.3);
}
.field textarea{resize:vertical;min-height:96px;line-height:1.5}

/* select native dropdown — chevron */
.field select{
  appearance:none;-webkit-appearance:none;
  background-image:
    linear-gradient(45deg, transparent 47%, var(--text-2) 47%, var(--text-2) 53%, transparent 53%),
    linear-gradient(-45deg, transparent 47%, var(--text-2) 47%, var(--text-2) 53%, transparent 53%);
  background-position: calc(100% - 22px) calc(50% + 2px), calc(100% - 16px) calc(50% + 2px);
  background-size: 7px 7px;
  background-repeat: no-repeat;
  padding-right:44px;
  cursor:pointer;
}
.field select option{background:#0d0d12;color:#fff}

/* date input — native calendar with dark icon */
.field input[type="date"]{
  color-scheme: dark;
  cursor:pointer;
}
.field input[type="date"]::-webkit-calendar-picker-indicator{
  opacity:.7;cursor:pointer;
  filter: invert(75%) sepia(20%) saturate(2000%) hue-rotate(155deg) brightness(105%);
}
.field input[type="date"]::-webkit-datetime-edit{padding:0}

/* invalid state */
.field.field--invalid input,
.field.field--invalid select{
  border-color: var(--pink);
  background: rgba(255,55,95,.07);
  box-shadow: 0 0 0 4px rgba(255,55,95,.16);
  animation: shakeField .4s cubic-bezier(.36,.07,.19,.97);
}
@keyframes shakeField{
  10%, 90% {transform: translateX(-2px)}
  20%, 80% {transform: translateX(3px)}
  30%, 50%, 70% {transform: translateX(-5px)}
  40%, 60% {transform: translateX(5px)}
}
.field-hint{
  font-size:12.5px;color:var(--text-3);font-family:var(--font-text);line-height:1.4;
  display:none;
}
.field.field--invalid .field-hint{
  display:block;
  color: #ff6b6b;
  animation: hintIn .35s var(--ease-out) both;
}
@keyframes hintIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}

/* messenger tiles — премиум-плитки выбора связи */
.msg-tiles{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:10px;margin-top:6px;
}
@media (max-width:760px){.msg-tiles{grid-template-columns:repeat(2, 1fr)}}
.msg-tile{
  position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:6px;
  padding:14px 14px 12px;border-radius:18px;
  background:var(--surface);
  border:1.4px solid var(--stroke-2);
  cursor:pointer;overflow:hidden;isolation:isolate;
  transition: background .35s var(--ease-out), border-color .35s var(--ease-out), transform .4s var(--ease-spring), box-shadow .4s var(--ease-out);
  min-height:96px;
}
.msg-tile input{
  position:absolute;opacity:0;pointer-events:none;
  width:1px;height:1px;padding:0;border:0;
}
.msg-tile .msg-ico{
  display:grid;place-items:center;
  width:34px;height:34px;border-radius:11px;
  background:linear-gradient(135deg, color-mix(in srgb, var(--c1) 24%, transparent), color-mix(in srgb, var(--c2) 24%, transparent));
  border:1px solid color-mix(in srgb, var(--c1) 35%, transparent);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.12);
  transition: transform .45s var(--ease-spring), background .35s var(--ease-out);
}
.msg-tile .msg-ico svg{
  width:18px;height:18px;color:#fff;
  transition: color .35s var(--ease-out);
}
.msg-tile .msg-name{
  font-family:var(--font-display);font-weight:640;font-size:14.5px;letter-spacing:-.010em;
  color:#fff;line-height:1.1;
}
.msg-tile .msg-meta{
  font-family:var(--font-mono);font-size:10.5px;letter-spacing:.02em;
  color:var(--text-3);line-height:1.2;
  max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  transition: color .35s var(--ease-out);
}
/* tick badge — появляется когда выбран */
.msg-tile .msg-tick{
  position:absolute;top:10px;right:10px;
  width:20px;height:20px;border-radius:50%;
  display:grid;place-items:center;
  background:linear-gradient(135deg, var(--c1), var(--c2));
  border:1px solid rgba(255,255,255,.25);
  box-shadow: 0 4px 12px -2px color-mix(in srgb, var(--c1) 55%, transparent);
  transform: scale(.4) rotate(-90deg);opacity:0;
  transition: transform .35s var(--ease-spring), opacity .25s var(--ease-out);
}
.msg-tile .msg-tick svg{width:11px;height:11px;color:#fff}
/* hover */
.msg-tile:hover{
  background:var(--surface-2);
  border-color: color-mix(in srgb, var(--c1) 40%, var(--stroke-2));
  transform: translateY(-2px);
  box-shadow: 0 12px 28px -10px rgba(0,0,0,.45);
}
.msg-tile:hover .msg-ico{transform:rotate(-4deg) scale(1.05)}
/* checked state — gradient-border, цветной icon, tick visible */
.msg-tile:has(input:checked){
  background:linear-gradient(140deg,
    color-mix(in srgb, var(--c1) 15%, transparent),
    color-mix(in srgb, var(--c2) 12%, transparent));
  border-color:transparent;
  box-shadow:
    0 0 0 1.5px color-mix(in srgb, var(--c1) 65%, transparent),
    0 14px 30px -10px color-mix(in srgb, var(--c1) 45%, transparent),
    0 0 0 1px rgba(255,255,255,.06) inset;
}
.msg-tile:has(input:checked) .msg-ico{
  background:linear-gradient(135deg, var(--c1), var(--c2));
  border-color: rgba(255,255,255,.22);
  box-shadow: 0 6px 16px -4px color-mix(in srgb, var(--c1) 60%, transparent), inset 0 1px 0 rgba(255,255,255,.22);
  transform: rotate(0) scale(1.02);
}
.msg-tile:has(input:checked) .msg-meta{color:color-mix(in srgb, var(--c1) 80%, #fff)}
.msg-tile:has(input:checked) .msg-tick{
  transform: scale(1) rotate(0);opacity:1;
}
/* keyboard focus */
.msg-tile:focus-within{
  outline:none;
  box-shadow:
    0 0 0 2px color-mix(in srgb, var(--c1) 70%, transparent),
    0 14px 30px -10px color-mix(in srgb, var(--c1) 50%, transparent);
}

.brief-cta{
  margin-top:var(--s-4);
  display:flex;flex-wrap:wrap;align-items:center;gap:var(--s-3);
  position:relative;z-index:1;
}
.brief-submit{
  cursor:pointer;background:linear-gradient(135deg, #0e0e16, #1a0d24);
  font-family:var(--font-mono);font-weight:500;font-size:18px;letter-spacing:.01em;color:#fff;
  padding:var(--s-3) var(--s-4) var(--s-3) var(--s-3);
}
.brief-submit .ico svg{color:#fff;width:22px;height:22px}
.brief-submit:disabled{cursor:wait}
.brief-submit.is-loading{pointer-events:none}
.brief-submit.is-loading .ico svg{
  animation: planeFlyLoop .9s linear infinite;
}
@keyframes planeFlyLoop{
  0%   { transform: translate(-6px, 6px) rotate(-10deg); opacity:0 }
  10%  { opacity:1 }
  60%  { transform: translate(18px, -10px) rotate(8deg); opacity:1 }
  70%  { transform: translate(18px, -10px) rotate(8deg); opacity:0 }
  100% { transform: translate(-6px, 6px) rotate(-10deg); opacity:0 }
}
.brief-submit.is-loading::after{
  content:"";position:absolute;inset:0;
  background: linear-gradient(105deg, transparent 30%, rgba(255,255,255,.15) 50%, transparent 70%);
  background-size: 220% 100%;
  animation: loadingShimmer 1.1s linear infinite;
  pointer-events:none;mix-blend-mode:screen;
}
@keyframes loadingShimmer{
  from{background-position:-120% 0}
  to  {background-position:120% 0}
}

/* honeypot — скрыто для людей, видно ботам */
.brief-honey{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}

/* date trio — три селекта (day / month / year) — legacy desktop fallback */
.date-trio{display:flex;flex-direction:column;gap:8px;border:0;padding:0;margin:0;min-width:0}
.date-trio .date-trio-row{display:grid;grid-template-columns:1fr 1.5fr 1fr;gap:10px}
.date-trio select{min-width:0;width:100%}

/* ==========================================================
   VPN WARNING MODAL — adaptive, polished
   ========================================================== */
.modal-card--vpn{
  text-align:center;
  width:min(420px, 92vw);
  padding:30px 24px 22px;
}
.vpn-modal-ico{
  width:84px;height:84px;margin:0 auto 16px;
  border-radius:24px;
  display:grid;place-items:center;
  background:linear-gradient(135deg, rgba(255,55,95,.28), rgba(255,159,10,.28));
  border:1px solid rgba(255,255,255,.22);
  box-shadow: 0 14px 36px -10px rgba(255,55,95,.5), inset 0 1px 0 rgba(255,255,255,.18);
  color:#fff;
  animation: vpnIcoPulse 2.4s ease-in-out infinite;
}
.vpn-modal-ico svg{width:38px;height:38px}
@keyframes vpnIcoPulse{
  0%, 100% { transform: scale(1) rotate(0); }
  50%      { transform: scale(1.06) rotate(-3deg); }
}
.modal-card h3.vpn-modal-title{
  font-size:22px;letter-spacing:-.024em;line-height:1.18;
  margin-bottom:10px;
  background:linear-gradient(120deg, #fff 0%, #fff 50%, #ff9f0a 90%, #ff375f 110%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.vpn-modal-text{
  font-family:var(--font-text);font-size:14px;line-height:1.5;color:var(--text-1);
  margin:0 auto 14px;max-width:38ch;
}
.vpn-cc{
  font-family:var(--font-mono);font-size:12px;
  padding:2px 8px;border-radius:6px;
  background:rgba(255,55,95,.18);
  color:#ffb0b0;letter-spacing:.04em;
  text-transform:uppercase;display:inline-block;
}
.vpn-cc:empty{display:none}
.vpn-modal-list{
  list-style:none;display:flex;flex-direction:column;gap:8px;
  margin:0 0 16px;text-align:left;
  font-family:var(--font-text);font-size:13.5px;color:var(--text-1);line-height:1.42;
}
.vpn-modal-list li{
  display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:flex-start;
}
.vpn-step-n{
  flex-shrink:0;width:22px;height:22px;border-radius:50%;
  display:grid;place-items:center;
  background:linear-gradient(135deg, rgba(30,200,230,.32), rgba(191,90,242,.32));
  border:1px solid rgba(255,255,255,.18);
  font-family:var(--font-mono);font-size:11px;font-weight:600;color:#fff;
}

/* === date trigger field — single button with placeholder, opens modal === */
.date-field{position:relative}
.date-trigger{
  display:flex;align-items:center;gap:12px;
  width:100%;
  font-family:var(--font-text);font-size:15px;color:var(--text-3);
  background:rgba(255,255,255,.04);
  border:1.4px solid var(--stroke-2);
  border-radius:14px;
  padding:14px 16px;
  text-align:left;
  cursor:pointer;
  transition: border-color .35s var(--ease-out), background .3s var(--ease-out);
  position:relative;
}
.date-trigger:hover, .date-trigger:focus-visible{
  outline:none;
  border-color: var(--cyan);
  background:rgba(255,255,255,.07);
}
.date-trigger.has-value{color:#fff;font-weight:500}
.date-trigger-ico{width:18px;height:18px;color:var(--cyan-bright);flex-shrink:0;opacity:.75}
.date-trigger.has-value .date-trigger-ico{opacity:1}
.date-trigger-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.date-trigger-chev{width:14px;height:14px;color:var(--text-2);flex-shrink:0;transition: transform .3s var(--ease-out)}
.date-trigger[aria-expanded="true"] .date-trigger-chev{transform:rotate(180deg)}

/* === date picker modal — bottom sheet style === */
.date-modal .modal-card{
  margin-top:auto;margin-bottom:0;
  border-radius:24px 24px 0 0;
  width:100%;max-width:540px;
  padding:22px 18px 24px;
  text-align:left;
}
.date-modal{align-items:flex-end !important;padding:0 !important}
.date-modal-title{
  font-family:var(--font-display);font-weight:780;
  font-size:22px;letter-spacing:-.026em;line-height:1.15;
  margin-bottom:6px;
  background:linear-gradient(120deg, #fff 0%, #fff 50%, #64e0ff 90%, #bf5af2 110%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.date-modal-sub{
  font-family:var(--font-text);font-size:13px;color:var(--text-2);line-height:1.45;
  margin:0 0 18px;
}
.date-modal-wheels{
  display:grid;grid-template-columns:1fr 1.4fr 1fr;gap:8px;
  margin-bottom:18px;
}
.date-wheel-col{display:flex;flex-direction:column;gap:6px}
.date-wheel-col > span{
  font-family:var(--font-text);font-size:11.5px;font-weight:500;color:var(--text-3);
  letter-spacing:.04em;text-transform:uppercase;padding-left:2px;
}
.date-wheel-col select{
  font-family:var(--font-text);font-size:16px;color:#fff;font-weight:500;
  background:rgba(255,255,255,.06);
  border:1.4px solid var(--stroke-2);
  border-radius:12px;
  padding:14px 28px 14px 12px;
  width:100%;min-width:0;
  appearance:none;-webkit-appearance:none;
  background-image:
    linear-gradient(45deg, transparent 47%, var(--text-2) 47%, var(--text-2) 53%, transparent 53%),
    linear-gradient(-45deg, transparent 47%, var(--text-2) 47%, var(--text-2) 53%, transparent 53%);
  background-position: calc(100% - 14px) calc(50% + 1px), calc(100% - 10px) calc(50% + 1px);
  background-size: 5px 5px;
  background-repeat: no-repeat;
}
.date-wheel-col select option{background:#0d0d12;color:#fff}
.date-modal-actions{
  display:flex;gap:10px;
}
.date-modal-actions button{flex:1;justify-content:center}
.date-modal-actions .date-modal-apply{
  background:linear-gradient(135deg, rgba(30,200,230,.22), rgba(191,90,242,.22));
  border-color:rgba(255,255,255,.32);color:#fff;
  font-weight:600;
}

.brief-note{
  font-family:var(--font-text);font-size:13px;color:#ff6b6b;font-weight:500;line-height:1.4;
  min-height:1em;flex:1;min-width:0;
}
.brief-disclaimer{
  margin-top:var(--s-3);font-size:12px;color:var(--text-3);font-family:var(--font-text);
  line-height:1.45;max-width:60ch;position:relative;z-index:1;
}

/* ==========================================================
   SUCCESS MODAL
   ========================================================== */
body.modal-open{overflow:hidden}
.modal{position:fixed;inset:0;z-index:10000;display:none;align-items:center;justify-content:center;padding:24px}
.modal.open{display:flex}
.modal-backdrop{
  position:absolute;inset:0;
  background:rgba(0,0,0,.72);
  backdrop-filter:blur(24px) saturate(1.2);
  -webkit-backdrop-filter:blur(24px) saturate(1.2);
  animation: modalFadeIn .35s var(--ease-out) forwards;
}
@keyframes modalFadeIn{from{opacity:0}to{opacity:1}}

.modal-card{
  position:relative;z-index:1;
  width:min(540px, 92vw);
  padding:var(--s-5) var(--s-4) var(--s-4);
  border-radius:32px;
  background:linear-gradient(170deg, #0d0d18, #1a0d24);
  border:1px solid var(--stroke-2);
  text-align:center;
  isolation:isolate;overflow:hidden;
  transform:translateY(28px) scale(.94);opacity:0;
  animation: modalCardIn .55s cubic-bezier(.34,1.4,.64,1) .15s forwards;
  box-shadow: 0 40px 100px -20px rgba(30,200,230,.35), 0 20px 60px -16px rgba(191,90,242,.4);
}
.modal-card::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.6px;
  background:linear-gradient(135deg, #1ec8e6, #5e5ce6 35%, #bf5af2 65%, #ff375f);
  background-size:200% 200%;
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;
  animation: phoneBorder 7s linear infinite;
}
@keyframes modalCardIn{
  to{transform:translateY(0) scale(1);opacity:1}
}

.modal-close{
  position:absolute;top:18px;right:18px;
  width:36px;height:36px;border-radius:50%;
  background:var(--surface);border:1px solid var(--stroke-2);
  color:var(--text-1);font-size:22px;line-height:0;
  cursor:pointer;display:grid;place-items:center;
  transition:background .3s var(--ease-out), transform .4s var(--ease-spring), border-color .3s var(--ease-out);
  font-family:var(--font-text);
}
.modal-close:hover{background:var(--surface-2);transform:rotate(90deg);border-color:rgba(255,255,255,.32)}

.modal-ico{
  position:relative;display:grid;place-items:center;
  width:120px;height:120px;margin:0 auto var(--s-3);
}
.modal-check{width:100%;height:100%;position:relative;z-index:1}
.modal-check .check-circle{
  fill:none;stroke:url(#checkGrad);stroke-width:3;
  stroke-dasharray:226;stroke-dashoffset:226;
  animation: drawCircle .9s cubic-bezier(.4,0,.2,1) .4s forwards;
}
.modal-check .check-line{
  fill:none;stroke:#fff;stroke-width:5;stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:60;stroke-dashoffset:60;
  filter: drop-shadow(0 0 8px rgba(255,255,255,.7));
  animation: drawCheck .45s cubic-bezier(.4,0,.2,1) 1.05s forwards;
}
@keyframes drawCircle{to{stroke-dashoffset:0}}
@keyframes drawCheck{to{stroke-dashoffset:0}}
.modal-glow{
  position:absolute;inset:-10px;border-radius:50%;
  background:radial-gradient(circle, rgba(30,200,230,.45), rgba(191,90,242,.25) 40%, transparent 70%);
  filter:blur(20px);z-index:0;
  animation: glowPulse 2.6s ease-in-out infinite;
}
@keyframes glowPulse{
  0%, 100%{opacity:.55;transform:scale(1)}
  50%{opacity:.85;transform:scale(1.08)}
}

.modal-card h3{
  font-family:var(--font-display);font-weight:780;font-size:clamp(28px, 2.8vw, 42px);
  letter-spacing:-.038em;line-height:1.05;margin-bottom:14px;
  background:linear-gradient(120deg, #fff 0%, #fff 40%, #64e0ff 80%, #bf5af2 110%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.modal-card p{
  color:var(--text-1);font-size:15.5px;line-height:1.55;font-family:var(--font-text);
  margin-bottom:var(--s-4);max-width:42ch;margin-left:auto;margin-right:auto;
}
.modal-card p a{color:#64e0ff;text-decoration:underline;text-underline-offset:3px}
.modal-card p a:hover{color:#fff}
.modal-cta-row{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.modal-call svg{color:var(--cyan)}
.modal-dismiss{cursor:pointer}

/* ==========================================================
   QUICK-LEAD MODAL (от CTA «Оставить заявку» в бюджете)
   ========================================================== */
.modal-card--form{
  text-align:left;
  width:min(540px, 92vw);
  padding:var(--s-4) var(--s-4) var(--s-3);
}
.lead-eyebrow{
  display:inline-flex;align-items:center;gap:14px;margin-bottom:var(--s-2);
  font-family:var(--font-text);
}
.lead-eyebrow .line{
  width:36px;height:1.6px;flex-shrink:0;border-radius:2px;
  background:linear-gradient(90deg,#1ec8e6,#bf5af2,#ff375f);
}
.lead-eyebrow .n{font-family:var(--font-mono);font-size:12px;color:var(--text-3);letter-spacing:.02em}
.lead-eyebrow .l{font-family:var(--font-accent);font-weight:500;font-size:15px;color:var(--text-1)}

.modal-card--form h3{
  text-align:left;
  font-size:clamp(22px, 1.9vw, 28px);
  letter-spacing:-.030em;line-height:1.18;
  margin-bottom:var(--s-2);
}
.modal-sub{
  text-align:left;color:var(--text-2);font-size:14.5px;line-height:1.5;
  margin:0 0 var(--s-3) 0;max-width:none;
}
.lead-tier{
  display:inline-block;margin-top:6px;
  font-family:var(--font-mono);font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--cyan-bright);
}
.lead-tier:empty{display:none}

.lead-fields{
  display:grid;grid-template-columns:1fr;gap:var(--s-2);
  margin-bottom:var(--s-3);
}
.modal-card--form .field input{font-size:15px;padding:13px 16px}
.modal-card--form .field-hint{font-size:12.5px;color:var(--text-3);line-height:1.4}
.modal-card--form .field.field--invalid .field-hint{color:#ff6b6b}

.lead-submit-row{
  display:flex;flex-wrap:wrap;gap:var(--s-2);align-items:center;
  margin-bottom:var(--s-2);
}
.lead-submit{
  cursor:pointer;
  font-family:var(--font-mono);font-weight:500;font-size:16px;letter-spacing:.01em;color:#fff;
  padding:var(--s-2) var(--s-3) var(--s-2) var(--s-2);
}
.lead-submit .ico svg{color:#fff;width:20px;height:20px}
.lead-submit:disabled{cursor:wait}
.lead-submit.is-loading{pointer-events:none}
.lead-submit.is-loading .ico svg{animation: planeFlyLoop .9s linear infinite}
.lead-submit.is-loading::after{
  content:"";position:absolute;inset:0;
  background: linear-gradient(105deg, transparent 30%, rgba(255,255,255,.15) 50%, transparent 70%);
  background-size: 220% 100%;
  animation: loadingShimmer 1.1s linear infinite;
  pointer-events:none;mix-blend-mode:screen;border-radius:inherit;
}

.lead-error{
  font-family:var(--font-text);font-size:12.5px;font-weight:500;line-height:1.4;
  color:#ff6b6b;flex:1;min-width:0;
}
.lead-error.is-throttled{color:var(--orange)}

.lead-disclaimer{
  font-family:var(--font-text);font-size:11.5px;color:var(--text-3);line-height:1.4;
  margin:0;padding-top:var(--s-2);border-top:1px solid var(--stroke);max-width:none;
}
.lead-disclaimer a{color:var(--cyan-bright);text-decoration:underline;text-underline-offset:2px}
.lead-disclaimer a:hover{color:#fff}

.lead-honey{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}

/* ==========================================================
   EXIT-INTENT ЛОВЕЦ ЛИДОВ
   ========================================================== */
.modal-card--exit{
  width:min(680px, 94vw);
  padding:var(--s-5) var(--s-4) var(--s-3);
  text-align:left;
  position:relative;overflow:hidden;
}

/* parallax orbs внутри карточки — реагируют на мышь */
.exit-orbs{position:absolute;inset:0;pointer-events:none;z-index:0;border-radius:inherit;overflow:hidden}
.exit-orb{position:absolute;border-radius:50%;filter:blur(48px);opacity:.5;transition: transform .4s var(--ease-out);will-change:transform}
.exit-orb.a{width:340px;height:340px;background:radial-gradient(circle, #1ec8e6, transparent 60%);top:-120px;left:-100px}
.exit-orb.b{width:280px;height:280px;background:radial-gradient(circle, #bf5af2, transparent 60%);bottom:-80px;right:-80px;opacity:.55}
.exit-orb.c{width:200px;height:200px;background:radial-gradient(circle, #ff375f, transparent 60%);top:30%;right:18%;opacity:.4}

.modal-card--exit > *:not(.exit-orbs):not(.modal-close){position:relative;z-index:1}

.exit-bangle{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 14px;border-radius:999px;
  font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.10em;text-transform:uppercase;
  color:#fff;
  background:linear-gradient(135deg, #ff9f0a, #ff375f);
  box-shadow: 0 8px 22px -6px rgba(255,55,95,.55), inset 0 1px 0 rgba(255,255,255,.18);
  margin-bottom:var(--s-3);
  animation: bangleFlash 2.4s ease-in-out infinite;
}
.exit-bangle svg{width:14px;height:14px;color:#ffd60a}
@keyframes bangleFlash{
  0%,100%{box-shadow: 0 8px 22px -6px rgba(255,55,95,.5), inset 0 1px 0 rgba(255,255,255,.18); transform:translateY(0)}
  50%    {box-shadow: 0 12px 32px -6px rgba(255,55,95,.8), inset 0 1px 0 rgba(255,255,255,.18); transform:translateY(-2px)}
}

.modal-card--exit h3{
  text-align:left;
  font-family:var(--font-display);font-weight:780;
  font-size:clamp(24px, 2.2vw, 36px);
  letter-spacing:-.034em;line-height:1.12;
  margin-bottom:var(--s-2);
  background:none;-webkit-text-fill-color:#fff;color:#fff;
}
.modal-card--exit h3 .fr{
  background:linear-gradient(120deg,#1ec8e6,#bf5af2 55%,#ff375f);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;
}
.exit-strike{
  text-decoration:line-through;text-decoration-color:rgba(255,107,107,.7);text-decoration-thickness:2px;
  color:var(--text-2);
}

.exit-sub{
  text-align:left;color:var(--text-1);font-size:15px;line-height:1.5;
  margin:0 0 var(--s-3) 0;max-width:none;
}
.exit-sub b{color:#fff;font-weight:660}

.exit-perks{
  list-style:none;display:flex;flex-direction:column;gap:10px;margin:0 0 var(--s-3) 0;
  font-family:var(--font-text);font-size:14px;color:var(--text-1);line-height:1.45;
}
.exit-perks li{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:flex-start}
.exit-perks .check{
  flex-shrink:0;width:24px;height:24px;border-radius:50%;display:grid;place-items:center;
  background:linear-gradient(135deg, rgba(30,200,230,.32), rgba(191,90,242,.32));
  border:1px solid rgba(255,255,255,.18);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.14);
}
.exit-perks .check svg{width:11px;height:11px;color:#fff}
.exit-perks b{color:#fff;font-weight:660}

.exit-lead-fields{grid-template-columns:1fr 1fr}
@media (max-width:560px){.exit-lead-fields{grid-template-columns:1fr}}

/* ==========================================================
   CLICK RIPPLE — стеклянные refraction-волны
   backdrop-filter + radial mask = ring искажающий фон, без цвета
   ========================================================== */
.ripple-layer{position:fixed;inset:0;pointer-events:none;z-index:9998;overflow:hidden}

/* лёгкая центральная вспышка — едва уловимый блик */
.ripple-splash{
  position:absolute;width:14px;height:14px;border-radius:50%;
  transform:translate(-50%,-50%);
  background:radial-gradient(circle, rgba(255,255,255,.42) 0%, rgba(255,255,255,.12) 45%, transparent 70%);
  filter:blur(2px);
  animation: rippleSplash .35s cubic-bezier(.22,1,.36,1) forwards;
  pointer-events:none;
}
@keyframes rippleSplash{
  0%   { width:0;   height:0;   opacity:.9 }
  60%  { width:54px; height:54px; opacity:.55 }
  100% { width:120px;height:120px; opacity:0 }
}

/* основные стеклянные волны: ring через mask, blur через backdrop-filter */
.ripple{
  position:absolute;width:10px;height:10px;border-radius:50%;
  transform:translate(-50%,-50%);
  background:transparent;
  backdrop-filter: blur(10px) saturate(1.18);
  -webkit-backdrop-filter: blur(10px) saturate(1.18);
  mask-image: radial-gradient(circle,
    transparent 28%,
    rgba(0,0,0,.55) 38%,
    #000 46%,
    #000 50%,
    rgba(0,0,0,.55) 58%,
    transparent 68%);
  -webkit-mask-image: radial-gradient(circle,
    transparent 28%,
    rgba(0,0,0,.55) 38%,
    #000 46%,
    #000 50%,
    rgba(0,0,0,.55) 58%,
    transparent 68%);
  box-shadow:
    inset 0 0 20px rgba(255,255,255,.05),
    0 0 28px rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  animation: rippleExpand 1.3s cubic-bezier(.22,1,.36,1) forwards;
  pointer-events:none;
  opacity:0;
  will-change: width, height, opacity, backdrop-filter;
}
.ripple.r2{ animation-delay:.15s; animation-duration:1.42s }
.ripple.r3{ animation-delay:.31s; animation-duration:1.55s }

@keyframes rippleExpand{
  0%   { width:10px;  height:10px;  opacity:0;
         backdrop-filter:blur(12px) saturate(1.2);
         -webkit-backdrop-filter:blur(12px) saturate(1.2) }
  8%   { opacity:1 }
  60%  { opacity:.55 }
  100% { width:880px; height:880px; opacity:0;
         backdrop-filter:blur(2px) saturate(1.04);
         -webkit-backdrop-filter:blur(2px) saturate(1.04) }
}

@media (prefers-reduced-motion: reduce){
  .ripple, .ripple-splash{display:none}
}

/* ==========================================================
   ACCESSIBILITY
   ========================================================== */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
  .orb,.hero-chips .chip,.marquee-track,.bg-mesh{animation:none !important}
  [data-px]{transform:none !important}
}
@media print{
  .bg-mesh,.bg-grid,.spotlight,.hero-orbs,.hero-chips{display:none !important}
  body{background:#fff;color:#000}
}

/* ==========================================================
   MOBILE — iPhone 14 Pro target (393×852), covers 360–480
   No zoom, no horizontal scroll, premium polish kept.
   ========================================================== */
@media (max-width: 768px){
  :root{
    --gutter: 18px;
    --section-pad: 56px;
    --nav-h: 56px;
    --marquee-h: 64px;
  }
  html, body{
    overflow-x: hidden;
    max-width: 100vw;
    touch-action: pan-y;
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
  }
  body{font-size:15.5px; line-height:1.5}
  /* kill custom cursor + spotlight on touch */
  html, a, button, .card, .niche, .venue, .level, .faq summary, .tab, .nav-link, .cta, .phone-cta, .magnetic{cursor:auto !important}
  .spotlight{display:none}
  /* hide decorative absolutes that cause body overflow */
  .hero-chips{display:none}
  .hero-orbs .orb{filter:blur(60px);opacity:.45}
  .hero-orbs .orb.a{width:320px;height:320px;top:-100px;right:-80px}
  .hero-orbs .orb.b{width:260px;height:260px;bottom:-60px;left:-100px}
  .hero-orbs .orb.c{display:none}
  /* tighter sections */
  section[id]{scroll-margin-top: 64px}
  /* clamp everything visual to viewport */
  .wrap{padding-left:max(var(--gutter), env(safe-area-inset-left));padding-right:max(var(--gutter), env(safe-area-inset-right))}
  /* eyebrow tighter */
  .eyebrow{gap:10px}
  .eyebrow .line{width:28px}
  .eyebrow .n{font-size:11px}
  .eyebrow .l{font-size:13px}

  /* ===== NAV (mobile) ===== */
  .nav{height:var(--nav-h)}
  .nav .wrap{gap:8px;align-items:center;justify-content:space-between}
  .nav-links{display:none}
  .nav-logo{font-size:18px;gap:8px;letter-spacing:-.028em}
  .nav-logo svg.mark{width:28px;height:28px}
  .nav-phone{
    padding:4px 12px 4px 4px;
    font-size:12px;
    gap:7px;
    border-radius:999px;
    flex-shrink:0;
    min-width:0;
    white-space:nowrap;
  }
  .nav-phone .pico{width:26px;height:26px;flex-shrink:0}
  .nav-phone .pico svg{width:12px;height:12px}
  .nav-phone .phone-text{
    letter-spacing:0;
    font-weight:500;
    white-space:nowrap;
    font-variant-numeric: tabular-nums;
    overflow:visible;
  }

  /* ===== HERO (mobile) ===== */
  .hero{
    padding: calc(var(--nav-h) + 14px) 0 var(--s-3);
    height: auto;
    min-height: calc(100svh - var(--marquee-h));
    align-items: flex-start;
  }
  .hero .wrap{max-width:100%}
  .hero h1{
    font-size: clamp(34px, 10.6vw, 46px);
    letter-spacing: -.036em;
    max-width: 12ch;
    margin-top: 14px;
    margin-bottom: 16px;
    line-height: .98;
  }
  .hero h1 br{display:none}
  .hero-sub{
    font-size: 14.5px;
    line-height: 1.5;
    max-width: 100%;
    margin-bottom: 18px;
  }
  .hero-cta-row{gap:10px;flex-direction:column;align-items:stretch}
  .phone-cta{
    padding: 11px 16px 11px 11px;
    font-size: 16px;
    border-radius: 16px;
    width: 100%;
    gap: 12px;
  }
  .phone-cta .ico{width:42px;height:42px;border-radius:12px}
  .phone-cta .ico svg{width:18px;height:18px}
  .phone-cta .label{gap:3px}
  .phone-cta .label small{font-size:10px;letter-spacing:.14em}
  .phone-cta .num{font-size:17px}
  .cta-secondary{
    padding: 12px 18px;
    font-size: 14px;
    width: 100%;
    justify-content: center;
    border-radius: 14px;
  }
  .hero-stats{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin-top: 20px;
  }
  .hero-stat{
    padding: 10px 11px;
    border-radius: 14px;
    gap: 10px;
  }
  .hero-stat .usp-ico{width:30px;height:30px;border-radius:9px}
  .hero-stat .usp-ico svg{width:15px;height:15px}
  .hero-stat .v{font-size:19px;gap:3px}
  .hero-stat .v .unit{font-size:9px;letter-spacing:.04em}
  .hero-stat .l{font-size:10.5px;line-height:1.3}
  /* veil stronger to mask Rutube play button on tall portrait */
  .hero-veil{
    background:
      radial-gradient(circle 260px at 50% 46%, rgba(6,6,10,.97) 0%, rgba(6,6,10,.72) 60%, rgba(6,6,10,.35) 100%),
      linear-gradient(180deg,
        rgba(6,6,10,.85) 0%,
        rgba(6,6,10,.55) 25%,
        rgba(6,6,10,.50) 55%,
        rgba(6,6,10,.80) 85%,
        rgba(6,6,10,.96) 100%),
      radial-gradient(ellipse 80% 60% at 50% 25%, rgba(94,92,230,.10), transparent 70%);
  }
  /* iframe — heavier crop on mobile so play button stays masked */
  .hero-bg iframe{
    width: max(140%, 177.78vh);
    transform: translate(-50%, -50%) scale(1.18);
  }

  /* ===== MARQUEE (mobile) ===== */
  .marquee{padding:16px 0}
  .marquee::before, .marquee::after{width:60px}
  .marquee-track{gap:28px;animation-duration:34s}
  .marquee-item{font-size:18px;gap:28px;letter-spacing:-.02em;font-weight:620}
  .marquee-item .sep{width:6px;height:6px}

  /* ===== MANIFESTO (mobile · compact 1-screen) ===== */
  #manifesto{padding:42px 0 32px}
  #manifesto h2{font-size:26px;letter-spacing:-.028em;line-height:1.06;max-width:14ch;margin-top:14px !important}
  #manifesto .lead{font-size:13.5px;line-height:1.48;margin-top:12px !important;max-width:42ch}
  .manifesto-grid{grid-template-columns:1fr;gap:8px;margin-top:18px}
  .manif{padding:14px 14px;border-radius:16px;display:flex;flex-direction:column;gap:6px}
  .manif .x{font-size:10px;margin-bottom:2px;letter-spacing:.05em;line-height:1.2}
  .manif .y{font-size:15px;letter-spacing:-.014em;line-height:1.22;margin-bottom:2px;font-weight:680}
  .manif .y .fr{font-weight:700}
  .manif .why{
    display:-webkit-box;
    -webkit-line-clamp:3;line-clamp:3;
    -webkit-box-orient:vertical;
    overflow:hidden;
    font-size:12px;line-height:1.4;color:var(--text-2);
    margin-bottom:0;
  }

  /* email CTA — compact */
  .email-cta-wrap{margin-top:14px}
  .email-cta{padding:14px 14px;border-radius:16px}
  .email-cta-content{
    grid-template-columns: auto 1fr auto;
    grid-template-rows: auto;
    gap: 12px;
    align-items: center;
  }
  .email-cta-ico{width:40px;height:40px;border-radius:12px;grid-row:1;grid-column:1}
  .email-cta-ico .env{width:18px;height:18px}
  .email-cta-ico .plane{width:14px;height:14px}
  .email-cta-text{grid-row:1;grid-column:2;gap:2px}
  .email-cta-text small{font-size:10.5px;letter-spacing:.005em}
  .email-cta-text b{font-size:14px;letter-spacing:-.016em;line-height:1.15}
  .email-cta-arrow{
    grid-row:1;grid-column:3;
    padding:8px 12px;border-radius:10px;
    font-size:11px;gap:6px;
  }
  .email-cta-arrow .mail{display:none}
  .email-cta-arrow svg{width:12px;height:12px}

  /* ===== POVODY (mobile · animated tabs + compact tiles) ===== */
  #povody{padding:42px 0 32px}
  #povody h2{font-size:26px;letter-spacing:-.026em;line-height:1.06;max-width:14ch}
  #povody .lead{font-size:13.5px;line-height:1.48;margin-top:12px !important;max-width:46ch}
  .tabs{
    margin-top:18px;margin-bottom:16px;
    padding:4px;gap:0;
    display:flex;width:100%;
    background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015));
    border:1px solid var(--stroke-2);
    position:relative;
    border-radius:999px;
    isolation:isolate;
  }
  .tabs::before{
    /* sliding active indicator */
    content:"";
    position:absolute;
    top:4px;left:4px;
    width:calc(50% - 4px);height:calc(100% - 8px);
    border-radius:999px;
    background:linear-gradient(135deg, rgba(30,200,230,.32), rgba(191,90,242,.32));
    box-shadow:
      inset 0 0 0 1px rgba(255,255,255,.18),
      0 6px 16px -6px rgba(30,200,230,.45),
      0 4px 14px -8px rgba(191,90,242,.4);
    transition: transform .5s var(--ease-spring);
    z-index:0;
  }
  .tabs[data-active="b2b"]::before{ transform: translateX(100%); }
  .tab{
    flex:1;padding:10px 8px;font-size:12.5px;
    display:flex;align-items:center;justify-content:center;gap:6px;
    border-radius:999px;
    position:relative;z-index:1;
    background:transparent !important;
    box-shadow:none !important;
    transition: color .35s var(--ease-out), transform .4s var(--ease-spring);
    font-weight:580;color:var(--text-2);
  }
  .tab[aria-selected="true"]{ color:#fff; transform: scale(1.02); }
  .tab .count{font-size:10px;margin-left:2px;letter-spacing:0;color:var(--text-3);font-weight:500}
  .tab[aria-selected="true"] .count{color:rgba(255,255,255,.7)}

  .tab-panel{transition: opacity .4s var(--ease-out), transform .45s var(--ease-out)}
  .tab-panel[data-anim="leaving"]{opacity:0;transform:translateY(-6px) scale(.98)}
  .tab-panel[data-anim="entering"]{opacity:0;transform:translateY(8px) scale(.985)}
  .tab-panel[data-anim="entered"]{opacity:1;transform:none}

  /* niche tiles — denser layout */
  .niches{grid-template-columns:1fr;gap:8px}
  .niche{
    padding:12px 14px;border-radius:14px;
    min-height:auto;gap:12px;
    flex-direction:row;align-items:center;
  }
  .niche .glyph{width:36px;height:36px;border-radius:10px;flex-shrink:0}
  .niche .glyph svg{width:18px;height:18px}
  .niche > div:last-child{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
  .niche .name{font-size:13.5px;letter-spacing:-.012em;line-height:1.22;margin-bottom:0;font-weight:680}
  .niche .meta{font-size:11.5px;line-height:1.35;color:var(--text-3)}
  .niche .meta b{color:var(--text-1);font-weight:600}

  /* ===== BRIEF (mobile) ===== */
  #brief h2{font-size:32px;letter-spacing:-.030em;line-height:1.04;max-width:15ch}
  #brief .lead{font-size:14.5px;line-height:1.55;margin-top:18px !important}
  .brief{
    margin-top:28px;
    padding:22px 18px;
    border-radius:22px;
  }
  .brief-grid{grid-template-columns:1fr;gap:14px}
  .field input, .field select, .field textarea{
    font-size:16px; /* >=16px чтобы iOS не зумил при фокусе */
    padding:13px 14px;
    border-radius:12px;
  }
  .field-label{font-size:13px}
  .field-hint{font-size:12px}
  .msg-tiles{grid-template-columns:repeat(2, 1fr);gap:8px}
  .msg-tile{padding:12px 12px 10px;border-radius:14px;min-height:84px;gap:4px}
  .msg-tile .msg-ico{width:32px;height:32px;border-radius:9px}
  .msg-tile .msg-ico svg{width:16px;height:16px}
  .msg-tile .msg-name{font-size:13.5px}
  .msg-tile .msg-meta{font-size:11px;letter-spacing:0}
  .msg-tile .msg-tick{width:18px;height:18px;top:8px;right:8px}
  .brief-cta{margin-top:18px;gap:12px;flex-direction:column;align-items:stretch}
  .brief-submit{font-size:15px;padding:13px 16px 13px 13px;border-radius:16px;justify-content:flex-start;gap:12px;width:100%}
  .brief-submit .ico{width:42px;height:42px;border-radius:12px}
  .brief-submit .ico svg{width:18px;height:18px}
  .brief-submit .label small{font-size:10px;letter-spacing:.14em}
  .brief-submit .label b{font-size:15px}
  .brief-note{font-size:12.5px;text-align:left}
  .brief-disclaimer{font-size:11.5px;margin-top:16px;line-height:1.5}

  /* ===== VENUES (mobile) ===== */
  #venues h2{font-size:32px;letter-spacing:-.030em;line-height:1.04;max-width:14ch}
  #venues .lead{font-size:14.5px;line-height:1.55;margin-top:18px !important}
  .venues-wrap{margin-top:28px}
  .venues-rail{gap:14px;padding:6px 0 24px}
  .venue{
    flex: 0 0 calc(100vw - 2 * var(--gutter) - 28px);
    min-height: auto;
    border-radius: 20px;
  }
  /* disable 3D tilt + hover scale on touch */
  .venue:hover{transform:none;border-color:var(--stroke);box-shadow:none}
  .venue:hover .venue-img img{transform:none}
  .venue-body{padding:18px 18px 20px;gap:10px}
  .venue h3{font-size:20px;letter-spacing:-.022em}
  .venue .desc{font-size:13.5px;line-height:1.5}
  .venue .specs{gap:8px 12px;font-size:12px;padding-top:12px}
  .venue .specs .k{font-size:10px}
  .venue .specs .v{font-size:13.5px}
  .venue-img .tag{font-size:10px;padding:5px 10px;top:10px;left:10px}
  .rail-hint{font-size:11.5px;margin-top:4px}

  /* venues-lead (mobile) */
  .venues-lead{margin-top:22px;padding:18px 16px;border-radius:18px}
  .venues-lead-head{gap:12px;margin-bottom:14px;align-items:flex-start}
  .venues-lead-icon{width:42px;height:42px;border-radius:13px}
  .venues-lead-icon svg{width:19px;height:19px}
  .venues-lead h3{font-size:17px;letter-spacing:-.020em;line-height:1.18;margin-bottom:4px}
  .venues-lead-sub{font-size:12.5px;line-height:1.45}
  .venues-lead-fields{grid-template-columns:1fr;gap:10px;margin-bottom:14px}
  .venues-lead-submit-row{flex-direction:column;align-items:stretch;gap:10px;margin-bottom:10px}
  .venues-lead-submit{
    font-size:14px;padding:11px 16px 11px 11px;border-radius:14px;
    justify-content:flex-start;gap:12px;width:100%;
  }
  .venues-lead-submit .ico{width:38px;height:38px;border-radius:11px}
  .venues-lead-submit .ico svg{width:16px;height:16px}
  .venues-lead-submit .label small{font-size:10px;letter-spacing:.12em}
  .venues-lead-submit .label .num{font-size:13px}

  /* ===== PROCESS (mobile) ===== */
  #process h2{font-size:30px;letter-spacing:-.028em;line-height:1.06;max-width:14ch}
  #process .lead{font-size:14.5px;line-height:1.55;margin-top:18px !important}
  .steps{
    grid-template-columns:1fr;gap:16px;margin-top:32px;
  }
  .steps::before{
    /* convert top horizontal line into vertical connector on left */
    left:24px;right:auto;top:48px;bottom:32px;
    width:2px;height:auto;
    background:linear-gradient(180deg,#1ec8e6,#5e5ce6,#bf5af2,#ff375f,#ff9f0a);
  }
  .step{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:start}
  .step .n{
    width:48px;height:48px;border-radius:14px;font-size:17px;
    grid-row:1 / span 3;
  }
  .step h4{margin-top:6px;font-size:17px;letter-spacing:-.012em}
  .step p{margin-top:4px;font-size:13.5px;line-height:1.48}

  /* ===== ENHANCERS (mobile · 4×2 icon grid · tap → modal) ===== */
  #enhancers{padding:42px 0 32px}
  #enhancers h2{font-size:26px;letter-spacing:-.026em;line-height:1.06;max-width:14ch}
  #enhancers .lead{font-size:13.5px;line-height:1.48;margin-top:12px !important;max-width:46ch}
  .enhancers{grid-template-columns:repeat(4,1fr);gap:8px;margin-top:16px}
  .enhancer{
    padding:14px 8px 12px;border-radius:14px;
    min-height:90px;gap:8px;
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    text-align:center;
    background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.015));
    appearance:none;-webkit-appearance:none;
    cursor:pointer;
    position:relative;
  }
  .enhancer::after{
    /* tap indicator — small "+" badge */
    content:"+";
    position:absolute;top:5px;right:7px;
    font-family:var(--font-text);font-size:11px;font-weight:700;color:var(--text-3);
    width:14px;height:14px;line-height:14px;text-align:center;
    border-radius:50%;border:1px solid var(--stroke-2);
    background:rgba(255,255,255,.04);
    transition: transform .35s var(--ease-spring), background .35s var(--ease-out);
  }
  .enhancer:active{transform:scale(.96)}
  .enhancer:active::after{transform:rotate(45deg);background:linear-gradient(135deg,rgba(30,200,230,.35),rgba(191,90,242,.35))}
  .enhancer .ico{
    width:40px;height:40px;border-radius:12px;
    transition: transform .4s var(--ease-spring);
  }
  .enhancer .ico svg{width:20px;height:20px}
  .enhancer h4{font-size:11px;letter-spacing:-.005em;line-height:1.18;font-weight:680;color:var(--text-0)}
  .enhancer p{display:none}

  /* ===== ENHANCER MODAL ===== */
  .modal-card--enhancer{
    width:min(420px, 92vw);
    padding:30px 22px 22px;text-align:center;
  }
  .enhancer-modal-ico{
    width:80px;height:80px;margin:0 auto 16px;
    border-radius:24px;
    display:grid;place-items:center;
    background:linear-gradient(135deg, rgba(30,200,230,.32), rgba(191,90,242,.32));
    border:1px solid rgba(255,255,255,.22);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.18), 0 14px 36px -10px rgba(30,200,230,.5);
    color:#fff;
  }
  .enhancer-modal-ico svg{width:36px;height:36px}
  .modal-card--enhancer h3.enhancer-modal-title{
    font-size:24px;letter-spacing:-.026em;line-height:1.12;
    margin-bottom:10px;
    background:linear-gradient(120deg, #fff 0%, #fff 40%, #64e0ff 80%, #bf5af2 110%);
    -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  }
  .enhancer-modal-text{
    font-size:14.5px;line-height:1.5;color:var(--text-1);
    margin:0 auto 18px;max-width:38ch;
  }

  /* ===== QUICK-LEAD MODAL fit mobile + thank-you lag fix ===== */
  .modal{padding:max(16px, env(safe-area-inset-top)) 14px max(16px, env(safe-area-inset-bottom)) 14px;overflow-y:auto;align-items:flex-start}
  .modal-card{
    margin: max(20px, env(safe-area-inset-top)) 0 max(20px, env(safe-area-inset-bottom));
    max-height: calc(100svh - 40px);
    overflow-y: auto;
  }
  .modal-card--form{
    width:100%;
    padding:22px 18px 18px;
    border-radius:22px;
  }
  .modal-close{width:32px;height:32px;font-size:20px;top:12px;right:12px}
  .lead-eyebrow{gap:10px;margin-bottom:10px}
  .lead-eyebrow .line{width:24px;height:1.4px}
  .lead-eyebrow .n{font-size:11px}
  .lead-eyebrow .l{font-size:13px}
  .modal-card--form h3{font-size:21px;letter-spacing:-.024em;line-height:1.18;margin-bottom:8px}
  .modal-sub{font-size:13.5px;line-height:1.45;margin-bottom:14px}
  .lead-tier{font-size:11px;letter-spacing:.05em}
  .lead-fields{gap:10px;margin-bottom:14px}
  .modal-card--form .field input{font-size:16px;padding:12px 14px;border-radius:12px}
  .modal-card--form .field-hint{font-size:11.5px}
  .lead-submit-row{gap:10px;flex-direction:column;align-items:stretch;margin-bottom:10px}
  .lead-submit{
    font-size:14px;padding:11px 16px 11px 11px;border-radius:14px;
    justify-content:flex-start;width:100%;gap:12px;
  }
  .lead-submit .ico{width:38px;height:38px;border-radius:11px}
  .lead-submit .ico svg{width:16px;height:16px}
  .lead-submit .label small{font-size:10px;letter-spacing:.12em}
  .lead-submit .label .num{font-size:12px}
  .lead-error{font-size:11.5px}
  .lead-disclaimer{font-size:11px;padding-top:10px}

  /* === Success modal — compact + faster anim === */
  .modal-card:not(.modal-card--form):not(.modal-card--enhancer):not(.modal-card--exit){
    padding:28px 18px 18px;
    border-radius:24px;
    width:min(420px, 92vw);
  }
  .modal-ico{width:88px;height:88px;margin-bottom:14px}
  .modal-card h3{font-size:24px;line-height:1.1;letter-spacing:-.028em;margin-bottom:10px}
  .modal-card p{font-size:13.5px;line-height:1.5;margin-bottom:18px}
  .modal-cta-row{flex-direction:column;gap:8px}
  .modal-cta-row .cta-secondary{width:100%;justify-content:center;padding:11px 16px;font-size:13.5px;border-radius:12px}

  /* faster success animation — мобильный CPU не успевает */
  .modal-check .check-circle{ animation-duration:.55s; animation-delay:.15s }
  .modal-check .check-line  { animation-duration:.30s; animation-delay:.55s }
  .modal-card{
    animation-duration: .35s !important;
    animation-delay: 0s !important;
  }
  .modal-card::before{animation-duration:5s !important}

  /* ===== VPN MODAL (mobile compact) ===== */
  .modal-card--vpn{
    padding:24px 18px 18px;
    border-radius:24px;
    width:min(360px, 92vw);
  }
  .vpn-modal-ico{width:64px;height:64px;border-radius:18px;margin-bottom:12px}
  .vpn-modal-ico svg{width:30px;height:30px}
  .modal-card h3.vpn-modal-title{font-size:18px;letter-spacing:-.020em;line-height:1.18;margin-bottom:8px}
  .vpn-modal-text{font-size:13px;line-height:1.5;margin-bottom:12px}
  .vpn-cc{font-size:10.5px;padding:1px 6px}
  .vpn-modal-list{font-size:12.5px;gap:6px;margin-bottom:14px}
  .vpn-step-n{width:20px;height:20px;font-size:10.5px}

  /* ===== EXIT MODAL — compact 1-screen + shimmer (mobile) ===== */
  .exit-modal{align-items:flex-end !important;padding:0 !important}
  .modal-card--exit{
    width:100%;
    margin-top:auto;margin-bottom:0;
    max-height: calc(100svh - 16px);
    overflow-y:auto;
    padding:18px 16px 14px;
    border-radius:24px 24px 0 0;
    position:relative;isolation:isolate;
  }
  /* hide heavy orbs on mobile (perf + space) */
  .modal-card--exit .exit-orbs{display:none}
  /* shimmer overlay across the entire card */
  .modal-card--exit::after{
    content:"";position:absolute;inset:0;border-radius:inherit;
    background:linear-gradient(115deg,
      transparent 35%,
      rgba(255,214,10,.10) 45%,
      rgba(255,255,255,.14) 50%,
      rgba(255,55,95,.10) 55%,
      transparent 65%);
    background-size: 260% 100%;
    background-position: -100% 0;
    animation: exitShimmer 3.6s ease-in-out infinite;
    pointer-events:none;mix-blend-mode:screen;
    z-index:2;
  }
  @keyframes exitShimmer{
    0%   { background-position: -100% 0; opacity: 0; }
    18%  { opacity: 1; }
    78%  { opacity: 1; }
    100% { background-position: 200% 0; opacity: 0; }
  }
  /* compact internal layout */
  .exit-bangle{
    font-size:10px;padding:5px 10px;
    margin-bottom:10px;letter-spacing:.08em;
  }
  .exit-bangle svg{width:12px;height:12px}
  .modal-card--exit h3{
    font-size:18px;letter-spacing:-.024em;line-height:1.2;margin-bottom:8px;
  }
  .modal-card--exit h3 br{display:none}
  .exit-sub{font-size:12.5px;line-height:1.45;margin-bottom:12px}
  .exit-perks{gap:6px;margin-bottom:12px;font-size:12px;line-height:1.35}
  .exit-perks li{gap:8px}
  .exit-perks .check{width:18px;height:18px}
  .exit-perks .check svg{width:9px;height:9px}
  .exit-lead-fields{grid-template-columns:1fr;gap:8px}
  .modal-card--exit .field-hint{display:none}
  .modal-card--exit .field-label{font-size:12px}
  .modal-card--exit .field input{font-size:16px;padding:11px 14px;border-radius:11px}
  .modal-card--exit .lead-submit-row{gap:8px;margin-bottom:6px;flex-direction:column;align-items:stretch}
  .modal-card--exit .lead-submit{
    font-size:13.5px;padding:10px 14px 10px 10px;border-radius:13px;
    width:100%;justify-content:flex-start;gap:10px;
  }
  .modal-card--exit .lead-submit .ico{width:36px;height:36px;border-radius:10px}
  .modal-card--exit .lead-submit .ico svg{width:15px;height:15px}
  .modal-card--exit .lead-submit .label small{font-size:9.5px;letter-spacing:.10em}
  .modal-card--exit .lead-submit .label .num{font-size:12px}
  .modal-card--exit .lead-disclaimer{font-size:11px;padding-top:8px;margin-top:6px}

  /* ===== LEVELS (Бюджет) (mobile · 2×2 grid + Premium shimmer) ===== */
  #levels{padding:42px 0 36px}
  #levels h2{font-size:26px;letter-spacing:-.026em;line-height:1.06;max-width:15ch}
  #levels .lead{font-size:13.5px;line-height:1.48;margin-top:12px !important;max-width:46ch}
  .levels{grid-template-columns:repeat(2, minmax(0,1fr));gap:10px;margin-top:18px}
  .level{
    padding:14px 12px 12px;border-radius:16px;
    min-height:auto;gap:10px;
  }
  .level:hover{transform:none;box-shadow:none;border-color:var(--stroke)}
  .level-head{min-height:auto}
  .head-titles{padding-right:0;gap:2px}
  .level .name{font-size:15.5px;letter-spacing:-.020em;line-height:1.05;gap:5px}
  .level .name .crown{width:13px;height:13px}
  .level .kicker{font-size:10.5px;line-height:1.2}
  /* pill — under titles instead of absolute on 2-col layout (too narrow) */
  .level .pill{
    position:static;display:inline-flex;align-self:flex-start;
    font-size:10.5px;padding:3px 8px;letter-spacing:.03em;
    margin-top:3px;text-transform:none;
    font-family:var(--font-mono);
    white-space:nowrap;
  }
  .level-example{font-size:11.5px;line-height:1.4;padding-left:8px;border-left-width:1.5px}
  .level-price{padding-bottom:10px}
  .level-price::after{right:20%}
  .level-price .price-row{gap:3px;flex-wrap:wrap}
  .level-price .price-num{font-size:22px;letter-spacing:-.030em}
  .level-price .price-num--inquire{font-size:18px;letter-spacing:-.022em;white-space:nowrap;line-height:1.05}
  .level-price .curr{font-size:14px}
  .level-price .prefix{font-size:10.5px}
  .level-price .price-sub{font-size:10.5px;max-width:100%;margin-top:6px;line-height:1.35}
  .level-features{font-size:11.5px;gap:6px;line-height:1.35}
  .level-features li{gap:8px}
  .level-features .check{width:16px;height:16px}
  .level-features .check svg{width:8px;height:8px}
  .level-cta-btn{padding:9px 10px;font-size:11.5px;border-radius:10px;gap:6px}
  .level-cta-btn svg{width:10px;height:10px}

  /* ===== PREMIUM — alignment + shimmer ===== */
  /* On 2-col grid, the desktop translateY(-10px) breaks row alignment.
     Reset transform on mobile; keep glow + shimmer instead. */
  .level.featured,
  .reveal-up.level.featured.in,
  .level.featured:hover,
  .reveal-up.level.featured.in:hover{
    transform: none !important;
    z-index: 1;
  }
  .level.featured{
    /* stronger glow + animated gradient overlay */
    box-shadow:
      0 12px 32px -10px color-mix(in srgb, var(--c1) 60%, transparent),
      0 0 0 1px color-mix(in srgb, var(--c1) 25%, transparent);
  }
  .level.featured::after{
    content:"";position:absolute;inset:0;border-radius:inherit;
    background:linear-gradient(115deg, transparent 30%, rgba(255,214,10,.18) 50%, transparent 70%);
    background-size:280% 100%;background-position:-100% 0;
    animation: premiumShimmer 3.6s ease-in-out infinite;
    pointer-events:none;mix-blend-mode:screen;
    z-index:3;
  }
  @keyframes premiumShimmer{
    0%   { background-position: -100% 0; opacity: 0; }
    20%  { opacity: 1; }
    70%  { opacity: 1; }
    100% { background-position: 220% 0; opacity: 0; }
  }
  /* premium crown badge — pulse */
  .level.featured .name .crown{
    animation: crownGlow 2.2s ease-in-out infinite;
  }
  @keyframes crownGlow{
    0%, 100% { filter: drop-shadow(0 0 4px rgba(255,214,10,.45)); transform:scale(1) rotate(-3deg); }
    50%      { filter: drop-shadow(0 0 12px rgba(255,159,10,.95)); transform:scale(1.12) rotate(3deg); }
  }

  /* ===== FAQ (mobile) ===== */
  #faq h2{font-size:30px;letter-spacing:-.028em;line-height:1.06;max-width:14ch}
  #faq .lead{font-size:14.5px;line-height:1.55;margin-top:18px !important}
  .faq{margin-top:28px}
  .faq details{border-radius:14px;margin-bottom:8px}
  .faq summary{padding:16px 18px;font-size:15px;letter-spacing:-.012em;line-height:1.3;gap:14px}
  .faq summary .plus{width:26px;height:26px;border-radius:8px;flex-shrink:0}
  .faq summary .plus::before{width:9px;height:1.4px}
  .faq summary .plus::after{width:1.4px;height:9px}
  .faq .answer{padding:0 18px 18px 18px;font-size:13.5px;line-height:1.55}

  /* ===== CONTACT (mobile) ===== */
  .contact{padding:48px 0 36px}
  .contact h2{font-size:30px;letter-spacing:-.028em;line-height:1.06;margin-bottom:14px}
  .contact .sub{font-size:14.5px;margin-bottom:32px;line-height:1.5}
  .giant-phone{
    padding:16px 14px;border-radius:22px;
    font-size:19px;gap:10px;letter-spacing:.005em;
    width:100%;justify-content:center;
    box-sizing:border-box;
    white-space:nowrap;
    min-width:0;
  }
  .giant-phone .ico{width:44px;height:44px;border-radius:14px;flex-shrink:0}
  .giant-phone .ico svg{width:20px;height:20px}
  .giant-phone > span:last-child{white-space:nowrap;font-variant-numeric:tabular-nums;flex-shrink:1;min-width:0}
  .work-strip{
    gap:10px;margin-top:18px;
    display:flex;flex-wrap:wrap;justify-content:center;
  }
  .work-hours{padding:8px 14px;font-size:12px;gap:8px;border-radius:999px}
  .work-hours .dot{width:6px;height:6px;box-shadow:0 0 0 3px rgba(48,209,88,.16),0 0 10px rgba(48,209,88,.6)}
  .weather{padding:7px 16px 7px 8px;gap:10px;min-width:0;font-size:12px}
  .weather .w-ico{width:28px;height:28px}
  .weather .w-ico svg{width:15px;height:15px}
  .weather .w-temp{font-size:16px}
  .weather .w-temp .label{font-size:9.5px}
  .weather .w-text{font-size:11px}
  .contact-extras{margin-top:18px;gap:8px}
  .contact-extras .ce{padding:9px 16px;font-size:12.5px;border-radius:999px;gap:8px}
  .contact-extras .ce svg{width:13px;height:13px}

  /* ===== FOOTER (mobile · premium restyle) ===== */
  .footer{padding:38px 0 calc(24px + env(safe-area-inset-bottom));position:relative}
  .footer::before{
    content:"";position:absolute;left:0;right:0;top:0;height:1px;
    background:linear-gradient(90deg, transparent, var(--cyan), var(--purple), transparent);
    opacity:.5;
  }
  .footer-grid{grid-template-columns:1fr;gap:24px}
  .footer-brand{display:flex;flex-direction:column;gap:12px}
  .footer-brand .logo{font-size:22px;margin-bottom:0;gap:10px}
  .footer-brand .logo svg.mark{width:30px;height:30px}
  .footer-brand p{font-size:12.5px;line-height:1.5;color:var(--text-2);max-width:42ch;margin-bottom:0 !important}
  .footer-contacts{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
  .footer-contacts a{
    display:inline-flex;align-items:center;gap:8px;
    padding:8px 14px;border-radius:999px;
    background:linear-gradient(135deg, rgba(30,200,230,.12), rgba(191,90,242,.12));
    border:1px solid var(--stroke-2);
    font-family:var(--font-mono);font-size:12px;color:#fff !important;letter-spacing:.005em;
  }
  .footer-contacts svg{width:14px;height:14px;color:var(--cyan-bright)}
  .footer h5{font-size:10.5px;margin-bottom:12px;letter-spacing:.14em;color:var(--text-3);font-weight:680}
  .footer ul{display:grid !important;grid-template-columns:1fr 1fr;gap:10px 14px}
  .footer ul li{font-size:13px}
  .footer ul li a{color:var(--text-1)}
  .footer-legal dl{font-size:11.5px;gap:6px 12px}
  .footer-legal dl dt{color:var(--text-3);font-family:var(--font-text);font-size:10.5px;letter-spacing:.04em;text-transform:uppercase}
  .footer-legal dl dd{font-size:11.5px;color:var(--text-1);font-family:var(--font-mono);word-break:break-word}
  .footer-bot{margin-top:18px;padding-top:14px;font-size:11px;flex-direction:column;align-items:flex-start;gap:10px;text-align:left;color:var(--text-3)}
  .footer-bot .made-with{font-size:11px;color:var(--text-3)}
  .footer-bot .made-with svg{width:12px;height:12px}

  /* ===== DATE TRIO (mobile · 3 selects) ===== */
  .date-trio-row{display:grid;grid-template-columns:1fr 1.4fr 1fr;gap:6px}
  .date-trio select{font-size:14.5px;padding:13px 26px 13px 10px}
  .date-trio select{
    background-position: calc(100% - 14px) calc(50% + 1px), calc(100% - 10px) calc(50% + 1px);
    background-size: 5px 5px;
  }

  /* ===== VENUES — peek next + animated swipe hint (mobile) ===== */
  .venues-wrap{position:relative;touch-action:pan-y}
  .venues-rail{
    /* rail explicitly handles ONLY horizontal pans;
       vertical pans bubble to parent (page scroll). */
    touch-action: pan-x !important;
    overscroll-behavior-x: contain;
    overscroll-behavior-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .venue{
    flex: 0 0 calc(100vw - 2 * var(--gutter) - 56px);
    touch-action: pan-x !important;
  }
  .venue *{touch-action: inherit}
  /* edge hint must not block taps/swipes */
  .rail-edge-hint{pointer-events:none !important}
  .rail-hint{
    display:inline-flex;align-items:center;gap:8px;
    padding:7px 14px;border-radius:999px;
    background:linear-gradient(135deg, rgba(30,200,230,.12), rgba(191,90,242,.12));
    border:1px solid var(--stroke-2);
    color:var(--text-1);font-size:11.5px;font-family:var(--font-mono);
    margin-top:14px;margin-bottom:2px;
    letter-spacing:.02em;
  }
  .rail-hint::before, .rail-hint::after{
    content:"";width:14px;height:1.4px;border-radius:1px;
    background:linear-gradient(90deg,#1ec8e6,#bf5af2,#ff375f);
  }
  .rail-hint .swipe-ico{
    width:18px;height:18px;display:inline-grid;place-items:center;
    color:#fff;
    animation: swipeNudge 1.8s var(--ease-out) infinite;
  }
  @keyframes swipeNudge{
    0%, 100% {transform: translateX(-3px)}
    50%      {transform: translateX(5px)}
  }

  /* Right-edge floating hint — disappears after first swipe */
  .rail-edge-hint{
    position:absolute;
    top:50%;right:6px;transform:translateY(-50%);
    width:44px;height:44px;border-radius:50%;
    display:grid;place-items:center;
    background:linear-gradient(135deg, rgba(30,200,230,.32), rgba(191,90,242,.32));
    border:1px solid rgba(255,255,255,.22);
    box-shadow:
      0 14px 32px -10px rgba(30,200,230,.55),
      inset 0 1px 0 rgba(255,255,255,.18);
    color:#fff;pointer-events:none;
    z-index:5;
    opacity:.95;
    animation: edgeHintPulse 1.6s var(--ease-out) infinite;
    transition: opacity .45s var(--ease-out), transform .55s var(--ease-spring);
  }
  .rail-edge-hint svg{width:18px;height:18px}
  .rail-edge-hint.is-gone{opacity:0;transform:translateY(-50%) translateX(60px)}
  @keyframes edgeHintPulse{
    0%, 100% {transform: translateY(-50%) translateX(0);    box-shadow: 0 10px 24px -8px rgba(30,200,230,.45), inset 0 1px 0 rgba(255,255,255,.18);}
    50%      {transform: translateY(-50%) translateX(-6px); box-shadow: 0 18px 40px -8px rgba(191,90,242,.7),  inset 0 1px 0 rgba(255,255,255,.18);}
  }
  /* dots */
  .rail-dots{
    display:flex;justify-content:center;gap:6px;
    margin-top:8px;
  }
  .rail-dots .d{
    width:6px;height:6px;border-radius:50%;
    background:rgba(255,255,255,.18);
    transition: background .35s, transform .35s, width .35s;
  }
  .rail-dots .d.is-active{
    width:18px;border-radius:3px;
    background:linear-gradient(90deg,#1ec8e6,#bf5af2);
  }

  /* ===== SCROLL CUE — between sections (mobile) ===== */
  .scroll-cue{
    display:flex;flex-direction:column;align-items:center;gap:6px;
    margin:24px auto 0;color:var(--text-3);
    font-family:var(--font-mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;
    pointer-events:none;
  }
  .scroll-cue .arr{
    width:28px;height:28px;border-radius:50%;
    display:grid;place-items:center;
    background:linear-gradient(135deg, rgba(30,200,230,.12), rgba(191,90,242,.12));
    border:1px solid var(--stroke-2);
    animation: cueBounce 1.9s var(--ease-out) infinite;
  }
  .scroll-cue .arr svg{width:14px;height:14px;color:#fff}
  @keyframes cueBounce{
    0%, 100% {transform: translateY(0); opacity: .7}
    50%      {transform: translateY(5px); opacity: 1}
  }

  /* ===== FAB STACK — scroll-up + call (mobile) ===== */
  .fab-stack{
    position:fixed;
    right:14px;
    bottom:calc(16px + env(safe-area-inset-bottom));
    display:flex;flex-direction:column;gap:10px;
    z-index:80;
    pointer-events:none;
  }
  .fab{
    width:52px;height:52px;border-radius:50%;
    display:grid;place-items:center;flex-shrink:0;
    background:linear-gradient(135deg, #0e0e16, #1a0d24);
    color:#fff;
    position:relative;overflow:hidden;isolation:isolate;
    box-shadow:
      0 14px 36px -10px rgba(0,0,0,.65),
      0 8px 18px -6px rgba(30,200,230,.25);
    transform:translateY(20px) scale(.85);
    opacity:0;
    transition: opacity .4s var(--ease-out), transform .45s var(--ease-spring);
    pointer-events:none;
  }
  .fab-stack.show .fab{ opacity:1; transform:translateY(0) scale(1); pointer-events:auto; }
  .fab::before{
    content:"";position:absolute;inset:0;border-radius:50%;padding:1.4px;
    background:linear-gradient(135deg, #1ec8e6, #5e5ce6 30%, #bf5af2 60%, #ff375f 100%);
    -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite:xor;mask-composite:exclude;
    pointer-events:none;
  }
  .fab svg{width:20px;height:20px;color:#fff;position:relative;z-index:1}
  .fab:active{transform:translateY(2px) scale(.97)}
  /* phone fab — ring waves */
  .fab-call::after{
    content:"";position:absolute;inset:0;border-radius:50%;
    border:1.4px solid var(--cyan);
    animation: fabRing 2.4s var(--ease-out) infinite;
    pointer-events:none;
  }
  .fab-call.r2::after{ border-color: var(--purple); animation-delay:1.2s }
  @keyframes fabRing{
    0%{transform:scale(.85);opacity:.75}
    70%{opacity:0}
    100%{transform:scale(1.85);opacity:0}
  }
  .fab-call svg{ animation: phoneShake 5s ease-in-out infinite; }
  /* up arrow micro-animation */
  .fab-up svg{ transition: transform .35s var(--ease-spring); }
  .fab-up:active svg{ transform: translateY(-2px); }

  /* during active scroll — keep FAB visible but slightly dim to reduce
     visual weight while user reads content */
  .fab-stack.is-scrolling .fab{
    opacity:.55;
    transition: opacity .25s var(--ease-out);
  }
}

/* hide FAB on desktop & in landscape on very short screens */
@media (min-width: 769px){ .fab-stack{display:none} }
@media (max-width: 768px) and (max-height: 500px){ .fab-stack{display:none} }

/* ==========================================================
   TABLET NAV ZONE (769–1023px) — desktop layout breaks here:
   5 nav-links + logo + full-number phone pill don't fit, so
   nav-phone wraps to 2 lines. Solution: shrink gaps + smaller
   text, hide nav-link count badges.
   ========================================================== */
@media (min-width: 769px) and (max-width: 1023px){
  .nav .wrap{gap:14px}
  .nav-links{gap:16px}
  .nav-link{font-size:13px;padding:6px 2px}
  .nav-phone{
    padding:6px 14px 6px 6px;
    font-size:12.5px;gap:8px;
  }
  .nav-phone .pico{width:28px;height:28px}
  .nav-phone .pico svg{width:13px;height:13px}
  .nav-phone .phone-text{
    white-space:nowrap;
    font-variant-numeric:tabular-nums;
  }
  .nav-logo{font-size:18px;gap:9px}
  .nav-logo svg.mark{width:28px;height:28px}
}
@media (hover:none) and (pointer:coarse){
  /* disable hover-only tilts + spotlights on touch devices */
  html{cursor:auto !important}
  .spotlight{display:none}
}

