:root{
  --ink:#0b0712;
  --ink2:#120b1d;
  --orange:#ff7a00; --pink:#ff2d8a; --purple:#8a2ff7; --blue:#4aa8ff;
  --grad:linear-gradient(100deg,#ff7a00 0%,#ff3d2e 25%,#ff2d8a 50%,#8a2ff7 78%,#4aa8ff 100%);
  --mute:#a99cc4;
  --line:rgba(255,255,255,.1);
  --disp:'Unbounded',sans-serif; --body:'Manrope',sans-serif;
  --radius:22px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--ink);color:#fff;overflow-x:hidden;-webkit-font-smoothing:antialiased}
::selection{background:var(--pink);color:#fff}
a{color:inherit;text-decoration:none}
img,video{display:block;max-width:100%}
.wrap{max-width:1240px;margin:0 auto;padding:0 24px;width:100%}
h1,h2,h3{font-family:var(--disp);line-height:1.04;letter-spacing:-.02em;text-transform:uppercase}
.gtext{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

/* progress */
.progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--grad);z-index:300}

/* ================= HEADER ================= */
header{position:fixed;inset:0 0 auto;z-index:150;transition:.35s}
header.sc{background:rgba(11,7,18,.82);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px;gap:20px}
.logo{font-family:var(--disp);font-weight:800;font-size:22px;display:flex;align-items:baseline;flex:none}
.logo .gym{font-size:13px;margin-left:4px;letter-spacing:.14em;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.menu{display:flex;gap:34px;list-style:none;margin-left:auto}
.menu a{font-weight:600;font-size:14.5px;color:#e6def5;opacity:.85;transition:.2s}
.menu a:hover{opacity:1;color:#fff}
.hbtn{font-family:var(--disp);font-weight:700;font-size:12px;color:#fff;padding:13px 22px;border-radius:40px;background:var(--grad);background-size:220% 220%;animation:gmove 7s ease infinite;letter-spacing:.04em;text-transform:uppercase;flex:none}
@keyframes gmove{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{width:24px;height:2px;background:#fff;display:block;border-radius:2px}

/* mobile nav */
.mnav{position:fixed;inset:0;z-index:200;background:rgba(11,7,18,.97);backdrop-filter:blur(20px);display:flex;flex-direction:column;justify-content:center;align-items:center;gap:26px;transform:translateY(-100%);transition:transform .45s;visibility:hidden}
.mnav.open{transform:none;visibility:visible}
.mnav a{font-family:var(--disp);font-weight:700;font-size:26px;text-transform:uppercase}
.mnav .x{position:absolute;top:18px;right:22px;font-size:40px;line-height:1;background:none;border:0;color:#fff;cursor:pointer}

/* ================= HERO ================= */
.hero{position:relative;min-height:100svh;overflow:hidden;display:flex;align-items:flex-end}
.hero-media{position:absolute;inset:0}
.hero-media video,.hero-media .poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-media .poster{background:linear-gradient(140deg,#ff7a00,#ff2d8a 40%,#8a2ff7 75%,#4aa8ff);background-size:300% 300%;animation:gmove 10s ease infinite}
.hero-media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(11,7,18,.55) 0%,rgba(11,7,18,.15) 38%,rgba(11,7,18,.94) 100%)}
.hero-tint{position:absolute;inset:0;background:linear-gradient(120deg,rgba(255,122,0,.16),rgba(255,45,138,.12) 45%,rgba(74,168,255,.14));mix-blend-mode:overlay;pointer-events:none}
.hero-content{position:relative;z-index:3;width:100%;padding-top:120px;padding-bottom:72px;will-change:transform,opacity}
.kicker{display:inline-flex;align-items:center;gap:10px;font-family:var(--disp);font-weight:700;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:#fff;margin-bottom:22px;opacity:.9}
.kicker::before{content:"";width:34px;height:2px;background:var(--grad);border-radius:2px}
.hero h1{font-size:clamp(38px,8.5vw,138px);font-weight:800;text-shadow:0 8px 50px rgba(11,7,18,.55)}
.hero h1 .g{background:var(--grad);background-size:220% 220%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gmove 8s ease infinite}
.hero-row{display:flex;align-items:flex-end;justify-content:space-between;gap:28px;margin-top:30px;flex-wrap:wrap}
.hero-row p{max-width:430px;color:#e8e1f5;font-size:17px;line-height:1.6}
.actions{display:flex;gap:14px;flex-wrap:wrap}
.btn{font-family:var(--disp);font-weight:700;font-size:13px;padding:17px 28px;border-radius:50px;border:0;display:inline-flex;align-items:center;justify-content:center;gap:10px;text-transform:uppercase;letter-spacing:.03em;transition:transform .2s,box-shadow .25s;cursor:pointer;line-height:1}
.btn:hover{transform:translateY(-3px)}
.btn-grad{background:var(--grad);background-size:220% 220%;animation:gmove 7s ease infinite;color:#fff;box-shadow:0 14px 40px rgba(255,45,138,.35)}
.btn-glass{background:rgba(255,255,255,.1);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.28);color:#fff}
.btn-glass:hover{background:rgba(255,255,255,.2)}
.scroll-hint{position:absolute;right:30px;bottom:30px;z-index:3;display:flex;flex-direction:column;align-items:center;gap:10px;color:#fff;opacity:.7;font-size:11px;letter-spacing:.2em;text-transform:uppercase;writing-mode:vertical-rl}
.scroll-hint i{width:1px;height:46px;background:linear-gradient(#fff,transparent);display:block;animation:drop 1.6s ease-in-out infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ================= MARQUEE ================= */
.marq{background:var(--grad);background-size:300% 300%;animation:gmove 12s ease infinite;color:#fff;padding:18px 0;overflow:hidden;white-space:nowrap;position:relative;z-index:5}
.marq .t{display:inline-flex;gap:30px;align-items:center;font-family:var(--disp);font-weight:800;font-size:clamp(17px,2.6vw,30px);text-transform:uppercase;animation:slide 26s linear infinite}
.marq .t span{display:inline-flex;gap:30px;align-items:center}
.marq .d{width:9px;height:9px;border-radius:50%;background:#fff;flex:none}
@keyframes slide{to{transform:translateX(-50%)}}

/* ================= COMMON ================= */
.pad{padding:clamp(72px,10vw,120px) 0}
.pad-b0{padding-bottom:0}
.pad-t0{padding-top:0}
.eyebrow{font-family:var(--disp);font-weight:700;text-transform:uppercase;letter-spacing:.2em;font-size:11px;display:inline-flex;align-items:center;gap:12px;margin-bottom:18px;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.eyebrow::before{content:"";width:30px;height:2px;background:var(--grad);border-radius:2px}
.sec-title{font-size:clamp(32px,5.4vw,72px);font-weight:800}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px 40px;flex-wrap:wrap;margin-bottom:8px}
.sec-head .sh-l{max-width:680px}
.sec-head p{max-width:380px;color:var(--mute);line-height:1.65;font-size:16px}

/* reveal */
.has-js .rev{opacity:0;transform:translateY(34px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.rev.in{opacity:1;transform:none}
.has-js .stg>*{opacity:0;transform:translateY(34px);transition:opacity .7s,transform .7s}
.stg.in>*{opacity:1;transform:none}
.stg.in>*:nth-child(2){transition-delay:.07s}.stg.in>*:nth-child(3){transition-delay:.14s}
.stg.in>*:nth-child(4){transition-delay:.21s}.stg.in>*:nth-child(5){transition-delay:.28s}
.stg.in>*:nth-child(6){transition-delay:.35s}

/* ================= STATS ================= */
.stats .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.stat{background:var(--ink2);padding:clamp(30px,4vw,46px) clamp(22px,2.5vw,32px);display:flex;flex-direction:column;justify-content:center}
.stat .n{font-family:var(--disp);font-weight:800;font-size:clamp(34px,4vw,56px);background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.stat p{color:var(--mute);margin-top:10px;font-size:13px;text-transform:uppercase;letter-spacing:.08em}

/* ================= ZONES ================= */
.zgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:54px}
.zcard{position:relative;border-radius:var(--radius);overflow:hidden;height:380px;border:1px solid var(--line);background:var(--ink2)}
.zcard video,.zcard .zfall{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.zcard .zfall{background:linear-gradient(150deg,var(--c1,#ff7a00),var(--c2,#8a2ff7) 70%,#0b0712)}
.zcard:hover video{transform:scale(1.06)}
.zcard::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(11,7,18,.92));pointer-events:none}
.zcap{position:absolute;left:0;right:0;bottom:0;padding:28px;z-index:3}
.zcap .tag{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);color:#fff;font-family:var(--disp);font-size:10px;font-weight:700;padding:7px 13px;border-radius:20px;margin-bottom:14px;text-transform:uppercase;letter-spacing:.06em}
.zcap .tag i{width:6px;height:6px;border-radius:50%;background:var(--grad)}
.zcap h3{font-size:clamp(20px,2.4vw,30px);margin-bottom:8px}
.zcap p{color:#d9d1ea;font-size:14.5px;line-height:1.55;max-width:440px}
.zcard .play{position:absolute;top:22px;right:22px;width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.25);display:grid;place-items:center;z-index:3;transition:.3s;opacity:0;transform:scale(.7)}
.zcard:hover .play{opacity:1;transform:scale(1)}
.zcard .play svg{width:16px;fill:#fff;margin-left:2px}

/* ================= SHOWREEL ================= */
.reel{position:relative;height:78vh;min-height:460px;overflow:hidden;display:grid;place-items:center}
.reel video,.reel .poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;will-change:transform}
.reel .poster{background:linear-gradient(140deg,#8a2ff7,#ff2d8a 50%,#ff7a00)}
.reel::after{content:"";position:absolute;inset:0;background:rgba(11,7,18,.45)}
.reel h2{position:relative;z-index:3;font-size:clamp(32px,7vw,108px);text-align:center;padding:0 20px;text-shadow:0 10px 60px rgba(11,7,18,.6)}
.reel h2 span{display:block;font-size:.4em;font-weight:700;letter-spacing:.28em;margin-top:16px;opacity:.85}

/* ================= PRICING ================= */
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:54px;align-items:stretch}
.pcard{border-radius:var(--radius);padding:38px 32px;background:var(--ink2);border:1.5px solid var(--line);position:relative;transition:transform .3s,border-color .3s;display:flex;flex-direction:column}
.pcard:hover{transform:translateY(-8px);border-color:rgba(255,45,138,.5)}
.pcard.pop{background:linear-gradient(var(--ink2),var(--ink2)) padding-box,var(--grad) border-box;border:1.5px solid transparent}
.pcard .pn{font-family:var(--disp);font-weight:700;font-size:16px;text-transform:uppercase;color:#cfc4e6}
.pcard .pp{font-family:var(--disp);font-weight:800;font-size:clamp(40px,4.5vw,46px);margin:16px 0 2px;line-height:1}
.pcard .pp small{font-size:17px;color:var(--mute);font-weight:700}
.pcard .per{font-size:13.5px;color:var(--mute);margin-bottom:24px;min-height:20px}
.pcard ul{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:28px;flex:1}
.pcard li{display:flex;gap:10px;font-size:14.5px;color:#e3dbf3;line-height:1.45}
.pcard li::before{content:"";width:18px;height:18px;flex:none;border-radius:50%;background:var(--grad);mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3'%3E%3Cpath d='M5 13l4 4L19 7'/%3E%3C/svg%3E") center/100% no-repeat;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3'%3E%3Cpath d='M5 13l4 4L19 7'/%3E%3C/svg%3E") center/100% no-repeat;margin-top:1px}
.pcard .ptag{position:absolute;top:-12px;right:26px;background:var(--grad);color:#fff;font-family:var(--disp);font-size:10px;font-weight:700;padding:7px 14px;border-radius:20px;text-transform:uppercase;letter-spacing:.05em}
.pcard .btn{width:100%;justify-content:center}
.single{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:20px}
.srow{display:flex;align-items:center;justify-content:space-between;gap:14px;border-radius:16px;padding:22px 24px;background:var(--ink2);border:1px solid var(--line)}
.srow span{font-family:var(--disp);font-size:12px;text-transform:uppercase;color:#d9d1ea;line-height:1.4}
.srow b{font-family:var(--disp);font-size:21px;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;white-space:nowrap}
.note{margin-top:34px;padding:24px 28px;border-radius:18px;background:var(--ink2);border:1px solid var(--line);color:#d9d1ea;line-height:1.7;font-size:15px;max-width:860px;position:relative;overflow:hidden}
.note::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--grad)}
.note b{color:#fff}

/* ================= TRAINERS ================= */
.tgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:54px}
.tcard{border-radius:18px;overflow:hidden;background:var(--ink2);border:1px solid var(--line);transition:transform .3s,border-color .3s}
.tcard:hover{transform:translateY(-6px);border-color:rgba(138,47,247,.5)}
.tcard .av{aspect-ratio:4/3;display:grid;place-items:center;position:relative}
.tcard .av .ini{font-family:var(--disp);font-weight:800;font-size:clamp(38px,5vw,56px);color:rgba(255,255,255,.95)}
.tcard .av::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(11,7,18,.5))}
.tcard .info{padding:18px 20px 22px}
.tcard .exp{font-family:var(--disp);font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:.12em;margin-bottom:7px;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.tcard h3{font-size:15.5px;line-height:1.2}
.tcard .role{color:var(--mute);font-size:13px;margin-top:4px}

/* ================= CTA ================= */
.cta-card{border-radius:28px;overflow:hidden;position:relative}
.cta-card .bgv{position:absolute;inset:0}
.cta-card .bgv video{width:100%;height:100%;object-fit:cover}
.cta-card .bgv::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(11,7,18,.93) 35%,rgba(11,7,18,.55))}
.cta-in{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:44px;padding:clamp(40px,5vw,64px) clamp(28px,4vw,56px);align-items:center}
.cta-in h2{font-size:clamp(28px,4vw,52px)}
.cta-in .lead{color:#ddd5ee;margin-top:16px;line-height:1.6;font-size:16.5px;max-width:420px}
.cform{background:rgba(18,11,29,.88);backdrop-filter:blur(14px);border:1px solid var(--line);border-radius:20px;padding:32px 30px}
.cform label{font-family:var(--disp);font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:var(--mute);display:block;margin:14px 0 7px}
.cform label:first-child{margin-top:0}
.cform input{width:100%;background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:12px;padding:14px 15px;color:#fff;font-family:var(--body);font-size:15px;transition:.2s}
.cform input:focus{outline:0;border-color:var(--pink);box-shadow:0 0 0 3px rgba(255,45,138,.2)}
.cform .btn{width:100%;justify-content:center;margin-top:22px}
.cform small{display:block;color:var(--mute);font-size:11.5px;margin-top:12px;text-align:center;line-height:1.5}
.cform .done{text-align:center;padding:30px 6px}
.cform .done .ok{width:64px;height:64px;border-radius:50%;background:var(--grad);display:grid;place-items:center;margin:0 auto 18px}
.cform .done .ok svg{width:30px;stroke:#fff;fill:none;stroke-width:3}
.cform .done h3{font-size:20px;margin-bottom:8px}
.cform .done p{color:var(--mute);font-size:14.5px;line-height:1.55}

/* ================= FAQ ================= */
.faq-list{margin-top:50px;border-top:1px solid var(--line)}
.fitem{border-bottom:1px solid var(--line)}
.fq{width:100%;background:none;border:0;color:#fff;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:24px 4px;text-align:left;font-family:var(--disp);font-weight:700;font-size:clamp(15px,1.9vw,21px);text-transform:uppercase;cursor:pointer}
.fq .ic{width:38px;height:38px;border-radius:50%;border:1.5px solid var(--line);display:grid;place-items:center;flex:none;position:relative;transition:.3s}
.fq .ic::before,.fq .ic::after{content:"";position:absolute;background:#fff;transition:.3s}
.fq .ic::before{width:14px;height:2px}.fq .ic::after{width:2px;height:14px}
.fitem.open .ic{background:var(--grad);border-color:transparent}
.fitem.open .ic::after{transform:scaleY(0)}
.fa{max-height:0;overflow:hidden;transition:max-height .4s ease}
.fa p{padding:0 4px 26px;color:#cfc4e6;line-height:1.7;max-width:780px;font-size:15px}

/* ================= FOOTER ================= */
footer{padding:80px 0 32px;border-top:1px solid var(--line);background:var(--ink2)}
.fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;padding-bottom:44px;border-bottom:1px solid var(--line)}
.fgrid .logo{font-size:30px;margin-bottom:16px}
footer p{color:var(--mute);line-height:1.7;font-size:14.5px}
.fcol h4{font-family:var(--disp);font-size:11px;text-transform:uppercase;letter-spacing:.14em;margin-bottom:16px;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.fcol a,.fcol span{display:block;color:#ddd5ee;margin-bottom:11px;font-size:14.5px;transition:.2s}
.fcol a:hover{color:#fff}
.fbot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:24px;color:#7d6fa0;font-size:12.5px}

/* ================= RESPONSIVE ================= */
@media(max-width:1024px){
  .menu{gap:24px}
  .tgrid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:880px){
  .zgrid{grid-template-columns:1fr;gap:16px}
  .zcard{height:300px}
  .pgrid{grid-template-columns:1fr;max-width:520px;margin-left:auto;margin-right:auto}
  .single{grid-template-columns:1fr}
  .cta-in{grid-template-columns:1fr;gap:30px}
  .fgrid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .menu,.hbtn{display:none}
  .burger{display:flex}
  .tgrid{grid-template-columns:repeat(2,1fr);gap:14px}
  .sec-head p{max-width:none}
}
@media(max-width:560px){
  .stats .grid{grid-template-columns:1fr 1fr}
  .actions{width:100%}
  .actions .btn{flex:1 1 auto}
  .fgrid{grid-template-columns:1fr;gap:28px}
  .scroll-hint{display:none}
  .reel{height:60vh;min-height:340px}
  .hero-row{gap:22px}
  .srow{padding:18px 20px}
}
@media (prefers-reduced-motion:reduce){*{animation-duration:.001s!important;transition-duration:.05s!important}}
/* ===== WP additions ===== */
.tcard .av img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.tcard .av .ini{position:relative;z-index:1}
.admin-bar header{top:32px}
@media(max-width:782px){.admin-bar header{top:46px}}

/* ============ TRAINERS v2 (editorial photo cards + modal) ============ */
.trn-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:54px}
.trn{position:relative;display:block;border-radius:20px;overflow:hidden;aspect-ratio:3/4;background:var(--ink2);border:1px solid var(--line);cursor:pointer;isolation:isolate;color:#fff;transition:transform .4s cubic-bezier(.2,.7,.2,1),border-color .4s}
.trn__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 22%;filter:grayscale(1) contrast(1.03) brightness(.92);transition:filter .55s ease,transform .8s cubic-bezier(.2,.7,.2,1);z-index:1}
.trn__fallback{position:absolute;inset:0;display:grid;place-items:center;z-index:1}
.trn__fallback .ini{font-family:var(--disp);font-weight:800;font-size:clamp(34px,4vw,52px);color:rgba(255,255,255,.96)}
.trn::after{content:"";position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(11,7,18,.06) 0%,rgba(11,7,18,0) 30%,rgba(11,7,18,.5) 62%,rgba(11,7,18,.92) 100%);transition:opacity .4s;pointer-events:none}
.trn::before{content:"";position:absolute;inset:0;z-index:5;border-radius:20px;padding:1.5px;background:var(--grad);-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;pointer-events:none}
.trn:hover{transform:translateY(-6px);border-color:transparent}
.trn:hover::before{opacity:1}
.trn:hover .trn__img{filter:grayscale(0) contrast(1.04) brightness(1) saturate(1.06);transform:scale(1.05)}
.trn__num{position:absolute;top:14px;left:16px;z-index:4;font-family:var(--disp);font-weight:800;font-size:13px;letter-spacing:.04em;color:rgba(255,255,255,.5)}
.trn__open{position:absolute;top:12px;right:12px;z-index:4;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.25);display:grid;place-items:center;opacity:0;transform:scale(.7) rotate(-15deg);transition:.35s}
.trn:hover .trn__open{opacity:1;transform:none}
.trn__open svg{width:15px;stroke:#fff;fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.trn__over{position:absolute;left:0;right:0;bottom:0;z-index:4;padding:18px 16px}
.trn__exp{display:inline-flex;font-family:var(--disp);font-weight:700;font-size:9px;letter-spacing:.08em;text-transform:uppercase;padding:5px 9px;border-radius:20px;background:rgba(255,255,255,.13);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.2);margin-bottom:11px}
.trn__name{font-family:var(--disp);font-weight:700;font-size:15px;line-height:1.12;text-transform:uppercase;letter-spacing:-.01em}
.trn__spec{margin-top:7px;color:#cabfe0;font-size:12px;line-height:1.4;max-height:0;opacity:0;overflow:hidden;transition:max-height .45s ease,opacity .4s,margin-top .45s}
.trn:hover .trn__spec{max-height:60px;opacity:1}

/* modal */
.trn-modal{position:fixed;inset:0;z-index:400;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:opacity .35s,visibility .35s}
.trn-modal.open{opacity:1;visibility:visible}
.trn-modal__bd{position:absolute;inset:0;background:rgba(6,3,12,.74);backdrop-filter:blur(10px)}
.trn-modal__card{position:relative;z-index:2;width:min(840px,100%);max-height:90vh;overflow:hidden;border-radius:24px;background:var(--ink2);border:1px solid var(--line);display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);transform:translateY(22px) scale(.97);transition:transform .42s cubic-bezier(.2,.7,.2,1)}
.trn-modal.open .trn-modal__card{transform:none}
.trn-modal__photo{position:relative;min-height:380px;background:var(--ink)}
.trn-modal__photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 20%}
.trn-modal__photo .ini{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--disp);font-weight:800;font-size:72px;color:#fff}
.trn-modal__photo::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 55%,rgba(18,11,29,.65))}
.trn-modal__info{padding:42px 38px;display:flex;flex-direction:column;justify-content:center}
.trn-modal__info .m-exp{font-family:var(--disp);font-weight:700;font-size:11px;letter-spacing:.12em;text-transform:uppercase;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:13px}
.trn-modal__info h3{font-size:clamp(24px,3vw,34px);text-transform:uppercase;line-height:1.04;margin-bottom:9px}
.trn-modal__info .m-role{color:var(--mute);font-size:14px;margin-bottom:24px}
.trn-modal__info .m-spec-l{font-family:var(--disp);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);margin-bottom:9px}
.trn-modal__info .m-spec{color:#e6dff5;font-size:15.5px;line-height:1.6;margin-bottom:30px}
.trn-modal__info .btn{align-self:flex-start}
.trn-modal__close{position:absolute;top:14px;right:16px;z-index:6;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);color:#fff;font-size:24px;line-height:1;cursor:pointer;display:grid;place-items:center;backdrop-filter:blur(8px);transition:.25s}
.trn-modal__close:hover{background:rgba(255,255,255,.22);transform:rotate(90deg)}

@media(max-width:1024px){.trn-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.trn-grid{grid-template-columns:repeat(2,1fr);gap:12px}.trn__spec{display:none}}
@media(max-width:720px){
  .trn-modal__card{grid-template-columns:1fr;max-height:90vh;overflow-y:auto}
  .trn-modal__photo{min-height:300px}
  .trn-modal__info{padding:28px 24px}
}

/* ============ ABOUT (was plain stats) ============ */
.about-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.about-grid--solo{grid-template-columns:1fr;max-width:760px}
.about-media{position:relative}
.about-media .main{position:relative;border-radius:24px;overflow:hidden;aspect-ratio:4/3;border:1px solid var(--line)}
.about-media .main img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.about-media .main::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,transparent 55%,rgba(11,7,18,.45))}
.about-inset{position:absolute;left:-24px;bottom:-24px;width:42%;aspect-ratio:1/1;border-radius:20px;overflow:hidden;border:4px solid var(--ink);box-shadow:0 24px 60px rgba(0,0,0,.55)}
.about-inset img{width:100%;height:100%;object-fit:cover}
.about-inset::after{content:"";position:absolute;inset:0;border-radius:16px;padding:1.5px;background:var(--grad);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.about-title{font-size:clamp(28px,4vw,52px);margin:14px 0 18px}
.about-text{color:var(--mute);font-size:16.5px;line-height:1.7;max-width:520px;margin-bottom:34px}
.about-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:18px;overflow:hidden}
.about-stat{background:var(--ink2);padding:26px clamp(18px,2.2vw,28px)}
.about-stat .n{font-family:var(--disp);font-weight:800;font-size:clamp(28px,3.2vw,42px);background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.about-stat p{color:var(--mute);margin-top:8px;font-size:12.5px;text-transform:uppercase;letter-spacing:.07em}
@media(max-width:900px){
  .about-grid{grid-template-columns:1fr;gap:30px}
  .about-media .main{aspect-ratio:16/10}
  .about-inset{width:34%;left:auto;right:16px;bottom:-18px}
}
@media(max-width:560px){
  .about-inset{display:none}
  .about-stat{padding:22px 18px}
}

/* ============ Zone real photos ============ */
.zcard .zimg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.zcard:hover .zimg{transform:scale(1.06)}
.zcard::after{z-index:2}
.zcard video{z-index:2}
.zcard .zcap,.zcard .play{z-index:3}

/* hero static photo (when no video) */
.hero-media .hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

/* ============ ABOUT v2 (no photo — typographic stats band) ============ */
.about-band{display:grid;grid-template-columns:repeat(4,1fr);margin-top:clamp(42px,6vw,66px);border-top:1px solid var(--line)}
.about-cell{padding:clamp(28px,3.4vw,46px) clamp(18px,2.2vw,30px) 4px;border-right:1px solid var(--line)}
.about-cell:last-child{border-right:0}
.about-cell .n{font-family:var(--disp);font-weight:800;font-size:clamp(30px,5.6vw,78px);line-height:.95;letter-spacing:-.02em;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.about-cell p{color:var(--mute);margin-top:14px;font-size:13px;text-transform:uppercase;letter-spacing:.08em}
@media(max-width:760px){
  .about-band{grid-template-columns:1fr 1fr;border-left:1px solid var(--line)}
  .about-cell{border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
  .about-cell:nth-last-child(-n+2){border-bottom:0}
}

/* ============ ZONES slider ============ */
.zslider{position:relative;margin-top:54px;padding:0 76px}
.ztrack{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:6px 2px;scrollbar-width:none;-ms-overflow-style:none}
.ztrack::-webkit-scrollbar{display:none}
.ztrack .zcard{flex:0 0 360px;scroll-snap-align:start}
.zarrow{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;border:0;cursor:pointer;display:grid;place-items:center;z-index:10;background:var(--grad);background-size:200% 200%;color:#fff;box-shadow:0 14px 34px rgba(255,45,138,.4);transition:transform .25s}
.zarrow:hover{transform:translateY(-50%) scale(1.08)}
.zarrow svg{width:22px;fill:none;stroke:#fff;stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round}
.zprev{left:11px}
.znext{right:11px}
@media(max-width:880px){
  .zslider{padding:0}
  .zarrow{display:none}
}
@media(max-width:560px){
  .ztrack .zcard{flex:0 0 84%}
}

/* ============ Pricing: student/adult price table ============ */
.pcard .ptable{margin:16px 0 2px;display:flex;flex-direction:column;gap:9px}
.pcard .prow{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding-bottom:9px;border-bottom:1px solid var(--line)}
.pcard .prow:last-child{border-bottom:0}
.pcard .prow span{font-size:14px;color:#cfc4e6}
.pcard .prow b{font-family:var(--disp);font-weight:800;font-size:clamp(21px,2.3vw,27px);line-height:1;white-space:nowrap;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.pcard .per{font-size:13px;color:var(--mute);margin:8px 0 4px}
/* singles: 4 items in 2 columns */
.single{grid-template-columns:repeat(2,1fr)}
@media(max-width:600px){.single{grid-template-columns:1fr}}

/* pricing card: push button to bottom (no features list now) */
.pcard .btn{margin-top:auto}
.pcard .ptable{margin-bottom:8px}

/* trainer modal: full bio */
.m-bio{white-space:pre-line;color:#d6cde8;font-size:14px;line-height:1.6;margin-bottom:24px;max-height:40vh;overflow-y:auto;padding-right:10px}
.m-bio::-webkit-scrollbar{width:6px}
.m-bio::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:4px}
.m-bio::-webkit-scrollbar-track{background:transparent}
@media(max-width:720px){.m-bio{max-height:none}}

/* ===== Responsive polish ===== */
@media(max-width:480px){
  .wrap{padding:0 18px}
  .about-cell{padding:24px 14px 4px}
  .trn__over{padding:14px 12px}
  .pcard{padding:30px 24px}
}
/* trainer modal: keep close button reachable when card scrolls on mobile */
@media(max-width:720px){
  .trn-modal{padding:0}
  .trn-modal__card{max-height:100vh;border-radius:0;width:100%}
  .trn-modal__close{position:fixed;top:12px;right:12px}
}

/* ===== iPhone notch / Dynamic Island — full-bleed immersion (safe-area) ===== */
header{padding-top:env(safe-area-inset-top,0px)}
.wrap{padding-left:max(24px,env(safe-area-inset-left));padding-right:max(24px,env(safe-area-inset-right))}
@media(max-width:480px){.wrap{padding-left:max(18px,env(safe-area-inset-left));padding-right:max(18px,env(safe-area-inset-right))}}
.mnav{padding-top:env(safe-area-inset-top,0px);padding-bottom:env(safe-area-inset-bottom,0px)}
.mnav .x{top:calc(18px + env(safe-area-inset-top,0px))}
.hero-content{padding-bottom:calc(72px + env(safe-area-inset-bottom,0px))}
footer{padding-bottom:calc(32px + env(safe-area-inset-bottom,0px))}
.trn-modal__close{top:calc(14px + env(safe-area-inset-top,0px))}

/* ===== Zones slider: bigger cards ===== */
.ztrack .zcard{flex:0 0 400px;height:440px}
@media(max-width:880px){.ztrack .zcard{height:430px}}
@media(max-width:560px){.ztrack .zcard{flex:0 0 88%;height:460px}}
/* ===== Showreel: photo background + tidy mobile text ===== */
.reel .reel-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
@media(max-width:560px){
  .reel{height:auto;min-height:0;padding:90px 0}
  .reel h2{font-size:clamp(30px,8vw,52px);padding:0 20px;line-height:1.06}
  .reel h2 span{font-size:13px;letter-spacing:.12em;margin-top:12px}
}

/* ===== Trainers: full-colour cards + better modal (v3) ===== */
/* cards always in colour */
.trn__img{filter:none}
.trn:hover .trn__img{filter:none;transform:scale(1.05)}
.trn::after{background:linear-gradient(180deg,rgba(11,7,18,0) 28%,rgba(11,7,18,.5) 60%,rgba(11,7,18,.95) 100%)}
.trn__spec{display:none}
.trn__name{font-size:16px;line-height:1.15}
.trn__img{object-position:center 18%}
/* modal: show full photo (no crop) on a blurred fill, readable bio */
.trn-modal__card{grid-template-columns:minmax(0,.88fr) minmax(0,1.12fr)}
.trn-modal__photo{background:#0b0712;min-height:460px}
.trn-modal__photo::after{display:none}
.trn-modal__photo .ph-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:blur(26px) brightness(.45);transform:scale(1.2)}
.trn-modal__photo .ph-fg{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;object-position:center;z-index:1}
.trn-modal__info{padding:38px 36px}
.m-bio{color:#e6dff4;font-size:14.5px;line-height:1.72;max-height:48vh}
@media(max-width:720px){
  .trn-modal__photo{min-height:340px}
  .m-bio{max-height:none}
}

/* ===== Trainer modal v4: photo on top, text below ===== */
.trn-modal__card{grid-template-columns:1fr;grid-template-rows:auto minmax(0,1fr);width:min(460px,100%);max-height:92vh;overflow:hidden}
.trn-modal__photo{height:min(48vh,440px);min-height:0}
.trn-modal__photo .ph-bg{display:none}
.trn-modal__photo .ph-fg{object-fit:cover;object-position:center 12%}
.trn-modal__info{overflow-y:auto;padding:30px 32px}
.m-bio{max-height:none;margin-bottom:22px}
@media(max-width:720px){
  .trn-modal__card{width:100%;max-height:100vh}
  .trn-modal__photo{height:44vh}
}

/* ===== Trainer modal v5: easier to close + flip through trainers ===== */
/* bigger, higher-contrast close button */
.trn-modal__close{width:46px;height:46px;font-size:30px;background:rgba(20,12,32,.74);border-color:rgba(255,255,255,.3)}
/* "3 / 16" counter badge over the photo */
.trn-modal__count{position:absolute;top:16px;left:18px;z-index:6;font-family:var(--disp);font-weight:700;font-size:12px;letter-spacing:.06em;color:#fff;background:rgba(11,7,18,.5);backdrop-filter:blur(6px);padding:5px 11px;border-radius:20px;border:1px solid rgba(255,255,255,.18)}
/* prev / next arrows */
.trn-nav{position:absolute;z-index:5;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;background:rgba(20,12,32,.62);border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(8px);display:grid;place-items:center;cursor:pointer;transition:background .25s,border-color .25s,transform .25s}
.trn-nav svg{width:22px;stroke:#fff;fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.trn-nav:hover{background:var(--grad);border-color:transparent;transform:translateY(-50%) scale(1.07)}
.trn-nav--prev{left:calc(50% - 290px)}
.trn-nav--next{right:calc(50% - 290px)}
@media(max-width:980px){
  .trn-nav--prev{left:16px}
  .trn-nav--next{right:16px}
}
@media(max-width:720px){
  /* mobile: arrows as a centred "‹ ›" pair at the bottom — clear of the chat bubble (bottom-right) */
  .trn-nav{top:auto;bottom:calc(16px + env(safe-area-inset-bottom,0px));transform:none;width:50px;height:50px}
  .trn-nav:hover{transform:none}
  .trn-nav--prev{left:calc(50% - 58px);right:auto}
  .trn-nav--next{left:calc(50% + 8px);right:auto}
  .trn-modal__close{width:48px;height:48px}
  /* leave room below the bio so the CTA button clears the bottom arrows */
  .trn-modal__info{padding-bottom:96px}
}

/* ===== CTA form: wider on small screens (trim nested padding) ===== */
@media(max-width:560px){
  .cta-in{padding:36px 14px}
  .cform{padding:26px 16px}
}

/* ===== Trainer modal v6: chat-free — distinct scrollable sheet + tidy footer nav ===== */
.trn-modal__card{display:flex;flex-direction:column}
.trn-modal__photo{flex:0 0 auto;height:min(42vh,360px)}
/* info + footer = a "sheet" overlapping the photo bottom → reads as a separate, scrollable panel */
.trn-modal__sheet{position:relative;z-index:3;flex:1 1 auto;min-height:0;display:flex;flex-direction:column;margin-top:-22px;background:var(--ink2);border-radius:22px 22px 0 0;box-shadow:0 -16px 38px rgba(6,3,12,.5)}
.trn-modal__sheet::before{content:"";position:absolute;top:9px;left:50%;transform:translateX(-50%);width:42px;height:4px;border-radius:4px;background:rgba(255,255,255,.22);z-index:2}
.trn-modal__info{flex:1 1 auto;min-height:0;overflow-y:auto;padding:26px 30px 16px;-webkit-overflow-scrolling:touch}
.trn-modal__info .m-exp{margin-top:4px}
.m-bio-l{font-family:var(--disp);font-weight:700;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--mute);margin:2px 0 10px}
.trn-modal__info .m-bio{color:#ece6f7;font-size:15px;line-height:1.72;max-height:none;margin:0}
/* footer pinned under the scroll area: prev | Записаться | next */
.trn-modal__foot{position:relative;flex:0 0 auto;display:flex;align-items:center;gap:12px;padding:14px 22px calc(16px + env(safe-area-inset-bottom,0px));border-top:1px solid var(--line);background:var(--ink2)}
.trn-modal__foot .btn{flex:1 1 auto;justify-content:center;margin:0;padding-left:14px;padding-right:14px}
/* fade just above the footer = "there is more below" cue */
.trn-modal__fade{position:absolute;left:0;right:0;top:-38px;height:38px;background:linear-gradient(to top,#120b1d,rgba(18,11,29,0));pointer-events:none}
/* arrows: compact, in-flow inside the footer */
.trn-modal__foot .trn-nav{position:static;transform:none;width:46px;height:46px;flex:0 0 auto;background:rgba(255,255,255,.07);border:1px solid var(--line);backdrop-filter:none}
.trn-modal__foot .trn-nav:hover{transform:none;background:var(--grad);border-color:transparent}
.trn-modal__foot .trn-nav svg{width:19px}
@media(max-width:720px){
  .trn-modal__photo{height:40vh}
  .trn-modal__info{padding:22px 22px 14px}
  .trn-modal__foot{padding:12px 16px calc(14px + env(safe-area-inset-bottom,0px));gap:10px}
  .trn-modal__foot .trn-nav{width:48px;height:48px}
}

/* ===== Lead form: honeypot + states ===== */
.cform .hp{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;opacity:0;pointer-events:none}
.cform input.err{border-color:#ff4d6d;box-shadow:0 0 0 3px rgba(255,77,109,.18)}
.cform button[disabled]{opacity:.7;cursor:default}
.form-err{color:#ff8da6;font-size:13px;margin-top:12px;text-align:center;line-height:1.45}

/* ===== Location map (Yandex iframe) ===== */
.map-wrap{position:relative;margin-top:46px;border-radius:24px;overflow:hidden;border:1px solid var(--line)}
.map-box{height:clamp(380px,52vh,560px);width:100%;background:var(--ink);z-index:1}
.map-box iframe{width:100%;height:100%;border:0;display:block;filter:grayscale(.15)}
.map-card{position:absolute;left:24px;bottom:24px;z-index:10;width:310px;max-width:calc(100% - 48px);background:rgba(18,11,29,.92);backdrop-filter:blur(14px);border:1px solid var(--line);border-radius:20px;padding:26px 24px;box-shadow:0 24px 60px rgba(6,3,12,.5)}
.map-card .logo{font-size:26px;margin-bottom:18px}
.map-row{display:flex;align-items:flex-start;gap:10px;color:#e6dff5;font-size:14.5px;line-height:1.45;margin-bottom:13px;text-decoration:none}
.map-row svg{flex:none;width:18px;height:18px;stroke:var(--pink);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;margin-top:1px}
a.map-phone span{color:#fff;font-weight:600;transition:.2s}
a.map-phone:hover span{color:var(--pink)}
.map-route{width:100%;justify-content:center;margin-top:6px}
@media(max-width:720px){
  .map-wrap{overflow:visible;border:0;border-radius:0;margin-top:30px}
  .map-box{height:300px;border-radius:20px;border:1px solid var(--line)}
  .map-card{position:static;width:auto;max-width:none;margin-top:14px;padding:24px 22px}
}

/* ============================================================
   РЕДИЗАЙН 2026-06-09 — шапка-локап + hero «две локации» + лента.
   Заменяет старый .hero / .marq (их правила выше остаются мёртвыми,
   т.к. классы новой вёрстки другие).
   ============================================================ */
.vh{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* — Логотип-локап: LIM + GYM + ФИТНЕС/КЛУБ — */
.logo--lock{display:inline-flex;align-items:flex-start;gap:.26em;line-height:1;color:#fff;font-size:34px}
.logo--lock .logo__lim{font-family:var(--disp);font-weight:800;font-size:1em;letter-spacing:-.01em;line-height:.82;color:#fff}
.logo--lock .logo__r{display:flex;flex-direction:column;align-items:flex-start;padding-top:.03em}
.logo--lock .logo__gym{font-family:var(--disp);font-weight:800;font-size:.53em;letter-spacing:.04em;line-height:.9;color:#fff}
.logo--lock .logo__sub{font-family:var(--disp);font-weight:700;font-size:.22em;letter-spacing:.08em;line-height:1.18;margin-top:.09em;color:#fff}

/* — Меню по центру, белое, заглавными; кнопка справа — */
header#hd .nav{gap:26px}
header#hd .menu{margin:0 auto;gap:40px}
header#hd .menu a{font-family:var(--disp);font-weight:700;font-size:14px;letter-spacing:.04em;text-transform:uppercase;color:#fff;opacity:.92}
header#hd .menu a:hover{opacity:1;color:#fff}

/* — Светлая кнопка «Записаться» (малиновый текст) — */
.hbtn--light{background:#e9e9ea;background-image:none;animation:none;color:#e5165e;font-family:var(--disp);font-weight:800;font-size:13px;letter-spacing:.04em;padding:14px 26px;border-radius:34px;transition:transform .2s,box-shadow .25s,background .2s}
.hbtn--light:hover{transform:translateY(-2px);background:#fff;box-shadow:0 12px 30px rgba(229,22,94,.22)}

/* — Hero «две локации» — */
.lhero{position:relative;background:#000;padding:100px 0 0;overflow:hidden}
.lhero>.wrap{max-width:1340px}
.lhero__row{display:flex;align-items:flex-start;gap:clamp(20px,8vw,118px)}
.lhero__cell{display:block;min-width:0}
.lhero__cell--photo{flex:1.62 1 0;transition:transform .35s ease}
.lhero__cell--photo:hover{transform:translateY(-4px)}
.lhero__cell--soon{flex:1 1 0}
.lhero__cell img{width:100%;height:auto;display:block}
.lhero__ribbon{margin-top:30px;line-height:0}
.lhero__ribbon img{width:100%;height:auto;display:block}

@media(max-width:880px){
  .logo--lock{font-size:30px}
  .lhero{padding-top:88px}
  .lhero__row{gap:18px}
}
@media(max-width:760px){
  .lhero__row{flex-direction:column;gap:16px}
  .lhero__cell--photo,.lhero__cell--soon{flex:1 1 auto;width:100%}
  .lhero__ribbon{margin-top:22px}
}

/* — Плашка «Запись к тренеру» в форме (выставляется из карточки тренера) — */
.lead-trn[hidden]{display:none}
.lead-trn{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;padding:12px 14px;border-radius:14px;background:linear-gradient(var(--ink2),var(--ink2)) padding-box,var(--grad) border-box;border:1.5px solid transparent}
.lead-trn__txt{font-size:14px;color:#e8e1f5;line-height:1.35}
.lead-trn__txt b{color:#fff;font-weight:700}
.lead-trn__x{flex:none;width:26px;height:26px;border-radius:50%;border:1px solid var(--line);background:rgba(255,255,255,.06);color:#fff;font-size:18px;line-height:1;cursor:pointer;display:grid;place-items:center;transition:background .2s,border-color .2s}
.lead-trn__x:hover{background:rgba(255,45,138,.2);border-color:rgba(255,45,138,.5)}

/* ============================================================
   Страница «Политика конфиденциальности» (page-politic.php)
   ============================================================ */
.legal{display:block}
.legal-hero{padding:128px 0 36px;position:relative;border-bottom:1px solid var(--line);background:
  radial-gradient(120% 140% at 0% 0%,rgba(138,47,247,.16),transparent 55%),
  radial-gradient(120% 140% at 100% 0%,rgba(255,45,138,.12),transparent 55%)}
.legal-hero h1{font-size:clamp(28px,4.6vw,52px);font-weight:800;margin-top:16px;word-break:break-word}
.legal-sub{color:#cabfe2;font-size:clamp(15px,2vw,19px);margin-top:16px;max-width:680px;line-height:1.5}
.legal-meta{display:flex;flex-wrap:wrap;gap:10px 12px;margin-top:26px}
.legal-meta .lm{display:inline-flex;align-items:center;gap:9px;font-size:13px;color:#d9d1ea;background:var(--ink2);border:1px solid var(--line);border-radius:30px;padding:9px 15px}
.legal-meta .lm i{width:7px;height:7px;border-radius:50%;background:var(--grad);flex:none}
.legal-meta a.lm{transition:border-color .2s,color .2s}
.legal-meta a.lm:hover{border-color:rgba(255,45,138,.5);color:#fff}

.legal-body{display:flex;align-items:flex-start;gap:54px;padding:48px 0 96px}
.legal-toc{flex:0 0 248px;position:sticky;top:94px}
.legal-toc__in{border:1px solid var(--line);border-radius:18px;background:var(--ink2);padding:20px 18px}
.legal-toc__h{display:block;font-family:var(--disp);font-weight:700;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#fff;margin-bottom:14px}
.legal-toc nav{display:flex;flex-direction:column;gap:2px}
.legal-toc a{font-size:13.5px;line-height:1.35;color:#a99cc4;padding:7px 10px;border-radius:9px;border-left:2px solid transparent;transition:.2s}
.legal-toc a:hover{color:#fff;background:rgba(255,255,255,.04);border-left-color:#ff2d8a}

.legal-doc{flex:1 1 auto;min-width:0;max-width:840px;overflow-wrap:break-word;word-break:break-word}
.legal-doc>h2{border-top:1px solid var(--line);margin-top:34px;padding-top:30px;scroll-margin-top:88px}
.legal-doc>h2:first-child{border-top:0;margin-top:0;padding-top:4px}
.legal-doc h2{display:flex;align-items:center;gap:16px;font-size:clamp(20px,2.5vw,28px);font-weight:800;line-height:1.15;margin-bottom:18px;text-transform:none}
.legal-doc h2 .n{flex:none;display:grid;place-items:center;width:42px;height:42px;border-radius:12px;background:var(--grad);background-size:200% 200%;font-family:var(--disp);font-weight:800;font-size:18px;color:#fff;box-shadow:0 8px 22px rgba(255,45,138,.3)}
.legal-doc p{color:#c9c0de;line-height:1.78;font-size:15.5px;margin:0 0 14px}
.legal-doc p:last-child{margin-bottom:0}
.legal-doc b,.legal-doc strong{color:#fff;font-weight:700}
.legal-doc a{color:#ff5ea0;text-decoration:underline;text-underline-offset:2px;text-decoration-color:rgba(255,94,160,.4);transition:.2s;word-break:break-word}
.legal-doc a:hover{color:#fff;text-decoration-color:#fff}
.legal-doc ul{list-style:none;display:flex;flex-direction:column;gap:11px;margin:0 0 16px;padding:0}
.legal-doc ul li{position:relative;padding-left:24px;color:#c9c0de;line-height:1.7;font-size:15px}
.legal-doc ul li::before{content:"";position:absolute;left:0;top:9px;width:9px;height:9px;border-radius:50%;background:var(--grad)}

.legal-card{border-radius:18px;border:1px solid var(--line);background:var(--ink2);overflow:hidden}
.legal-card .lc-row{display:grid;grid-template-columns:230px 1fr;gap:20px;padding:20px 24px;border-top:1px solid var(--line)}
.legal-card .lc-row:first-child{border-top:0}
.legal-card .k{font-family:var(--disp);font-weight:700;font-size:11px;letter-spacing:.1em;text-transform:uppercase;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1.4}
.legal-card .v{color:#e3dbf3;font-size:15px;line-height:1.7}
.legal-card .v ul{margin:0}
.legal-card .v ul.chips{flex-direction:row;flex-wrap:wrap;gap:9px}
.legal-card .v ul.chips li{padding:8px 14px;background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:30px;font-size:13.5px;color:#e8e1f5}
.legal-card .v ul.chips li::before{display:none}

.legal-back{display:inline-flex;align-items:center;gap:8px;margin-top:34px;font-family:var(--disp);font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.03em;color:#fff;padding:14px 24px;border-radius:40px;border:1px solid var(--line);background:var(--ink2);transition:.2s}
.legal-back:hover{border-color:rgba(255,45,138,.5);transform:translateY(-2px)}

.fbot .flegal{display:inline-flex;gap:18px;flex-wrap:wrap;justify-content:center}
.fbot .flegal a{color:#a99cc4;transition:color .2s}
.fbot .flegal a:hover{color:#fff;text-decoration:underline}

@media(max-width:960px){
  .legal-toc{display:none}
  .legal-body{gap:0}
}
@media(max-width:600px){
  .legal-hero{padding-top:104px}
  .legal-card .lc-row{grid-template-columns:1fr;gap:8px}
  .legal-doc h2{gap:12px}
  .legal-doc h2 .n{width:36px;height:36px;font-size:16px}
}
