/* Theme - Dark Mode (Default) */
:root{
  --bg:#0b0b0b;
  --panel:#101214;
  --text:#e6e9ef;
  --muted:#a6adbb;
  --green:#00c853;
  --green-600:#00a844;
  --green-light:#7cffc0;
  --border:#1a1f24;
  --shadow:0 10px 30px rgba(0,0,0,.35);
  --card-bg:linear-gradient(180deg,#0f1114,#0b0d0f);
  --hero-badge-bg:rgba(124,255,192,0.1);
  --hero-badge-border:rgba(124,255,192,0.2);
  --stats-bg:radial-gradient(120% 120% at 0% 0%, #0f1e15 0%, #0b100d 60%);
  --cta-bg:radial-gradient(120% 100% at 0% 0%, #0e160f, #0b0b0b);
}

/* Light Mode */
[data-theme="light"]{
  --bg:#ffffff;
  --panel:#f8f9fa;
  --text:#1a1f24;
  --muted:#6b7280;
  --green:#00c853;
  --green-600:#00a844;
  --green-light:#00a844;
  --border:#e5e7eb;
  --shadow:0 10px 30px rgba(0,0,0,.08);
  --card-bg:linear-gradient(180deg,#ffffff,#f8f9fa);
  --hero-badge-bg:rgba(0,200,83,0.1);
  --hero-badge-border:rgba(0,200,83,0.2);
  --stats-bg:linear-gradient(180deg,#f0fdf4 0%, #ffffff 60%);
  --cta-bg:linear-gradient(180deg,#f0fdf4, #ffffff);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{height:100%}
body{
  margin:0;
  padding-top:72px;
  background:var(--bg);
  background-image:linear-gradient(180deg,var(--bg) 0%, var(--bg) 60%);
  color:var(--text);
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,Apple Color Emoji,Segoe UI Emoji;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  transition:background-color 0.3s ease, color 0.3s ease;
}

.container{max-width:1200px;margin:0 auto;padding:0 24px;background:transparent}
.sr-only{position:absolute;width:1px;height:1px;margin:-1px;clip:rect(0,0,0,0);overflow:hidden;border:0;padding:0}

/* Header */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  backdrop-filter:saturate(160%) blur(10px);
  background:rgba(11,11,11,.6);
  transition:background-color 0.3s ease, border-color 0.3s ease;
}
[data-theme="light"] .site-header{
  background:rgba(255,255,255,.8);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:10px;color:var(--text);text-decoration:none;font-weight:700;letter-spacing:.2px;font-size:20px}
.brand-logo{height:42px;width:auto;display:block}
.brand-logo-dark{display:block}
.brand-logo-light{display:none}
[data-theme="light"] .brand-logo-dark{display:none}
[data-theme="light"] .brand-logo-light{display:block}
.brand-mark{display:inline-block;width:12px;height:12px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--green-light))}
.brand-text{font-size:20px}

.nav-toggle{display:none;align-items:center;justify-content:center;gap:8px;padding:0 12px;height:40px;border:1px solid var(--border);border-radius:10px;background:var(--panel);color:var(--text);cursor:pointer;transition:all 0.2s;position:relative;font-weight:600;font-size:14px}
.nav-toggle:hover{background:var(--bg);border-color:var(--green);transform:scale(1.05)}
.nav-toggle[aria-expanded="true"]{background:var(--green);border-color:var(--green);color:#fff}
.nav-toggle[aria-expanded="true"] .nav-burger{background:transparent}
.nav-toggle[aria-expanded="true"] .nav-burger:before{transform:rotate(45deg);top:0;background:#fff}
.nav-toggle[aria-expanded="true"] .nav-burger:after{transform:rotate(-45deg);top:0;background:#fff}
.nav-burger, .nav-burger:before, .nav-burger:after{display:block;background:var(--text);height:2px;width:18px;border-radius:2px;position:relative;transition:all 0.3s ease;flex-shrink:0}
.nav-toggle[aria-expanded="true"] .nav-burger, .nav-toggle[aria-expanded="true"] .nav-burger:before, .nav-toggle[aria-expanded="true"] .nav-burger:after{background:#fff}
.nav-burger:before,.nav-burger:after{content:"";position:absolute;left:0}
.nav-burger:before{top:-6px}.nav-burger:after{top:6px}

.nav-list{display:flex;gap:28px;list-style:none;margin:0;padding:0}
@media (min-width: 1025px){
  .nav-list{display:flex !important}
  .nav-list-cta{display:none !important}
}
@media (max-width: 1024px){
  .nav-list:not(.show){
    display:none !important;
  }
}
.nav-list a{color:var(--muted);text-decoration:none;font-weight:600;transition:all 0.2s;position:relative;padding:4px 0}
.nav-list a:hover{color:var(--text)}
.nav-list a::after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--green);transition:width 0.3s ease}
.nav-list a:hover::after{width:100%}
.nav-list a.active{color:var(--green)}
.nav-list a.active::after{width:100%}

.header-ctas{display:flex;gap:12px;align-items:center}
.theme-toggle{
  display:flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
  border:1px solid var(--border);
  border-radius:10px;
  background:var(--panel);
  color:var(--text);
  cursor:pointer;
  transition:all 0.2s;
  position:relative;
}
.theme-toggle:hover{
  border-color:var(--green);
  transform:translateY(-1px);
}
.theme-icon{
  position:absolute;
  transition:opacity 0.3s, transform 0.3s;
}
.theme-icon-sun{
  opacity:0;
  transform:rotate(90deg);
}
.theme-icon-moon{
  opacity:1;
  transform:rotate(0deg);
}
[data-theme="light"] .theme-icon-sun{
  opacity:1;
  transform:rotate(0deg);
}
[data-theme="light"] .theme-icon-moon{
  opacity:0;
  transform:rotate(-90deg);
}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;height:44px;padding:0 20px;border-radius:12px;border:1px solid var(--border);color:var(--text);text-decoration:none;font-weight:600;background:var(--panel);box-shadow:var(--shadow);transition:all 0.2s;cursor:pointer}
.btn:hover{transform:translateY(-1px);box-shadow:0 12px 35px rgba(0,0,0,.4)}
.btn-primary{background:linear-gradient(180deg,var(--green),var(--green-600));border-color:transparent;color:#ffffff}
.btn-ghost{background:transparent}

/* Store badges */
.store-badges{display:flex;gap:12px;flex-wrap:wrap}
.store-badge{display:flex;align-items:center;gap:10px;background:#0c0f0d;border:1px solid var(--border);border-radius:12px;padding:8px 12px;text-decoration:none;color:var(--text);box-shadow:var(--shadow);transition:all 0.2s}
.store-badge:hover{border-color:#1f2c23;transform:translateY(-1px)}
.store-badge-img{
  padding:0;
  background:transparent;
  border:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:50px;
  min-width:155px;
  width:155px;
}
.store-badge-img img{
  height:50px;
  width:auto;
  max-width:155px;
  display:block;
  object-fit:contain;
}

/* Hero Section */
.hero{padding:40px 0 60px;min-height:85vh;display:flex;align-items:center;background:transparent}
.hero-inner{display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center;background:transparent}
.partner-hero .hero-inner{
  grid-template-columns:1fr 1.2fr;
  gap:80px;
  align-items:center;
}
.hero-content{display:flex;flex-direction:column;gap:32px}
.hero-badge{display:inline-block;padding:10px 20px;background:var(--hero-badge-bg);border:1px solid var(--hero-badge-border);border-radius:24px;color:var(--green-light);font-size:14px;font-weight:600;width:fit-content;margin-bottom:0;transition:background-color 0.3s, border-color 0.3s;letter-spacing:0.3px}
.hero-title{font-size:64px;line-height:1.1;margin:0;font-weight:800;letter-spacing:-0.02em;margin-top:8px}
.hero-subtitle{font-size:20px;line-height:1.6;color:var(--muted);margin:0;max-width:540px;margin-top:-8px}
.accent{color:var(--green-light)}
.hero-ctas{display:flex;flex-direction:column;gap:16px;margin-top:8px}
.cta-label{font-weight:600;font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:0.8px;margin-bottom:0}
.hero-features{display:flex;flex-wrap:wrap;gap:20px;margin-top:12px}
.feature-item{display:flex;align-items:center;gap:8px;color:var(--green-light);font-size:15px}
.feature-item svg{flex-shrink:0}

.hero-art{display:flex;align-items:center;justify-content:flex-end;background:transparent}
.hero-image{width:100%;max-width:800px;height:auto;object-fit:contain;display:block;background:transparent}

/* Sections */
.section{padding:80px 0}
.section-title{font-size:42px;line-height:1.2;margin:0 0 16px;font-weight:800;letter-spacing:-0.02em;text-align:center}
.section-subtitle{font-size:18px;line-height:1.6;color:var(--muted);margin:0 auto 48px;text-align:center;max-width:600px}

/* Stats Section */
.section.stats{
  background:var(--bg);
  padding:20px 0 80px 0;
  border-bottom:1px solid var(--border);
  transition:background 0.3s ease;
  position:relative;
  z-index:1;
}
.stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:32px}
.stat-card{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:16px;
  padding:40px 32px;
  box-shadow:none;
  display:flex;
  flex-direction:column;
  align-items:center;
  transition:all 0.2s ease;
}
.stat-card:hover{
  transform:translateY(-4px);
  border-color:var(--green);
}
[data-theme="light"] .stat-card{
  background:var(--panel);
  border-color:var(--border);
}
.stat-content{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  text-align:center;
  width:100%;
}
.stat-label{
  color:var(--muted);
  font-size:14px;
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:0.5px;
  margin-bottom:4px;
}
.stat-value{
  font-size:56px;
  font-weight:800;
  color:var(--text);
  line-height:1;
  letter-spacing:-0.02em;
  margin-bottom:0;
}
[data-theme="light"] .stat-value{
  color:#1a1f24;
}
.stat-weekly{
  color:var(--green);
  font-size:14px;
  font-weight:600;
  margin-top:0;
}
.stat-weekly-up{
  color:var(--green);
}
.stat-weekly-down{
  color:#ff6b6b;
}
.stat-weekly-range{
  color:var(--muted);
  font-weight:400;
}

/* How it Works */
.steps-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:24px;
  margin-top:40px;
  position:relative;
}
.steps-grid::before{
  content:"";
  position:absolute;
  top:328px;
  left:calc(16.66% + 24px);
  width:calc(66.66% - 48px);
  height:2px;
  background:var(--border);
  z-index:0;
}
[data-theme="light"] .steps-grid::before{
  background:var(--border);
}
.step-card{
  background:transparent;
  border:none;
  border-radius:0;
  padding:0;
  box-shadow:none;
  transition:none;
  display:flex;
  flex-direction:column;
  align-items:center;
}
.step-card:hover{transform:none}
.step-image{
  width:100%;
  max-width:280px;
  height:auto;
  border-radius:12px;
  margin-bottom:24px;
  object-fit:contain;
  display:block;
}
.step-number-circle{
  width:48px;
  height:48px;
  border-radius:50%;
  background:var(--green);
  color:#08140c;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:20px;
  font-weight:700;
  margin-bottom:16px;
  flex-shrink:0;
  position:relative;
  z-index:1;
}
[data-theme="light"] .step-number-circle{
  background:#1a1f24;
  color:#ffffff;
}
.step-card h3{font-size:22px;font-weight:700;margin:0 0 12px;color:var(--text);text-align:center}
.step-card p{color:var(--muted);line-height:1.6;margin:0;font-size:15px;text-align:center}

/* Benefits Section */
.benefits-compact{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:32px;
  margin-top:48px;
}
.benefit-compact-item{
  display:flex;
  gap:20px;
  align-items:flex-start;
  padding:24px;
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:16px;
  transition:all 0.2s ease;
}
.benefit-compact-item:hover{
  border-color:var(--green);
  transform:translateY(-2px);
  box-shadow:0 4px 16px rgba(0,200,83,0.1);
}
.benefit-compact-icon{
  width:56px;
  height:56px;
  border-radius:12px;
  background:rgba(0,200,83,0.1);
  border:1px solid rgba(0,200,83,0.2);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--green);
  flex-shrink:0;
  transition:all 0.2s ease;
}
.benefit-compact-item:hover .benefit-compact-icon{
  background:var(--green);
  color:#08140c;
  transform:scale(1.05);
}
.benefit-compact-icon svg{
  width:28px;
  height:28px;
}
.benefit-compact-text{
  flex:1;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.benefit-compact-text h3{
  font-size:20px;
  font-weight:700;
  margin:0;
  color:var(--text);
  line-height:1.3;
}
.benefit-compact-text p{
  color:var(--muted);
  line-height:1.6;
  margin:0;
  font-size:15px;
}
@media (max-width: 1024px){
  .benefits-compact{
    grid-template-columns:1fr;
    gap:20px;
  }
}

/* Gyms Section */
.gyms-revamped{
  max-width:1200px;
  margin:0 auto;
}
.gyms-header{
  margin-bottom:48px;
}
.gyms-intro{
  font-size:18px;
  line-height:1.6;
  color:var(--muted);
  margin:0;
  max-width:700px;
}
.gyms-split{
  display:grid;
  grid-template-columns:1.1fr 0.9fr;
  gap:80px;
  align-items:start;
}
.gyms-content{
  display:flex;
  flex-direction:column;
  gap:40px;
}
.gyms-image-column{
  position:sticky;
  top:100px;
  height:fit-content;
}
.gyms-image-area{
  width:100%;
  border-radius:24px;
  overflow:hidden;
  background:var(--panel);
  border:1px solid var(--border);
  box-shadow:0 20px 60px rgba(0, 0, 0, 0.15);
  transition:transform 0.3s ease, box-shadow 0.3s ease;
}
.gyms-image-area:hover{
  transform:translateY(-4px);
  box-shadow:0 24px 80px rgba(0, 0, 0, 0.2);
}
.gyms-image{
  width:100%;
  height:auto;
  display:block;
  object-fit:cover;
}
.gyms-features{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.gym-feature{
  display:flex;
  gap:20px;
  align-items:flex-start;
  padding:24px;
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:16px;
  transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  position:relative;
  overflow:hidden;
}
.gym-feature::before{
  content:'';
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:4px;
  background:var(--green);
  opacity:0;
  transition:opacity 0.3s ease;
}
.gym-feature:hover{
  border-color:var(--green);
  transform:translateX(4px);
  box-shadow:0 8px 24px rgba(0, 200, 83, 0.1);
}
.gym-feature:hover::before{
  opacity:1;
}
.gym-feature-icon-wrapper{
  width:56px;
  height:56px;
  border-radius:12px;
  background:rgba(0, 200, 83, 0.1);
  border:1px solid rgba(0, 200, 83, 0.2);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  transition:all 0.3s ease;
}
.gym-feature:hover .gym-feature-icon-wrapper{
  background:var(--green);
  transform:scale(1.05);
}
.gym-feature-icon{
  font-size:28px;
  line-height:1;
  transition:transform 0.3s ease;
}
.gym-feature:hover .gym-feature-icon{
  transform:scale(1.1);
}
.gym-feature-text{
  flex:1;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.gym-feature-text h4{
  font-size:20px;
  font-weight:700;
  margin:0;
  color:var(--text);
  line-height:1.3;
  letter-spacing:-0.01em;
}
.gym-feature-text p{
  font-size:15px;
  color:var(--muted);
  line-height:1.6;
  margin:0;
}
.gyms-cta{
  background:linear-gradient(135deg, rgba(0, 200, 83, 0.05) 0%, rgba(0, 200, 83, 0.02) 100%);
  border:1px solid var(--border);
  border-radius:20px;
  padding:40px;
  text-align:left;
  position:relative;
  overflow:hidden;
}
.gyms-cta::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:4px;
  background:linear-gradient(90deg, var(--green), var(--green-light));
}
.gyms-cta-content{
  display:flex;
  flex-direction:column;
  gap:20px;
  align-items:flex-start;
}
.gyms-cta-content h3{
  font-size:28px;
  font-weight:700;
  margin:0;
  color:var(--text);
  line-height:1.2;
}
.gyms-cta-content p{
  font-size:16px;
  color:var(--muted);
  line-height:1.6;
  margin:0;
}
.form-hint{color:var(--muted);font-size:13px;margin:8px 0 0}
@media (max-width: 1024px){
  .gyms-split{
    grid-template-columns:1fr;
    gap:48px;
    display:flex;
    flex-direction:column;
  }
  .gyms-image-column{
    position:static;
    order:1;
  }
  .gyms-content{
    order:2;
  }
  .gyms-header{
    margin-bottom:40px;
  }
  .gyms-intro{
    max-width:100%;
  }
}
@media (max-width: 1024px){
  .gyms-cta{
    padding:32px 24px;
  }
  .gyms-cta-content{
    text-align:center;
    align-items:center;
  }
  .gyms-content{
    gap:32px;
  }
  .gyms-split{
    gap:32px;
  }
  .gyms-header{
    margin-bottom:32px;
  }
  .gyms-intro{
    font-size:16px;
  }
  .gym-feature{
    padding:20px;
  }
  .gym-feature-icon-wrapper{
    width:48px;
    height:48px;
  }
  .gym-feature-icon{
    font-size:24px;
  }
  .gym-feature-text h4{
    font-size:18px;
  }
  .gym-feature-text p{
    font-size:14px;
  }
}

/* CTA Section */
.cta{
  background:var(--cta-bg);
  border-top:1px solid var(--border);
  transition:background 0.3s ease;
}
.cta-inner{text-align:center}
.cta .section-title{margin-bottom:16px}
.cta .section-subtitle{margin-bottom:32px}

/* FAQ Section */
.accordion{max-width:800px;margin:0 auto}
.accordion details{
  border:1px solid var(--border);
  border-radius:16px;
  padding:20px 24px;
  background:var(--panel);
  margin-bottom:16px;
  transition:all 0.2s;
}
.accordion details:hover{
  border-color:#1f2c23;
}
.accordion summary{
  cursor:pointer;
  font-weight:600;
  font-size:18px;
  color:var(--text);
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.accordion summary::-webkit-details-marker{display:none}
.accordion summary::after{
  content:"+";
  font-size:24px;
  color:var(--green-light);
  font-weight:300;
  transition:transform 0.2s;
}
.accordion details[open] summary::after{
  content:"−";
}
.accordion details p{
  color:var(--muted);
  line-height:1.7;
  margin:16px 0 0;
  padding-top:16px;
  border-top:1px solid var(--border);
  font-size:15px;
}

/* Footer */
.site-footer{
  padding:40px 0;
  border-top:1px solid var(--border);
  background:var(--panel);
  transition:background-color 0.3s ease, border-color 0.3s ease;
}
.footer-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  flex-wrap:wrap;
}
.footer-brand{display:flex;align-items:center;gap:10px}
.footer-brand .brand-logo{height:36px}
.footer-nav{
  display:flex;
  gap:24px;
  flex-wrap:wrap;
}
.footer-nav a{
  color:var(--muted);
  text-decoration:none;
  font-size:14px;
  transition:color 0.2s;
}
.footer-nav a:hover{color:var(--text)}
.footer-social{
  display:flex;
  gap:12px;
  align-items:center;
}
.social-link{
  width:40px;
  height:40px;
  border-radius:10px;
  border:1px solid var(--border);
  background:var(--panel);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--muted);
  text-decoration:none;
  transition:all 0.2s ease;
}
.social-link:hover{
  color:var(--text);
  border-color:var(--green);
  transform:translateY(-2px);
}
.social-link svg{
  width:20px;
  height:20px;
}
.legal{color:var(--muted);font-size:14px}

/* Toast */
.toast{
  position:fixed;
  left:50%;
  top:20px;
  transform:translate(-50%, -100px);
  background:#0f1511;
  border:1px solid var(--border);
  border-radius:16px;
  padding:16px 24px;
  color:#c3ead7;
  font-size:14px;
  font-weight:500;
  opacity:0;
  pointer-events:none;
  transition:all 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55);
  box-shadow:0 8px 32px rgba(0, 0, 0, 0.4);
  z-index:1000;
  display:flex;
  align-items:center;
  gap:12px;
  min-width:300px;
  max-width:90vw;
  text-align:left;
}
.toast.show{
  opacity:1;
  transform:translate(-50%, 0);
}
.toast.success{
  background:linear-gradient(135deg, #00c853 0%, #00a844 100%);
  border:1px solid rgba(124, 255, 192, 0.3);
  color:#ffffff;
  box-shadow:0 8px 32px rgba(0, 200, 83, 0.3);
  padding:20px 28px;
  font-size:16px;
  font-weight:600;
}
.toast.success::before{
  content:'✓';
  display:flex;
  align-items:center;
  justify-content:center;
  width:28px;
  height:28px;
  background:rgba(255, 255, 255, 0.2);
  border-radius:50%;
  font-size:18px;
  font-weight:700;
  flex-shrink:0;
}
.toast.error{
  background:linear-gradient(135deg, #ff4444 0%, #cc0000 100%);
  border:1px solid rgba(255, 170, 170, 0.3);
  color:#ffffff;
  box-shadow:0 8px 32px rgba(255, 68, 68, 0.3);
}
.toast.error::before{
  content:'✕';
  display:flex;
  align-items:center;
  justify-content:center;
  width:28px;
  height:28px;
  background:rgba(255, 255, 255, 0.2);
  border-radius:50%;
  font-size:18px;
  font-weight:700;
  flex-shrink:0;
}

/* Responsive - Tablet and Mobile */
@media (max-width: 1024px){
  .hero{
    padding:32px 0 48px;
    min-height:auto;
    position:relative;
    z-index:0;
    background:transparent;
  }
  .section.stats{
    padding:40px 0 80px 0;
    position:relative;
    z-index:2;
    margin-top:0;
  }
  .steps-grid{
    gap:20px;
    margin-top:32px;
  }
  .steps-grid::before{
    display:none;
  }
  .step-image{
    margin-bottom:20px;
  }
  .step-number-circle{
    margin-bottom:14px;
  }
  .step-card h3{
    margin:0 0 10px;
  }
  .hero-inner{
    display:flex;
    flex-direction:column;
    gap:32px;
    align-items:stretch;
    background:transparent;
  }
  .hero-content{
    order:1;
    display:flex;
    flex-direction:column;
    gap:24px;
    text-align:center;
    align-items:center;
    width:100%;
    max-width:100%;
    margin:0;
  }
  .hero-badge{
    font-size:12px;
    padding:8px 16px;
    margin:0 auto;
    width:fit-content;
  }
  .hero-title{
    font-size:clamp(32px, 8vw, 56px);
    line-height:1.15;
    margin:0;
    text-align:center;
    letter-spacing:-0.02em;
  }
  .hero-subtitle{
    font-size:clamp(16px, 4vw, 18px);
    line-height:1.6;
    margin:0;
    text-align:center;
    max-width:100%;
    color:var(--muted);
  }
  .hero-ctas{
    display:flex;
    flex-direction:column;
    gap:16px;
    align-items:center;
    width:100%;
    margin-top:8px;
  }
  .cta-label{
    font-size:11px;
    letter-spacing:0.8px;
    margin-bottom:0;
  }
  .store-badges{
    justify-content:center;
    width:100%;
    gap:24px;
    flex-wrap:wrap;
    display:flex;
  }
  .store-badge-img{
    flex-shrink:0;
    min-width:155px;
    width:155px;
    height:50px;
  }
  .store-badge-img .image-skeleton-wrapper{
    width:155px;
    height:50px;
    min-width:155px;
  }
  .store-badge-img img{
    width:auto;
    height:50px;
    max-width:155px;
  }
  .hero-art{
    order:2;
    display:flex;
    align-items:center;
    justify-content:center;
    width:100%;
    margin-top:8px;
    position:relative;
    z-index:0;
    overflow:visible;
    padding:0;
    background:transparent;
  }
  .hero-image{
    width:100%;
    max-width:100%;
    height:auto;
    min-height:auto;
    max-height:none;
    border-radius:16px;
    box-shadow:0 20px 60px rgba(0, 0, 0, 0.2);
    position:relative;
    z-index:0;
    object-fit:contain;
    object-position:center;
    display:block;
    background:transparent;
  }
  .hero-art .image-skeleton-wrapper{
    width:100%;
    max-width:100%;
    overflow:visible;
    background:transparent;
  }
  .hero-image-skeleton{
    border-radius:16px;
  }
  .section-title{
    font-size:clamp(28px, 6vw, 36px);
  }
  .testimonials-grid{grid-template-columns:1fr}
  
  /* Partner Hero - Mobile/Tablet */
  .partner-hero{
    padding:32px 0 48px;
    min-height:auto;
    background:transparent;
  }
  .partner-hero .hero-inner{
    display:flex;
    flex-direction:column;
    gap:32px;
    align-items:stretch;
    background:transparent;
  }
  .partner-hero .hero-content{
    order:1;
    display:flex;
    flex-direction:column;
    gap:24px;
    text-align:center;
    align-items:center;
    width:100%;
    max-width:100%;
    margin:0;
  }
  .partner-hero .hero-badge{
    font-size:12px;
    padding:8px 16px;
    margin:0 auto;
    width:fit-content;
  }
  .partner-hero .hero-title{
    font-size:clamp(32px, 8vw, 48px);
    line-height:1.15;
    margin:0;
    text-align:center;
    letter-spacing:-0.02em;
  }
  .partner-hero .hero-title-main{
    display:block;
    margin-bottom:4px;
  }
  .partner-hero .hero-title .accent{
    display:block;
    white-space:normal;
    margin-top:0;
  }
  .partner-hero .hero-subtitle{
    font-size:clamp(16px, 4vw, 18px);
    line-height:1.6;
    margin:0;
    text-align:center;
    max-width:100%;
    color:var(--muted);
  }
  .partner-hero .hero-art{
    order:2;
    display:flex;
    align-items:center;
    justify-content:center;
    width:100%;
    margin-top:8px;
    position:relative;
    z-index:0;
    overflow:visible;
    padding:0;
    background:transparent;
  }
  .partner-hero .hero-image{
    width:100%;
    max-width:100%;
    height:auto;
    min-height:auto;
    max-height:none;
    border-radius:16px;
    box-shadow:0 20px 60px rgba(0, 0, 0, 0.2);
    position:relative;
    z-index:0;
    object-fit:contain;
    object-position:center;
    display:block;
    background:transparent;
  }
  .partner-hero .hero-art .image-skeleton-wrapper{
    width:100%;
    max-width:100%;
    overflow:visible;
    background:transparent;
  }
}

@media (max-width: 1024px){
  .container{padding:0 20px;background:transparent}
  .hero .container{
    background:transparent;
  }
  body{padding-top:64px}
  .header-inner{
    height:64px;
    position:relative;
    justify-content:center;
  }
  .brand{
    position:absolute;
    left:50%;
    transform:translateX(-50%);
  }
  .nav{
    order:2;
    position:relative !important;
    width:100% !important;
    z-index:1000 !important;
  }
  .nav-toggle{display:flex}
  
  /* Mobile Menu - Rebuilt from scratch */
  .nav-list{
    position:absolute !important;
    top:calc(100% + 8px) !important;
    left:0 !important;
    right:0 !important;
    width:100% !important;
    background:#ffffff !important;
    border:1px solid #e5e5e5 !important;
    border-radius:12px !important;
    padding:8px !important;
    margin:0 !important;
    list-style:none !important;
    box-shadow:0 4px 20px rgba(0,0,0,0.15) !important;
    z-index:1001 !important;
    max-height:0 !important;
    overflow:hidden !important;
    opacity:0 !important;
    transform:translateY(-10px) !important;
    transition:max-height 0.3s ease, opacity 0.3s ease, transform 0.3s ease, padding 0.3s ease !important;
    pointer-events:none !important;
    display:block !important;
    flex-direction:column !important;
    gap:0 !important;
  }
  
  [data-theme="dark"] .nav-list{
    background:#1a1a1a !important;
    border-color:#333333 !important;
  }
  
  .nav-list.show{
    max-height:500px !important;
    opacity:1 !important;
    transform:translateY(0) !important;
    pointer-events:auto !important;
    padding:8px !important;
    overflow:visible !important;
    display:block !important;
    visibility:visible !important;
  }
  
  .nav-list li{
    width:100% !important;
    margin:0 !important;
    padding:0 !important;
    display:block !important;
    list-style:none !important;
    visibility:visible !important;
    opacity:1 !important;
  }
  
  .nav-list.show li{
    display:block !important;
    visibility:visible !important;
    opacity:1 !important;
  }
  
  .nav-list a{
    display:block !important;
    padding:14px 20px !important;
    margin:2px 0 !important;
    border-radius:8px !important;
    width:100% !important;
    color:#1a1a1a !important;
    font-size:16px !important;
    font-weight:600 !important;
    text-decoration:none !important;
    text-align:left !important;
    background:transparent !important;
    transition:background-color 0.2s ease, color 0.2s ease !important;
    visibility:visible !important;
    opacity:1 !important;
    line-height:1.5 !important;
  }
  
  .nav-list.show a{
    display:block !important;
    visibility:visible !important;
    opacity:1 !important;
  }
  
  [data-theme="dark"] .nav-list a{
    color:#ffffff !important;
  }
  
  .nav-list a:hover{
    background:#f5f5f5 !important;
    color:#1a1a1a !important;
  }
  
  [data-theme="dark"] .nav-list a:hover{
    background:#2a2a2a !important;
    color:#ffffff !important;
  }
  
  .nav-list a.active{
    background:#e8f5e9 !important;
    color:#00c853 !important;
  }
  
  [data-theme="dark"] .nav-list a.active{
    background:rgba(0,200,83,0.2) !important;
    color:#7cffc0 !important;
  }
  
  .nav-list a::after{
    display:none !important;
  }
  
  .nav-list-cta{
    margin-top:8px !important;
    padding-top:8px !important;
    border-top:1px solid var(--border) !important;
  }
  
  .nav-list-cta a{
    background:transparent !important;
    color:var(--text) !important;
    border:1px solid var(--border) !important;
    font-weight:600 !important;
    text-align:center !important;
    margin:0 !important;
  }
  
  .nav-list-cta a:hover{
    background:var(--panel) !important;
    color:var(--text) !important;
    border-color:var(--green) !important;
    transform:translateY(-1px) !important;
  }
  
  [data-theme="dark"] .nav-list-cta{
    border-top-color:#333333 !important;
  }
  .header-ctas{
    order:3;
    display:flex;
    gap:12px;
    margin-left:auto;
  }
  .header-ctas .btn{display:none}
  .theme-toggle{display:flex}
  /* Mobile-specific refinements */
  .hero{
    padding:24px 0 40px;
    position:relative;
    z-index:0;
  }
  .section.stats{
    padding:32px 0 60px 0;
    position:relative;
    z-index:2;
  }
  .hero-content{
    gap:20px;
  }
  .hero-badge{
    font-size:11px;
    padding:6px 14px;
  }
  .hero-title{
    font-size:clamp(28px, 10vw, 40px);
  }
  .hero-subtitle{
    font-size:clamp(15px, 4vw, 17px);
  }
  .hero-ctas{
    gap:14px;
    margin-top:4px;
  }
  .cta-label{
    font-size:10px;
    margin-bottom:0;
  }
  .store-badges{
    gap:20px;
    flex-wrap:wrap;
    justify-content:center;
  }
  .store-badge-img{
    flex-shrink:0;
    min-width:140px;
    width:140px;
    height:45px;
  }
  .store-badge-img .image-skeleton-wrapper{
    width:140px;
    height:45px;
    min-width:140px;
  }
  .store-badge-img img{
    height:45px;
    max-width:140px;
    width:auto;
  }
  .hero-art{
    margin-top:4px;
  }
  .hero-image{
    border-radius:12px;
    object-fit:contain;
    object-position:center;
    max-height:none;
    min-height:auto;
    width:100%;
    max-width:100%;
    background:transparent;
  }
  .hero-art{
    overflow:visible;
    padding:0;
    background:transparent;
  }
  .hero-art .image-skeleton-wrapper{
    width:100%;
    max-width:100%;
    overflow:visible;
    background:transparent;
  }
  
  .partner-hero{
    padding:24px 0 40px;
  }
  .partner-hero .hero-content{
    gap:20px;
  }
  .partner-hero .hero-badge{
    font-size:11px;
    padding:6px 14px;
  }
  .partner-hero .hero-title{
    font-size:clamp(28px, 10vw, 40px);
  }
  .partner-hero .hero-subtitle{
    font-size:clamp(15px, 4vw, 17px);
  }
  .partner-hero .hero-art{
    margin-top:4px;
  }
  .partner-hero .hero-image{
    border-radius:12px;
    object-fit:contain;
    object-position:center;
    max-height:none;
    min-height:auto;
    width:100%;
    max-width:100%;
    background:transparent;
  }
  .partner-hero .hero-art{
    overflow:visible;
    padding:0;
    background:transparent;
  }
  .partner-hero .hero-art .image-skeleton-wrapper{
    width:100%;
    max-width:100%;
    overflow:visible;
    background:transparent;
  }
  .section{padding:60px 0}
  .section-title{font-size:32px}
  .stats-grid{grid-template-columns:1fr}
  .steps-grid{
    grid-template-columns:1fr;
    gap:16px;
    margin-top:32px;
  }
  .steps-grid::before{
    display:none;
  }
  .step-image{
    margin-bottom:16px;
  }
  .step-number-circle{
    margin-bottom:12px;
  }
  .step-card h3{
    margin:0 0 8px;
  }
  .step-card p{
    margin:0;
  }
  .benefits-compact{grid-template-columns:1fr}
  .footer-inner{
    flex-direction:column;
    text-align:center;
    gap:16px;
  }
  .footer-social{
    justify-content:center;
  }
}

/* Partner Page Styles */
.partner-hero{
  padding:80px 0 60px;
  min-height:70vh;
  display:flex;
  align-items:center;
}
.partner-hero .hero-content{
  max-width:700px;
  margin:0;
  text-align:left;
}
.partner-hero .hero-title{
  text-align:left;
  font-size:56px;
}
.partner-hero .hero-title-main{
  font-size:1.2em;
  font-weight:800;
}
.partner-hero .hero-title .accent{
  white-space:nowrap;
  display:inline-block;
}
.partner-hero .hero-subtitle{
  text-align:left;
  margin:0;
  max-width:100%;
}
.partner-hero .hero-art{
  display:flex;
  align-items:center;
  justify-content:flex-end;
}
.partner-hero .hero-image{
  border-radius:8px;
  width:100%;
  max-width:800px;
  height:auto;
  object-fit:cover;
  display:block;
  box-shadow:0 20px 60px rgba(0, 0, 0, 0.3);
}

.partner-benefits-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  grid-template-rows:1fr 1fr;
  gap:24px 40px;
  margin-top:48px;
}
.partner-benefit-weekly{
  grid-row:1 / -1;
  grid-column:2;
}
.partner-benefit-card{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:20px;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:0;
  transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  text-align:left;
  align-items:stretch;
  overflow:hidden;
  position:relative;
}
.partner-benefit-card::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:4px;
  background:linear-gradient(90deg, var(--green), var(--green-light));
  opacity:0;
  transition:opacity 0.3s ease;
}
.partner-benefit-card:hover{
  transform:translateY(-6px);
  border-color:var(--green);
  box-shadow:0 12px 32px rgba(0, 200, 83, 0.15);
}
.partner-benefit-card:hover::before{
  opacity:1;
}
.partner-benefit-image-wrapper{
  width:100%;
  overflow:hidden;
  position:relative;
  background:var(--bg);
}
.partner-benefit-image{
  width:100%;
  height:auto;
  display:block;
  object-fit:cover;
  transition:transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.partner-benefit-card:hover .partner-benefit-image{
  transform:scale(1.05);
}
.partner-benefit-content{
  padding:24px;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.partner-benefit-card h3{
  font-size:24px;
  font-weight:700;
  margin:0;
  color:var(--text);
  line-height:1.2;
  text-align:left;
  letter-spacing:-0.01em;
}
.partner-benefit-card p{
  color:var(--muted);
  line-height:1.6;
  margin:0;
  font-size:15px;
  text-align:left;
}

.onboarding-split{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:48px;
  align-items:start;
  margin-top:48px;
}
.onboarding-content h2{
  text-align:left;
  margin-bottom:16px;
}
.onboarding-intro{
  font-size:18px;
  line-height:1.6;
  color:var(--muted);
  margin:0 0 32px;
}
.onboarding-checklist{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:24px;
}
.onboarding-checklist li{
  display:flex;
  gap:16px;
  align-items:flex-start;
}
.check-icon{
  width:32px;
  height:32px;
  border-radius:8px;
  background:var(--green);
  color:#ffffff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:700;
  font-size:18px;
  flex-shrink:0;
}
.onboarding-checklist li div:last-child{
  flex:1;
}
.onboarding-checklist li strong{
  display:block;
  font-size:16px;
  font-weight:600;
  color:var(--text);
  margin-bottom:4px;
}
.onboarding-checklist li p{
  font-size:14px;
  color:var(--muted);
  margin:0;
  line-height:1.5;
}

.form-card-partner{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:20px;
  padding:32px;
  box-shadow:var(--shadow);
  position:sticky;
  top:100px;
}
.form-card-partner h3{
  font-size:24px;
  font-weight:700;
  margin:0 0 24px;
  color:var(--text);
}
.form-card-partner label{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-bottom:20px;
}
.form-card-partner label span{
  font-size:14px;
  font-weight:500;
  color:var(--text);
}
.required{
  color:var(--green);
}
.form-card-partner input{
  height:48px;
  border-radius:12px;
  border:1px solid var(--border);
  background:var(--bg);
  color:var(--text);
  padding:0 16px;
  font-size:15px;
  transition:all 0.2s;
}
.form-card-partner input:focus{
  outline:none;
  border-color:var(--green);
  box-shadow:0 0 0 3px rgba(0,200,83,0.1);
}
.phone-input-wrapper{
  position:relative;
  display:flex;
  align-items:center;
  height:48px;
  border-radius:12px;
  border:1px solid var(--border);
  background:var(--bg);
  transition:all 0.2s;
}
.phone-input-wrapper:focus-within{
  border-color:var(--green);
  box-shadow:0 0 0 3px rgba(0,200,83,0.1);
}
.phone-prefix{
  padding:0 12px 0 16px;
  font-size:15px;
  font-weight:500;
  color:var(--text);
  user-select:none;
  border-right:1px solid var(--border);
}
.phone-input-wrapper input{
  flex:1;
  border:none;
  background:transparent;
  height:100%;
  padding:0 16px 0 12px;
  font-size:15px;
  color:var(--text);
  outline:none;
}
.phone-input-wrapper input::placeholder{
  color:var(--muted);
}
.form-row-2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}
.form-hint{
  color:var(--muted);
  font-size:13px;
  margin:16px 0 0;
  text-align:center;
}
.form-note{
  color:var(--muted);
  font-size:12px;
  margin:12px 0 0;
  text-align:center;
  line-height:1.5;
}

@media (max-width: 1024px){
  .onboarding-split{
    grid-template-columns:1fr;
    gap:40px;
  }
  .form-card-partner{
    position:static;
  }
}

@media (max-width: 1024px){
  .partner-benefits-grid{
    grid-template-columns:1fr;
    gap:24px;
  }
  .form-row-2{
    grid-template-columns:1fr;
  }
  .partner-benefits-grid{
    grid-template-columns:1fr;
    grid-template-rows:auto;
    gap:24px;
  }
  .partner-benefit-weekly{
    grid-row:auto;
    grid-column:1;
  }
  .partner-benefit-content{
    padding:20px;
  }
  .partner-benefit-card h3{
    font-size:20px;
  }
  .toast{
    min-width:auto;
    max-width:calc(100vw - 40px);
    padding:14px 20px;
    font-size:14px;
  }
  .toast.success{
    padding:18px 24px;
    font-size:15px;
  }
  .toast.success::before,
  .toast.error::before{
    width:24px;
    height:24px;
    font-size:16px;
  }
}

/* Skeleton Loading Styles */
.image-skeleton-wrapper{
  position:relative;
  width:100%;
  height:auto;
  display:block;
  overflow:visible;
  background:transparent;
}
.hero-art .image-skeleton-wrapper{
  background:transparent;
}
.step-card .image-skeleton-wrapper{
  display:inline-block;
  width:auto;
  max-width:280px;
  height:auto;
}
.image-skeleton{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  background:linear-gradient(90deg, var(--panel) 25%, var(--bg) 50%, var(--panel) 75%);
  background-size:200% 100%;
  animation:skeleton-loading 1.5s ease-in-out infinite;
  border-radius:inherit;
  z-index:1;
}
.hero-art .image-skeleton{
  background:transparent;
}
.hero-art .image-skeleton-wrapper .image-skeleton.hidden{
  display:none !important;
  opacity:0 !important;
  visibility:hidden !important;
}
@keyframes skeleton-loading{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}
.image-skeleton-wrapper img{
  position:relative;
  z-index:2;
  opacity:0;
  transition:opacity 0.3s ease;
  width:100%;
  height:auto;
  display:block;
  background:transparent;
}
.image-skeleton-wrapper img.loaded{
  opacity:1;
  background:transparent;
}
.hero-art .image-skeleton-wrapper img{
  background:transparent;
}
.hero-art .image-skeleton-wrapper img.loaded{
  background:transparent;
}
.image-skeleton-wrapper .image-skeleton.hidden{
  opacity:0;
  pointer-events:none;
  transition:opacity 0.3s ease;
  display:none;
}
.hero-art .image-skeleton-wrapper .image-skeleton.hidden{
  display:none;
}

/* Specific skeleton heights for different image types */
.hero-image-skeleton{
  aspect-ratio:auto;
  min-height:auto;
  width:100%;
  overflow:visible;
  height:auto;
}
.store-badge-skeleton{
  height:50px;
  width:155px;
  border-radius:12px;
  min-width:155px;
}
.store-badge-img .image-skeleton-wrapper{
  width:155px;
  height:50px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:155px;
}
.store-badge-img .image-skeleton-wrapper img{
  width:auto;
  height:50px;
  max-width:155px;
}
.step-image-skeleton{
  aspect-ratio:auto;
  max-width:280px;
  width:100%;
  border-radius:12px;
  height:auto;
  min-height:0;
}
.partner-benefit-image-skeleton{
  aspect-ratio:16/9;
  width:100%;
}
.gyms-image-skeleton{
  aspect-ratio:4/3;
  width:100%;
  border-radius:24px;
}
@media (max-width: 1024px){
  .hero-image-skeleton{
    min-height:auto;
    aspect-ratio:auto;
    height:auto;
  }
  .partner-hero .hero-image-skeleton{
    min-height:auto;
    aspect-ratio:auto;
    height:auto;
  }
}
@media (max-width: 768px){
  .hero-image-skeleton{
    min-height:auto;
    aspect-ratio:auto;
    height:auto;
  }
  .partner-hero .hero-image-skeleton{
    min-height:auto;
    aspect-ratio:auto;
    height:auto;
  }
}
