/* ============================================================
   Social Play — Martial Arts edition (US direct-response style)
   ============================================================ */

:root{
  --ink:        #0B0B0C;
  --ink-1:      #0F0F11;
  --ink-2:      #141417;
  --ink-3:      #1B1B1F;
  --line:       rgba(255,255,255,0.10);
  --line-2:     rgba(255,255,255,0.06);

  --paper:      #F4F1EE;
  --paper-2:    #E9E5E1;
  --ink-on-paper:#16161A;

  --text:       #F4F2F0;
  --dim:        rgba(244,242,240,0.60);
  --dim-2:      rgba(244,242,240,0.40);

  --red:        #D81F2C;
  --red-bright: #F0212E;
  --red-deep:   #A2151F;
  --red-grad:   linear-gradient(140deg, #F0212E 0%, #B8141F 100%);
  --red-soft:   rgba(216,31,44,0.14);

  --maxw: 1180px;
  --gut: clamp(20px, 5vw, 64px);

  --f-disp: "Saira Condensed", "Saira", system-ui, sans-serif;
  --f-body: "Saira", system-ui, sans-serif;
  --f-mono: "JetBrains Mono", ui-monospace, monospace;
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; scroll-padding-top: 84px; }
body{
  margin:0;
  background: var(--ink);
  color: var(--text);
  font-family: var(--f-body);
  font-size: 18px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img{ max-width:100%; display:block; }
a{ color: inherit; text-decoration: none; }
button{ font-family: inherit; cursor: pointer; }

/* ---------- typography helpers ---------- */
.kicker{
  font-family: var(--f-mono);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--red);
  margin: 0 0 18px;
  display:flex; align-items:center; gap:10px;
}
.kicker::before{
  content:""; width:26px; height:1px; background: var(--red); display:inline-block;
}
.display{
  font-family: var(--f-disp);
  font-weight: 800;
  line-height: 0.96;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  margin: 0;
}
h2.display{ font-size: clamp(34px, 4.6vw, 62px); }
.lead{ color: var(--dim); font-size: clamp(17px, 1.3vw, 20px); max-width: 60ch; }
.red{ color: var(--red); }
.tm{ font-size: 0.62em; vertical-align: super; font-weight:700; }
strong{ color: var(--text); font-weight: 700; }

/* ---------- layout ---------- */
.wrap{ max-width: var(--maxw); margin: 0 auto; padding-inline: var(--gut); }
section{ position: relative; }
.band{ padding-block: clamp(70px, 9vw, 132px); }
.band.paper{ background: var(--paper); color: var(--ink-on-paper); }
.band.paper .lead{ color: rgba(22,22,26,0.62); }
.band.paper .kicker{ color: var(--red); }
.band.ink2{ background: var(--ink-1); }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:11px;
  font-family: var(--f-disp); text-transform: uppercase;
  font-weight: 700; letter-spacing: 0.02em; font-size: 18px;
  padding: 17px 30px; border: none; border-radius: 2px;
  background: var(--red-grad); color: #fff;
  box-shadow: 0 8px 30px -8px rgba(216,31,44,0.6);
  transition: transform .15s ease, box-shadow .15s ease, filter .15s ease;
  line-height: 1; white-space: nowrap;
}
.btn:hover{ transform: translateY(-2px); box-shadow: 0 14px 40px -10px rgba(216,31,44,0.75); filter: brightness(1.05); }
.btn:active{ transform: translateY(0); }
.btn .arr{ transition: transform .2s ease; }
.btn:hover .arr{ transform: translateX(4px); }
.btn.ghost{
  background: transparent; color: var(--text);
  border: 1px solid var(--line); box-shadow: none;
  padding: 16px 26px;
}
.btn.ghost:hover{ border-color: var(--red); color:#fff; filter:none; }
.band.paper .btn.ghost{ color: var(--ink-on-paper); border-color: rgba(22,22,26,0.22); }
.btn.sm{ font-size: 15px; padding: 12px 20px; }

/* pulsing CTA */
.btn.pulse{ position: relative; }
@media (prefers-reduced-motion: no-preference){
  .btn.pulse{ animation: btnPulse 2.2s ease-in-out infinite; }
}
@keyframes btnPulse{
  0%{ box-shadow: 0 8px 30px -8px rgba(216,31,44,0.6), 0 0 0 0 rgba(216,31,44,0.5); }
  60%{ box-shadow: 0 8px 30px -8px rgba(216,31,44,0.6), 0 0 0 16px rgba(216,31,44,0); }
  100%{ box-shadow: 0 8px 30px -8px rgba(216,31,44,0.6), 0 0 0 0 rgba(216,31,44,0); }
}

/* ============================================================
   HEADER
   ============================================================ */
.header{
  position: fixed; inset: 0 0 auto 0; z-index: 60;
  transition: background .25s ease, border-color .25s ease, backdrop-filter .25s ease;
  border-bottom: 1px solid transparent;
}
.header.solid{
  background: rgba(11,11,12,0.82);
  backdrop-filter: blur(14px);
  border-bottom-color: var(--line);
}
.nav{ display:flex; align-items:center; gap:28px; height: 76px; }
.nav .logo{ height: 34px; width:auto; }
.nav-links{ display:flex; gap:30px; margin-left: auto; align-items:center; }
.nav-links a{
  font-size: 14px; font-weight: 500; color: var(--dim);
  letter-spacing: 0.04em; transition: color .15s ease;
  font-family: var(--f-body);
}
.nav-links a:hover{ color: #fff; }
.nav-right{ display:flex; align-items:center; gap:18px; margin-left: 6px; }

/* language toggle */
.lang{
  display:flex; border: 1px solid var(--line); border-radius: 2px; overflow:hidden;
  font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.06em;
}
.lang button{
  background: transparent; color: var(--dim); border: none;
  padding: 7px 11px; transition: all .15s ease;
}
.lang button.on{ background: var(--red); color:#fff; }
.lang button:not(.on):hover{ color:#fff; }

.burger{ display:none; background:none; border:none; width:40px; height:40px; padding:8px; }
.burger span{ display:block; height:2px; background:#fff; margin:5px 0; transition: .25s; }

/* mobile drawer */
.drawer{
  position: fixed; inset: 0; z-index: 70; background: var(--ink-1);
  transform: translateX(100%); transition: transform .3s ease;
  display:flex; flex-direction:column; padding: 28px var(--gut);
}
.drawer.open{ transform: translateX(0); }
.drawer .x{ align-self:flex-end; background:none; border:none; color:#fff; font-size: 32px; line-height:1; }
.drawer a{ font-family: var(--f-disp); text-transform:uppercase; font-size: 30px; padding: 14px 0; border-bottom: 1px solid var(--line); }

/* ============================================================
   HERO
   ============================================================ */
.hero{ padding-top: 130px; padding-bottom: clamp(60px, 8vw, 110px); position: relative; overflow:hidden; min-height: 88vh; display:flex; align-items:center; }
.hero-bg{
  position:absolute; inset:0; z-index:0;
  background-image: url("assets/hero-bg.jpg");
  background-size: cover; background-position: center 28%; background-repeat:no-repeat;
  animation: heroPan 26s ease-in-out infinite alternate;
}
.hero-bg::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(8,8,9,0.94) 0%, rgba(8,8,9,0.82) 38%, rgba(8,8,9,0.42) 70%, rgba(8,8,9,0.55) 100%),
    linear-gradient(0deg, rgba(8,8,9,0.85) 0%, transparent 40%);
}
@keyframes heroPan{ from{ transform: scale(1.06) translateX(0); } to{ transform: scale(1.12) translateX(-2%); } }
@media (prefers-reduced-motion: reduce){ .hero-bg{ animation:none; } }
.hero::before{
  content:""; position:absolute; top:-20%; right:-10%; width:60vw; height:120%; z-index:0;
  background: radial-gradient(closest-side, rgba(216,31,44,0.18), transparent 70%);
  pointer-events:none;
}
.hero-inner{ position:relative; z-index:2; width:100%; }
.hero-copy{ max-width: 760px; }
.hero h1{
  font-family: var(--f-disp); font-weight: 800; text-transform: uppercase;
  font-size: clamp(36px, 4.8vw, 66px); line-height: 0.96; letter-spacing: -0.012em;
  margin: 0 0 26px;
  /* shimmer sweep across the letters */
  background: linear-gradient(105deg,
    #E9E6E3 0%, #E9E6E3 40%,
    #FFFFFF 47%, #FF4D57 50%, #FFFFFF 53%,
    #E9E6E3 60%, #E9E6E3 100%);
  background-size: 220% 100%;
  background-position: 150% 0;
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 2px 22px rgba(0,0,0,0.55));
}
@media (prefers-reduced-motion: no-preference){
  .hero h1{ animation: heroShine 4.5s linear 0.4s infinite; }
}
@keyframes heroShine{
  0%{ background-position: 150% 0; }
  50%{ background-position: -50% 0; }
  100%{ background-position: -50% 0; }
}
.hero h1 .num{ color: var(--red); -webkit-text-fill-color: var(--red); }
.hero h1 .tm{ -webkit-text-fill-color: #ECE9E6; }
.hero-checks{ list-style:none; margin: 0 0 28px; padding: 0; display:grid; gap: 12px; }
.hero-checks li{ display:flex; align-items:flex-start; gap:12px; color: var(--dim); font-size: 17px; }

/* checklist items appear one by one (JS-driven; final state is inline → never stuck hidden) */
.cstagger .ci{ transition: opacity .55s ease, transform .55s ease; }

.hero-checks .tick{
  flex: 0 0 auto; width:22px; height:22px; border-radius: 50%;
  background: var(--red-soft); color: var(--red); display:grid; place-items:center;
  margin-top: 2px; font-size: 12px; font-weight: 700;
}
.hero-checks li strong{ color: var(--text); font-weight: 600; }
.lockline{
  font-family: var(--f-body); font-size: 15px; color: var(--text);
  border-left: 2px solid var(--red); padding: 6px 0 6px 16px; margin: 0 0 30px;
  max-width: 46ch;
}
.lockline strong{ color:#fff; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; }
.hero-media{ position: relative; }

/* live sales notification toast */
.enroll-toast{
  position:absolute; right: var(--gut); bottom: 88px; z-index:3;
  display:flex; align-items:center; gap:13px;
  background: rgba(18,18,21,0.86); backdrop-filter: blur(10px);
  border:1px solid var(--line); border-left:3px solid var(--red);
  border-radius: 10px; padding: 13px 18px 13px 15px;
  box-shadow: 0 18px 44px -16px rgba(0,0,0,0.8);
  opacity:0; transform: translateY(14px) scale(.96); pointer-events:none;
}
.enroll-toast.show{ animation: toastInOut 5s cubic-bezier(.2,.8,.2,1) forwards; }
@keyframes toastInOut{
  0%{ opacity:0; transform: translateY(14px) scale(.96); }
  8%{ opacity:1; transform: translateY(0) scale(1); }
  86%{ opacity:1; transform: translateY(0) scale(1); }
  100%{ opacity:0; transform: translateY(-10px) scale(.98); }
}
.et-dot{ flex:0 0 auto; width:10px; height:10px; border-radius:50%; background: var(--red); box-shadow: 0 0 0 0 rgba(216,31,44,0.6); animation: etPulse 1.8s ease-out infinite; }
@keyframes etPulse{ 0%{ box-shadow: 0 0 0 0 rgba(216,31,44,0.55);} 70%{ box-shadow: 0 0 0 9px rgba(216,31,44,0);} 100%{ box-shadow:0 0 0 0 rgba(216,31,44,0);} }
.et-title{ font-family: var(--f-disp); text-transform:uppercase; font-weight:700; font-size: 16px; line-height:1; letter-spacing:0.01em; }
.et-sub{ font-family: var(--f-mono); font-size: 12px; color: var(--dim); margin-top: 5px; }
.et-sub .et-ago{ color: var(--dim-2); }
@media (max-width:560px){ .enroll-toast{ left:12px; right:12px; bottom:16px; } }
/* image placeholder */
.ph{
  position: relative; border: 1px solid var(--line); border-radius: 4px; overflow:hidden;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.035) 0 2px, transparent 2px 11px),
    var(--ink-2);
  display:grid; place-items:center; min-height: 200px;
}
.band.paper .ph{
  border-color: rgba(22,22,26,0.16);
  background:
    repeating-linear-gradient(135deg, rgba(0,0,0,0.04) 0 2px, transparent 2px 11px),
    var(--paper-2);
}
.ph .ph-label{
  font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.05em;
  color: var(--dim-2); padding: 8px 12px; text-align:center;
}
.band.paper .ph .ph-label{ color: rgba(22,22,26,0.4); }
.hero-media .ph{ aspect-ratio: 4/5; }
.hero-media .badge{
  position:absolute; left:-14px; bottom: 26px; background: var(--red-grad);
  padding: 14px 18px; border-radius: 3px; box-shadow: 0 14px 36px -10px rgba(0,0,0,0.7);
  max-width: 70%;
}
.hero-media .badge .big{ font-family: var(--f-disp); font-weight:800; font-size: 30px; line-height:1; text-transform:uppercase; }
.hero-media .badge .small{ font-size: 12px; letter-spacing: 0.04em; opacity:.9; margin-top:4px; }

/* ============================================================
   SCARCITY STRIP
   ============================================================ */
.strip{ background: var(--red-grad); }
.strip .wrap{ display:flex; align-items:center; gap: 24px; padding-block: 30px; flex-wrap:wrap; }
.strip .lock{
  font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.16em; text-transform:uppercase;
  border:1px solid rgba(255,255,255,0.5); padding: 7px 12px; border-radius: 2px; white-space:nowrap;
}
.strip p{ margin:0; font-family: var(--f-disp); text-transform: uppercase; font-weight: 700;
  font-size: clamp(18px, 2.1vw, 27px); line-height:1.05; letter-spacing:-0.005em; flex:1; min-width: 240px; }

/* ============================================================
   AUTHORITY / TWO-COLUMN CONTENT
   ============================================================ */
.split{ display:grid; grid-template-columns: 0.95fr 1.05fr; gap: clamp(34px,5vw,72px); align-items:start; }
.split .sticky-h{ position: sticky; top: 110px; }
.authority-lists{ display:grid; gap: 34px; }
.alist h4{
  font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.12em; text-transform:uppercase;
  color: var(--dim); margin: 0 0 14px; font-weight:500;
}
.alist ul{ list-style:none; margin:0; padding:0; display:grid; gap: 10px; }
.alist li{ display:flex; gap: 12px; align-items:flex-start; font-size: 17px; color: var(--text); }
.alist li::before{ content:""; flex:0 0 auto; width:7px; height:7px; margin-top:11px; background: var(--red); transform: rotate(45deg); }
.alist.dim li{ color: var(--dim); }
.alist.dim li::before{ background: var(--dim-2); }
.callout{
  margin-top: 6px; padding: 26px 28px; background: var(--ink-2); border:1px solid var(--line);
  border-left: 3px solid var(--red); border-radius: 4px;
}
.callout p{ margin:0 0 16px; font-family: var(--f-disp); text-transform:uppercase; font-weight:700; font-size: 22px; }
.callout ul{ list-style:none; margin:0; padding:0; display:grid; gap:9px; }
.callout li{ display:flex; gap:11px; align-items:center; font-size: 16px; color: var(--text); }
.callout li .n{ font-family: var(--f-mono); color: var(--red); font-size: 13px; }

/* ============================================================
   PROBLEM CARDS
   ============================================================ */
.head-block{ max-width: 720px; margin-bottom: clamp(40px,5vw,64px); }
.head-block h2{ margin-bottom: 18px; }
.cards3{ display:grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.pcard{
  background: var(--ink-2); border:1px solid var(--line); border-radius: 14px; overflow:hidden;
  display:flex; flex-direction:column; transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.pcard:hover{ transform: translateY(-6px); border-color: rgba(216,31,44,0.55); box-shadow: 0 24px 50px -24px rgba(0,0,0,0.8); }
.pcard .ph{ position:relative; border:none; border-radius:0; aspect-ratio: 16/11; min-height:0; }
.pcard-img{ position:absolute; inset:0; width:100%; height:100%; object-fit: cover; transition: transform .5s ease; }
.pcard:hover .pcard-img{ transform: scale(1.05); }
.pcard .ph::after{
  content:""; position:absolute; inset:0;
  background: linear-gradient(to bottom, rgba(11,11,12,0) 40%, rgba(11,11,12,0.55) 78%, var(--ink-2) 100%);
}
.pcard-num{
  position:absolute; top:14px; left:16px; z-index:2;
  font-family: var(--f-disp); font-weight:800; font-size: 30px; line-height:1; color:#fff;
  text-shadow: 0 2px 14px rgba(0,0,0,0.7); letter-spacing: 0.01em;
}
.pcard-num::before{ content:""; display:inline-block; width:9px; height:9px; background:var(--red); transform: rotate(45deg); margin-right:9px; vertical-align: 3px; }
.pcard-tag{
  position:absolute; top:16px; right:16px; z-index:2;
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color:#fff; background: rgba(216,31,44,0.9); padding: 6px 10px; border-radius: 3px;
}
.pcard .body{ padding: 22px 24px 28px; flex:1; display:flex; flex-direction:column; }
.pcard h3{ font-family: var(--f-disp); text-transform: uppercase; font-weight: 700; font-size: 23px; line-height:1.04; margin: 0 0 12px; }
.pcard h3::after{ content:""; display:block; width:34px; height:3px; background: var(--red-grad); border-radius:2px; margin-top:12px; }
.pcard p{ margin:0; color: var(--dim); font-size: 16px; }

/* ============================================================
   THE SYSTEM (numbered steps)
   ============================================================ */
.steps{ display:grid; grid-template-columns: repeat(2,1fr); gap: 1px; background: var(--line); border:1px solid var(--line); border-radius: 6px; overflow:hidden; }
.step{ background: var(--ink-1); padding: 38px clamp(26px,3vw,42px); position: relative; transition: background .25s ease, transform .25s ease; overflow:hidden; }
.step::before{
  content:""; position:absolute; left:0; top:0; bottom:0; width:3px; background: var(--red);
  transform: scaleY(0); transform-origin: top; transition: transform .35s cubic-bezier(.2,.8,.2,1);
}
.step:hover{ background: var(--ink-2); transform: translateY(-2px); }
.step:hover::before{ transform: scaleY(1); }
.step .idx{ font-family: var(--f-disp); font-weight: 800; font-size: 60px; line-height:1; color: rgba(255,255,255,0.10); position:absolute; top: 24px; right: 28px; transition: color .3s ease, transform .3s ease; }
.step:hover .idx{ color: rgba(240,33,46,0.4); transform: translateY(-4px); }
.step .tag{
  display:inline-flex; align-items:center; gap:10px; font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.12em;
  color: var(--red); text-transform: uppercase; margin-bottom: 14px;
}
.step .tag::after{
  content:""; height:1px; width: 34px; background: linear-gradient(90deg, var(--red), transparent);
  display:inline-block;
}
@media (prefers-reduced-motion: no-preference){
  .step .tag::after{ width: 34px; animation: tagSweep 3.4s ease-in-out infinite; }
  .step:nth-child(2) .tag::after{ animation-delay:.4s; }
  .step:nth-child(3) .tag::after{ animation-delay:.8s; }
  .step:nth-child(4) .tag::after{ animation-delay:1.2s; }
  .step:nth-child(5) .tag::after{ animation-delay:1.6s; }
  .step:nth-child(6) .tag::after{ animation-delay:2s; }
}
@keyframes tagSweep{ 0%,100%{ width:18px; opacity:.5; } 50%{ width:46px; opacity:1; } }
.step h3{ font-family: var(--f-disp); text-transform: uppercase; font-weight:700; font-size: 26px; line-height:1.0; margin: 0 0 14px; max-width: 80%; }
.step p{ margin:0; color: var(--dim); font-size: 16px; max-width: 46ch; }
.step.lock{ background: linear-gradient(140deg, rgba(216,31,44,0.16), var(--ink-1) 60%); background-size: 180% 180%; }
.step.lock .idx{ color: rgba(240,33,46,0.22); }
@media (prefers-reduced-motion: no-preference){
  .step.lock{ animation: lockGlow 6s ease-in-out infinite; }
}
@keyframes lockGlow{ 0%,100%{ background-position: 0% 0%; } 50%{ background-position: 100% 100%; } }

/* generates list */
.generates{ display:grid; grid-template-columns: 1fr 1fr; gap: clamp(30px,4vw,60px); align-items:center; margin-top: clamp(46px,6vw,80px); }
.glist{ list-style:none; margin:0; padding:0; display:grid; gap: 0; }
.glist li{ display:flex; align-items:center; gap:16px; padding: 16px 0; border-bottom:1px solid var(--line); font-family: var(--f-disp); text-transform:uppercase; font-weight:700; font-size: clamp(18px,1.8vw,24px); }
.glist li:first-child{ border-top:1px solid var(--line); }
.glist li .g-n{ font-family: var(--f-mono); font-size: 13px; color: var(--red); font-weight:700; min-width: 30px; }

/* staggered one-by-one entrance for the results list.
   Resting state is VISIBLE; entrance is a one-shot keyframe with
   `backwards` fill so items hide only during their own delay window
   and can never get stuck hidden. */
@media (prefers-reduced-motion: no-preference){
  .gstagger.play .gi{ animation: giIn .55s cubic-bezier(.2,.8,.2,1) backwards; }
  .gstagger.play .gi:nth-child(1){ animation-delay: .05s; }
  .gstagger.play .gi:nth-child(2){ animation-delay: .23s; }
  .gstagger.play .gi:nth-child(3){ animation-delay: .41s; }
  .gstagger.play .gi:nth-child(4){ animation-delay: .59s; }
  .gstagger.play .gi:nth-child(5){ animation-delay: .77s; }
  .gstagger.play .gi:nth-child(6){ animation-delay: .95s; }
}
@keyframes giIn{
  from{ opacity: 0; transform: translateX(-22px); }
  55%{ opacity: 1; }
  to{ opacity: 1; transform: none; }
}
.punch{ font-family: var(--f-disp); text-transform: uppercase; font-weight:800; font-size: clamp(26px,3.4vw,46px); line-height:1.0; }
.punch .red{ display:block; }

/* ============================================================
   INVESTMENT (paper)
   ============================================================ */
.invest-grid{ display:grid; grid-template-columns: 1fr 1fr; gap: clamp(34px,5vw,70px); align-items:start; }
.factors{ list-style:none; margin: 22px 0 0; padding:0; display:grid; grid-template-columns:1fr 1fr; gap: 14px; }
.factors li{ display:flex; align-items:center; gap:11px; font-size: 16px; font-weight:500; }
.factors li .n{ font-family: var(--f-mono); color: var(--red); font-size: 13px; }
.budget{ background:#fff; border:1px solid rgba(22,22,26,0.1); border-radius: 6px; padding: 34px; box-shadow: 0 20px 50px -28px rgba(0,0,0,0.3); }
.budget .label{ font-family: var(--f-mono); font-size: 12px; letter-spacing:0.1em; text-transform:uppercase; color: rgba(22,22,26,0.5); }
.budget .amount{ font-family: var(--f-disp); font-weight:800; text-transform:uppercase; font-size: clamp(34px,4.4vw,56px); line-height:1; margin: 8px 0 6px; }
.budget .amount .red{ color: var(--red); }
.budget .note{ font-size: 15px; color: rgba(22,22,26,0.6); margin: 0 0 26px; }
.budget hr{ border:none; border-top:1px solid rgba(22,22,26,0.1); margin: 0 0 22px; }
.budget .calc-h{ font-family: var(--f-disp); text-transform:uppercase; font-weight:700; font-size: 19px; margin: 0 0 16px; }
.budget .calc{ list-style:none; margin:0; padding:0; display:grid; gap:11px; }
.budget .calc li{ display:flex; gap:11px; align-items:center; font-size: 16px; }
.budget .calc li::before{ content:""; width:7px; height:7px; background: var(--red); transform: rotate(45deg); flex:0 0 auto; }

/* before/after table */
.table-block{ margin-top: clamp(56px,7vw,96px); }
.cmp{ width:100%; border-collapse: collapse; margin-top: 30px; background:#fff; border:1px solid rgba(22,22,26,0.1); border-radius:6px; overflow:hidden; }
.cmp th, .cmp td{ padding: 20px 24px; text-align:left; border-bottom:1px solid rgba(22,22,26,0.08); }
.cmp thead th{ font-family: var(--f-mono); font-size: 12px; letter-spacing:0.08em; text-transform:uppercase; color: rgba(22,22,26,0.55); font-weight:500; }
.cmp thead th.aft{ color: var(--red); }
.cmp tbody td:first-child{ font-weight:600; }
.cmp td.before{ color: rgba(22,22,26,0.55); }
.cmp td.after{ font-family: var(--f-disp); text-transform:uppercase; font-weight:700; color: var(--red); font-size: 19px; }
.cmp tr:last-child td{ border-bottom:none; }
.cmp tbody tr:last-child td{ border-bottom: none; }

/* ============================================================
   FINAL CTA (territory)
   ============================================================ */
.final{ text-align:center; position:relative; overflow:hidden; }
/* background video — sits at the very back, heavily darkened so the
   section keeps its dark/red identity and only the motion shows through */
.final-video{
  position:absolute; inset:0; z-index:0;
  width:100%; height:100%; object-fit:cover;
  opacity:0.42; filter: grayscale(0.25) contrast(1.05) brightness(0.78);
  pointer-events:none;
}
.final::after{
  content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    radial-gradient(closest-side at 50% 42%, rgba(216,31,44,0.22), transparent 60%),
    linear-gradient(180deg, var(--ink) 0%, rgba(11,11,12,0.58) 32%, rgba(11,11,12,0.58) 68%, var(--ink) 100%);
}
.final::before{
  content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background: radial-gradient(closest-side, rgba(216,31,44,0.16), transparent 65%);
}
.final .wrap{ position:relative; z-index:2; }
.final h2{ margin: 0 auto 22px; max-width: 16ch; }
.final p{ color: var(--dim); max-width: 56ch; margin: 0 auto 36px; }
.final .mark{ width: 66px; margin: 0 auto 26px; opacity:.9; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background: var(--ink-1); border-top:1px solid var(--line); padding-block: 60px 40px; }
.footer-grid{ display:grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 40px; align-items:start; }
.footer .logo{ height: 38px; margin-bottom: 18px; }
.footer .tag{ color: var(--dim); font-size: 15px; max-width: 38ch; }
.footer h5{ font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.1em; text-transform:uppercase; color: var(--dim-2); margin:0 0 16px; font-weight:500; }
.footer ul{ list-style:none; margin:0; padding:0; display:grid; gap:11px; }
.footer ul li{ color: var(--dim); font-size: 15px; }
.footer ul li a:hover{ color:#fff; }
.footer-bottom{ display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-top: 50px; padding-top: 24px; border-top:1px solid var(--line); color: var(--dim-2); font-size: 13px; }
.footer-bottom a{ color: var(--dim); }

/* ============================================================
   BOOKING MODAL
   ============================================================ */
.modal-root{ position: fixed; inset:0; z-index: 100; display:none; }
.modal-root.open{ display:block; }
.modal-bg{ position:absolute; inset:0; background: rgba(5,5,6,0.78); backdrop-filter: blur(6px); }
.modal{
  position: absolute; top:50%; left:50%; transform: translate(-50%,-50%);
  width: min(560px, calc(100vw - 32px)); max-height: 90vh; overflow:auto;
  background: var(--ink-2); border:1px solid var(--line); border-radius: 8px;
}
.modal-root.open .modal{ animation: modalIn .26s cubic-bezier(.2,.8,.2,1); }
@keyframes modalIn{ from{ transform: translate(-50%,-47%); } to{ transform: translate(-50%,-50%); } }
.modal-head{ padding: 24px 28px; border-bottom:1px solid var(--line); display:flex; align-items:flex-start; justify-content:space-between; gap:16px; }
.modal-head .mh-k{ font-family: var(--f-mono); font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color: var(--red); }
.modal-head h3{ font-family: var(--f-disp); text-transform:uppercase; font-weight:800; font-size: 26px; margin: 6px 0 0; line-height:1; }
.modal-head .x{ background:none; border:none; color: var(--dim); font-size: 26px; line-height:1; }
.modal-head .x:hover{ color:#fff; }
.steps-dots{ display:flex; gap:8px; padding: 16px 28px 0; }
.steps-dots span{ height:3px; flex:1; background: var(--line); border-radius:2px; transition: background .2s; }
.steps-dots span.on{ background: var(--red); }
.modal-body{ padding: 22px 28px 28px; }
.mstep{ display:none; }
.mstep.on{ display:block; animation: fadeIn .25s ease; }
@keyframes fadeIn{ from{ transform: translateY(8px);} to{ transform:none;} }
.field{ margin-bottom: 16px; }
.field label{ display:block; font-size: 13px; color: var(--dim); margin-bottom: 7px; letter-spacing:0.02em; }
.field input{
  width:100%; background: var(--ink); border:1px solid var(--line); border-radius: 3px;
  color:#fff; font-family: var(--f-body); font-size: 16px; padding: 13px 14px; transition: border-color .15s;
}
.field input:focus{ outline:none; border-color: var(--red); }
.field input.err{ border-color: var(--red-bright); }
.field .msg{ color: var(--red-bright); font-size: 12px; margin-top: 6px; display:none; }
.field .msg.show{ display:block; }
.row2{ display:grid; grid-template-columns:1fr 1fr; gap: 14px; }
.chips{ display:flex; flex-wrap:wrap; gap: 9px; }
.chip{
  font-family: var(--f-mono); font-size: 12px; letter-spacing:0.04em; text-transform:uppercase;
  padding: 9px 13px; border:1px solid var(--line); border-radius: 2px; color: var(--dim); background:transparent;
  transition: all .15s;
}
.chip.on{ background: var(--red); border-color: var(--red); color:#fff; }
.chip:not(.on):hover{ color:#fff; border-color: var(--dim); }
.slots{ display:grid; grid-template-columns: repeat(3,1fr); gap: 10px; margin-top: 4px; }
.day-h{ font-family: var(--f-mono); font-size:12px; letter-spacing:0.08em; text-transform:uppercase; color: var(--dim); margin: 16px 0 8px; }
.slot{
  background: var(--ink); border:1px solid var(--line); border-radius:3px; color: var(--text);
  padding: 11px 0; font-family: var(--f-mono); font-size: 13px; transition: all .15s;
}
.slot.on{ background: var(--red); border-color: var(--red); color:#fff; }
.slot:not(.on):hover{ border-color: var(--dim); }
.modal-foot{ display:flex; justify-content:space-between; gap:12px; margin-top: 24px; }
.modal-foot .btn{ font-size: 16px; padding: 14px 24px; }
.confirm{ text-align:center; padding: 10px 0 6px; }
.confirm .check{ width:64px; height:64px; border-radius:50%; background: var(--red-soft); color: var(--red); display:grid; place-items:center; margin: 0 auto 18px; font-size: 30px; }
.confirm h4{ font-family: var(--f-disp); text-transform:uppercase; font-weight:800; font-size: 28px; margin: 0 0 10px; }
.confirm p{ color: var(--dim); margin: 0 auto 18px; max-width: 40ch; }
.summary{ text-align:left; background: var(--ink); border:1px solid var(--line); border-radius: 5px; padding: 18px 20px; margin-top: 6px; }
.summary div{ display:flex; justify-content:space-between; gap:12px; padding: 7px 0; font-size: 14px; border-bottom:1px solid var(--line-2); }
.summary div:last-child{ border-bottom:none; }
.summary .k{ color: var(--dim); font-family: var(--f-mono); font-size: 12px; }
.summary .v{ color:#fff; text-align:right; }

/* ============================================================
   REVEAL ANIMATION
   Resting state is VISIBLE; the entrance is a one-shot keyframe
   applied via .in. Content can never get stuck hidden.
   ============================================================ */
@media (prefers-reduced-motion: no-preference){
  .reveal.in{ animation: revealIn .6s cubic-bezier(.2,.7,.2,1); }
  .reveal.in.d1{ animation-delay: .08s; }
  .reveal.in.d2{ animation-delay: .16s; }
  .reveal.in.d3{ animation-delay: .24s; }
}
@keyframes revealIn{
  from{ transform: translateY(22px); }
  to{ transform: none; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 920px){
  .nav-links{ display:none; }
  .burger{ display:block; }
  .hero-grid{ grid-template-columns: 1fr; }
  .hero-media{ order:-1; max-width: 420px; }
  .split{ grid-template-columns: 1fr; }
  .split .sticky-h{ position: static; }
  .steps{ grid-template-columns: 1fr; }
  .cards3{ grid-template-columns: 1fr; }
  .generates{ grid-template-columns: 1fr; }
  .invest-grid{ grid-template-columns: 1fr; }
  .footer-grid{ grid-template-columns: 1fr; gap: 34px; }
}
@media (max-width: 560px){
  body{ font-size: 17px; }
  .factors{ grid-template-columns: 1fr; }
  .slots{ grid-template-columns: repeat(2,1fr); }
  .row2{ grid-template-columns: 1fr; }
  .hero-cta{ flex-direction: column; align-items: stretch; }
  .hero-cta .btn{ justify-content:center; }
  .nav .logo{ height: 28px; }
}

/* ============================================================
   TESTIMONIALS — expanding video accordion
   ============================================================ */
.tband{ background: var(--ink); }
h2.thead{ font-size: clamp(25px, 2.9vw, 40px); line-height: 1.0; }
.thead .hl{ color: var(--red); }
.thead .ar{ color: var(--red); font-weight: 700; display: inline-block; }
@media (prefers-reduced-motion: no-preference){
  .thead .hl{ animation: neonPulse 3.2s ease-in-out infinite; }
  .thead .hl:nth-of-type(2){ animation-delay: .5s; }
  .thead .hl:nth-of-type(3){ animation-delay: 1s; }
  .thead .ar{ animation: arrNudge 2.4s ease-in-out infinite; }
  .thead .ar:nth-of-type(2){ animation-delay: .35s; }
  .thead .ar:nth-of-type(3){ animation-delay: .7s; }
}
@keyframes neonPulse{
  0%, 100%{ text-shadow: 0 0 6px rgba(216,31,44,0.25); color: var(--red); }
  50%{ text-shadow: 0 0 16px rgba(240,33,46,0.65), 0 0 34px rgba(216,31,44,0.35); color: #ff2f3b; }
}
@keyframes arrNudge{
  0%, 100%{ transform: translate(0,0); }
  50%{ transform: translate(3px,-3px); }
}
.accordion{ display: flex; gap: 14px; height: clamp(380px, 44vw, 480px); }
.tcard{
  position: relative; flex: 1 1 0; min-width: 0; overflow: hidden;
  border: 1px solid var(--line); border-radius: 22px; background: var(--ink-1);
  cursor: pointer; padding: 0; text-align: left; color: inherit; font-family: inherit;
  transition: flex-grow .55s cubic-bezier(.2,.8,.2,1), border-color .3s ease, background .3s ease;
}
.tcard.active{ flex-grow: 4.4; border-color: rgba(255,255,255,0.16); background: var(--ink-2); }
.tcard:focus-visible{ outline: 2px solid var(--red); outline-offset: 2px; }
.tcard-media{
  position: absolute; inset: 0; opacity: 0; transition: opacity .5s ease; overflow: hidden;
  background: var(--ink-3);
}
.tcard-thumb{
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  filter: saturate(1.05) contrast(1.02);
}
.tcard-media::after{
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(8,8,9,0.95) 0%, rgba(8,8,9,0.15) 46%, rgba(8,8,9,0.45) 100%);
}
.tcard.active .tcard-media{ opacity: 1; }
.tcard-vert{ position: absolute; inset: 0; display: grid; place-items: center; transition: opacity .4s ease; }
.tcard.active .tcard-vert{ opacity: 0; }
.tcard-vert span{
  writing-mode: vertical-rl; transform: rotate(180deg);
  font-family: var(--f-disp); font-weight: 700; text-transform: uppercase;
  font-size: clamp(26px, 3.1vw, 44px); letter-spacing: 0.02em; color: rgba(255,255,255,0.16); white-space: nowrap;
}
.tcard-label{ position: absolute; left: 26px; right: 26px; bottom: 24px; opacity: 0; transition: opacity .4s ease .08s; z-index: 2; }
.tcard.active .tcard-label{ opacity: 1; }
.tcard-label .nm{ font-family: var(--f-disp); font-weight: 700; text-transform: uppercase; font-size: clamp(26px, 2.8vw, 42px); line-height: 1; color: #fff; }
.tcard-label .since{ font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.08em; color: var(--dim); margin-top: 8px; }
.tplay{
  position: absolute; top: 46%; left: 50%; transform: translate(-50%,-50%) scale(.9); z-index: 2;
  width: 66px; height: 66px; border-radius: 50%; border: 2px solid var(--red);
  display: grid; place-items: center; color: var(--red); background: rgba(10,10,12,0.4); backdrop-filter: blur(2px);
  opacity: 0; transition: opacity .4s ease, transform .25s ease, background .2s ease;
}
.tcard.active .tplay{ opacity: 1; transform: translate(-50%,-50%) scale(1); }
.tcard.active:hover .tplay{ transform: translate(-50%,-50%) scale(1.08); background: var(--red); color: #fff; }
.tplay svg{ margin-left: 3px; }
.thint{ margin-top: 26px; text-align:center; font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--dim); display:flex; align-items:center; justify-content:center; gap:10px; }
.thint::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--red); box-shadow:0 0 0 0 rgba(216,31,44,0.6); animation: etPulse 1.8s ease-out infinite; }

/* video lightbox — vertical (YouTube Shorts) */
.vmodal{
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  width: min(440px, calc(100vw - 32px)); background: var(--ink-2);
  border: 1px solid var(--line); border-radius: 10px; padding: 22px;
}
.modal-root.open .vmodal{ animation: modalIn .26s cubic-bezier(.2,.8,.2,1); }
.vmodal .x{ position: absolute; top: 14px; right: 16px; background: none; border: none; color: var(--dim); font-size: 26px; line-height: 1; cursor: pointer; z-index: 3; }
.vmodal .x:hover{ color: #fff; }
.vmodal .vk{ font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--red); }
.vmodal h3{ font-family: var(--f-disp); text-transform: uppercase; font-weight: 800; font-size: 28px; margin: 6px 0 16px; }
.vplayer{
  position: relative; width: 100%; max-width: 300px; margin: 0 auto;
  aspect-ratio: 9 / 16; border-radius: 10px; overflow: hidden; background: #000;
}
.vplayer iframe{ position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }

@media (max-width: 760px){
  .accordion{ flex-direction: column; height: auto; gap: 12px; }
  .tcard{ flex: none; height: 220px; }
  .tcard.active{ flex: none; }
  .tcard-media{ opacity: 1; }
  .tcard-vert{ display: none; }
  .tcard-label{ opacity: 1; }
  .tplay{ opacity: 1; transform: translate(-50%,-50%) scale(1); }
}
