@font-face{font-family:"Rubik";src:url("/fonts/Rubik-Light.ttf") format("truetype");font-weight:300;font-style:normal;font-display:swap;}
@font-face{font-family:"Rubik";src:url("/fonts/Rubik-Regular.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap;}
@font-face{font-family:"Rubik";src:url("/fonts/Rubik-Medium.ttf") format("truetype");font-weight:500;font-style:normal;font-display:swap;}
@font-face{font-family:"Rubik";src:url("/fonts/Rubik-Bold.ttf") format("truetype");font-weight:600;font-style:normal;font-display:swap;}
@font-face{font-family:"Rubik";src:url("/fonts/Rubik-Bold.ttf") format("truetype");font-weight:700;font-style:normal;font-display:swap;}
@font-face{font-family:"Rubik";src:url("/fonts/Rubik-Bold.ttf") format("truetype");font-weight:800;font-style:normal;font-display:swap;}

/* ================= Base / Theme ================= */
:root{
  --header-h:64px;
  --brand:#e53935;
  --accent:#6f6bd5;
  --accent-2:#B7ADED;
  --accent-3:#141342;
  --accent-4:#ff7a45;
  --text:#141342;
  --muted:#6c6c6c;
  --white:#fff;
  --ok:#2e7d32;
  --err:#c62828;
  --shadow:0 10px 30px rgba(0,0,0,.08);
  --radius-hero:40px;
  --container-w:min(1200px,92vw);

  /* glass tokens */
  --glass-fg:#0e1320;
  --glass-bg-1:rgba(255,255,255,.72);
  --glass-bg-2:rgba(255,255,255,.90);
  --glass-br:rgba(255,255,255,.60);
  --glass-shadow:0 12px 28px rgba(13,18,30,.20);
}

*{box-sizing:border-box;}
html,body{height:100%;}
html{scroll-padding-top:var(--header-h);scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;color:var(--text);background:#fff;
  font-family:"Rubik",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  padding-top:var(--header-h);
}
img{max-width:100%;height:auto;display:block;}
.container{width:var(--container-w);margin-inline:auto;}
section[id]{scroll-margin-top:var(--header-h);}
html,body{overflow-x:hidden;}
a,button{-webkit-tap-highlight-color:transparent;}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important;}
}

/* ================= Header / Nav ================= */
.site-header{
  position:fixed;inset:0 0 auto;z-index:1100;background:#fff;border-bottom:1px solid rgba(0,0,0,.05);
  height:var(--header-h);
}
.header-inner{
  height:100%;
  display:grid;grid-template-columns:max-content 1fr max-content;align-items:center;
  column-gap:clamp(12px,2.5vw,28px);padding:0;
}
.header-inner a,.header-inner button,.header-inner span{line-height:1;}
.logo{display:inline-flex;align-items:center;gap:10px;font-weight:800;font-size:36px;letter-spacing:.5px;color:var(--brand);text-decoration:none;line-height:.9;}
.logo img{height:36px;width:auto;object-fit:contain;vertical-align:middle;}

.nav{margin:0 auto;padding:0 10px;display:flex;align-items:center;gap:40px;z-index:1001;}
.nav-link{position:relative;text-decoration:none;color:var(--accent-3);font-weight:500;font-size:16px;}
.nav-link::after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:2px;background:var(--accent-3);transform:scaleX(0);transform-origin:left;transition:transform .2s ease;opacity:.8;}
.nav-link:hover::after{transform:scaleX(1);}
.nav-link.disabled{opacity:.5;pointer-events:none;cursor:default;}

.header-cta{display:flex;align-items:center;gap:clamp(12px,2.6vw,20px);margin-left:auto;font-size:15px;font-weight:500}
.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:10px 18px;text-decoration:none;transition:transform .2s ease,box-shadow .2s ease,background .2s ease,color .2s ease;}
.btn:hover{transform:translateY(-1px);box-shadow:0 10px 28px rgba(0,0,0,.12);}
.btn-primary{background:#ffffff;color:var(--accent); border: 1px solid var(--accent);}
.phone{color:#ff7a45;white-space:nowrap;text-decoration:none;}
.vk{color:#26a7e0;text-decoration:none; font-weight: 600;}

.burger{display:none;width:40px;height:40px;border-radius:10px;border:1px solid rgba(0,0,0,.1);background:#fff;align-items:center;justify-content:center;}
.burger svg{width:22px;height:22px;}
.burger line{stroke:#222;stroke-linecap:round;stroke-width:2.5;}
.nav-close{display:none;}
.nav-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);border:0;padding:0;margin:0;}
/* Важно для «тёмного экрана»: бэкдроп виден ТОЛЬКО с .show */
.nav-backdrop:not(.show){display:none !important;}

@media (max-width:960px){
  .header-inner{grid-template-columns:1fr auto;}
  .header-inner a { line-height: 1.5;}
  .header-cta .btn{display:none;}
  .burger{display:inline-flex;margin-left:0;}
  .site-header .nav{position:fixed;inset:0 0 0 auto;width:min(82vw,320px);background:#fff;border-left:1px solid rgba(0,0,0,.06);flex-direction:column;align-items:flex-start;padding:24px;gap:18px;transform:translateX(100%);transition:transform .28s ease;z-index:1001;}
  .site-header .nav.open{transform:translateX(0);}
  .nav-close{display:inline-block;align-self:flex-end;font-size:30px;background:transparent;border:0;padding:6px;margin:-6px -6px 6px;cursor:pointer;}
  .nav-backdrop.show{display:block;z-index:1000;}
  .nav-link {font-size: clamp(12px, 4.2vw, 18px);}
  body.no-scroll{overflow:hidden;}
}
@media (max-width:350px){ .header-cta .phone{display:none;} }

/* ================= Hero ================= */
.hero{padding:12px 0 28px;}
.hero-card{
  position:relative;
  min-height: clamp(520px, 50vh, 600px);
display:grid;grid-template-columns:1.1fr 1fr;gap:30px;
  background:linear-gradient(270deg,var(--accent-2) 0%,var(--accent) 100%);
  border-radius:var(--radius-hero);box-shadow:var(--shadow);overflow:hidden;
  padding:min(5vw,40px) min(5vw,40px) 0 min(5vw,40px);
}
.hero-left{color:#fff;display:flex;flex-direction:column;gap:10px;padding-block:min(2vw,8px);}
.hero-title{margin:0;font-size:clamp(40px,5.5vw,60px);line-height:1.05;font-weight:800;}
.price-row{display:flex;align-items:flex-end;gap:16px;position:relative; padding-bottom: clamp(8px, 3vw, 20px)}
.price{font-size:clamp(48px,7.8vw,116px);font-weight:600;line-height:.9;letter-spacing:.5px;}
.price-badge{transform:rotate(22deg);background:#ff7a45;color:#fff;font-weight:800; font-size: clamp(12px, 4.2vw, 18px); padding: clamp(6px, 1.8vw, 12px) clamp(10px, 2.6vw, 18px);border-radius:999px;box-shadow:0 6px 18px rgba(0,0,0,.15);white-space:nowrap;animation:floaty 3s ease-in-out infinite;position:relative;z-index:2;margin-left:-35px;align-self:flex-start;}
.hero-right {
    position: relative;
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
    overflow: visible;
    min-height: 380px;
}
.hero-right img {
    position: absolute;
    right: 0;
    bottom: 0;
    height: 100%;
    width: auto;
    max-width: none;
    object-fit: contain;
}
@keyframes floaty{0%,100%{transform:rotate(22deg) translateY(0);}50%{transform:rotate(22deg) translateY(-5px);}}
@media (max-width:980px){
  .hero-card{ grid-template-columns:1fr; text-align:left; gap: clamp(6px, 2vw, 12px); min-height:auto;}
  .hero-left{ order:1; }
  .hero-right{ order:2; display:grid; place-items:end center; min-height:auto; }
  .hero-right img{ position:static; width:100%; height:auto; object-fit:contain; }
}

.cta-pill{
  width: fit-content;
  display:inline-flex; align-items:center; gap:12px;
  padding:5px 5px 5px 20px; /* right edge almost after the white circle */
  border-radius:999px; text-decoration:none;
  background: var(--accent);
  color:#fff; font-weight:500; font-size:clamp(16px, 1.6vw, 20px);
  box-shadow:0 14px 32px rgba(0,0,0,.14);
  border:0;
  transition:transform .18s ease, box-shadow .18s ease;
}
.cta-pill:hover{ transform:translateY(-1px); box-shadow:0 18px 40px rgba(111,107,213,.36); filter:saturate(1.05); }

/* ================= Plans ================= */
.plans{padding:24px 0;}
.plans-head h2{margin:0 0 14px;font-size:clamp(40px,5vw,60px);color:var(--text);font-weight:800;}
.plan-card{margin-top:0;background:#fff;border-radius:20px;box-shadow:var(--shadow);padding:18px;}
.plan-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:14px;}
.plan-top h3{margin:0;font-size:30px;color:var(--accent-3);}
.plan-ico{width:75px;height:75px;border-radius:12px;display:grid;place-items:center;}
.plan-ico svg{width:100%;height:100%;display:block;}
.plan-list{list-style:none;margin:6px 0 0;padding:0;}
.plan-list li{position:relative;padding-left:28px;margin:12px 0;color:var(--accent-3);line-height:1.35; font-size: 20px;}
.plan-list li::before{content:"";position:absolute;left:0;top:2px;width:18px;height:18px;border-radius:50%;background:radial-gradient(circle at 50% 50%,var(--accent-2) 40%,var(--accent) 40%);box-shadow:0 2px 6px rgba(0,0,0,.15);}
.plan-btn{margin-top:auto;;display:block;width:100%;background:#5b46c6;color:#fff;text-align:center;text-decoration:none;font-weight:500;font-size:20px;padding:23px 20px;border-radius:999px;box-shadow:0 8px 20px rgba(91,70,198,.25);transition:transform .2s ease,box-shadow .2s ease;}
.plan-btn:hover{transform:translateY(-1px);box-shadow:0 10px 28px rgba(0,0,0,.12);}

.plans-list{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
@media (max-width:959px){
  .plans-list{display:flex;gap:12px;overflow-x:auto;padding:4px 2px 8px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;}
  .plans-list>.plan-card{scroll-snap-align:center;min-width:86vw;}
  .plans-list::-webkit-scrollbar{height:0;}
}

/* Plans dots (mobile) */
@keyframes dotPulse{0%{box-shadow:0 0 0 0 rgba(91,70,198,.35);}70%{box-shadow:0 0 0 10px rgba(91,70,198,0);}100%{box-shadow:0 0 0 0 rgba(91,70,198,0);}}
.plans-dots{display:none;}
@media (max-width:959px){
  .plans-dots{display:flex;justify-content:center;gap:10px;margin-top:12px;}
  .plans-dots button{width:10px;height:10px;border-radius:50%;border:0;padding:0;background:#d9d9e9;position:relative;transition:transform .2s ease,background .2s ease,opacity .2s ease;}
  .plans-dots button.active{background:linear-gradient(135deg,var(--accent-2),var(--accent));transform:scale(1.25);}
  .plans-dots button.active::after{content:"";position:absolute;inset:-6px;border-radius:50%;animation:dotPulse 1.6s ease-out infinite;}
}

/* ================= Trial ================= */
.trial{padding:24px 0;}
.trial-card{
  display:grid;grid-template-columns:1.1fr 1fr;gap:26px;align-items:center;color:#fff;
  background:linear-gradient(270deg,var(--accent-2) 0%,var(--accent) 100%);
  border-radius:var(--radius-hero);padding:min(5vw,40px) min(5vw,40px) 0 min(5vw,40px);
}
.trial-left h2{margin:0;font-size:clamp(35px,4.5vw,60px);font-weight:800;color:#f9f9ff;}
.trial-left p{margin:4px 0 14px;font-size:25px;color:#f0f0f9;}
.trial-form{display:flex;flex-direction:column;gap:12px;margin-bottom: 20px;}
.trial-inputs{display:flex;gap:12px;flex-wrap:wrap;}
.trial-inputs input{flex:1;min-width:160px;padding:12px 14px;border-radius:999px;border:0;font-size:16px;transition:box-shadow .2s ease;}
.trial-inputs input:focus{outline:none;box-shadow:0 0 0 3px rgba(91,70,198,.25);}
.trial-inputs input.error{outline:3px solid rgba(198,40,40,.7);}
.trial-btn{border:0;cursor:pointer;background:#5b46c6;color:#fff;border-radius:999px;padding:12px 18px;font-weight:700;font-size:16px;margin-top:2px;}
.trial-check{display:flex;align-items:flex-start;gap:8px;font-size:14px;line-height:1.3;}
.trial-check input{margin-top:2px;accent-color:#ff7a45;}
.trial-check a{color:#fff;text-decoration:underline;}
.trial-right{position:relative;display:grid;}
.trial-right img{width:100%;object-fit:contain;}
@media (max-width:860px){
  .trial-card{grid-template-columns:1fr;text-align:center;gap:10;}
  .trial-left{order:1;}
  .trial-right{order:2;}
  .trial-inputs{flex-direction:column;}
  .trial-check{text-align:left;}
}

/* ================= Gym (tabs + slider) ================= */
.gym{padding:24px 0;}
.gym-head h2{margin:0 0 12px;font-size: clamp(40px, 5vw, 60px);color: var(--text);font-weight:800;}
.gym-sub{margin:0 0 10px;color:var(--accent-3);font-weight:500;line-height:1.25;font-size:clamp(18px,2.2vw,22px);}
.gym-tabs{display:flex;flex-wrap:wrap;gap:10px;margin:25px 0 25px;}
.gym-tab{padding:10px 16px;border-radius:999px;border:1px solid rgba(0,0,0,.15); color: var(--accent-3); background:#fff;cursor:pointer;font-weight:700;font-size:clamp(15px,1.8vw,18px);}
.gym-tab.active{background:var(--accent-3);color:#fff;}

.gym-slider{position:relative;border-radius:28px;overflow:hidden;box-shadow: 0 14px 36px rgba(0,0,0,.16);}
.gym-viewport{contain:layout paint size;overflow:hidden;border-radius:18px;position:relative;z-index:1;display:block;width:100%;aspect-ratio:16/9;}
.gym-track{display:flex;will-change:transform;transition:transform 420ms cubic-bezier(.22,.61,.36,1);gap:clamp(8px,1.4vw,14px);}
.gym-track.dragging{transition:none !important;}
.gym-slide{flex:0 0 100%;min-width:100%;height:auto;display:grid;border-radius:18px;overflow:hidden;}
.gym-slide img{pointer-events:none;width:100%;height:100%;object-fit:cover;border-radius:18px;}

.gym-thumbs{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:14px 0 6px;}
.gym-thumb{background:#eee;border-radius:12px;overflow:hidden;height:150px;border:0;padding:0;cursor:pointer;box-shadow:0 8px 18px rgba(0,0,0,.12);transition:transform .18s ease, box-shadow .18s ease;}
.gym-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
@media (max-width:860px){.gym-thumbs{grid-template-columns:1fr 1fr;gap:12px;}.gym-thumb{height:120px;}}

/* Dots for sliders (mobile) */
.slider-dots{display:none;justify-content:center;gap:10px;margin-top:10px;}
.slider-dots button{width:10px;height:10px;border-radius:50%;border:0;padding:0;background:#d9d9e9;position:relative;transition:transform .2s ease,background .2s ease;}
.slider-dots button.active{background:linear-gradient(135deg,var(--accent-2),var(--accent));transform:scale(1.25);}
.slider-dots button.active::after{content:"";position:absolute;inset:-6px;border-radius:50%;animation:dotPulse 1.6s ease-out infinite;}
@media (max-width:860px){.slider-dots{display:flex;}}

/* ================= SPA ================= */
.spa{padding:24px 0;}
.spa-head h2{margin:0 0 12px;font-size: clamp(40px, 5vw, 60px);color: var(--text);font-weight:800;}
.spa-sub{margin:0 0 16px;color:var(--accent-3);font-weight:500;font-size:clamp(18px,2.2vw,22px);line-height:1.25;}
.spa-grid{display:grid;grid-template-columns:minmax(240px,420px) 1fr;gap:22px;align-items:stretch;}
.spa-tabs{display:flex;flex-direction:column;gap:14px;}
.spa-tabs .gym-tab{width:100%;justify-content:flex-start;text-align:left;font-size:18px;padding:16px 20px;border-radius:22px;}
.spa-tabs .gym-tab.active{background:var(--accent-3);color:#fff;}
@media (max-width:860px){
  .spa-grid{grid-template-columns:1fr;}
  .spa-tabs{flex-direction:row;flex-wrap:wrap;}
  .spa-tabs .gym-tab{flex:1 0 calc(50% - 8px);text-align:center;}
}

/* SPA slider (наследует общие стрелки .gym-arrow) */
.spa-slider{position:relative;border-radius:28px;overflow:hidden;width:100%;}
.spa-slider .gym-viewport{contain:layout paint size;overflow:hidden;border-radius:18px;position:relative;z-index:1;display:block;width:100%;aspect-ratio:16/9;max-height:560px;}
.spa-slider .gym-track{display:flex;will-change:transform;transition:transform .35s ease;gap:clamp(8px,1.4vw,14px);}
.spa-slider .gym-slide{flex:0 0 100%;min-width:100%;height:auto;display:grid;border-radius:18px;overflow:hidden;}
.spa-slider .gym-slide img{pointer-events:none;width:100%;height:100%;object-fit:cover;border-radius:18px;}
.spa-slider .gym-prev{left:12px;}
.spa-slider .gym-next{right:12px;}

/* ================= Modal ================= */
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:50;}
.modal.show{display:flex;}
.modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55);}
.modal__content{position:relative;z-index:1;width:min(520px,92vw);background:#fff;border-radius:20px;box-shadow:var(--shadow);padding:22px 20px;animation:pop .2s ease;}
@keyframes pop{from{transform:translateY(6px) scale(.98);opacity:.7;}to{transform:none;opacity:1;}}
.modal__close{position:absolute;top:10px;right:10px;background:transparent;border:0;font-size:20px;cursor:pointer;}
.modal__title{margin:2px 0 10px;font-size:22px;font-weight:800;color:#202020;}
.modal__text{margin:0 0 16px;color:#333;}
.modal__btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 18px;border-radius:999px;background:#5b46c6;color:#fff;text-decoration:none;font-weight:800;margin:0 auto;}
.modal.success .modal__title{color:var(--ok);}
.modal.error .modal__title{color:var(--err);}

/* ================= Reveal ================= */
.reveal{opacity:1;transform:none;}
.reveal.in{opacity:1;transform:none;transition:none;}
@media (prefers-reduced-motion:reduce){.reveal,.reveal.in{opacity:1;transform:none;transition:none;}}

/* ================= Footer ================= */
.site-footer{padding:28px 0;}
.footer-card{background:#e9ebef;border-radius:28px;padding:min(4vw,28px);display:grid;grid-template-columns:1.2fr .8fr 1.2fr;gap:22px;align-items:start;overflow:hidden;contain:layout paint;}
.footer-logo img{max-width:200px;height:auto;display:block;}
.footer-left,.footer-actions,.footer-map{min-width:0;}
.footer-left p{margin:10px 0;color:#6c6c6c;}
.footer-actions{display:flex;flex-direction:column;gap:14px;align-items:center;}
.btn-phone{background:#fff;border:1.5px solid rgba(0,0,0,.25);color:#1d4ed8;font-weight:800;padding:14px 24px;min-width:220px;text-align:center;max-width:100%;box-sizing:border-box;}
.footer-vk{font-size:20px;}
.footer-map-title{margin:6px 0 10px;font-size:20px;font-weight:800;color:#505050;text-align:left;overflow-wrap:anywhere;word-break:break-word;}
.footer-map-embed{background:#fff;border-radius:12px;overflow:hidden;box-shadow:var(--shadow);}
.footer-map-embed iframe{width:100% !important;height:300px;display:block;border:0;}

.footer-links{
  display:flex;flex-wrap:wrap;gap:14px 22px;justify-content:center;margin:16px;text-align:center;
  align-items:baseline;
}
.footer-links a{
  padding:0;background:none;box-shadow:none;text-decoration:underline;border-radius:0;color:#6c6c6c;
  display:inline-block;line-height:1.2;vertical-align:baseline;text-underline-offset:2px;
}
.footer-links a:hover{transform:none;box-shadow:none;text-decoration:underline;}

@media (max-width:980px){
  .footer-card{grid-template-columns:1fr;gap:18px;text-align:center;}
  .footer-logo{margin:0 auto;display:block;}
  .footer-map-title{text-align:center;}
  .footer-logo img{margin-left: auto; margin-right: auto;}
}
@media (max-width:900px){
  .footer-left{text-align:center;}
  .footer-actions{align-items:center;}
  .footer-logo{margin-inline:auto;}
}
@media (max-width:560px){
  .footer-links{flex-direction:column;align-items:center;gap:10px;}
}

/* Yandex map helpers */
.ymap-embed{position:relative;overflow:hidden;}
.ymap-embed a{position:absolute;left:0;color:#eee;font-size:12px;line-height:1;}
.ymap-embed a:first-child{top:0;}
.ymap-embed a.ymap-sub{top:14px;}
.ymap-embed iframe{width:100%;height:300px;border:0;display:block;}

/* ================= Success Banner (top padding for close icon) ================= */
/* Fade/slide for show/hide */
@keyframes bannerIn{from{opacity:0;transform:translateY(12px) scale(.98);}to{opacity:1;transform:none;}}
.success-banner{opacity:0;transform:translateY(8px);transition:opacity .28s ease,transform .28s ease;pointer-events:none;padding:28px 0;}
.success-banner.show{opacity:1;transform:none;pointer-events:auto;animation:bannerIn .28s ease-out;}
.success-banner.hiding{opacity:0;transform:translateY(8px);}

.success-card{
  --close:36px;
  position:relative;background:#ECEEF1;border-radius:28px;box-shadow:var(--shadow);
  display:grid;grid-template-columns:1.1fr .9fr;grid-template-areas:"left right";
  align-items:center;gap:24px;
  padding:calc(16px + var(--close) + 10px) clamp(14px,5vw,40px) 0 clamp(14px,5vw,40px);
  overflow:hidden;
}
.success-left{grid-area:left;color:#1d1d1f;}
.success-title{margin:0 0 10px;font-weight:800;font-size:clamp(28px,4vw,48px);line-height:1.1;}
.success-text{margin:0 0 16px;color:#4a4a4a;font-size:clamp(14px,1.6vw,18px);}
.success-btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 18px;border-radius:999px;background:#5b46c6;color:#fff;text-decoration:none;font-weight:800;box-shadow:0 10px 24px rgba(91,70,198,.25);transition:transform .2s ease,box-shadow .2s ease;}
.success-btn:hover{transform:translateY(-1px);box-shadow:0 14px 30px rgba(91,70,198,.28);}

.success-right{grid-area:right;position:relative;min-height:clamp(260px,28vw,520px);}
.success-right img{
  position:absolute;right:min(5vw,40px);bottom:0;height:100%;width:auto;max-width:none;object-fit:contain;pointer-events:none;z-index:1;
}

.success-close{
  position:absolute;top:12px;right:12px;width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;border:1px solid rgba(0,0,0,.08);background:rgba(255,255,255,.7);backdrop-filter:blur(8px);color:#333;cursor:pointer;z-index:3;
}
.success-close:hover{transform:scale(1.05);}
.success-close svg{width:18px;height:18px;}

/* Mobile */
@media (max-width:860px){
  .success-card{
    grid-template-columns:1fr;
    grid-template-areas:
      "left"
      "right";
    grid-template-rows:auto auto;
    text-align:center;
    padding:calc(12px + var(--close) + 8px) 12px 0;
  }
  .success-left{padding:4px 0 6px;}
  .success-title{margin:6px 0 6px;font-size:clamp(22px,6vw,28px);}
  .success-text{margin:0 0 10px;font-size:clamp(13px,3.7vw,16px);}
  .success-right{min-height:clamp(220px,40vh,360px);}
  .success-right img{left:50%;transform:translateX(-50%);right:auto;width:auto;height:100%;bottom:0;top:auto;}
  .success-close{top:10px;right:10px;}
}

/* ================= Unified slider arrows + CTA dot ================= */
/* Единственная версия стрелок для обоих слайдеров: .gym-arrow / .gym-prev / .gym-next */
.gym-arrow{
  position:absolute; top:50%; transform:translateY(-50%);
  width:46px; height:46px; border-radius:50%;
  background:
    radial-gradient(circle at 30% 30%, #ffffff 0%, #fdfdff 60%, #f7f7ff 100%) padding-box,
    linear-gradient(135deg,var(--accent-2),var(--accent)) border-box;
  border:2px solid transparent;
  box-shadow:0 10px 26px rgba(111,107,213,.25);
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  color:var(--accent);
  z-index:2; font-size:0; line-height:1;
  transition:transform .18s ease, box-shadow .18s ease, opacity .2s ease;
}
.gym-arrow::before{
  content:"";
  width:16px; height:16px; display:block; background:currentColor;
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%23000' d='M8.12 4.12a1 1 0 0 1 1.41 0l7 7a1 1 0 0 1 0 1.41l-7 7a1 1 0 1 1-1.41-1.41L14.3 12 8.12 5.53a1 1 0 0 1 0-1.41z'/></svg>") no-repeat center / contain;
          mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%23000' d='M8.12 4.12a1 1 0 0 1 1.41 0l7 7a1 1 0 0 1 0 1.41l-7 7a1 1 0 1 1-1.41-1.41L14.3 12 8.12 5.53a1 1 0 0 1 0-1.41z'/></svg>") no-repeat center / contain;
}
.gym-prev{ left:12px; }
.gym-next{ right:12px; }
.gym-prev::before{ transform:rotate(180deg); }

.gym-arrow:hover{ transform:translateY(-50%) scale(1.05); box-shadow:0 14px 34px rgba(111,107,213,.32); }
.gym-arrow[disabled]{ opacity:0; pointer-events:none; visibility:hidden; }

/* Мобильное скрытие стрелок: одно правило для везде */
@media (max-width:860px){ .gym-arrow{ display:none; } }

/* CTA pill-dot — единая версия (без дублей) */
.pill-dot{
  width:72px;
  height:72px;
  flex:0 0 72px;
  border-radius:50%;
  background:#fff;
  display:grid; place-items:center;
  line-height:1;
  position:relative; overflow:hidden;
  box-shadow:0 6px 18px rgba(0,0,0,.12);
}
.pill-dot .pill-arrow{ display:block; width:28px; height:28px; }
.cta-pill:hover .pill-arrow{ transform:translateX(2px); transition:transform .18s ease; }


.cta-pill:hover 

/* ================= Interaction hygiene ================= */
/* Не даём перетаскивать/выделять интерактив */
img, svg, button, .gym-slider, .spa-slider, .gym-viewport, .gym-track, .gym-slide, .spa-slider .gym-slide,
.gym-thumbs, .spa-tabs, .gym-tabs, .plan-card, .cta-pill, .plan-btn{
  -webkit-user-drag:none;
  user-select:none;
}
.gym-slide img, .spa-slider .gym-slide img{ pointer-events:none; -webkit-user-drag:none; }



/* Buy modal layout based on trial-card */
.modal.modal--trial .modal__content{
  width:min(1000px,96vw);
  background:transparent;
  padding:0;
  box-shadow:none;
}
.modal.modal--trial .trial-card{ margin:0; }
.modal.modal--trial .modal__close{ position:absolute; top:10px; right:10px; z-index:5; }

/* Prevent page scroll when any modal is open (using body.no-scroll already in project) */
body.no-scroll{ overflow:hidden; }



/* Rounded select in trial/buy */
.trial-inputs select{
  appearance:none; -webkit-appearance:none; -moz-appearance:none;
  background:#fff;
  color:#000;
  border:0;
  border-radius:999px;
  padding:12px 42px 12px 14px;
  font-size:16px;
  box-shadow:0 0 0 0 rgba(0,0,0,0);
  transition:box-shadow .2s ease;
}
.trial-inputs select:focus{ outline:none; box-shadow:0 0 0 3px rgba(91,70,198,.25); }
.trial-inputs select.error{ outline:3px solid rgba(198,40,40,.7); }
/* custom dropdown arrow */
.trial-inputs select{
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M6 9l6 6 6-6' fill='none' stroke='%236c6c6c' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat;
  background-position: right 14px center;
  background-size: 16px 16px;
}


/* Buy modal text wrapping fix */
.modal.modal--trial .trial-left{ max-width: 640px; }
.modal.modal--trial .trial-check{
  white-space:normal;
  word-break:break-word;
  overflow-wrap:anywhere;
  text-align:left;
}
/* place the close button like success banner */
.modal.modal--trial .success-close{
  position:absolute; top:12px; right:12px;
  z-index:5;
}


/* Wide-screen width cap for gym slider */


/* Thumbs strict 16:9 */
.gym-thumb{ aspect-ratio:16/9; height:auto; }
.gym-thumb img{ width:100%; height:100%; object-fit:cover; }

@media (max-width:980px){
  .price-badge{ margin-left:-25px; }
 
}

.gym-thumb:hover{ transform:translateY(-2px); box-shadow:0 12px 24px rgba(0,0,0,.16); }
/* Modal exit animation */
.modal__backdrop{ opacity:1; transition:opacity .22s ease; }
.modal.hiding .modal__backdrop{ opacity:0; }
.modal__content{ transition:transform .22s ease, opacity .22s ease; }
.modal.hiding .modal__content{ transform:translateY(6px) scale(.98); opacity:0; }


/* === Modal fit fix (respect header height & viewport) === */
.modal{
  /* Keep content out from under the fixed header */
  padding: calc(var(--header-h) + 12px) 16px 16px;
}
/* Scroll inside the dialog if needed and cap height to viewport minus header */
.modal__content{
  max-height: calc(100dvh - var(--header-h) - 32px);
  overflow: auto;
}
@supports not (height: 100dvh){
  .modal__content{ max-height: calc(100vh - var(--header-h) - 32px); }
}

/* ===== Trial Light Variant (reusable) ===== */
.trial--light .trial-card{
  background: linear-gradient(90deg,rgba(217, 225, 255, 1) 10%, rgba(235, 239, 255, 1) 90%);
  color:var(--accent-3);
}
.trial--light .trial-left h2{ color:var(--accent-3); }
.trial--light .trial-left p{ color:var(--accent-3); }
.trial--light .trial-inputs input{
  background:#fff; color:var(--accent-3);
  border:1px solid rgba(0,0,0,.08);
}
.trial--light .trial-check a{
  color: var(--accent);
  text-decoration: underline;
}
.trial--light .trial-btn{
  background: linear-gradient(135deg, var(--accent-2), var(--accent));
  color:#fff;
  box-shadow: 0 10px 24px rgba(111,107,213,.28);
}
@media (max-width:860px){
  .trial--light .trial-card{ text-align:center; }
}

/* ===== Trial Dark Variant (explicit for trial3) ===== */
.trial--dark .trial-card{
  background:linear-gradient(270deg,var(--accent-2) 0%,var(--accent) 100%);
  color:#fff;
}
.trial--dark .trial-left h2{ color:#fff; }
.trial--dark .trial-left p{ color:#fff; }
.trial--dark .trial-inputs input{
  background: #fff;
  color:#000;
  border:1px solid rgba(255,255,255,.28);
}

.trial--dark .trial-check a{color:#fff;text-decoration:underline;}


.trial--dark .trial-btn{
  background: linear-gradient(135deg, #FF7A45, #F2591D);
  color:#fff;
  box-shadow: 0 12px 28px rgba(0,0,0,.35);
}

/* ===== Sales overlay (hover/tap) ===== */
.sales{padding:24px 0;}
.sales-head h2{margin:0 0 14px;font-size: clamp(40px, 5vw, 60px);color:var(--text);font-weight:800;}
.sales-list{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.sale-card{position:relative;overflow:hidden;border-radius:24px;box-shadow:var(--shadow);min-height:340px;color:#fff;display:flex;align-items:flex-start;justify-content:space-between;padding:18px 18px 0 18px;isolation:isolate;transition:transform .2s ease, box-shadow .25s ease;}
.sale-card:hover{transform:translateY(-2px); box-shadow:0 18px 40px rgba(0,0,0,.18);}
.sale-content{position:relative;z-index:2;display:flex;flex-direction:column;gap:10px;width:100%;}
.sale-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;}
.sale-title{margin:0;font-size:clamp(20px,2.4vw,26px);font-weight:800;line-height:1.15;letter-spacing:.2px;}
.sale-badge{background:rgba(255,255,255,.2);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.35);color:#fff;font-weight:800;border-radius:999px;align-self:flex-start; padding:8px 14px;white-space:nowrap;box-shadow:0 6px 18px rgba(0,0,0,.15);}
.sale-image{position:absolute;inset:auto 0 0 0;display:grid;place-items:end center;z-index:1;pointer-events:none;}
.sale-image img{width:min(82%,520px);height:auto;object-fit:contain;transform:translateY(4px);}
@media (max-width:959px){
  .sales-list{display:flex;gap:12px;overflow-x:auto;padding:4px 2px 8px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;}
  .sales-list>.sale-card{scroll-snap-align:center;min-width:86vw;}
  .sales-list::-webkit-scrollbar{height:0;}
}
.sales-dots{display:none;}
@media (max-width:959px){
  .sales-dots{display:flex;justify-content:center;gap:10px;margin-top:12px;}
  .sales-dots button{width:10px;height:10px;border-radius:50%;border:0;padding:0;background:#d9d9e9;position:relative;transition:transform .2s ease,background .2s ease,opacity .2s ease;}
  .sales-dots button.active{background:linear-gradient(135deg,var(--accent-2),var(--accent));transform:scale(1.25);}
  .sales-dots button.active::after{content:"";position:absolute;inset:-6px;border-radius:50%;animation:dotPulse 1.6s ease-out infinite;}
}
.sale-overlay{
  position:absolute; inset:0; display:flex; flex-direction:column; gap:12px; 
  justify-content:flex-end; padding:18px; z-index:3; 
  background:linear-gradient(180deg, rgba(0,0,0,0) 20%, rgba(0,0,0,.5) 70%, rgba(0,0,0,.7) 100%);
  color:#fff; opacity:0; transform:translateY(8px); pointer-events:none;
  transition:opacity .22s ease, transform .22s ease;
}

/* стеклянная плашка описания */
.sale-desc{
  display:inline-block;
  margin:0;
  padding:12px 16px;
  border-radius:16px;
  color:var(--accent-3);
  background:linear-gradient(180deg, var(--glass-bg-1), var(--glass-bg-2));
  border:1px solid var(--glass-br);
  box-shadow:var(--glass-shadow);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  max-width:min(92%,640px);
  line-height:1.45;
  font-size:clamp(14px,1.9vw,16px);
  white-space:pre-line; /* переносы строк из данных */
}

/* небольшой зазор между плашкой и кнопкой */
.sale-overlay .sale-btn{ margin-top:10px; }

.sale-btn{
  align-self:flex-start; border:0; border-radius:999px; padding:10px 16px; font-weight:800; 
  background:linear-gradient(135deg, var(--accent-2), var(--accent));
  color:#fff; cursor:pointer; box-shadow:0 10px 22px rgba(0,0,0,.22);
  transition:transform .18s ease, box-shadow .18s ease, opacity .18s ease;
}
.sale-btn:hover{transform:translateY(-1px); box-shadow:0 16px 32px rgba(0,0,0,.28);}
@media (pointer:fine){
  .sale-card:hover .sale-overlay,
  .sale-card:focus-within .sale-overlay{ opacity:1; transform:translateY(0); pointer-events:auto; }
}
@media (max-width:959px){
  .sale-overlay{justify-content:flex-end; background:linear-gradient(180deg, rgba(0,0,0,.05) 0%, rgba(0,0,0,.55) 70%);}
  .sale-card.show-info .sale-overlay{opacity:1; transform:translateY(0); pointer-events:auto;}
}
/* Gradient classes */
.sale-g1{background:linear-gradient(270deg,#C9C5FF 0%,#8D87F5 100%);}
.sale-g2{background:linear-gradient(270deg,#FFC59E 0%,#FF8A5C 100%);}
.sale-g3{background:linear-gradient(270deg,#B6F17A 0%,#26F0C2 100%);}
.sale-g4{background:linear-gradient(270deg,#C7A7FF 0%,#8B5CE6 100%);}
.sale-g5{background:linear-gradient(270deg,#34D6E0 0%,#6BE9D9 100%);}
.sale-g6{background:linear-gradient(270deg,#FFA0C8 0%,#FF85A1 100%);}


/* Extra gradient classes to match admin presets */
.sale-g7{background:linear-gradient(270deg,#74C0FF 0%,#3DEDFF 100%);}   /* Сапфир */
.sale-g8{background:linear-gradient(270deg,#FFB75E 0%,#FFE08B 100%);}   /* Сансет */
.sale-g9{background:linear-gradient(270deg,#375A7F 0%,#6CB7CC 100%);}   /* Глубокое море */
.sale-g10{background:linear-gradient(270deg,#2E7D68 0%,#9AD1A0 100%);}  /* Лесная хвоя */
.sale-g11{background:linear-gradient(270deg,#FFA074 0%,#FF6E6E 100%);}  /* Кораллы */
.sale-g12{background:linear-gradient(270deg,#AEB8C2 0%,#F2F5F7 100%);}  /* Графит */
/* Show overlay when unhidden via JS (keyboard focus / mobile tap) */
.sale-overlay[aria-hidden="false"]{opacity:1; transform:translateY(0); pointer-events:auto;}

/* -- bumped sizes for sales -- */
.sale-badge{ font-size: clamp(14px, 1.6vw, 18px); padding: 10px 16px; }
.sale-btn{ font-size: clamp(14px, 1.6vw, 18px); padding: 12px 18px; }
@media (max-width: 959px){
  .sale-badge{ font-size: 15px; padding: 10px 16px; }
  .sale-btn{ font-size: 16px; padding: 13px 18px; }
}

/* Improve mobile tap behavior */
.sale-card{ touch-action: manipulation; }


/* === Responsive multi-card widths for mid (square-ish) screens ===
   Show more than 1 card between ~470px and 959px width, while keeping horizontal scroll.
   We override previous min-width:86vw to a flexible basis so 2–3 cards can fit. */
@media (min-width:470px) and (max-width:959px){
  .plans-list > .plan-card,
  .sales-list > .sale-card{
    flex: 0 0 clamp(280px, 44vw, 420px);
    min-width: auto; /* cancel earlier 86vw */
  }
}



@media (min-width:861px) and (max-width:1045px){
  /* trial2 (light) */
  section.trial.trial--light .trial-right{
    display:flex; flex-direction:column; justify-content:flex-end;
  }
  section.trial.trial--light .trial-right img{
    align-self:flex-end;
  }
}
@media (min-width:861px) and (max-width:961px){
  /* buy modal's trial-card */
  .modal--trial .trial-right{
    display:flex; flex-direction:column; justify-content:flex-end;
  }
  .modal--trial .trial-right img{
    align-self:flex-end;
  }
}



/* === Generic bottom-anchored trial image (no hard breakpoints) ===
   Stretch the right column to the grid row height and align its content to the bottom.
   Works for trial (dark), trial--light, and modal .modal--trial since they reuse .trial-right. */
.trial-card{ /* keep existing layout, just ensure row equal height via item override */
  /* no change to grid here; per-item override below */
}
.trial-right{
  align-self:stretch;              /* stretch this grid item even if the row uses align-items:center */
  display:grid;                    /* create a grid context */
  align-content:end;               /* push child(ren) to the bottom of this area */
  justify-content:center;          /* center horizontally */
}
.trial-right img{
  max-height:100%;
  width:auto;
  object-fit:contain;
  align-self:end;
  justify-self:center;
}



/* ================= Promo Banner (overlay) ================= */
.promo-overlay{ position:fixed; inset:0; display:none; align-items:center; justify-content:center; background:rgba(0,0,0,.55); z-index:9999; padding:20px; min-height:100dvh; }
.promo-overlay.show{ display:flex; }
.promo-card{
  position:relative; width:min(1020px,96vw); min-height:420px;
  border-radius:28px; box-shadow: var(--shadow); overflow:hidden;
  padding:20px 20px 0 20px; color:#fff; isolation:isolate;
}
.promo-card .success-close{ position:absolute; top:12px; right:12px; z-index:5; }
.promo-card .sale-image img{ width:min(86%,620px); }
.promo-overlay .promo-backdrop{ position:absolute; inset:0; background:transparent; }

/* Small screens: stack nicely */
@media (max-width: 680px){
  .promo-card{ min-height: 360px; padding: 16px 16px 0 16px; }
  .promo-card .sale-image img{ width:min(92%,560px); }
}

/* Enter/leave animation */
@keyframes promoIn{ from{ opacity:0; transform: translateY(10px) scale(.98);} to{ opacity:1; transform:none; } }
.promo-overlay.show .promo-card{ animation: promoIn .24s ease-out; }

html.no-scroll{ overflow:hidden; }


/* -- Promo hardening -- */
.promo-overlay.show{ display:flex; }
.promo-overlay .promo-card{ margin:auto; }

/* Some themes set body as flex: ensure overlay covers screen */
body { position: relative; }



/* ==== Promo overlay layout overrides ==== */
.promo-card{ 
  display:grid; grid-template-columns: 1.05fr .95fr; grid-template-areas: "content image";
  align-items:stretch; grid-auto-rows: 1fr; /* rows only matter on 2-col layout */
  padding: clamp(14px, 3.4vw, 24px) clamp(14px, 4vw, 28px) 0 clamp(14px, 4vw, 28px);
}
.promo-card .sale-image{ grid-area: image; position: relative; inset: auto; align-self:stretch; display:flex; align-items:flex-end; justify-content:center; min-height: 0; }
.promo-card .sale-image img{ max-height: min(72vh, 100%); width: auto; height: auto; object-fit: contain; }

/* Description must always be visible (no hover), keep glass look */
.promo-card .sale-overlay{
  position: static; 
  opacity: 1; transform: none; pointer-events: auto; 
  background: none; padding: 0; 
}

/* Mobile: stack content above image */
@media (max-width: 700px){
  .promo-card{
    grid-template-columns: 1fr;
    grid-template-areas: "content" "image";
    grid-auto-rows: auto;            /* no forced 1fr rows -> нет пустот */
    align-items: start;
    row-gap: clamp(10px, 2.6vw, 18px);
    min-height: 0;
  }
  .promo-card .sale-content{ padding-bottom: 0px; }
  .promo-card .sale-image{ align-items:flex-end; justify-content:center; }
  .promo-card .sale-image img{ max-height: min(46vh, 100%); height:auto; }
}


/* ==== Promo overlay type scale ==== */
.promo-card .sale-content{ grid-area: content; align-self:start; display:flex; flex-direction:column; gap: clamp(8px, 1.4vw, 16px); padding-bottom: 28px; }
.promo-card .sale-top{ display:flex; flex-direction:column; align-items:flex-start; gap: clamp(6px, 1vw, 10px); }
.promo-card .sale-title{ font-weight: 800; line-height:1.05; letter-spacing:-0.01em; 
  font-size: clamp(28px, 4.8vw, 56px); 
  text-wrap: balance;
}
.promo-card .sale-badge{ display:inline-block; border-radius:999px; 
  padding: clamp(6px, .9vw, 10px) clamp(12px, 1.2vw, 16px);
  font-size: clamp(16px, 2.2vw, 28px); font-weight:700; 
  background: rgba(255,255,255,.18); backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,.3);
}
.promo-card .sale-desc{ font-size: clamp(16px, 1.8vw, 22px); line-height: 1.45; max-width: 56ch; }
.promo-card .sale-btn{ font-size: clamp(16px, 1.8vw, 20px); padding: clamp(12px, 1.4vw, 16px) clamp(18px, 2vw, 22px); border-radius: 999px; }


/* === FIX: Promo overlay mid-width gap (≈490–700px) ===
   Remove forced min-height and prevent grid track stretch so content+image pack tightly.
   Keep image bottom-anchored with a sensible max-height to avoid overflow. */
@media (min-width:490px) and (max-width:700px){
  .promo-card{ 
    min-height:auto; 
    align-content:start; 
    grid-auto-rows:auto; 
  }
  .promo-card .sale-image{ align-items:flex-end; }
  .promo-card .sale-image img{ max-height: clamp(220px, 48vh, 420px); }
}


/* --- Fix: iOS Safari grid + object-fit bug on mobile (images not rendering) --- */
@media (max-width:860px){
  .trial-card{ min-height: 0; } /* allow row to shrink correctly */
  .trial-right{
    display:flex;                /* use flex on mobile for stable painting */
    align-items:flex-end;
    justify-content:center;
    min-height: clamp(220px, 46vw, 420px);
  }
  .trial-right img{
    width: min(92%, 560px);
    height: auto;
    max-height: 100%;
    object-fit: contain;
  }
}


/* --- Ultra-narrow safety for hero & badge --- */
@media (max-width:420px){
  .hero-card{ min-height:auto; }
  .price-badge{ transform: rotate(16deg); }
}


/* === (New) Pretty selects (rounded + shadow) site-wide === */
select{
  appearance:none; -webkit-appearance:none; -moz-appearance:none;
  background:#fff;
  border:0;
  border-radius:14px;
  padding:12px 42px 12px 14px;
  font-size:16px;
  box-shadow:0 8px 22px rgba(0,0,0,.08);
  transition:box-shadow .2s ease;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24'><path d='M7 10l5 5 5-5' fill='none' stroke='%23333' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat; background-position:right 14px center; background-size:20px;
}
select:focus{ outline:none; box-shadow:0 0 0 3px rgba(91,70,198,.18); }

/* === Nice Select (custom dropdown) === */
.nice-select{ position:relative; display:inline-flex; align-items:center; gap:8px; min-width: 180px; }
.nice-select__button{
  display:flex; align-items:center; justify-content:space-between;
  width:100%; background:#fff; border:1px solid rgba(0,0,0,.12); border-radius:12px;
  padding:10px 36px 10px 12px; font-size:14px; line-height:1.3;
  box-shadow:0 8px 20px rgba(0,0,0,.06); cursor:pointer;
}
.nice-select__button:focus{ outline:none; border-color:rgba(91,70,198,.45); box-shadow:0 0 0 3px rgba(91,70,198,.18); }
.nice-select__caret{ position:absolute; right:10px; top:50%; transform:translateY(-50%); pointer-events:none; width:18px; height:18px; }
.nice-select__caret svg{ width:18px; height:18px; display:block; }
.nice-select[aria-expanded="true"] .nice-select__caret{ transform:translateY(-50%) rotate(180deg); }

.nice-select__menu{
  position:absolute; left:0; right:0; top:calc(100% + 6px);
  background:#fff; border:1px solid rgba(0,0,0,.08); border-radius:20px;
  box-shadow:0 18px 42px rgba(13,18,30,.22); padding:6px; margin:0;
  list-style:none; max-height:280px; overflow:auto; z-index:1002;
  display:none;
}
.nice-select[aria-expanded="true"] .nice-select__menu{ display:block; }
.nice-select__option{
  display:flex; align-items:center; gap:8px; width:100%;
  border-radius:10px; padding:9px 10px; cursor:pointer; user-select:none;
  font-size:14px;
}
.nice-select__option[aria-selected="true"]{ font-weight:700; }
.nice-select__option:hover, .nice-select__option:focus{ background:#f2f3fb; outline:none; }

/* Compact modifier (auto-applied when original select is narrow) */
.nice-select--compact .nice-select__button{ padding:8px 32px 8px 10px; font-size:16px; }
.nice-select--compact .nice-select__option{ padding:8px 8px; font-size:16px; color: #000; }

/* Hide the original select but keep it accessible for forms & screen readers */
.select--upgraded{
  position:absolute !important; inset:0 auto auto 0 !important; width:1px !important; height:1px !important;
  padding:0 !important; margin:-1px !important; overflow:hidden !important; clip:rect(0 0 0 0) !important;
  white-space:nowrap !important; border:0 !important;
}

/* === Generic pretty native select (fallback) === */
select.inp, select{
  background-color:#fff; border-radius:12px; border:1px solid rgba(0,0,0,.12);
  padding:10px 36px 10px 12px; appearance:none; -webkit-appearance:none; -moz-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M6 9l6 6 6-6' fill='none' stroke='%236c6c6c' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat; background-position:right 12px center; background-size:16px 16px;
}
select.inp:focus, select:focus{ outline:none; border-color:rgba(91,70,198,.45); box-shadow:0 0 0 3px rgba(91,70,198,.18); }


/* === Harmonize custom select with pill inputs inside .trial-inputs === */
.trial-inputs .nice-select{ flex:1; min-width:160px; }
.trial-inputs .nice-select__button{
  background:#fff;
  color:#000;
  border:0;
  border-radius:999px;
  padding:12px 42px 12px 14px;
  font-size:16px;
  box-shadow:0 0 0 0 rgba(0,0,0,0);
  transition:box-shadow .2s ease;
}
.trial-inputs .nice-select__button:focus{
  outline:none;
  box-shadow:0 0 0 3px rgba(91,70,198,.25);
}
.trial-inputs .nice-select__caret{ right:16px; }

.nice-select__value{display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}


/* === Hero ticker (inside .hero-card, 20px from bottom) === */
.hero-ticker{
  position:absolute; left:0; right:0; bottom:20px; z-index:6;
  pointer-events:none; overflow:hidden;
}
.hero-ticker__track{
  display:flex; align-items:center;
  white-space:nowrap;
  will-change:transform;
  padding-inline:20px;
  color:#fff; font-weight:500; letter-spacing:.06em; text-transform:uppercase;
  text-shadow:0 2px 6px rgba(0,0,0,.25);
  opacity:.96;
  animation:none !important;
}
.hero-ticker__item{opacity:.96}
@keyframes heroMarquee{
  from{ transform:translateX(0); }
  to{ transform:translateX(-50%); }
}
/* pause on reduced motion */
@media (prefers-reduced-motion:reduce){
  .hero-ticker__track{
  display:flex; align-items:center;
  white-space:nowrap;
  will-change:transform;
  padding-inline:20px;
  color:#fff; font-weight:500; letter-spacing:.06em; text-transform:uppercase;
  text-shadow:0 2px 6px rgba(0,0,0,.25);
  opacity:.96;
  animation:none !important;
}
}
/* soft edge fade */
.hero-ticker::before,.hero-ticker::after{
  content:""; position:absolute; top:0; bottom:0; width:40px; pointer-events:none;
}
.hero-ticker::before{ left:0; background:linear-gradient(90deg, rgba(0,0,0,.0), rgba(0,0,0,.0)); }
.hero-ticker::after{ right:0; background:linear-gradient(270deg, rgba(0,0,0,.0), rgba(0,0,0,.0)); }


/* === Nice Select portal (menu detached to body for overflow-clip ancestors) === */
.nice-select__menu--portal{
  position:fixed !important; left:0; top:0; right:auto; bottom:auto;
  max-height:none; overflow:visible; z-index: 2000;
  /* same aesthetics */
  background:#fff; border-radius:20px; box-shadow:0 18px 42px rgba(13,18,30,.22);
}


.hero-ticker__group{
  display:flex; align-items:center; gap:40px; flex-shrink:0;
}

/* === [PATCH] Plans: equal heights + fixed icon size and button pinned bottom === */
.plans-list{ align-items: stretch; }
.plan-card{ display: flex; flex-direction: column; }
.plan-ico{ flex-shrink: 0; min-width: 75px; min-height: 75px; }
.plan-btn{ margin-top: auto; } /* already present, ensure last wins */
/* Ensure titles wrap without shrinking icon */
.plan-top h3{ flex: 1 1 auto; min-width: 0; }
/* (Optional) make each grid item stretch full height of its track */
.plans-list > .plan-card{ height: 100%; }


/* === [FIX] Plans carousel: force equal heights and remove top gaps on shorter cards === */
@media (max-width: 959px){
  .plans-list{ align-items: stretch; }
}
.plan-card{ display:flex; flex-direction:column; height:100%; }
.plan-top h3{ flex:1 1 auto; min-width:0; }
.plan-ico{ flex-shrink:0; }
.plan-btn{ margin-top:auto; }



/* Tariff price display */
.plan-price{font-size:35px;font-weight:500;color:var(--accent-3);margin:6px 0 18px;}

/* ==== GYM slider: show photo fully inside 16:9 without cropping; blurred cover bg behind ==== */
.gym-viewport{ aspect-ratio: 16 / 9; }
.gym-slide{ position: relative; }
.gym-slide .gym-bg{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  filter: blur(20px);
  transform: scale(1.08);
  opacity: .35;
  border-radius: 18px;
}
.gym-slide .gym-img{
  position: relative; z-index: 1;
  width: 100%; height: 100%;
  object-fit: contain !important; /* override older cover rule */
  border-radius: 18px;
  background: transparent;
}


/* ==== GYM slider top-strip fix: ensure slides fill viewport height and remove inline gaps ==== */
#gymSlider .gym-viewport,
#gymSlider .gym-track,
#gymSlider .gym-slide{ height:100%; }
#gymSlider .gym-slide{
  padding:0; margin:0;
  display:block;
  overflow:hidden;
  background: transparent;
}
#gymSlider .gym-slide img{ display:block; }
#gymSlider .gym-slide .gym-bg{ position:absolute; inset:0; }
#gymSlider .gym-slide .gym-img{ width:100%; height:100%; object-fit:contain !important; }


/* ==== GYM blurred bg tuning: richer colors, less white peeking through ==== */
#gymSlider .gym-slide .gym-bg{
  opacity: .65;                    /* was ~.35 */
  transform: scale(1.12);          /* cover edges stronger */
  filter: blur(16px) saturate(1.15) contrast(1.05);
}



/* ================= FAQ ================= */
.faq{ padding: 36px 0 48px; }
.faq-title{ margin:0 0 18px; font-size: clamp(40px, 5vw, 60px); font-weight: 800; color: var(--text); }
.faq-tabs{ display:flex; gap:12px; flex-wrap:wrap; margin-bottom:18px; }
.faq-tab{ padding:10px 14px; border-radius:999px; font-size: 18px; background:#fff; border:1px solid rgba(0,0,0,.08); box-shadow:0 2px 8px rgba(0,0,0,.05); font-weight:700; color:#2f2661; cursor:pointer; }
.faq-tab.active{ background:#2f2661; color:#fff; }
.faq-content{ display:grid; gap:12px; }
.faq-item{ background:#fff; border:1px solid rgba(0,0,0,.08); border-radius:40px; box-shadow:0 2px 12px rgba(0,0,0,.04); overflow:hidden; }
.faq-q{ width:100%; background:transparent; border:0; display:flex; align-items:center; justify-content:space-between; padding:18px 18px 18px 24px; font-size:18px; font-weight:800; color:#2f2661; cursor:pointer; text-align: left;}
.faq-q .plus{ min-width:28px; height:28px; stroke:#6a45d1; }
.faq-q[aria-expanded="true"] .plus{ transform:rotate(45deg); transition:transform .2s ease; }
.faq-a{ padding:0px 18px 0px 24px; overflow:hidden; height:0; font-size: 18px; font-weight: 400; opacity:0; display:block; will-change:height,opacity; contain:layout; }

.faq-empty{ color:#777; }

/* --- Admin FAQ rows --- */
.card.faq-tab .faq-qa{ display:flex; flex-direction:column; gap:10px; margin:10px 0; }
.card.faq-tab .qa-row{ display:grid; grid-template-columns: minmax(200px, 1fr) 2fr auto; gap:8px; align-items:start; }
.card.faq-tab .qa-row .qa-actions button{ border:0; padding:8px 10px; border-radius:8px; background:#ece9ff; color:#352b78; font-weight:800; cursor:pointer; }
.card.faq-tab .qa-row .qa-actions{ display:flex; gap:6px; }
.card.faq-tab .hint{ color:#777; }



/* ==== [FIX] FAQ: smooth accordion, JS controls padding; avoid CSS jumps ==== */
.faq-a__inner{ margin: 0 0 18px; }
.faq-q[aria-expanded="true"] + .faq-a{ /* neutralize any old overrides if left from previous builds */ height:auto !important; }

/* ==== [TWEAK] Gym slider width cap for perfect 16:9 fit on desktop ==== */
#gymSlider, #gymThumbs{ width: clamp(720px, 78vw, 1100px); margin-left:auto; margin-right:auto; }
@media (max-width: 959px){
  #gymSlider, #gymThumbs{ width: 100%; }
}

/* ==== [FIX] Buy modal (mobile): prevent select from pushing layout horizontally ==== */
.modal.modal--trial .trial-inputs .nice-select{ width:100%; min-width:0; }
.modal.modal--trial .trial-inputs .nice-select__button{ width:100%; }
.modal.modal--trial .trial-inputs .nice-select__menu{ width:100%; max-width:100%; min-width:0; }
.trial-inputs .nice-select__value{ display:block; max-width:100%; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.trial-inputs .nice-select{ min-width:0; }
