/* ============================================================
   BOOTCAMP SPORTS ACADEMY — Premium Styles
   Dark gold theme · motionframes.io-inspired
   ============================================================ */

:root {
  --bg:          #07070F;
  --bg-2:        #0C0C1A;
  --bg-card:     #101022;
  --gold:        #D4AF37;
  --gold-light:  #F0CC55;
  --gold-dim:    rgba(212,175,55,0.12);
  --gold-border: rgba(212,175,55,0.18);
  --white:       #FFFFFF;
  --grey:        #8888A8;
  --grey-dim:    #44445A;
  --border:      rgba(255,255,255,0.07);
  --grad-gold:   linear-gradient(135deg, #D4AF37 0%, #F0CC55 100%);
  --grad-dark:   linear-gradient(180deg, transparent 0%, rgba(7,7,15,0.96) 100%);
  --shadow-gold: 0 8px 40px rgba(212,175,55,0.14);
  --shadow-card: 0 4px 24px rgba(0,0,0,0.4);
  --font-display:'Bebas Neue', sans-serif;
  --font-head:   'Montserrat', sans-serif;
  --font-body:   'Inter', sans-serif;
  --ease:        cubic-bezier(0.4,0,0.2,1);
  --r:           12px;
  --r-lg:        20px;
}

/* ─── Reset ──────────────────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--white);
  -webkit-font-smoothing:antialiased;
}
a{text-decoration:none;color:inherit}
img{max-width:100%;height:auto;display:block}
ul{list-style:none}
h1,h2,h3,h4,h5{font-family:var(--font-head);font-weight:800;line-height:1.1}

/* ─── Scrollbar ──────────────────────────────────────────── */
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--gold);border-radius:2px}

/* ─── Noise overlay ──────────────────────────────────────── */
body::before{
  content:'';
  position:fixed;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  pointer-events:none;
  z-index:9997;
  opacity:0.6;
}

/* ─── Preloader ──────────────────────────────────────────── */
#preloader{
  position:fixed;inset:0;
  background:var(--bg);
  z-index:9999;
  display:flex;align-items:center;justify-content:center;
}
.preloader-inner{text-align:center}
.preloader-logo{
  margin-bottom:28px;
  animation:preload-pulse 1.2s ease-in-out infinite;
}
.preloader-logo img{
  width:220px;height:220px;
  object-fit:contain;
  margin:0 auto;
  filter:invert(1) brightness(1.1);
}
@keyframes preload-pulse{0%,100%{opacity:1}50%{opacity:0.4}}
.preloader-text{
  font-size:11px;letter-spacing:5px;text-transform:uppercase;
  color:var(--grey-dim);margin-top:16px;
}
.preloader-bar{
  width:180px;height:1px;
  background:rgba(212,175,55,0.15);
  border-radius:1px;overflow:hidden;margin:0 auto;
}
.preloader-progress{
  height:100%;background:var(--grad-gold);
  width:0;animation:preload-bar 2.2s ease-in-out forwards;
}
@keyframes preload-bar{to{width:100%}}

/* ─── Custom Cursor — disabled ───────────────────────────── */
.cursor-dot,.cursor-outline{display:none}

/* ─── Utility ────────────────────────────────────────────── */
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.section{padding:110px 0}
.section-dark{background:var(--bg-2)}
.text-accent{
  background:var(--grad-gold);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.section-tag{
  display:inline-block;
  font-size:11px;font-weight:700;letter-spacing:4px;text-transform:uppercase;
  color:var(--gold);border:1px solid var(--gold-border);
  padding:5px 16px;border-radius:100px;margin-bottom:18px;
}
.section-title{font-size:clamp(34px,5vw,54px);margin-bottom:18px}
.section-desc{color:var(--grey);font-size:16px;max-width:480px}
.section-header{text-align:center;margin-bottom:64px}
.section-header .section-desc{margin:0 auto}

/* ─── Buttons ────────────────────────────────────────────── */
.btn-primary{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 32px;
  background:var(--grad-gold);color:#000;
  font-family:var(--font-head);font-weight:700;font-size:13px;
  letter-spacing:1.5px;text-transform:uppercase;
  border-radius:100px;border:none;cursor:pointer;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);
  position:relative;overflow:hidden;
}
.btn-primary::after{
  content:'';position:absolute;inset:0;
  background:rgba(255,255,255,0.18);
  transform:translateX(-100%);
  transition:transform .4s var(--ease);
}
.btn-primary:hover::after{transform:translateX(0)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:var(--shadow-gold)}
.btn-primary.btn-large{padding:17px 42px;font-size:14px}
.btn-primary.btn-full{width:100%;justify-content:center}

.btn-ghost{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 32px;color:var(--white);
  font-family:var(--font-head);font-weight:600;font-size:13px;
  letter-spacing:1.5px;text-transform:uppercase;
  border-radius:100px;border:1px solid var(--border);cursor:pointer;
  transition:border-color .3s,color .3s,transform .3s var(--ease);
}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-3px)}
.btn-ghost.btn-large{padding:17px 42px;font-size:14px}

/* ─── Navigation ─────────────────────────────────────────── */
#navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:22px 0;transition:padding .3s var(--ease),background .3s,border .3s;
}
#navbar.scrolled{
  background:rgba(7,7,15,0.88);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  padding:13px 0;
}
.nav-container{
  max-width:1200px;margin:0 auto;padding:0 24px;
  display:flex;align-items:center;justify-content:space-between;gap:40px;
}
.nav-logo{
  display:flex;align-items:center;gap:10px;
  line-height:1;cursor:pointer;
}
.logo-img{
  height:140px;width:auto;
  object-fit:contain;
  filter:invert(1) brightness(1.1);
  transition:transform .3s var(--ease);
}
.nav-logo:hover .logo-img{transform:scale(1.05)}
.logo-subtitle{
  font-size:9px;letter-spacing:3px;text-transform:uppercase;
  color:var(--grey-dim);
  opacity:0;transition:opacity .3s;
  white-space:nowrap;
}
#navbar.scrolled .logo-subtitle{opacity:1}

.nav-links{display:flex;align-items:center;gap:34px}
.nav-links a{
  font-size:12px;font-weight:600;letter-spacing:2px;text-transform:uppercase;
  color:var(--grey);cursor:pointer;
  transition:color .25s;position:relative;
}
.nav-links a::after{
  content:'';position:absolute;bottom:-4px;left:0;
  width:0;height:1px;background:var(--gold);
  transition:width .3s var(--ease);
}
.nav-links a:hover{color:var(--white)}
.nav-links a:hover::after{width:100%}

.nav-cta{
  padding:10px 24px;background:var(--grad-gold);color:#000;
  font-family:var(--font-head);font-size:11px;font-weight:700;
  letter-spacing:2.5px;text-transform:uppercase;border-radius:100px;cursor:pointer;
  transition:transform .3s,box-shadow .3s;
}
.nav-cta:hover{transform:translateY(-2px);box-shadow:var(--shadow-gold)}

.hamburger{
  display:none;flex-direction:column;gap:5px;
  background:none;border:none;cursor:pointer;padding:4px;
}
.hamburger span{
  display:block;width:22px;height:1.5px;
  background:var(--white);transition:transform .3s var(--ease),opacity .3s;
  transform-origin:center;
}

/* Mobile Menu */
.mobile-menu{
  position:fixed;inset:0;background:var(--bg);z-index:999;
  display:flex;align-items:center;justify-content:center;
  transform:translateX(100%);
  transition:transform .45s cubic-bezier(0.76,0,0.24,1);
}
.mobile-menu.open{transform:translateX(0)}
.mobile-close{
  position:absolute;top:24px;right:24px;
  background:none;border:none;color:var(--grey);font-size:22px;cursor:pointer;
}
.mobile-menu ul{text-align:center}
.mobile-menu li{margin-bottom:28px}
.mobile-link{
  font-family:var(--font-display);font-size:46px;letter-spacing:4px;
  color:var(--grey-dim);cursor:pointer;
  transition:color .25s,letter-spacing .25s;
}
.mobile-link:hover{color:var(--gold);letter-spacing:6px}
.mobile-cta{color:var(--gold)}

/* ─── HERO ───────────────────────────────────────────────── */
#hero{
  position:relative;min-height:100vh;
  display:flex;flex-direction:column;justify-content:center;
  overflow:hidden;
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-img{
  width:100%;height:100%;object-fit:cover;
  transform:scale(1.08);
  transition:transform 9s ease-out;
}
#hero.hero-loaded .hero-img{transform:scale(1)}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(120deg,rgba(7,7,15,0.93) 0%,rgba(7,7,15,0.72) 55%,rgba(7,7,15,0.88) 100%);
}

/* Floating shapes */
.hero-shapes{position:absolute;inset:0;z-index:1;pointer-events:none}
.shape{position:absolute;border-radius:50%;filter:blur(80px)}
.shape-1{
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(212,175,55,0.07) 0%,transparent 70%);
  top:-10%;right:5%;
  animation:float1 12s ease-in-out infinite;
}
.shape-2{
  width:350px;height:350px;
  background:radial-gradient(circle,rgba(212,175,55,0.05) 0%,transparent 70%);
  bottom:10%;left:-5%;
  animation:float2 15s ease-in-out infinite;
}
.shape-3{
  width:200px;height:200px;
  background:radial-gradient(circle,rgba(240,204,85,0.08) 0%,transparent 70%);
  top:40%;right:20%;
  animation:float1 10s ease-in-out infinite reverse;
}
@keyframes float1{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-30px) scale(1.05)}}
@keyframes float2{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(20px) rotate(5deg)}}

.hero-content{
  position:relative;z-index:2;
  max-width:1200px;margin:0 auto;
  padding:130px 24px 50px;width:100%;
}
.hero-tag{
  display:inline-flex;align-items:center;gap:12px;
  font-size:11px;font-weight:700;letter-spacing:5px;text-transform:uppercase;
  color:var(--gold);margin-bottom:28px;
}
.hero-tag::before{content:'';display:block;width:28px;height:1px;background:var(--gold)}

.hero-title{
  font-family:var(--font-display);
  font-size:clamp(80px,13vw,170px);
  line-height:.88;letter-spacing:-1px;
  margin-bottom:32px;
  display:flex;flex-direction:column;
}
.hero-line{display:block}
.hero-accent{
  background:var(--grad-gold);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}

.hero-sub{
  font-size:17px;color:rgba(255,255,255,0.88);
  max-width:480px;line-height:1.8;margin-bottom:44px;
  text-shadow:0 1px 12px rgba(0,0,0,0.7);
  font-weight:400;
}
.hero-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.hero-scroll{
  display:flex;align-items:center;gap:14px;
  margin-top:64px;
  font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--grey-dim);
}
.scroll-line{
  width:56px;height:1px;
  background:linear-gradient(90deg,var(--gold),transparent);
  animation:scroll-pulse 2s ease-in-out infinite;
}
@keyframes scroll-pulse{0%,100%{transform:scaleX(1)}50%{transform:scaleX(.5)}}

/* Hero reveal */
.reveal-up{opacity:0;transform:translateY(42px)}
.reveal-up.in{
  animation:reveal-up-anim .85s var(--ease) both;
  animation-delay:var(--d,0s);
}
@keyframes reveal-up-anim{to{opacity:1;transform:translateY(0)}}


/* ─── About ──────────────────────────────────────────────── */
.about-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:center;
}
.about-visual{position:relative}
.about-img-wrap{
  border-radius:var(--r-lg);overflow:hidden;
  position:relative;
  background:var(--bg-card);
}
.about-img-wrap img{width:100%;height:auto;display:block;transition:transform .6s var(--ease)}
.about-visual:hover .about-img-wrap img{transform:scale(1.02)}
.about-img-border{
  position:absolute;inset:-2px;border-radius:var(--r-lg);
  background:var(--grad-gold);z-index:-1;opacity:.45;
  left:0;
}
.about-badge{
  position:absolute;bottom:-28px;right:-28px;
  background:var(--bg-card);border:1px solid var(--gold-border);
  border-radius:var(--r);padding:20px 24px;text-align:center;
  box-shadow:var(--shadow-gold);
}
.badge-num{
  font-family:var(--font-display);font-size:52px;line-height:1;
  background:var(--grad-gold);-webkit-background-clip:text;-webkit-text-fill-color:transparent;display:block;
}
.badge-text{font-size:11px;color:var(--grey);letter-spacing:1px}

.about-tag-float{
  position:absolute;top:24px;left:-20px;
  background:var(--bg-card);border:1px solid var(--gold-border);
  border-radius:100px;padding:10px 18px;
  display:flex;align-items:center;gap:10px;
  font-size:13px;font-weight:600;color:var(--white);
  box-shadow:var(--shadow-card);
}
.about-tag-float i{color:var(--gold)}

.about-desc{color:var(--grey);line-height:1.82;margin-bottom:18px;font-size:15.5px}
.about-features{
  display:grid;grid-template-columns:1fr 1fr;
  gap:12px;margin:32px 0;
}
.feature-item{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--grey)}
.feature-item i{color:var(--gold);font-size:15px;flex-shrink:0}

/* ─── Programs ───────────────────────────────────────────── */
.programs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.program-card{
  background:var(--bg-card);border-radius:var(--r-lg);
  border:1px solid var(--border);overflow:hidden;
  position:relative;cursor:pointer;
  transition:transform .45s var(--ease),border-color .45s,box-shadow .45s;
}
.program-card:hover{transform:translateY(-10px);border-color:var(--gold-border);box-shadow:var(--shadow-gold)}
.program-card.program-featured{
  border-color:rgba(212,175,55,.28);
  background:linear-gradient(160deg,#111128 0%,#16162E 100%);
}
.program-badge-label{
  position:absolute;top:18px;right:18px;z-index:3;
  background:var(--grad-gold);color:#000;
  font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;
  padding:5px 14px;border-radius:100px;
}
.program-img-wrap{position:relative;aspect-ratio:16/9;overflow:hidden}
.program-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.program-card:hover .program-img-wrap img{transform:scale(1.06)}
.program-overlay{position:absolute;inset:0;background:var(--grad-dark)}
.program-num-bg{
  position:absolute;top:100px;right:12px;z-index:0;
  font-family:var(--font-display);font-size:72px;
  color:rgba(255,255,255,0.04);line-height:1;pointer-events:none;
}
.program-content{padding:28px;position:relative;z-index:1}
.program-icon{
  width:48px;height:48px;border-radius:12px;
  background:var(--gold-dim);border:1px solid var(--gold-border);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;color:var(--gold);margin-bottom:18px;
}
.program-content h3{font-size:24px;font-weight:800;margin-bottom:10px}
.program-content p{color:var(--grey);font-size:14px;line-height:1.72;margin-bottom:20px}
.program-features{
  border-top:1px solid var(--border);
  padding-top:18px;margin-bottom:22px;
  display:flex;flex-direction:column;gap:8px;
}
.program-features li{
  font-size:13px;color:var(--grey);
  padding-left:16px;position:relative;
}
.program-features li::before{
  content:'→';position:absolute;left:0;color:var(--gold);font-size:11px;
}
.program-cta{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--gold);cursor:pointer;transition:gap .25s var(--ease);
}
.program-cta:hover{gap:14px}

/* ─── Stats ──────────────────────────────────────────────── */
.stats-section{
  background:var(--bg);
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat-card{
  padding:52px 28px;text-align:center;
  border-right:1px solid var(--border);
  transition:background .3s;
}
.stat-card:last-child{border-right:none}
.stat-card:hover{background:rgba(212,175,55,0.03)}
.stat-icon{font-size:30px;color:var(--gold);opacity:.65;margin-bottom:14px}
.stat-number{
  font-family:var(--font-display);font-size:62px;line-height:1;
  background:var(--grad-gold);-webkit-background-clip:text;-webkit-text-fill-color:transparent;
  margin-bottom:6px;
}
.stat-label{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--grey-dim)}

/* ─── Why Us ─────────────────────────────────────────────── */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.why-card{
  background:var(--bg-2);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:36px 28px;
  position:relative;overflow:hidden;cursor:pointer;
  transition:transform .4s var(--ease),border-color .4s,box-shadow .4s;
}
.why-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--grad-gold);transform:scaleX(0);transform-origin:left;
  transition:transform .45s var(--ease);
}
.why-card:hover::before{transform:scaleX(1)}
.why-card:hover{transform:translateY(-5px);border-color:var(--gold-border);box-shadow:var(--shadow-gold)}
.why-icon{font-size:28px;color:var(--gold);margin-bottom:18px}
.why-card h4{font-size:17px;font-weight:700;margin-bottom:10px}
.why-card p{font-size:14px;color:var(--grey);line-height:1.72}

/* ─── Coaches ────────────────────────────────────────────── */
.coaches-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.coach-card{cursor:pointer}
.coach-img-wrap{
  position:relative;aspect-ratio:3/4;
  border-radius:var(--r-lg);overflow:hidden;margin-bottom:20px;
}
.coach-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.coach-card:hover .coach-img-wrap img{transform:scale(1.05)}
.coach-social{
  position:absolute;bottom:-50px;left:0;right:0;
  display:flex;justify-content:center;gap:10px;
  padding:20px 20px 24px;
  background:linear-gradient(0deg,rgba(7,7,15,.9) 0%,transparent 100%);
  transition:bottom .4s var(--ease);
}
.coach-card:hover .coach-social{bottom:0}
.coach-social a{
  width:38px;height:38px;border-radius:50%;
  background:var(--gold-dim);border:1px solid var(--gold-border);
  display:flex;align-items:center;justify-content:center;
  font-size:15px;color:var(--gold);cursor:pointer;
  transition:background .25s,color .25s;
}
.coach-social a:hover{background:var(--gold);color:#000}
.coach-info h4{font-size:20px;font-weight:700;margin-bottom:3px}
.coach-info > span{
  display:block;font-size:12px;letter-spacing:1.5px;
  color:var(--gold);margin-bottom:8px;text-transform:uppercase;
}
.coach-info p{font-size:14px;color:var(--grey);line-height:1.65}

/* ─── Gallery ────────────────────────────────────────────── */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:auto auto;
  gap:14px;
}
.gallery-item{
  position:relative;border-radius:var(--r);
  overflow:hidden;aspect-ratio:1;cursor:pointer;
}
.gallery-large{grid-column:span 2;aspect-ratio:16/9}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .65s var(--ease)}
.gallery-item:hover img{transform:scale(1.07)}
.gallery-overlay{
  position:absolute;inset:0;
  background:linear-gradient(0deg,rgba(7,7,15,.78) 0%,transparent 55%);
  display:flex;align-items:flex-end;padding:18px;
  opacity:0;transition:opacity .3s;
}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-overlay span{
  font-size:12px;font-weight:700;letter-spacing:2.5px;
  text-transform:uppercase;color:var(--gold);
}

/* ─── Google Rating Summary ──────────────────────────────── */
.google-rating-summary{
  display:inline-flex;align-items:center;justify-content:center;
  gap:20px;margin-top:24px;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border);
  border-radius:16px;padding:16px 32px;
}
.rating-score-big{
  font-family:var(--font-display);font-size:44px;line-height:1;
  background:var(--grad-gold);-webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.rating-divider{
  width:1px;height:32px;
  background:var(--border);
  flex-shrink:0;
}
.rating-stars-row{
  display:flex;align-items:center;gap:5px;
  color:#F4B942;font-size:18px;
}
.rating-meta{display:flex;align-items:center;gap:8px}
.google-logo{height:18px;width:auto;filter:brightness(0) invert(1);opacity:.7}
.rating-meta span{font-size:13px;color:var(--grey);white-space:nowrap}

/* ─── Review Cards ───────────────────────────────────────── */
.review-stars{display:flex;gap:3px;color:var(--gold);font-size:14px;margin-bottom:16px}
.review-author{
  display:flex;align-items:center;gap:12px;
  margin-top:24px;padding-top:20px;
  border-top:1px solid var(--border);
}
.reviewer-initial{
  width:40px;height:40px;border-radius:50%;flex-shrink:0;
  background:var(--gold-dim);border:1px solid var(--gold-border);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-head);font-size:16px;font-weight:700;
  color:var(--gold);
}
.reviewer-info{flex:1}
.reviewer-info strong{display:block;font-size:14px;font-weight:700;margin-bottom:2px}
.reviewer-info span{font-size:11px;color:var(--grey);letter-spacing:1px;text-transform:uppercase}
.review-google-logo{height:14px;width:auto;filter:brightness(0) invert(1);opacity:.45;flex-shrink:0}

.google-reviews-cta{text-align:center;margin-top:40px}

/* ─── Testimonials ───────────────────────────────────────── */
.testimonials-swiper{padding-bottom:54px!important}
.swiper-pagination-bullet{background:var(--grey-dim)!important;opacity:1!important}
.swiper-pagination-bullet-active{background:var(--gold)!important}

.testimonial-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:40px;
  transition:border-color .3s;height:auto;
}
.testimonial-card:hover{border-color:var(--gold-border)}
.testimonial-stars{color:var(--gold);font-size:17px;letter-spacing:2px;margin-bottom:18px}
.testimonial-card p{
  font-size:15px;line-height:1.8;color:var(--grey);
  font-style:italic;margin-bottom:28px;
}
.testimonial-author{display:flex;align-items:center;gap:14px}
.author-avatar{
  width:46px;height:46px;border-radius:50%;flex-shrink:0;
}
.av-1{background:linear-gradient(135deg,#667eea,#764ba2)}
.av-2{background:linear-gradient(135deg,#f093fb,#f5576c)}
.av-3{background:linear-gradient(135deg,#4facfe,#00f2fe)}
.av-4{background:linear-gradient(135deg,#43e97b,#38f9d7)}
.testimonial-author strong{display:block;font-size:15px;margin-bottom:2px}
.testimonial-author span{font-size:12px;color:var(--grey-dim)}

/* ─── CTA Section ────────────────────────────────────────── */
.cta-section{
  background:var(--bg-2);text-align:center;
  position:relative;overflow:hidden;
}
.cta-bg-text{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  font-family:var(--font-display);font-size:280px;letter-spacing:24px;
  color:rgba(212,175,55,0.03);white-space:nowrap;pointer-events:none;
  animation:bg-text-drift 20s linear infinite;
}
@keyframes bg-text-drift{0%{letter-spacing:24px}50%{letter-spacing:36px}100%{letter-spacing:24px}}
.cta-content{position:relative;z-index:2}
.cta-title{
  font-family:var(--font-display);
  font-size:clamp(52px,8vw,100px);line-height:.95;letter-spacing:-1px;
  margin-bottom:22px;
}
.cta-content > p{color:var(--grey);margin-bottom:40px;font-size:16px;max-width:420px;margin-left:auto;margin-right:auto}
.cta-actions{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap}

/* ─── Contact ────────────────────────────────────────────── */
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:64px;align-items:start}
.contact-item{display:flex;align-items:flex-start;gap:16px;margin-bottom:26px}
.contact-icon{
  width:44px;height:44px;flex-shrink:0;border-radius:10px;
  background:var(--gold-dim);border:1px solid var(--gold-border);
  display:flex;align-items:center;justify-content:center;
  color:var(--gold);font-size:17px;
}
.contact-item strong{display:block;font-size:13px;font-weight:700;margin-bottom:4px}
.contact-item span{font-size:14px;color:var(--grey);line-height:1.6}
.social-links-row{display:flex;gap:10px;margin-top:8px}
.social-link{
  width:42px;height:42px;border-radius:10px;
  background:var(--gold-dim);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:17px;color:var(--grey);cursor:pointer;
  transition:background .25s,border-color .25s,color .25s,transform .25s;
}
.social-link:hover{background:var(--gold-dim);border-color:var(--gold);color:var(--gold);transform:translateY(-3px)}

/* Form */
.contact-form{display:flex;flex-direction:column;gap:18px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-group{position:relative}
.form-group input,
.form-group textarea{
  width:100%;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border);border-radius:var(--r);
  padding:17px 20px;color:var(--white);
  font-family:var(--font-body);font-size:14px;
  outline:none;cursor:pointer;
  transition:border-color .25s,background .25s;
}
.form-group input:focus,
.form-group textarea:focus{
  border-color:var(--gold);
  background:rgba(212,175,55,0.05);
}
.form-group label{
  position:absolute;top:17px;left:20px;
  font-size:14px;color:var(--grey-dim);pointer-events:none;
  transition:.25s var(--ease);
}
.form-group input:focus ~ label,
.form-group input:not(:placeholder-shown) ~ label,
.form-group textarea:focus ~ label,
.form-group textarea:not(:placeholder-shown) ~ label{
  top:-10px;font-size:10px;letter-spacing:1.5px;
  background:var(--bg-2);padding:0 8px;color:var(--gold);
}
.form-group textarea{resize:vertical;min-height:110px}
.form-select-wrap{position:relative}
.form-select-wrap select{
  width:100%;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border);border-radius:var(--r);
  padding:17px 44px 17px 20px;color:var(--grey-dim);
  font-family:var(--font-body);font-size:14px;
  outline:none;cursor:pointer;
  transition:border-color .25s,background .25s;
  appearance:none;-webkit-appearance:none;
}
.form-select-wrap select:focus{border-color:var(--gold);background:rgba(212,175,55,0.05)}
.form-select-wrap select option{background:var(--bg-card);color:var(--white)}
.select-label{
  position:absolute;top:17px;left:20px;
  font-size:14px;color:var(--grey-dim);pointer-events:none;
  transition:.25s var(--ease);
}
.form-select-wrap select:focus ~ .select-label,
.form-select-wrap select:not([value=""]):valid ~ .select-label{
  top:-10px;font-size:10px;letter-spacing:1.5px;
  background:var(--bg-2);padding:0 8px;color:var(--gold);
}
.select-arrow{
  position:absolute;right:16px;top:50%;transform:translateY(-50%);
  color:var(--grey-dim);pointer-events:none;font-size:12px;
}

/* ─── Footer ─────────────────────────────────────────────── */
#footer{background:var(--bg);border-top:1px solid var(--border);padding:64px 0 0}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1.6fr;
  gap:48px;padding-bottom:48px;
  border-bottom:1px solid var(--border);
}
.footer-logo{
  font-family:var(--font-display);font-size:52px;letter-spacing:5px;
  color:var(--white);
  margin-bottom:14px;
}
.footer-brand p{
  font-size:14px;color:var(--grey-dim);line-height:1.72;
  margin-bottom:22px;max-width:270px;
}
.footer-links h5,.footer-contact h5{
  font-size:11px;font-weight:700;letter-spacing:3.5px;
  text-transform:uppercase;color:var(--white);margin-bottom:20px;
}
.footer-links ul{display:flex;flex-direction:column;gap:12px}
.footer-links a{
  font-size:14px;color:var(--grey-dim);cursor:pointer;
  transition:color .25s,padding-left .25s;
}
.footer-links a:hover{color:var(--gold);padding-left:6px}
.footer-contact p{
  font-size:14px;color:var(--grey-dim);
  display:flex;align-items:flex-start;gap:10px;margin-bottom:10px;
}
.footer-contact i{color:var(--gold);flex-shrink:0;margin-top:2px}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding:20px 0;font-size:12px;color:var(--grey-dim);
}

/* ─── WhatsApp Float ─────────────────────────────────────── */
.whatsapp-float{
  position:fixed;bottom:28px;right:28px;z-index:9998;
  width:58px;height:58px;border-radius:50%;
  background:#25D366;
  display:flex;align-items:center;justify-content:center;
  font-size:30px;color:#fff;
  box-shadow:0 4px 20px rgba(37,211,102,0.45);
  transition:transform .3s var(--ease),box-shadow .3s;
}
.whatsapp-float:hover{transform:scale(1.12);box-shadow:0 6px 28px rgba(37,211,102,0.6)}
.whatsapp-float::before{
  content:'';
  position:absolute;inset:0;border-radius:50%;
  background:#25D366;
  animation:wa-pulse 2s ease-out infinite;
  z-index:-1;
}
@keyframes wa-pulse{
  0%{transform:scale(1);opacity:.7}
  100%{transform:scale(1.7);opacity:0}
}
.whatsapp-tooltip{
  position:absolute;right:68px;
  background:#111;color:#fff;
  font-size:13px;font-weight:600;
  padding:7px 14px;border-radius:8px;
  white-space:nowrap;pointer-events:none;
  opacity:0;transform:translateX(6px);
  transition:opacity .25s,transform .25s;
}
.whatsapp-tooltip::after{
  content:'';position:absolute;top:50%;right:-6px;
  transform:translateY(-50%);
  border:6px solid transparent;border-right:none;
  border-left-color:#111;
}
.whatsapp-float:hover .whatsapp-tooltip{opacity:1;transform:translateX(0)}

/* ─── Scroll Reveal ──────────────────────────────────────── */
.fade-in{opacity:0;transform:translateY(28px);transition:opacity .65s var(--ease),transform .65s var(--ease)}
.fade-in-left{opacity:0;transform:translateX(-28px);transition:opacity .65s var(--ease),transform .65s var(--ease)}
.fade-in-right{opacity:0;transform:translateX(28px);transition:opacity .65s var(--ease),transform .65s var(--ease)}
.fade-in.vis,.fade-in-left.vis,.fade-in-right.vis{opacity:1;transform:translate(0)}

/* ─── Touch devices — restore cursor ────────────────────── */
@media(hover:none) and (pointer:coarse){
  body{cursor:auto}
  .cursor-dot,.cursor-outline{display:none}
  a,button,select,input,textarea,
  .nav-logo,.nav-cta,.hamburger,.mobile-link,.mobile-close,
  .btn-primary,.btn-ghost,.program-card,.program-cta,
  .why-card,.coach-card,.coach-social a,.gallery-item,
  .social-link,.footer-links a,.form-select-wrap select{cursor:pointer}
}

/* ─── 1100px — Large tablets ─────────────────────────────── */
@media(max-width:1100px){
  .programs-grid{grid-template-columns:1fr 1fr}
  .about-grid{grid-template-columns:1fr}
  .about-visual{display:none}
  .coaches-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat-card:nth-child(2){border-right:none}
  .stat-card:nth-child(3){border-top:1px solid var(--border)}
  .stat-card:nth-child(4){border-top:1px solid var(--border)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .contact-grid{grid-template-columns:1fr;gap:48px}
}

/* ─── 768px — Tablets & Phones ───────────────────────────── */
@media(max-width:768px){
  .section{padding:64px 0}
  .container{padding:0 18px}

  /* Nav */
  .nav-links,.nav-cta{display:none}
  .hamburger{display:flex}

  /* Hero */
  .hero-content{padding:96px 18px 36px}
  .hero-title{font-size:clamp(48px,13vw,76px)}
  .hero-sub{font-size:15px}
  .hero-scroll{margin-top:40px}
  .hero-actions{gap:10px}


  /* Programs */
  .programs-grid{grid-template-columns:1fr;max-width:100%}

  /* About */
  .about-features{grid-template-columns:1fr}

  /* Coaches */
  .coaches-grid{grid-template-columns:1fr;max-width:380px;margin:0 auto}

  /* Why */
  .why-grid{grid-template-columns:1fr}

  /* Stats strip */
  .stats-grid{grid-template-columns:1fr 1fr}
  .stat-card{padding:36px 20px}
  .stat-card:nth-child(2){border-right:none}
  .stat-card:nth-child(3){border-top:1px solid var(--border)}
  .stat-card:nth-child(4){border-top:1px solid var(--border);border-right:none}
  .stat-number{font-size:48px}

  /* Gallery */
  .gallery-grid{grid-template-columns:1fr 1fr;gap:10px}
  .gallery-large{grid-column:span 2;aspect-ratio:16/9}
  .gallery-overlay{opacity:1}

  /* Testimonials */
  .testimonial-card{padding:28px}

  /* CTA */
  .cta-title{font-size:clamp(38px,10vw,68px)}
  .cta-bg-text{font-size:100px}
  .cta-actions{flex-direction:column;align-items:center}
  .btn-primary.btn-large,.btn-ghost.btn-large{width:100%;max-width:320px;justify-content:center}

  /* Contact */
  .contact-grid{grid-template-columns:1fr;gap:36px}
  .form-row{grid-template-columns:1fr}

  /* Footer */
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .footer-bottom{flex-direction:column;gap:6px;text-align:center}

  /* Typography */
  .section-title{font-size:clamp(28px,7vw,42px)}
  .section-desc{font-size:14px}
}

/* ─── 480px — Small phones ───────────────────────────────── */
@media(max-width:480px){
  .section{padding:52px 0}
  .container{padding:0 16px}

  /* Hero */
  .hero-content{padding:84px 16px 28px}
  .hero-title{font-size:clamp(40px,12vw,58px)}
  .hero-tag{font-size:10px;letter-spacing:3px}
  .hero-sub{font-size:14px;max-width:100%}
  .hero-actions{flex-direction:column;align-items:flex-start;gap:10px}
  .btn-primary,.btn-ghost{width:100%;justify-content:center}
  .hero-scroll{display:none}

  /* Sections */
  .section-title{font-size:26px}
  .section-tag{font-size:10px;letter-spacing:3px}

  /* Stats strip */
  .stats-grid{grid-template-columns:1fr 1fr}
  .stat-card{padding:28px 12px}
  .stat-number{font-size:40px}
  .stat-icon{font-size:24px}

  /* Gallery */
  .gallery-grid{grid-template-columns:1fr}
  .gallery-large{grid-column:1;aspect-ratio:16/9}

  /* CTA */
  .cta-title{font-size:38px}
  .cta-bg-text{font-size:60px}
  .cta-content > p{font-size:14px}

  /* Coaches */
  .coaches-grid{max-width:100%}
  .coach-social{bottom:0}

  /* Mobile menu */
  .mobile-link{font-size:36px}

  /* Preloader */
  .preloader-logo img{width:88px;height:88px}

  /* About badge */
  .about-badge{bottom:-14px;right:-8px;padding:14px 16px}
  .badge-num{font-size:36px}

  /* Footer */
  .footer-logo{font-size:40px}
  .footer-brand p{max-width:100%}

  /* Buttons */
  .btn-primary.btn-large,.btn-ghost.btn-large{padding:15px 30px;font-size:13px}

  /* Form */
  .form-group input,.form-group textarea,.form-select-wrap select{font-size:16px}
}

/* ─── 360px — Very small phones ──────────────────────────── */
@media(max-width:360px){
  .hero-title{font-size:38px}
  .stats-grid{grid-template-columns:1fr}
  .stat-card{border-right:none!important;border-top:none!important;border-bottom:1px solid var(--border)}
  .stat-card:last-child{border-bottom:none}
  .nav-container{padding:0 14px}
}
