/* ================================================================
   APEX Performance Studio — style.css (updated)
================================================================ */

/* ---------- 1. TOKENS ---------- */
:root {
    --color-bg:#080808; --color-bg-2:#0f0f0f; --color-bg-3:#141414;
    --color-surface:#1a1a1a; --color-border:rgba(255,255,255,0.07);
    --color-text:#e8e8e8; --color-text-muted:#6a6a6a; --color-text-faint:#3a3a3a;
    --color-accent:#c8a96e; --color-accent-2:#e0c58a; --color-accent-dim:rgba(200,169,110,0.12);
    --color-white:#fff; --color-black:#000;
    --glass-bg:rgba(255,255,255,0.04); --glass-border:rgba(255,255,255,0.08); --glass-blur:16px;
    --font-display:'Bebas Neue',sans-serif; --font-body:'Outfit',sans-serif; --font-serif-it:'Playfair Display',serif;
    --space-xs:.5rem; --space-sm:1rem; --space-md:2rem; --space-lg:4rem; --space-xl:7rem; --space-xxl:10rem;
    --container:1280px; --radius:4px; --radius-lg:12px; --radius-pill:50px;
    --ease:cubic-bezier(.25,.46,.45,.94); --ease-bounce:cubic-bezier(.34,1.56,.64,1);
    --duration:.35s; --duration-lg:.65s; --nav-h:76px;
}

/* ---------- 2. RESET ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--color-bg);color:var(--color-text);font-family:var(--font-body);font-weight:400;line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,textarea,select{font-family:inherit}

/* ---------- 3. SCROLLBAR ---------- */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--color-bg)}
::-webkit-scrollbar-thumb{background:var(--color-accent);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--color-accent-2)}

/* ---------- 4. CUSTOM CURSOR (desktop only, fully hidden on touch) ---------- */
@media (hover:hover) and (pointer:fine){
    *{cursor:none !important}
}
.cursor,.cursor-follower{display:none}
@media (hover:hover) and (pointer:fine){
    .cursor{display:block;position:fixed;width:8px;height:8px;background:var(--color-accent);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:transform .1s,opacity .3s;mix-blend-mode:screen}
    .cursor-follower{display:block;position:fixed;width:36px;height:36px;border:1.5px solid rgba(200,169,110,.5);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:transform .4s var(--ease),width .3s,height .3s,border-color .3s}
    .cursor.hovering{transform:translate(-50%,-50%) scale(2.5)}
    .cursor-follower.hovering{width:56px;height:56px;border-color:var(--color-accent)}
}
/* Absolute safety on touch */
@media (hover:none),(pointer:coarse){
    #cursor,#cursorFollower,.cursor,.cursor-follower{display:none !important;visibility:hidden !important;opacity:0 !important}
}

/* ---------- 5. LOADER ---------- */
.loader{position:fixed;inset:0;background:var(--color-black);z-index:10000;display:flex;align-items:center;justify-content:center;flex-direction:column;transition:opacity .6s var(--ease),visibility .6s}
.loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader__inner{text-align:center}
.loader__logo{font-family:var(--font-display);font-size:clamp(3rem,10vw,7rem);letter-spacing:.15em;color:#fff;animation:loaderPulse 1.2s ease-in-out infinite alternate}
@keyframes loaderPulse{from{opacity:.3}to{opacity:1}}
.loader__bar{width:200px;height:2px;background:rgba(255,255,255,.1);margin:1.5rem auto 1rem;border-radius:2px;overflow:hidden}
.loader__progress{height:100%;background:var(--color-accent);border-radius:2px;animation:loaderBar 1.8s var(--ease) forwards}
@keyframes loaderBar{from{width:0}to{width:100%}}
.loader__tagline{font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:var(--color-text-muted)}

/* ---------- 6. UTILS ---------- */
.container{max-width:var(--container);margin:0 auto;padding:0 var(--space-md)}
.section{padding:var(--space-xl) 0}
.section-label{font-size:.7rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--color-accent);margin-bottom:.75rem}
.section-title{font-family:var(--font-display);font-size:clamp(2.5rem,5vw,4.5rem);line-height:1.05;letter-spacing:.03em;color:#fff;margin-bottom:1rem}
.section-title em{font-family:var(--font-serif-it);font-style:italic;color:var(--color-accent)}
.section-desc{font-size:1.05rem;color:var(--color-text-muted);max-width:520px}
.section-header{text-align:center;margin-bottom:var(--space-lg)}
.section-header .section-desc{margin:0 auto}
.glass{background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border)}
.w-full{width:100%}

/* ---------- 7. BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.85rem 2.2rem;font-family:var(--font-body);font-weight:600;font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;border-radius:var(--radius);transition:all var(--duration) var(--ease);position:relative;overflow:hidden}
.btn::after{content:'';position:absolute;inset:0;background:#fff;opacity:0;transition:opacity .25s}
.btn:hover::after{opacity:.06}
.btn--primary{background:var(--color-accent);color:#000;border:2px solid var(--color-accent)}
.btn--primary:hover{background:var(--color-accent-2);border-color:var(--color-accent-2);transform:translateY(-2px);box-shadow:0 8px 30px rgba(200,169,110,.3)}
.btn--outline{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.3)}
.btn--outline:hover{border-color:var(--color-accent);color:var(--color-accent);transform:translateY(-2px)}
.btn--ghost{background:transparent;color:#fff;border:2px solid transparent;padding-left:0;padding-right:0}
.btn--ghost::before{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--color-accent);transition:width var(--duration) var(--ease)}
.btn--ghost:hover::before{width:100%}
.btn--ghost:hover{color:var(--color-accent)}
.btn--sm{padding:.6rem 1.4rem;font-size:.78rem}

/* ---------- 8. NAVBAR ---------- */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);display:flex;align-items:center;transition:background var(--duration) var(--ease),box-shadow var(--duration) var(--ease),height var(--duration) var(--ease)}
.navbar.scrolled{background:rgba(8,8,8,.95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 1px 0 var(--color-border);height:64px}
.navbar__inner{display:flex;align-items:center;justify-content:space-between;width:100%}
.navbar__logo{display:flex;align-items:center;gap:.5rem;text-decoration:none}
.logo__mark{color:var(--color-accent);font-size:1rem;transition:transform var(--duration) var(--ease)}
.navbar__logo:hover .logo__mark{transform:translateY(-3px)}
.logo__text{font-family:var(--font-display);font-size:1.6rem;letter-spacing:.12em;color:#fff;line-height:1}
.logo__sub{display:none;font-size:.55rem;letter-spacing:.25em;text-transform:uppercase;color:var(--color-text-muted);align-self:flex-end;padding-bottom:4px}
@media (min-width:1024px){.logo__sub{display:block}}
.navbar__links{display:flex;gap:2.5rem}
.nav-link{font-size:.78rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted);transition:color var(--duration);position:relative}
.nav-link::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--color-accent);transition:width var(--duration) var(--ease)}
.nav-link:hover{color:#fff}
.nav-link:hover::after{width:100%}
.navbar__actions{display:flex;align-items:center;gap:1.2rem}
#langToggle{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .8rem;border:1px solid var(--color-border);border-radius:var(--radius-pill);font-size:.7rem;letter-spacing:.15em;color:var(--color-text-muted);text-transform:uppercase;transition:all var(--duration)}
#langToggle:hover{color:var(--color-accent);border-color:var(--color-accent)}
#langLabel{color:#fff}

/* Hamburger */
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:30px;height:30px}
.hamburger span{display:block;height:2px;background:#fff;border-radius:2px;transition:transform var(--duration) var(--ease),opacity var(--duration)}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-menu{position:fixed;inset:0;background:rgba(8,8,8,.98);backdrop-filter:blur(20px);z-index:999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2.5rem;opacity:0;visibility:hidden;transition:opacity var(--duration-lg) var(--ease),visibility var(--duration-lg)}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu ul{display:flex;flex-direction:column;align-items:center;gap:1.8rem}
.mobile-link{font-family:var(--font-display);font-size:2.8rem;letter-spacing:.1em;color:#fff;transition:color var(--duration)}
.mobile-link:hover{color:var(--color-accent)}
@media (max-width:900px){.navbar__links{display:none}.hamburger{display:flex}.navbar__actions .btn--outline{display:none}}

/* ---------- 9. HERO (scroll indicator REMOVED) ---------- */
.hero{position:relative;height:100dvh;min-height:700px;display:flex;align-items:center;overflow:hidden}
.hero__bg{position:absolute;inset:0}
.hero__bg-img{position:absolute;inset:0;background-size:cover;background-position:center 30%;background-color:#111;transform:scale(1.05);animation:heroZoom 12s ease-out forwards}
@keyframes heroZoom{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(120deg,rgba(0,0,0,.88) 0%,rgba(0,0,0,.55) 50%,rgba(0,0,0,.3) 100%)}
.hero__vertical-text{position:absolute;right:2.5rem;top:50%;transform:translateY(-50%) rotate(90deg);transform-origin:center;font-size:.6rem;letter-spacing:.35em;text-transform:uppercase;color:rgba(255,255,255,.25);white-space:nowrap;pointer-events:none}
.hero__content{position:relative;z-index:2;padding-top:var(--nav-h)}
.hero__badge{display:inline-block;font-size:.65rem;letter-spacing:.35em;text-transform:uppercase;color:var(--color-accent);border:1px solid rgba(200,169,110,.3);padding:.35rem 1rem;border-radius:var(--radius-pill);margin-bottom:1.5rem}
.hero__headline{font-family:var(--font-display);font-size:clamp(4.5rem,11vw,10rem);line-height:.92;letter-spacing:.04em;color:#fff;margin-bottom:1.8rem}
.hero__headline--accent{font-family:var(--font-serif-it);font-style:italic;color:var(--color-accent);font-size:.85em}
.hero__sub{font-size:1rem;color:rgba(255,255,255,.65);max-width:420px;margin-bottom:2.5rem;line-height:1.7}
.hero__cta{display:flex;flex-wrap:wrap;gap:1rem}
/* SCROLL INDICATOR — hidden */
.hero__scroll{display:none !important}

/* ---------- 10. ABOUT ---------- */
.about{background:var(--color-bg-2)}
.about__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);align-items:center}
.about__visual{position:relative}
.about__img-wrap{position:relative;aspect-ratio:4/5;border-radius:var(--radius-lg);overflow:hidden}
.about__img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.about__img-wrap:hover .about__img{transform:scale(1.04)}
.about__img-placeholder{position:absolute;inset:0;background:linear-gradient(135deg,#1a1a1a 0%,#0f0f0f 100%);display:flex;align-items:center;justify-content:center;font-size:.7rem;letter-spacing:.2em;color:var(--color-text-faint);text-transform:uppercase;pointer-events:none}
.about__img[src] + .about__img-placeholder{display:none}
.about__badge-float{position:absolute;bottom:-1.5rem;right:-1.5rem;padding:1.2rem 1.8rem;border-radius:var(--radius-lg);text-align:center}
.badge-num{display:block;font-family:var(--font-display);font-size:2.8rem;line-height:1;color:var(--color-accent)}
.badge-label{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted)}
.about__text{color:var(--color-text-muted);margin-bottom:1.2rem;font-size:1.02rem}
.about__text strong{color:var(--color-text)}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:2rem}
.stat-card{padding:1.4rem;border-radius:var(--radius-lg);transition:border-color var(--duration)}
.stat-card:hover{border-color:var(--color-accent)}
.stat-num{display:inline-block;font-family:var(--font-display);font-size:2.4rem;color:#fff;line-height:1}
.stat-unit{font-family:var(--font-display);font-size:1.4rem;color:var(--color-accent);margin-left:2px}
.stat-label{display:block;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted);margin-top:.35rem}

/* ---------- 11. PROGRAMS ---------- */
.programs{background:var(--color-bg)}
.programs__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5px}
.program-card{position:relative;overflow:hidden;background:var(--color-bg-3);transition:transform var(--duration) var(--ease)}
.program-card__img{aspect-ratio:16/10;background-size:cover;background-position:center;position:relative;overflow:hidden;transition:transform .6s var(--ease)}
.prog-img-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.65rem;letter-spacing:.15em;color:var(--color-text-faint);text-transform:uppercase;background:linear-gradient(135deg,#141414,#0a0a0a)}
.program-card:hover .program-card__img{transform:scale(1.06)}
.program-card__body{padding:1.8rem;border-top:1px solid var(--color-border)}
.program-card__icon{display:none} /* emojis removed */
.program-card h3{font-family:var(--font-display);font-size:1.5rem;letter-spacing:.05em;color:#fff;margin-bottom:.6rem}
.program-card p{font-size:.9rem;color:var(--color-text-muted);line-height:1.6;margin-bottom:0}
.program-card__link{display:none} /* "Learn more" removed */

/* ---------- 12. TRAINERS (2 trainers — fill the space) ---------- */
.trainers{background:var(--color-bg-2)}
.trainers__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;max-width:900px;margin:0 auto}
.trainer-card{background:var(--color-bg-3);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-border);transition:transform var(--duration) var(--ease),border-color var(--duration)}
.trainer-card:hover{transform:translateY(-6px);border-color:var(--color-accent)}
.trainer-card__img-wrap{position:relative;overflow:hidden}
.trainer-card__img{aspect-ratio:3/4;background-size:cover;background-position:top center;transition:transform .6s var(--ease)}
.trainer-img-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.6rem;letter-spacing:.2em;color:var(--color-text-faint);text-transform:uppercase;background:linear-gradient(160deg,#1c1c1c,#0f0f0f)}
.trainer-card:hover .trainer-card__img{transform:scale(1.05)}
.trainer-card__overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 50%);opacity:0;transition:opacity var(--duration);display:flex;align-items:flex-end;padding:1.2rem}
.trainer-card:hover .trainer-card__overlay{opacity:1}
.trainer-social{display:flex;gap:.6rem}
.trainer-social a{width:32px;height:32px;background:var(--color-accent);color:#000;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;letter-spacing:.02em;text-transform:lowercase;transition:background var(--duration),transform var(--duration)}
.trainer-social a:hover{background:#fff;transform:scale(1.1)}
.trainer-card__body{padding:1.4rem}
.trainer-name{font-family:var(--font-display);font-size:1.35rem;letter-spacing:.05em;color:#fff;margin-bottom:.3rem}
.trainer-specialty{display:inline-block;font-size:.65rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--color-accent);margin-bottom:.75rem}
.trainer-bio{font-size:.85rem;color:var(--color-text-muted);line-height:1.6}

/* ---------- 13. PRICING ---------- */
.pricing{background:var(--color-bg)}
.pricing__toggle{display:flex;gap:.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-pill);padding:.3rem;width:fit-content;margin:0 auto var(--space-lg)}
.toggle-btn{padding:.55rem 1.6rem;font-size:.78rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);border-radius:var(--radius-pill);transition:all var(--duration) var(--ease);display:flex;align-items:center;gap:.4rem}
.toggle-btn.active{background:var(--color-accent);color:#000}
.toggle-save{font-size:.6rem;background:rgba(0,0,0,.2);padding:.1rem .4rem;border-radius:20px}
.pricing__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;align-items:start}
.price-card{padding:2.5rem;border-radius:var(--radius-lg);position:relative;transition:transform var(--duration) var(--ease),border-color var(--duration)}
.price-card:hover{transform:translateY(-6px)}
.price-card--featured{background:linear-gradient(160deg,rgba(200,169,110,.1),rgba(200,169,110,.02));border-color:rgba(200,169,110,.3) !important;transform:scale(1.02)}
.price-card--featured:hover{transform:scale(1.02) translateY(-6px)}
.price-card__badge{position:absolute;top:-1px;left:50%;transform:translateX(-50%);background:var(--color-accent);color:#000;font-size:.65rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;padding:.3rem 1.1rem;border-radius:0 0 var(--radius) var(--radius)}
.price-card__tier{font-family:var(--font-display);font-size:1.2rem;letter-spacing:.15em;color:var(--color-text-muted);margin-bottom:.6rem}
.price-card__price{display:flex;align-items:flex-end;gap:.1rem;margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--color-border)}
.price-currency{font-size:1.4rem;font-weight:300;color:var(--color-text-muted);padding-bottom:.4rem}
.price-amount{font-family:var(--font-display);font-size:4rem;line-height:1;color:#fff;transition:all var(--duration)}
.price-period{color:var(--color-text-muted);font-size:.85rem;padding-bottom:.6rem}
.price-card__features{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem;font-size:.9rem}
.price-card__features li{color:var(--color-text)}
.price-card__features li.muted{color:var(--color-text-faint)}

/* ---------- 14. GALLERY — removed entirely ---------- */
.gallery,.lightbox{display:none !important}

/* ---------- 15. TESTIMONIALS ---------- */
.testimonials{background:var(--color-bg);overflow:hidden}
.testimonials__carousel{position:relative}
.testimonials__track{display:flex;transition:transform .6s var(--ease)}
.testimonial-slide{min-width:100%;padding:0 var(--space-md);max-width:800px;margin:0 auto;text-align:center;display:flex;flex-direction:column;align-items:center}
.testimonial-quote{font-family:var(--font-serif-it);font-size:5rem;line-height:.5;color:var(--color-accent);margin-bottom:1rem}
.testimonial-text{font-size:1.15rem;color:var(--color-text);line-height:1.75;font-style:italic;max-width:640px;margin-bottom:2rem}
.testimonial-author{display:flex;align-items:center;gap:1rem}
.testimonial-avatar{width:52px;height:52px;border-radius:50%;background:var(--color-surface);background-size:cover;background-position:center;border:2px solid var(--color-accent);flex-shrink:0}
.testimonial-author > div{text-align:left}
.testimonial-author strong{display:block;color:#fff}
.testimonial-author span{font-size:.78rem;letter-spacing:.1em;color:var(--color-text-muted)}
.testimonials__controls{display:flex;align-items:center;justify-content:center;gap:1.5rem;margin-top:3rem}
.t-btn{font-size:1.8rem;color:var(--color-text-muted);width:44px;height:44px;border:1px solid var(--color-border);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all var(--duration)}
.t-btn:hover{color:#fff;border-color:var(--color-accent)}
.t-dots{display:flex;gap:.5rem}
.t-dot{width:6px;height:6px;border-radius:50%;background:var(--color-text-faint);transition:background var(--duration),transform var(--duration);cursor:pointer}
.t-dot.active{background:var(--color-accent);transform:scale(1.4)}

/* ---------- 16. CONTACT (map column matches text column) ---------- */
.contact{background:var(--color-bg-2)}
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);align-items:stretch}
.contact__info{display:flex;flex-direction:column}
.contact__info > p{color:var(--color-text-muted);margin-bottom:2rem;max-width:400px}
.contact__details{display:flex;flex-direction:column;gap:1.4rem;margin-bottom:2.5rem}
.contact__detail-item{display:flex;align-items:flex-start;gap:1rem}
.contact__detail-icon{display:none} /* emojis removed */
.contact__detail-item strong{display:block;font-size:.75rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:.2rem}
.contact__detail-item span,.contact__detail-item a{font-size:.95rem;color:var(--color-text);line-height:1.5}
.contact__detail-item a:hover{color:var(--color-accent)}
.contact__social{display:flex;gap:.75rem}
.social-btn{width:44px;height:44px;border:1px solid var(--color-border);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);transition:all var(--duration)}
.social-btn:hover{color:var(--color-accent);border-color:var(--color-accent);transform:translateY(-3px)}

/* Map wrapper — fills the right column, matches text column height */
.contact__map,.contact-map,.contact__form-wrap{display:flex;flex-direction:column;width:100%;height:100%;min-height:480px;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-border);background:#000}
.contact__map iframe,.contact-map iframe,.contact__form-wrap iframe{width:100%;height:100%;min-height:480px;flex:1;border:0;display:block;filter:invert(90%) hue-rotate(180deg) brightness(.9) contrast(.95)}
.contact__map-link,.contact-map-link{display:inline-flex;align-items:center;gap:.4rem;padding:.7rem 1rem;background:rgba(0,0,0,.85);color:var(--color-accent);font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;border-top:1px solid var(--color-border);transition:color var(--duration)}
.contact__map-link:hover,.contact-map-link:hover{color:#fff}

/* ---------- 17. FOOTER ---------- */
.footer{background:#000;border-top:1px solid var(--color-border);padding-top:var(--space-lg)}
.footer__inner{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:var(--space-lg);padding-bottom:var(--space-lg)}
.footer__logo{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}
.footer__logo .logo__mark{color:var(--color-accent)}
.footer__logo span:last-child{font-family:var(--font-display);font-size:1.4rem;letter-spacing:.1em;color:#fff}
.footer__brand p{font-size:.85rem;color:var(--color-text-muted);line-height:1.6}
.footer__links h4,.footer__contact h4{font-size:.7rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:1.2rem}
.footer__links ul{display:flex;flex-direction:column;gap:.7rem}
.footer__links a{font-size:.9rem;color:var(--color-text-muted);transition:color var(--duration)}
.footer__links a:hover{color:var(--color-accent)}
.footer__contact p,.footer__contact a{display:block;font-size:.9rem;color:var(--color-text-muted);line-height:1.6;transition:color var(--duration)}
.footer__contact a:hover{color:var(--color-accent)}
.footer__contact a{margin-top:.5rem}
.footer__bottom{border-top:1px solid var(--color-border);padding:1.5rem var(--space-md);display:flex;align-items:center;justify-content:space-between;font-size:.78rem;color:var(--color-text-faint)}
.footer__bottom-links{display:flex;gap:1.5rem}
.footer__bottom-links a{color:var(--color-text-faint);transition:color var(--duration)}
.footer__bottom-links a:hover{color:var(--color-text-muted)}

/* ---------- 18. BACK TO TOP ---------- */
.back-to-top{position:fixed;bottom:2rem;right:2rem;width:44px;height:44px;background:var(--color-accent);color:#000;border-radius:50%;font-size:.85rem;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transform:translateY(10px);transition:all var(--duration) var(--ease);z-index:500}
.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top:hover{background:var(--color-accent-2);transform:translateY(-3px)}

/* ---------- 19. REVEAL ---------- */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}
.program-card[data-index="0"].reveal{transition-delay:0s}
.program-card[data-index="1"].reveal{transition-delay:.08s}
.program-card[data-index="2"].reveal{transition-delay:.16s}
.program-card[data-index="3"].reveal{transition-delay:.24s}
.program-card[data-index="4"].reveal{transition-delay:.32s}
.program-card[data-index="5"].reveal{transition-delay:.40s}

/* ---------- 20. TABLET ---------- */
@media (max-width:1100px){
    .footer__inner{grid-template-columns:1fr 1fr}
}
@media (max-width:900px){
    :root{--space-xl:5rem}
    .about__grid{grid-template-columns:1fr}
    .about__visual{order:-1}
    .about__badge-float{display:none}
    .programs__grid{grid-template-columns:repeat(2,1fr)}
    .pricing__grid{grid-template-columns:1fr;max-width:420px;margin:0 auto}
    .price-card--featured{transform:none}
    .price-card--featured:hover{transform:translateY(-6px)}
    .contact__grid{grid-template-columns:1fr}
    .contact__map,.contact-map,.contact__form-wrap{min-height:360px}
}

/* ---------- 21. MOBILE ---------- */
@media (max-width:640px){
    :root{--space-xl:4rem;--nav-h:60px}
    .hero__headline{font-size:clamp(3.5rem,15vw,6rem)}
    .hero__vertical-text{display:none}
    .section-title{font-size:clamp(2rem,8vw,3rem)}
    .programs__grid{grid-template-columns:1fr}
    .trainers__grid{grid-template-columns:1fr;max-width:420px}
    .stats-grid{grid-template-columns:repeat(2,1fr)}
    .footer__inner{grid-template-columns:1fr;gap:2.5rem}
    .footer__bottom{flex-direction:column;gap:1rem;text-align:center}
    .testimonial-text{font-size:1rem}
}

/* ---------- 22. REDUCED MOTION ---------- */
@media (prefers-reduced-motion:reduce){
    *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}
    .reveal{opacity:1;transform:none}
}
