/* ============================================================
   FUSION GYM — style.css  (shared across all pages)
   ============================================================ */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

:root {
  --red: #e63946;
  --red-dark: #c1121f;
  --black: #0a0a0a;
  --off-black: #111111;
  --white: #ffffff;
  --off-white: #f5f4f0;
  --light-gray: #e8e8e8;
  --text: #1a1a1a;
  --text-light: #555;
  --nav-h: 70px;
  --tr: 0.3s cubic-bezier(0.4,0,0.2,1);
  --shadow: 0 8px 30px rgba(0,0,0,0.08);
  --shadow-lg: 0 25px 60px rgba(0,0,0,0.12);
  --fd: 'Bebas Neue', sans-serif;
  --fb: 'Barlow', sans-serif;
  --fc: 'Barlow Condensed', sans-serif;
  --r: 14px;
}

/* ── DARK MODE ── */
body.dark {
  --white: #0a0a0a; --off-white: #111;
  --text: #f0f0f0; --text-light: #999;
  --light-gray: #222;
}
body.dark .navbar { background: rgba(10,10,10,0.97); border-bottom-color: #1e1e1e; }
body.dark .section { background: #0a0a0a; }
body.dark .classes-section { background: #0f0f0f; }
body.dark .dark-section { background: #111; }
body.dark .page-hero { background: #111; }
body.dark .plan-card, body.dark .testi-card { background: #161616; border-color: #252525; }
body.dark .about-feat, body.dark .af-card { background: #161616; }
body.dark .trainer-spec span { background: #1e1e1e; }
body.dark .mobile-overlay { background: #0a0a0a; }
body.dark .tool-card { background: #161616; border-color: #252525; }
body.dark .t-input, body.dark .bmi-wrap input, body.dark select, body.dark textarea { background: #1e1e1e; border-color: #333; color: #f0f0f0; }
body.dark .history-li { background: #1e1e1e; }
body.dark .chart-empty { background: #1e1e1e; }
body.dark .cf-form { background: #161616; border-color: #252525; }
body.dark .info-card { background: #161616; }
body.dark .cta-strip { background: #161616; border-color: #252525; }
body.dark .footer-links-col ul li { color: #666; }
body.dark .hstat-div { background: rgba(255,255,255,0.1); }

html { scroll-behavior: smooth; }
body {
  font-family: var(--fb); background: var(--white);
  color: var(--text); line-height: 1.6;
  overflow-x: hidden; cursor: none;
}
@media (hover: none) { body { cursor: auto; } }

/* ── CURSOR ── */
.cursor { width:10px; height:10px; background:var(--red); border-radius:50%; position:fixed; top:0; left:0; pointer-events:none; z-index:9999; transform:translate(-50%,-50%); mix-blend-mode:difference; }
.cursor-follower { width:34px; height:34px; border:1.5px solid var(--red); border-radius:50%; position:fixed; top:0; left:0; pointer-events:none; z-index:9998; transform:translate(-50%,-50%); opacity:0.5; transition:all 0.14s ease; }
@media (hover:none) { .cursor, .cursor-follower { display:none; } }

/* ── LOADER ── */
.loader { position:fixed; inset:0; background:var(--black); z-index:99999; display:flex; align-items:center; justify-content:center; transition:opacity 0.5s, visibility 0.5s; }
.loader.hidden { opacity:0; visibility:hidden; pointer-events:none; }
.loader-text { font-family:var(--fd); font-size:2.2rem; color:#fff; letter-spacing:8px; display:block; margin-bottom:1.2rem; }
.loader-text span { color:var(--red); }
.loader-bar { width:180px; height:3px; background:#222; border-radius:2px; overflow:hidden; }
.loader-fill { height:100%; width:0; background:var(--red); animation:fill 1.8s ease forwards; }
@keyframes fill { to { width:100%; } }

/* ── UTILS ── */
.container { width:92%; max-width:1200px; margin:0 auto; }
.section { padding:6rem 0; background:var(--white); }
.dark-section { padding:6rem 0; background:var(--off-black); }
.classes-section { padding:6rem 0; background:var(--off-white); }
.red { color:var(--red) !important; }
.center { text-align:center; }
.section-label { font-family:var(--fc); font-size:0.8rem; letter-spacing:4px; font-weight:700; color:var(--red); text-transform:uppercase; margin-bottom:0.5rem; }
.section-h2 { font-family:var(--fd); font-size:clamp(2.2rem,5vw,3.8rem); line-height:1.05; color:var(--text); }
.section-h2.light { color:#fff; }
.section-sub { color:var(--text-light); margin-top:0.5rem; font-size:1rem; }
.section-sub.light { color:rgba(255,255,255,0.6); }

/* ── BUTTONS ── */
.btn-red { display:inline-flex; align-items:center; gap:8px; background:var(--red); color:#fff; padding:0.85rem 2rem; border:none; border-radius:4px; font-family:var(--fc); font-size:0.95rem; font-weight:700; letter-spacing:1px; text-transform:uppercase; cursor:pointer; text-decoration:none; transition:var(--tr); }
.btn-red:hover { background:var(--red-dark); transform:translateY(-2px); box-shadow:0 8px 25px rgba(230,57,70,0.4); }
.btn-ghost { display:inline-flex; align-items:center; gap:8px; background:transparent; color:#fff; padding:0.85rem 2rem; border:1.5px solid rgba(255,255,255,0.35); border-radius:4px; font-family:var(--fc); font-size:0.95rem; font-weight:700; letter-spacing:1px; text-transform:uppercase; cursor:pointer; text-decoration:none; transition:var(--tr); }
.btn-ghost:hover { border-color:#fff; background:rgba(255,255,255,0.08); }
.btn-ghost-dark { display:inline-flex; align-items:center; gap:8px; background:transparent; color:var(--text); padding:0.75rem 1.5rem; border:1.5px solid var(--light-gray); border-radius:4px; font-family:var(--fc); font-size:0.9rem; font-weight:700; letter-spacing:1px; text-transform:uppercase; cursor:pointer; text-decoration:none; transition:var(--tr); }
.btn-ghost-dark:hover { border-color:var(--red); color:var(--red); }
body.dark .btn-ghost-dark { color:#ccc; border-color:#333; }
body.dark .btn-ghost-dark:hover { border-color:var(--red); color:var(--red); }
.full-w { width:100%; justify-content:center; }

/* ── NAVBAR ── */
.navbar { position:fixed; top:0; left:0; right:0; height:var(--nav-h); background:rgba(255,255,255,0.97); backdrop-filter:blur(18px); border-bottom:1px solid var(--light-gray); z-index:1000; transition:var(--tr); }
.navbar.scrolled { box-shadow:0 4px 20px rgba(0,0,0,0.07); }
.nav-inner { height:100%; display:flex; align-items:center; justify-content:space-between; padding:0 2.5rem; max-width:1400px; margin:0 auto; }
.nav-logo { font-family:var(--fd); font-size:1.75rem; letter-spacing:2px; color:var(--text); text-decoration:none; display:flex; align-items:center; gap:8px; }
.nav-logo i { color:var(--red); font-size:1.3rem; }
.nav-logo span { color:var(--red); }
.nav-links { display:flex; align-items:center; gap:0.1rem; list-style:none; }
.nav-link { font-family:var(--fc); font-weight:700; font-size:0.88rem; letter-spacing:1px; text-transform:uppercase; color:var(--text); text-decoration:none; padding:0.45rem 0.85rem; border-radius:6px; transition:var(--tr); }
.nav-link:hover { color:var(--red); }
.nav-link.active-nav { color:var(--red); }
/* page-link indicator (BMI / Tracker links) */
.nav-page { position:relative; }
.nav-page::after { content:'↗'; font-size:0.6rem; margin-left:2px; opacity:0.5; }
.nav-cta { background:var(--red); color:#fff !important; padding:0.45rem 1.1rem; margin-left:0.4rem; }
.nav-cta:hover { background:var(--red-dark); }
.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:5px; }
.hamburger span { display:block; width:24px; height:2px; background:var(--text); border-radius:2px; transition:var(--tr); }
.hamburger.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ── MOBILE OVERLAY ── */
.mobile-overlay { position:fixed; inset:0; top:var(--nav-h); background:#fff; z-index:999; display:flex; align-items:center; justify-content:center; transform:translateX(-100%); transition:transform 0.4s cubic-bezier(0.4,0,0.2,1); }
.mobile-overlay.open { transform:translateX(0); }
.mobile-links { list-style:none; text-align:center; }
.mobile-links li { margin:1.4rem 0; }
.mobile-links a { font-family:var(--fd); font-size:2.4rem; letter-spacing:3px; color:var(--text); text-decoration:none; transition:color 0.2s; }
.mobile-links a:hover { color:var(--red); }
.mobile-cta { color:var(--red) !important; }

@media(max-width:900px){ .nav-links { display:none; } .hamburger { display:flex; } }

/* ── DARK + SCROLL BTNS ── */
.dark-toggle, .scroll-top { position:fixed; width:46px; height:46px; border-radius:50%; border:none; cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:1.05rem; z-index:998; transition:var(--tr); box-shadow:0 4px 14px rgba(0,0,0,0.15); }
.dark-toggle { bottom:1.8rem; left:1.8rem; background:var(--text); color:var(--white); }
.dark-toggle:hover { background:var(--red); }
.scroll-top { bottom:1.8rem; right:1.8rem; background:var(--red); color:#fff; opacity:0; visibility:hidden; }
.scroll-top.visible { opacity:1; visibility:visible; }
.scroll-top:hover { background:var(--red-dark); transform:translateY(-3px); }

/* ── HERO (homepage) ── */
.hero { min-height:100svh; position:relative; display:flex; align-items:center; justify-content:center; overflow:hidden; padding-top:var(--nav-h); }
.hero-bg { position:absolute; inset:0; background:url('https://static.vecteezy.com/system/resources/thumbnails/056/157/720/small/dynamic-fitness-advertisement-showcases-unique-geolocation-pin-crafted-from-gym-weights-and-kettlebells-set-in-dark-industrial-style-gym-bright-lighting-highlights-equipment-s-details-photo.jpeg') center/cover no-repeat; }
.hero-gradient { position:absolute; inset:0; background:linear-gradient(135deg,rgba(0,0,0,0.88) 0%,rgba(0,0,0,0.6) 60%,rgba(0,0,0,0.45) 100%); }
.hero-content { position:relative; z-index:2; text-align:center; padding:2rem 1rem; max-width:900px; }
.hero-badge { display:inline-flex; align-items:center; gap:6px; background:rgba(230,57,70,0.18); border:1px solid rgba(230,57,70,0.45); color:#fff; padding:0.35rem 1rem; border-radius:100px; font-family:var(--fc); font-size:0.82rem; letter-spacing:2px; text-transform:uppercase; margin-bottom:1.5rem; animation:fadeDown 0.8s ease 0.2s both; }
.hero-badge i { color:var(--red); }
.hero-title { font-family:var(--fd); font-size:clamp(5rem,14vw,11rem); line-height:0.93; letter-spacing:4px; color:#fff; display:flex; flex-direction:column; }
.hero-line { display:block; overflow:hidden; }
.hero-line em { display:block; font-style:normal; transform:translateY(110%); animation:slideUp 0.8s cubic-bezier(0.16,1,0.3,1) forwards; }
.hero-line:nth-child(1) em { animation-delay:0.35s; }
.hero-line:nth-child(2) em { animation-delay:0.5s; }
.hero-line:nth-child(3) em { animation-delay:0.65s; }
.hero-line.accent { color:var(--red); }
.hero-sub { color:rgba(255,255,255,0.72); font-size:1.05rem; margin:1.4rem auto 2rem; max-width:480px; animation:fadeUp 0.8s ease 0.9s both; font-weight:300; }
.hero-actions { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; animation:fadeUp 0.8s ease 1.1s both; }
.hero-scroll-hint { position:absolute; bottom:120px; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:7px; color:rgba(255,255,255,0.45); font-family:var(--fc); font-size:0.7rem; letter-spacing:3px; text-transform:uppercase; animation:fadeUp 1s ease 1.5s both; z-index:2; }
.scroll-line { width:1px; height:38px; background:linear-gradient(to bottom,rgba(255,255,255,0.45),transparent); animation:scrl 1.5s ease infinite; }
@keyframes scrl { 0%,100%{opacity:1;transform:scaleY(1)} 50%{opacity:0.3;transform:scaleY(0.5)} }
.hero-stats-bar { position:absolute; bottom:0; left:0; right:0; background:rgba(10,10,10,0.9); backdrop-filter:blur(10px); padding:1.2rem 2rem; display:flex; justify-content:center; align-items:center; gap:3rem; z-index:2; flex-wrap:wrap; animation:fadeUp 0.8s ease 1.3s both; }
.hstat { text-align:center; }
.hnum { display:block; font-family:var(--fd); font-size:1.75rem; color:#fff; letter-spacing:1px; }
.hlbl { display:block; font-family:var(--fc); font-size:0.7rem; color:#777; letter-spacing:2px; text-transform:uppercase; }
.hstat-div { width:1px; height:38px; background:rgba(255,255,255,0.1); }

/* ── TICKER ── */
.ticker-wrap { overflow:hidden; background:var(--red); padding:0.75rem 0; }
.ticker-track { display:inline-flex; gap:2rem; animation:tick 25s linear infinite; white-space:nowrap; }
.ticker-track span { font-family:var(--fd); font-size:0.95rem; letter-spacing:3px; color:#fff; text-transform:uppercase; }
.ticker-track .dot { color:rgba(255,255,255,0.45); }
@keyframes tick { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ── ABOUT ── */
.about-layout { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.about-img-wrap { position:relative; border-radius:var(--r); overflow:hidden; }
.about-img-wrap img { width:100%; height:570px; object-fit:cover; display:block; }
.about-badge-float { position:absolute; bottom:1.8rem; right:-1.2rem; background:var(--red); color:#fff; padding:0.9rem 1.3rem; border-radius:var(--r); text-align:center; box-shadow:0 8px 28px rgba(230,57,70,0.4); }
.about-badge-float i { font-size:1.4rem; display:block; margin-bottom:0.2rem; }
.about-badge-float span { display:block; font-family:var(--fd); font-size:1.1rem; }
.about-badge-float small { font-size:0.72rem; opacity:0.85; }
.about-feature-cards { display:flex; gap:1rem; margin-top:1.3rem; }
.af-card { flex:1; background:var(--off-white); border-radius:8px; padding:0.9rem 1rem; display:flex; align-items:center; gap:0.7rem; font-family:var(--fc); font-weight:700; font-size:0.88rem; }
.af-card i { color:var(--red); font-size:1.1rem; }
.about-p { color:var(--text-light); font-size:1rem; margin:1.1rem 0 1.8rem; line-height:1.8; }
.about-features { display:flex; flex-direction:column; gap:0.9rem; margin-bottom:2rem; }
.about-feat { display:flex; align-items:flex-start; gap:1rem; background:var(--off-white); padding:0.9rem 1.1rem; border-radius:8px; transition:var(--tr); }
.about-feat:hover { transform:translateX(5px); }
.feat-icon { width:42px; height:42px; border-radius:10px; background:var(--red); display:flex; align-items:center; justify-content:center; color:#fff; font-size:1rem; flex-shrink:0; }
.about-feat strong { display:block; font-weight:700; font-size:0.95rem; }
.about-feat p { font-size:0.85rem; color:var(--text-light); margin:0; }
.counter-row { display:flex; gap:2.5rem; padding-top:2rem; border-top:1px solid var(--light-gray); }
.ctr { text-align:center; }
.ctr .counter, .ctr > span:not(small) { font-family:var(--fd); font-size:2.4rem; color:var(--red); }
.ctr small { display:block; font-family:var(--fc); font-size:0.75rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-light); margin-top:0.2rem; }

/* ── CLASSES ── */
.classes-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; margin-top:3rem; }
.class-card { border-radius:var(--r); overflow:hidden; height:350px; position:relative; background:var(--img) center/cover no-repeat; cursor:pointer; transition:var(--tr); }
.class-card:hover { transform:scale(1.02); }
.class-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,0.85) 0%,rgba(0,0,0,0.1) 55%); transition:var(--tr); }
.class-card:hover .class-overlay { background:linear-gradient(to top,rgba(0,0,0,0.92) 0%,rgba(0,0,0,0.25) 100%); }
.class-content { position:absolute; bottom:0; left:0; right:0; padding:1.4rem; transition:transform 0.3s ease; color:#fff; }
.class-card:hover .class-content { transform:translateY(-8px); }
.class-icon { width:40px; height:40px; border-radius:9px; background:var(--red); display:flex; align-items:center; justify-content:center; font-size:1.1rem; margin-bottom:0.6rem; }
.class-content h3 { font-family:var(--fd); font-size:1.7rem; letter-spacing:2px; }
.class-content p { font-size:0.82rem; color:rgba(255,255,255,0.65); margin-top:0.2rem; }

/* ── PLANS ── */
.plans-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.8rem; margin-top:3rem; }
.plan-card { background:#1a1a1a; border:1px solid #252525; border-radius:var(--r); padding:2.3rem; position:relative; transition:var(--tr); }
.plan-card:hover { transform:translateY(-6px); border-color:#3a3a3a; }
.plan-card.featured { border-color:var(--red); background:#1c1010; transform:scale(1.02); }
.plan-card.featured:hover { transform:scale(1.02) translateY(-6px); }
.featured-badge { position:absolute; top:-13px; left:50%; transform:translateX(-50%); background:var(--red); color:#fff; font-family:var(--fc); font-size:0.72rem; font-weight:700; letter-spacing:2px; text-transform:uppercase; padding:0.28rem 1.1rem; border-radius:100px; }
.plan-top { display:flex; align-items:center; gap:1rem; margin-bottom:1.4rem; }
.plan-icon { width:48px; height:48px; background:rgba(255,255,255,0.05); border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:1.3rem; color:#777; }
.plan-icon.red-icon { background:rgba(230,57,70,0.15); color:var(--red); }
.plan-name { font-family:var(--fd); font-size:1.35rem; letter-spacing:2px; color:#fff; }
.plan-tag { font-family:var(--fc); font-size:0.7rem; letter-spacing:2px; color:#555; text-transform:uppercase; }
.plan-price { font-family:var(--fd); font-size:2.9rem; color:#fff; letter-spacing:1px; }
.plan-price.red { color:var(--red); }
.plan-price span { font-family:var(--fb); font-size:0.95rem; color:#666; }
.plan-divider { height:1px; background:#2a2a2a; margin:1.4rem 0; }
.plan-divider.red-div { background:rgba(230,57,70,0.3); }
.plan-list { list-style:none; display:flex; flex-direction:column; gap:0.75rem; margin-bottom:1.8rem; }
.plan-list li { display:flex; align-items:center; gap:0.6rem; font-size:0.92rem; }
.plan-list li.ok { color:#ccc; }
.plan-list li.no { color:#484848; }
.plan-list li.ok i { color:#4ade80; width:16px; }
.plan-list li.no i { color:#484848; width:16px; }
.plan-btn { display:block; width:100%; padding:0.8rem; border-radius:4px; font-family:var(--fc); font-size:0.9rem; font-weight:700; letter-spacing:1px; text-transform:uppercase; cursor:pointer; transition:var(--tr); background:transparent; color:#777; border:1px solid #333; text-align:center; text-decoration:none; }
.plan-btn:hover { border-color:#fff; color:#fff; }
.plan-btn.plan-btn-red { background:var(--red); color:#fff; border-color:var(--red); }
.plan-btn.plan-btn-red:hover { background:var(--red-dark); }

/* ── TRAINERS ── */
.trainers-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; margin-top:3rem; }
.trainer-card { border-radius:var(--r); overflow:hidden; transition:var(--tr); }
.trainer-card:hover { transform:translateY(-7px); }
.trainer-img-wrap { position:relative; overflow:hidden; }
.trainer-img-wrap img { width:100%; height:300px; object-fit:cover; display:block; transition:transform 0.5s ease; }
.trainer-card:hover .trainer-img-wrap img { transform:scale(1.05); }
.trainer-social { position:absolute; inset:0; background:rgba(230,57,70,0.85); display:flex; align-items:center; justify-content:center; gap:1.2rem; opacity:0; transition:var(--tr); }
.trainer-card:hover .trainer-social { opacity:1; }
.trainer-social a { color:#fff; font-size:1.3rem; transition:transform 0.2s; }
.trainer-social a:hover { transform:scale(1.2); }
.trainer-info { padding:1.1rem 0; }
.trainer-info h3 { font-family:var(--fc); font-size:1.1rem; font-weight:800; letter-spacing:1px; }
.trainer-info p { color:var(--text-light); font-size:0.88rem; margin:0.2rem 0 0.6rem; }
.trainer-spec { display:flex; gap:0.4rem; flex-wrap:wrap; }
.trainer-spec span { background:var(--off-white); color:var(--text-light); font-size:0.7rem; font-family:var(--fc); letter-spacing:1px; text-transform:uppercase; font-weight:700; padding:0.18rem 0.65rem; border-radius:100px; }

/* ── GALLERY ── */
.filter-row { display:flex; justify-content:center; gap:0.7rem; margin:2rem 0; flex-wrap:wrap; }
.f-btn { padding:0.45rem 1.4rem; border-radius:4px; font-family:var(--fc); font-size:0.8rem; font-weight:700; letter-spacing:2px; text-transform:uppercase; background:transparent; border:1px solid #444; color:#888; cursor:pointer; transition:var(--tr); }
.f-btn:hover, .f-btn.active { background:var(--red); border-color:var(--red); color:#fff; }
.gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; }
.g-item { border-radius:var(--r); overflow:hidden; position:relative; cursor:pointer; }
.g-item img { width:100%; height:250px; object-fit:cover; display:block; transition:transform 0.5s ease; }
.g-item:hover img { transform:scale(1.06); }
.g-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,0.82) 0%,transparent 55%); display:flex; flex-direction:column; justify-content:flex-end; padding:1.1rem; opacity:0; transition:opacity 0.3s; }
.g-item:hover .g-overlay { opacity:1; }
.g-tag { font-family:var(--fc); font-size:0.68rem; letter-spacing:2px; color:var(--red); text-transform:uppercase; margin-bottom:0.25rem; }
.g-result { color:#fff; font-weight:600; font-size:0.9rem; }

/* ── TESTIMONIALS ── */
.testi-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.8rem; margin-top:3rem; }
.testi-card { background:var(--off-white); border-radius:var(--r); padding:1.8rem; border-top:3px solid var(--red); transition:var(--tr); }
.testi-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.testi-stars { color:var(--red); font-size:0.95rem; margin-bottom:0.9rem; letter-spacing:2px; }
.testi-text { color:var(--text-light); font-size:0.93rem; line-height:1.75; margin-bottom:1.3rem; font-style:italic; }
.testi-author { display:flex; align-items:center; gap:0.75rem; }
.testi-author img { width:42px; height:42px; border-radius:50%; object-fit:cover; border:2px solid var(--red); }
.testi-author strong { display:block; font-weight:700; font-size:0.92rem; }
.testi-author small { color:var(--text-light); font-size:0.78rem; }

/* ── CTA STRIP ── */
.cta-strip { display:flex; align-items:center; justify-content:space-between; gap:2rem; margin-top:4rem; padding:2.5rem; border-radius:var(--r); border:1px solid var(--light-gray); background:var(--off-white); flex-wrap:wrap; }
.cta-strip-text h3 { font-family:var(--fd); font-size:1.9rem; }
.cta-strip-text p { color:var(--text-light); margin-top:0.3rem; }
.cta-strip-actions { display:flex; gap:0.8rem; flex-wrap:wrap; }

/* ── PAGE HERO (for sub-pages) ── */
.page-hero { padding:calc(var(--nav-h) + 3rem) 0 3.5rem; background:var(--off-white); border-bottom:1px solid var(--light-gray); }
.page-hero-inner { display:flex; align-items:flex-end; justify-content:space-between; gap:2rem; flex-wrap:wrap; }
.page-breadcrumb { font-family:var(--fc); font-size:0.78rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-light); margin-bottom:0.6rem; }
.page-breadcrumb a { color:var(--red); text-decoration:none; }
.page-hero h1 { font-family:var(--fd); font-size:clamp(2.8rem,6vw,5rem); line-height:1; }
.page-hero p { color:var(--text-light); font-size:1rem; margin-top:0.7rem; max-width:500px; }
.page-hero-icon { font-size:4rem; color:var(--red); opacity:0.12; }

/* ── TOOL CARD (BMI / Tracker container) ── */
.tool-card { background:#fff; border:1px solid var(--light-gray); border-radius:var(--r); padding:2.5rem; box-shadow:var(--shadow); }

/* ── BMI PAGE ── */
.bmi-layout { display:grid; grid-template-columns:1.1fr 1fr; gap:2.5rem; margin-top:2rem; align-items:start; }
.bmi-field label { display:block; font-family:var(--fc); font-size:0.78rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-light); margin-bottom:0.45rem; font-weight:700; }
.bmi-wrap { display:flex; align-items:center; background:var(--off-white); border:1px solid var(--light-gray); border-radius:6px; overflow:hidden; transition:border-color 0.2s; }
.bmi-wrap:focus-within { border-color:var(--red); }
.bmi-wrap input { flex:1; background:transparent; border:none; outline:none; padding:0.85rem 1rem; font-family:var(--fb); font-size:1rem; color:var(--text); }
.bmi-unit { padding:0 0.9rem; font-family:var(--fc); font-size:0.82rem; letter-spacing:1px; color:#aaa; border-left:1px solid var(--light-gray); }
.bmi-fields { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin-bottom:1.4rem; }
.bmi-result-box { margin-top:2rem; padding:2rem; background:var(--off-white); border-radius:var(--r); text-align:center; display:none; }
body.dark .bmi-result-box { background:#111; }
.bmi-big-num { font-family:var(--fd); font-size:5.5rem; color:var(--red); line-height:1; letter-spacing:2px; }
.bmi-cat-label { font-family:var(--fc); font-size:1.1rem; letter-spacing:3px; text-transform:uppercase; color:var(--text-light); margin:0.5rem 0 1.5rem; }
.bmi-scale { position:relative; }
.bmi-bar-track { height:10px; border-radius:100px; background:linear-gradient(to right,#3b82f6,#22c55e,#f59e0b,#ef4444); position:relative; overflow:visible; }
.bmi-pin { position:absolute; top:50%; width:18px; height:18px; border-radius:50%; background:#fff; border:3px solid var(--red); transform:translate(-50%,-50%); transition:left 0.6s cubic-bezier(0.4,0,0.2,1); box-shadow:0 0 10px rgba(230,57,70,0.5); left:0; }
.bmi-scale-labels { display:flex; justify-content:space-between; font-size:0.68rem; color:#aaa; margin-top:0.4rem; font-family:var(--fc); letter-spacing:1px; }
.bmi-advice-text { font-size:0.88rem; color:var(--text-light); margin-top:1.1rem; font-style:italic; }
.bmi-info-panel h3 { font-family:var(--fd); font-size:1.7rem; margin-bottom:1.3rem; }
.bmi-ranges { display:flex; flex-direction:column; gap:0.8rem; }
.bmi-rng { display:flex; align-items:center; gap:1rem; padding:0.85rem 1.1rem; border-radius:8px; background:var(--off-white); border-left:3px solid transparent; }
body.dark .bmi-rng { background:#111; }
.bmi-rng.u { border-left-color:#3b82f6; } .bmi-rng.n { border-left-color:#22c55e; } .bmi-rng.o { border-left-color:#f59e0b; } .bmi-rng.ob { border-left-color:#ef4444; }
.bmi-dot2 { width:9px; height:9px; border-radius:50%; flex-shrink:0; }
.bmi-rng.u .bmi-dot2{background:#3b82f6;} .bmi-rng.n .bmi-dot2{background:#22c55e;} .bmi-rng.o .bmi-dot2{background:#f59e0b;} .bmi-rng.ob .bmi-dot2{background:#ef4444;}
.bmi-rng strong { display:block; font-size:0.9rem; }
.bmi-rng small { color:var(--text-light); font-size:0.78rem; }
.bmi-note { font-size:0.82rem; color:var(--text-light); margin-top:1.4rem; font-style:italic; padding-top:1rem; border-top:1px solid var(--light-gray); }
.bmi-err { color:var(--red); font-size:0.8rem; margin-top:0.3rem; min-height:1rem; }

/* ── TRACKER PAGE ── */
.tracker-layout { display:grid; grid-template-columns:1fr 1.6fr; gap:2rem; margin-top:2rem; }
.tf-group { margin-bottom:1rem; }
.tf-group label { display:block; font-family:var(--fc); font-size:0.78rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-light); margin-bottom:0.4rem; font-weight:700; }
.t-input { width:100%; padding:0.8rem 1rem; border:1px solid var(--light-gray); border-radius:6px; font-family:var(--fb); font-size:0.95rem; color:var(--text); background:var(--off-white); outline:none; transition:border-color 0.2s; }
.t-input:focus { border-color:var(--red); }
.pv-head { display:flex; justify-content:space-between; align-items:center; margin-bottom:0.4rem; font-family:var(--fc); font-size:0.75rem; letter-spacing:1px; text-transform:uppercase; color:var(--text-light); }
.pv-pct { color:var(--red); font-weight:700; }
.pv-bg { height:8px; background:var(--light-gray); border-radius:100px; overflow:hidden; }
.pv-fill { height:100%; width:0; background:var(--red); border-radius:100px; transition:width 0.5s ease; }
.pv-status { font-size:0.82rem; color:var(--text-light); margin-top:0.5rem; }
.chart-wrap { margin-bottom:1rem; }
.chart-empty { height:170px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:0.5rem; color:var(--text-light); background:var(--off-white); border-radius:8px; }
.chart-empty i { font-size:1.8rem; opacity:0.25; }
.chart-empty p { font-size:0.82rem; opacity:0.45; }
#weightCanvas { border-radius:8px; max-width:100%; height:auto !important; }
.history-list { list-style:none; max-height:210px; overflow-y:auto; display:flex; flex-direction:column; gap:0.45rem; margin-top:1rem; }
.history-li { display:flex; justify-content:space-between; align-items:center; background:var(--off-white); padding:0.55rem 0.9rem; border-radius:6px; font-size:0.88rem; }
.e-date { font-family:var(--fc); letter-spacing:1px; font-size:0.82rem; color:var(--text-light); }
.e-wt { font-weight:700; color:var(--red); }
.e-del { color:#aaa; cursor:pointer; padding:0.15rem 0.45rem; border-radius:4px; font-size:0.78rem; transition:0.2s; }
.e-del:hover { background:var(--red); color:#fff; }
.clear-btn { display:flex; align-items:center; gap:0.4rem; justify-content:center; margin-top:0.8rem; width:100%; padding:0.55rem; background:transparent; border:1px dashed #aaa; color:#aaa; border-radius:6px; cursor:pointer; font-size:0.82rem; transition:0.2s; }
.clear-btn:hover { border-color:var(--red); color:var(--red); }
.tracker-tips { margin-top:2rem; }
.tracker-tips h4 { font-family:var(--fc); font-size:0.8rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-light); margin-bottom:0.8rem; }
.tip-item { display:flex; align-items:center; gap:0.6rem; padding:0.6rem 0.8rem; background:var(--off-white); border-radius:6px; font-size:0.85rem; margin-bottom:0.5rem; }
body.dark .tip-item { background:#111; }
.tip-item i { color:var(--red); width:14px; flex-shrink:0; }

/* ── JOIN US PAGE ── */
.join-layout { display:grid; grid-template-columns:1fr 1.4fr; gap:4rem; margin-top:2rem; align-items:start; }
.info-card { background:var(--off-white); border-radius:var(--r); padding:1.5rem; margin-bottom:1rem; }
.info-card h4 { font-family:var(--fc); font-size:0.85rem; letter-spacing:2px; text-transform:uppercase; margin-bottom:0.9rem; color:var(--text-light); }
.cd-row { display:flex; align-items:center; gap:0.8rem; color:var(--text-light); font-size:0.9rem; margin-bottom:0.6rem; }
.cd-row i { color:var(--red); width:16px; }
.social-row { display:flex; gap:0.7rem; margin-top:1rem; }
.social-row a { width:38px; height:38px; border-radius:50%; border:1px solid var(--light-gray); display:flex; align-items:center; justify-content:center; color:var(--text-light); font-size:0.95rem; transition:var(--tr); }
.social-row a:hover { background:var(--red); border-color:var(--red); color:#fff; }
.plan-chip { display:inline-flex; align-items:center; gap:0.5rem; background:rgba(230,57,70,0.1); color:var(--red); padding:0.3rem 0.9rem; border-radius:100px; font-family:var(--fc); font-size:0.78rem; letter-spacing:1px; font-weight:700; text-transform:uppercase; margin-bottom:1.5rem; }
.cf-form { background:var(--white); border:1px solid var(--light-gray); border-radius:var(--r); padding:2.5rem; box-shadow:var(--shadow); }
.cf-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin-bottom:1rem; }
.cf-field { display:flex; flex-direction:column; }
.cf-field.full { margin-bottom:1rem; }
.cf-field input, .cf-field textarea, .cf-field select { padding:0.85rem 1.1rem; border:1px solid var(--light-gray); background:var(--off-white); border-radius:6px; font-family:var(--fb); font-size:0.93rem; color:var(--text); outline:none; transition:border-color 0.2s; width:100%; }
.cf-field input:focus, .cf-field textarea:focus, .cf-field select:focus { border-color:var(--red); }
.cf-field textarea { resize:vertical; min-height:110px; }
.cf-err { font-size:0.75rem; color:var(--red); margin-top:0.25rem; min-height:1rem; }
.cf-success { text-align:center; margin-top:1rem; color:#22c55e; font-family:var(--fc); letter-spacing:1px; font-size:0.9rem; min-height:1.4rem; }

/* ── FOOTER ── */
.footer { background:var(--black); padding:5rem 0 2rem; }
.footer-top { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:3rem; padding-bottom:3rem; border-bottom:1px solid #1a1a1a; }
.footer-logo { font-family:var(--fd); font-size:1.9rem; letter-spacing:2px; color:#fff; display:flex; align-items:center; gap:8px; margin-bottom:0.9rem; }
.footer-logo i { color:var(--red); }
.footer-logo span { color:var(--red); }
.footer-brand p { color:#444; font-size:0.88rem; line-height:1.7; max-width:260px; }
.footer-links-col h4 { font-family:var(--fc); font-size:0.75rem; letter-spacing:3px; text-transform:uppercase; color:#444; margin-bottom:0.9rem; }
.footer-links-col ul { list-style:none; display:flex; flex-direction:column; gap:0.55rem; }
.footer-links-col ul li { font-size:0.88rem; color:#444; }
.footer-links-col ul li a { color:#444; text-decoration:none; transition:color 0.2s; }
.footer-links-col ul li a:hover { color:var(--red); }
.footer-bottom { padding-top:2rem; text-align:center; color:#2a2a2a; font-size:0.82rem; }
.footer-bottom i.red { color:var(--red); }

/* ── SCROLL REVEAL ── */
.reveal { opacity:0; transform:translateY(35px); transition:opacity 0.65s ease, transform 0.65s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-left { opacity:0; transform:translateX(-35px); transition:opacity 0.7s ease, transform 0.7s ease; }
.reveal-left.visible { opacity:1; transform:translateX(0); }
.reveal-right { opacity:0; transform:translateX(35px); transition:opacity 0.7s ease, transform 0.7s ease; }
.reveal-right.visible { opacity:1; transform:translateX(0); }

/* ── ANIMATIONS ── */
@keyframes fadeDown { from{opacity:0;transform:translateY(-14px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeUp { from{opacity:0;transform:translateY(18px)} to{opacity:1;transform:translateY(0)} }
@keyframes slideUp { from{transform:translateY(110%)} to{transform:translateY(0)} }

/* ── RESPONSIVE ── */
@media(max-width:1100px) {
  .about-layout { grid-template-columns:1fr; gap:2.5rem; }
  .about-img-wrap img { height:400px; }
  .classes-grid { grid-template-columns:repeat(2,1fr); }
  .plans-grid { grid-template-columns:1fr; max-width:380px; margin-left:auto; margin-right:auto; }
  .plan-card.featured { transform:none; }
  .trainers-grid { grid-template-columns:repeat(2,1fr); }
  .gallery-grid { grid-template-columns:repeat(2,1fr); }
  .testi-grid { grid-template-columns:1fr 1fr; }
  .bmi-layout { grid-template-columns:1fr; }
  .tracker-layout { grid-template-columns:1fr; }
  .join-layout { grid-template-columns:1fr; gap:2rem; }
  .footer-top { grid-template-columns:1fr 1fr; gap:2rem; }
}
@media(max-width:700px) {
  .classes-grid { grid-template-columns:1fr; }
  .gallery-grid { grid-template-columns:1fr; }
  .testi-grid { grid-template-columns:1fr; }
  .cf-row { grid-template-columns:1fr; }
  .bmi-fields { grid-template-columns:1fr; }
  .hero-stats-bar { gap:1.2rem; }
  .hstat-div { display:none; }
  .cta-strip { flex-direction:column; align-items:flex-start; }
  .footer-top { grid-template-columns:1fr; }
  .counter-row { gap:1.5rem; }
  .about-feature-cards { flex-direction:column; }
}
@media(max-width:480px) {
  .trainers-grid { grid-template-columns:1fr; }
  .hero-title { font-size:clamp(4rem,18vw,6rem); }
  .hero-actions { flex-direction:column; align-items:center; }
}

::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:var(--black); }
::-webkit-scrollbar-thumb { background:var(--red); border-radius:3px; }
/* ===== NEW: CTA STRIP & BUTTONS (for testimonial section) ===== */
.cta-strip {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  background: var(--off-white);
  border-radius: var(--radius);
  padding: 2rem 2.5rem;
  margin-top: 3rem;
  gap: 1.5rem;
  border: 1px solid var(--light-gray);
}
.cta-strip-text h3 {
  font-family: var(--font-display);
  font-size: 1.8rem;
  letter-spacing: 1px;
  color: var(--text);
}
.cta-strip-text p {
  color: var(--text-light);
  margin-top: 0.2rem;
}
.cta-strip-actions {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}
.btn-ghost-dark {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: transparent;
  color: var(--text);
  padding: 0.7rem 1.5rem;
  border: 1.5px solid var(--light-gray);
  border-radius: 4px;
  font-family: var(--font-cond);
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
  text-decoration: none;
  transition: var(--transition);
}
.btn-ghost-dark:hover {
  border-color: var(--red);
  color: var(--red);
  background: rgba(230, 57, 70, 0.05);
}

/* Dark mode support for new elements */
body.dark .cta-strip {
  background: #1e1e1e;
  border-color: #2a2a2a;
}
body.dark .btn-ghost-dark {
  border-color: #444;
  color: #ccc;
}
body.dark .btn-ghost-dark:hover {
  border-color: var(--red);
  color: var(--red);
}

/* Responsive for cta-strip */
@media (max-width: 1100px) {
  .cta-strip {
    flex-direction: column;
    text-align: center;
  }
  .cta-strip-actions {
    justify-content: center;
  }
}

/* Make testimonial images clickable + scale effect (optional but nice) */
.testi-author img {
  cursor: pointer;
  transition: transform 0.2s;
}
.testi-author img:hover {
  transform: scale(1.05);
}