/* ─────────────────────────────────────────────────────────
   AI Coaching — Landing Page styles
   Palette:
     --primary       #185FA5  deep blue
     --primary-700   #114A82
     --primary-50    #EAF2FA
     --emerald       #1D9E75
     --emerald-700   #137E5C
     --ink           #1A1A2E  near-black
     --ink-2         #3F4258
     --ink-3         #6E7287
     --line          #E5E8EE
     --surface       #F5F7FA
     --white         #FFFFFF
   ────────────────────────────────────────────────────────── */

:root{
  --primary:#185FA5;
  --primary-700:#114A82;
  --primary-50:#EAF2FA;
  --emerald:#1D9E75;
  --emerald-700:#137E5C;
  --emerald-50:#E4F4EE;
  --ink:#1A1A2E;
  --ink-2:#3F4258;
  --ink-3:#6E7287;
  --ink-4:#A4A8B8;
  --line:#E5E8EE;
  --line-2:#EFF1F5;
  --surface:#F5F7FA;
  --white:#FFFFFF;
  --radius:14px;
  --radius-sm:8px;
  --radius-lg:22px;
  --shadow-sm:0 1px 2px rgba(20,28,52,.04), 0 2px 6px rgba(20,28,52,.04);
  --shadow:0 6px 20px rgba(20,28,52,.06), 0 1px 2px rgba(20,28,52,.04);
  --shadow-lg:0 24px 60px rgba(20,28,52,.14), 0 4px 14px rgba(20,28,52,.06);
  --max:1180px;
  --pad:clamp(20px, 4vw, 40px);
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter','Helvetica Neue',Helvetica,Arial,sans-serif;
  background:var(--white);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.5;
  font-feature-settings:"ss01","cv11";
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit}
.mono{font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;letter-spacing:-.01em}

/* ────────────── Container ────────────── */
.container{
  max-width:var(--max);
  margin:0 auto;
  padding-left:var(--pad);
  padding-right:var(--pad);
}

/* ────────────── Buttons ────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:44px;padding:0 18px;border-radius:10px;
  font-weight:600;font-size:14.5px;letter-spacing:-.005em;
  border:1px solid transparent;cursor:pointer;
  transition:transform .12s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
  white-space:nowrap;
}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 1px 0 rgba(255,255,255,.15) inset, 0 4px 14px rgba(24,95,165,.28)}
.btn-primary:hover{background:var(--primary-700);box-shadow:0 1px 0 rgba(255,255,255,.15) inset, 0 6px 18px rgba(24,95,165,.36)}
.btn-emerald{background:var(--emerald);color:#fff;box-shadow:0 1px 0 rgba(255,255,255,.18) inset, 0 4px 14px rgba(29,158,117,.32)}
.btn-emerald:hover{background:var(--emerald-700)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{background:var(--surface)}
.btn-link{height:auto;padding:0;background:transparent;color:var(--primary);font-weight:600;font-size:15px}
.btn-link:hover{color:var(--primary-700)}
.btn-lg{height:52px;padding:0 22px;font-size:15.5px;border-radius:12px}
.btn-block{width:100%}

/* ────────────── Nav ────────────── */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.82);
  -webkit-backdrop-filter:saturate(180%) blur(12px);
  backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--line-2);
}
.nav-inner{
  display:flex;align-items:center;gap:24px;height:68px;
}
.nav-logo{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:-.015em;font-size:16px}
.nav-logo-mark{
  width:32px;height:32px;border-radius:9px;
  background:linear-gradient(135deg,var(--primary) 0%,#2576c4 65%, var(--emerald) 130%);
  display:grid;place-items:center;color:#fff;
  box-shadow:0 4px 12px rgba(24,95,165,.28), inset 0 1px 0 rgba(255,255,255,.25);
}
.nav-tag{
  font-size:11px;color:var(--ink-3);font-weight:500;letter-spacing:0;
  margin-top:-2px;
}
.nav-logo-text{display:flex;flex-direction:column;line-height:1.15}
.nav-links{display:flex;gap:6px;margin-left:auto;align-items:center}
.nav-link{
  padding:8px 12px;border-radius:8px;font-size:14px;font-weight:500;color:var(--ink-2);
  transition:background .12s, color .12s;
}
.nav-link:hover{background:var(--surface);color:var(--ink)}
.nav-cta{margin-left:6px}
.nav-toggle{display:none}
@media (max-width: 880px){
  .nav-links{display:none}
  .nav-toggle{display:inline-flex;margin-left:auto}
  .nav-cta-mobile{display:none}
  .nav-drawer{
    display:flex;flex-direction:column;gap:4px;
    padding:8px var(--pad) 18px;border-top:1px solid var(--line-2);background:#fff;
  }
  .nav-drawer .nav-link{padding:12px 10px;font-size:15px}
  .nav-drawer .btn{margin-top:8px}
}

/* ────────────── Hero ────────────── */
.hero{
  position:relative;overflow:hidden;
  padding:clamp(48px, 7vw, 96px) 0 clamp(48px, 6vw, 80px);
  background:
    radial-gradient(1100px 480px at 85% -10%, rgba(24,95,165,.10), transparent 60%),
    radial-gradient(900px 420px at -10% 30%, rgba(29,158,117,.08), transparent 55%),
    linear-gradient(180deg, #fff 0%, #fbfcfe 100%);
}
.hero-grid{
  display:grid;grid-template-columns:1.05fr 1.15fr;gap:clamp(28px, 5vw, 64px);
  align-items:center;
}
@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr;gap:44px}
}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px 6px 8px;border-radius:999px;
  background:#fff;border:1px solid var(--line);
  font-size:12.5px;font-weight:500;color:var(--ink-2);
  box-shadow:var(--shadow-sm);
}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--emerald);box-shadow:0 0 0 3px rgba(29,158,117,.18)}
.hero h1{
  font-size:clamp(34px, 4.6vw, 56px);
  line-height:1.04;letter-spacing:-.025em;margin:18px 0 18px;
  font-weight:700;text-wrap:balance;
}
.hero h1 .accent{color:var(--primary)}
.hero-sub{
  font-size:clamp(16px, 1.5vw, 18.5px);color:var(--ink-2);
  max-width:560px;line-height:1.55;text-wrap:pretty;
}
.hero-ctas{display:flex;gap:14px;align-items:center;margin-top:28px;flex-wrap:wrap}
.hero-proof{
  display:flex;gap:14px 22px;flex-wrap:wrap;align-items:center;
  margin-top:36px;padding-top:24px;border-top:1px solid var(--line-2);
  font-size:13px;color:var(--ink-3);
}
.hero-proof .pip{display:inline-flex;align-items:center;gap:8px}
.hero-proof .pip svg{flex:none;color:var(--primary)}

/* ────────────── Section primitives ────────────── */
.section{padding:clamp(64px, 8vw, 108px) 0}
.section-tight{padding:clamp(48px, 6vw, 80px) 0}
.section-tint{background:var(--surface)}
.section-dark{background:var(--ink);color:#fff}
.section-head{max-width:760px;margin:0 auto 48px;text-align:center}
.section-head-left{margin-left:0;text-align:left}
.kicker{
  display:inline-block;font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--primary);margin-bottom:14px;
}
.kicker-emerald{color:var(--emerald)}
.kicker-on-dark{color:#7DB8E8}
h2.title{
  font-size:clamp(28px, 3.4vw, 42px);line-height:1.1;letter-spacing:-.022em;
  font-weight:700;margin:0;text-wrap:balance;
}
.subtitle{
  margin-top:14px;color:var(--ink-2);font-size:clamp(15px, 1.3vw, 17.5px);line-height:1.55;
  text-wrap:pretty;
}
.section-dark .subtitle{color:rgba(255,255,255,.72)}

/* ────────────── Cards ────────────── */
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;
}
.card-pad-lg{padding:32px}
.card-soft{background:#fff;box-shadow:var(--shadow-sm)}

/* Problem grid */
.problem-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media (max-width: 880px){.problem-grid{grid-template-columns:1fr}}
.problem-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:28px;display:flex;flex-direction:column;gap:14px;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.problem-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:#D9DEE7}
.problem-ico{
  width:44px;height:44px;border-radius:12px;display:grid;place-items:center;
  background:var(--primary-50);color:var(--primary);
}
.problem-card h3{margin:0;font-size:18px;font-weight:600;letter-spacing:-.012em}
.problem-card p{margin:0;color:var(--ink-2);font-size:14.5px;line-height:1.55}

/* How it works */
.steps{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;position:relative;
}
@media (max-width: 880px){.steps{grid-template-columns:1fr}}
.step{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:28px;display:flex;flex-direction:column;gap:14px;position:relative;
}
.step-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:32px;height:32px;border-radius:50%;
  background:#fff;border:1.5px solid var(--primary);color:var(--primary);
  font-weight:700;font-size:14px;font-family:'JetBrains Mono',monospace;
}
.step h3{margin:0;font-size:19px;font-weight:600;letter-spacing:-.014em}
.step p{margin:0;color:var(--ink-2);font-size:14.5px;line-height:1.55}
.step-ico{color:var(--primary)}
.step-arrow{
  position:absolute;right:-18px;top:50%;transform:translateY(-50%);
  color:var(--ink-4);
}
@media (max-width: 880px){.step-arrow{display:none}}
.steps-foot{
  text-align:center;margin-top:28px;color:var(--ink-3);font-size:14.5px;font-style:italic;
}

/* Features grid */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media (max-width: 980px){.feat-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width: 620px){.feat-grid{grid-template-columns:1fr}}
.feat{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;display:flex;flex-direction:column;gap:12px;
  transition:border-color .2s, box-shadow .2s, transform .2s;
}
.feat:hover{border-color:#D9DEE7;box-shadow:var(--shadow);transform:translateY(-2px)}
.feat-ico{
  width:40px;height:40px;border-radius:10px;display:grid;place-items:center;
  background:linear-gradient(135deg, var(--primary-50), #fff);
  border:1px solid var(--line);color:var(--primary);
}
.feat h3{margin:0;font-size:16.5px;font-weight:600;letter-spacing:-.012em}
.feat p{margin:0;color:var(--ink-2);font-size:14px;line-height:1.55}

/* Target audience */
.aud-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media (max-width: 820px){.aud-grid{grid-template-columns:1fr}}
.aud{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:32px;display:flex;flex-direction:column;gap:18px;
}
.aud-head{display:flex;align-items:center;gap:12px}
.aud-head h3{margin:0;font-size:20px;font-weight:600;letter-spacing:-.014em}
.aud-yes .aud-bullet{color:var(--emerald)}
.aud-no .aud-bullet{color:#D9534F}
.aud-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.aud-list li{display:flex;align-items:flex-start;gap:12px;font-size:15px;color:var(--ink-2);line-height:1.5}
.aud-bullet{flex:none;margin-top:3px}

/* Pricing */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:stretch}
@media (max-width: 980px){.plans{grid-template-columns:1fr}}
.plan{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:28px;display:flex;flex-direction:column;gap:18px;position:relative;
}
.plan.featured{
  border-color:var(--primary);
  box-shadow:0 18px 50px rgba(24,95,165,.18), 0 1px 0 var(--primary) inset;
  transform:translateY(-4px);
}
@media (max-width: 980px){.plan.featured{transform:none}}
.plan-badge{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--primary);color:#fff;font-size:11px;font-weight:600;letter-spacing:.06em;
  padding:6px 12px;border-radius:999px;text-transform:uppercase;
  white-space:nowrap;
  box-shadow:0 4px 12px rgba(24,95,165,.32);
}
.plan-name{font-size:14px;font-weight:600;letter-spacing:.04em;color:var(--ink-3);text-transform:uppercase}
.plan-athletes{font-size:13px;color:var(--ink-3)}
.plan-price{display:flex;align-items:baseline;gap:6px}
.plan-price .num{font-size:36px;font-weight:700;letter-spacing:-.025em;color:var(--ink)}
.plan-price .per{font-size:14px;color:var(--ink-3)}
.plan-feats{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;flex:1}
.plan-feats li{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--ink-2)}
.plan-feats li.off{color:var(--ink-4);text-decoration:line-through}
.plan-foot{display:flex;flex-direction:column;gap:10px}
.plan-note{
  text-align:center;margin-top:20px;color:var(--ink-3);font-size:14px;
}

/* Founders */
.founders-body{max-width:760px;margin:0 auto;text-align:center}
.founders-body p{font-size:17px;line-height:1.65;color:var(--ink-2);text-wrap:pretty}
.badges{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:36px;
}
@media (max-width: 720px){.badges{grid-template-columns:1fr}}
.badge{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:22px;text-align:left;display:flex;flex-direction:column;gap:6px;
}
.badge-ico{
  width:36px;height:36px;border-radius:10px;background:var(--primary-50);color:var(--primary);
  display:grid;place-items:center;margin-bottom:6px;
}
.badge h4{margin:0;font-size:15px;font-weight:600;letter-spacing:-.01em}
.badge p{margin:0;font-size:13.5px;color:var(--ink-3);line-height:1.5}

/* Final CTA */
.cta-final{
  background:
    radial-gradient(800px 360px at 10% -10%, rgba(24,95,165,.35), transparent 60%),
    radial-gradient(700px 320px at 100% 110%, rgba(29,158,117,.22), transparent 55%),
    #15172A;
  color:#fff;border-radius:0;
}
.cta-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:64px;align-items:center}
@media (max-width: 920px){.cta-grid{grid-template-columns:1fr;gap:40px}}
.cta-final h2{font-size:clamp(28px, 3.4vw, 42px);line-height:1.1;letter-spacing:-.022em;margin:0;text-wrap:balance;font-weight:700}
.cta-final .subtitle{color:rgba(255,255,255,.72);max-width:520px}
.cta-perks{display:flex;flex-direction:column;gap:14px;margin-top:32px}
.cta-perks li{display:flex;align-items:flex-start;gap:12px;color:rgba(255,255,255,.85);font-size:14.5px;list-style:none}
.cta-perks svg{color:#42D5A4;flex:none;margin-top:2px}

.form{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  border-radius:var(--radius-lg);
  padding:28px;
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  display:flex;flex-direction:column;gap:14px;
}
.form-row{display:flex;flex-direction:column;gap:6px}
.form-row label{font-size:12.5px;font-weight:500;color:rgba(255,255,255,.7);letter-spacing:.02em}
.form-row input,
.form-row select{
  appearance:none;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  border-radius:10px;color:#fff;
  padding:0 14px;height:44px;font:inherit;font-size:14.5px;
  transition:border-color .15s, background .15s;
}
.form-row input::placeholder{color:rgba(255,255,255,.4)}
.form-row input:focus,
.form-row select:focus{
  outline:none;border-color:#42D5A4;background:rgba(255,255,255,.10);
}
.form-row select{
  background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23ffffffb3' stroke-width='1.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;
}
.form-row option{background:#15172A;color:#fff}
.form-row.err input,
.form-row.err select{border-color:#FF8585}
.form-err{font-size:12px;color:#FFB7B7;margin-top:2px}
.radio-row{display:flex;gap:8px}
.radio-pill{
  flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);
  border-radius:10px;height:44px;font-size:14.5px;font-weight:500;cursor:pointer;
  color:#fff;transition:all .15s;
}
.radio-pill.on{background:rgba(66,213,164,.18);border-color:#42D5A4;color:#fff}
.radio-pill input{position:absolute;opacity:0;pointer-events:none}
.form-fine{font-size:12px;color:rgba(255,255,255,.5);margin-top:4px;line-height:1.5}
.form-success{
  background:rgba(66,213,164,.12);border:1px solid rgba(66,213,164,.4);
  border-radius:var(--radius);padding:24px;color:#fff;display:flex;flex-direction:column;gap:8px;
  align-items:center;text-align:center;
}
.form-success .ok{
  width:48px;height:48px;border-radius:50%;background:#42D5A4;color:#0E1422;
  display:grid;place-items:center;margin-bottom:6px;
}

/* Footer */
.footer{background:#0F1122;color:rgba(255,255,255,.7);padding:56px 0 36px;font-size:14px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;margin-bottom:36px}
@media (max-width: 720px){.footer-grid{grid-template-columns:1fr;gap:28px}}
.footer h5{color:#fff;font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin:0 0 14px}
.footer-links{display:flex;flex-direction:column;gap:10px}
.footer-links a:hover{color:#fff}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  padding-top:24px;border-top:1px solid rgba(255,255,255,.08);font-size:13px;color:rgba(255,255,255,.5);
  flex-wrap:wrap;
}
.socials{display:flex;gap:10px}
.social{
  width:36px;height:36px;border-radius:9px;display:grid;place-items:center;
  background:rgba(255,255,255,.06);color:#fff;transition:background .15s;
}
.social:hover{background:rgba(255,255,255,.14)}

/* ────────────── Dashboard mockup ────────────── */
.mock{
  position:relative;
  border-radius:18px;
  background:#fff;
  border:1px solid var(--line);
  box-shadow:
    0 30px 70px rgba(20,28,52,.16),
    0 8px 22px rgba(20,28,52,.06);
  overflow:hidden;
}
.mock::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg, rgba(255,255,255,0) 40%, rgba(245,247,250,.6) 100%);
}
.mock-bar{
  display:flex;align-items:center;gap:8px;height:36px;padding:0 14px;
  border-bottom:1px solid var(--line-2);background:#FAFBFD;
}
.mock-bar .dot{width:10px;height:10px;border-radius:50%;background:#E1E4EC}
.mock-bar .dot.r{background:#FF6B6B}
.mock-bar .dot.y{background:#FFC451}
.mock-bar .dot.g{background:#4FD18B}
.mock-bar .url{
  margin-left:14px;font-size:11.5px;color:var(--ink-3);font-family:'JetBrains Mono',monospace;
}
.mock-body{display:grid;grid-template-columns:1.4fr .9fr;min-height:380px}
@media (max-width: 540px){.mock-body{grid-template-columns:1fr}}
.mock-left{padding:18px;border-right:1px solid var(--line-2)}
.mock-right{padding:18px;background:#FAFBFD}
.mock-h{
  display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px;
}
.mock-h>div:first-child{min-width:0;flex:1}
.mock-h-title{font-size:13px;font-weight:600;letter-spacing:-.005em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mock-h-sub{font-size:11px;color:var(--ink-3);font-family:'JetBrains Mono',monospace;white-space:nowrap;flex:none}
.metric-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.metric{
  background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px;
}
.metric-lbl{font-size:10px;color:var(--ink-3);font-weight:600;letter-spacing:.06em;text-transform:uppercase}
.metric-val{font-size:18px;font-weight:700;letter-spacing:-.02em;color:var(--ink);margin-top:2px;font-feature-settings:"tnum"}
.metric-delta{font-size:10.5px;font-family:'JetBrains Mono',monospace}
.up{color:var(--emerald)}
.down{color:#D9534F}
.chart{
  position:relative;background:#fff;border:1px solid var(--line);border-radius:10px;
  padding:8px 10px 4px;height:180px;
}
.legend{
  display:flex;gap:10px;font-size:10px;color:var(--ink-3);margin-bottom:4px;font-family:'JetBrains Mono',monospace;
}
.legend .swatch{width:10px;height:3px;border-radius:2px;margin-right:5px;display:inline-block;vertical-align:middle}

.ai-card{
  background:#fff;border:1px solid var(--line);border-radius:10px;padding:14px;margin-bottom:10px;
}
.ai-head{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.ai-badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:3px 8px;border-radius:999px;
  background:linear-gradient(135deg,var(--primary) 0%, var(--emerald) 120%);
  color:#fff;font-size:10px;font-weight:600;letter-spacing:.04em;
}
.ai-time{font-size:10px;color:var(--ink-3);font-family:'JetBrains Mono',monospace}
.ai-body{font-size:12.5px;line-height:1.5;color:var(--ink-2)}
.ai-body b{color:var(--ink);font-weight:600}
.ai-actions{display:flex;gap:6px;margin-top:10px}
.ai-btn{
  font-size:11px;padding:5px 10px;border-radius:7px;border:1px solid var(--line);
  background:#fff;color:var(--ink-2);font-weight:500;cursor:pointer;
}
.ai-btn.primary{background:var(--primary);color:#fff;border-color:var(--primary)}

.athlete-row{
  display:flex;align-items:center;gap:10px;padding:8px 0;
  border-top:1px solid var(--line-2);
}
.athlete-row:first-of-type{border-top:none}
.av{width:24px;height:24px;border-radius:50%;background:var(--primary-50);color:var(--primary);
  display:grid;place-items:center;font-size:10px;font-weight:700;flex:none}
.av.e{background:var(--emerald-50);color:var(--emerald)}
.av.r{background:#FFE8E8;color:#D9534F}
.athlete-name{font-size:12px;font-weight:500;flex:1;color:var(--ink)}
.athlete-tag{font-size:10px;font-family:'JetBrains Mono',monospace;color:var(--ink-3)}
.tag-up{color:var(--emerald)}
.tag-warn{color:#E89400}
.tag-fatigue{color:#D9534F}

/* Hero floating cards */
.float-card{
  position:absolute;background:#fff;border:1px solid var(--line);border-radius:12px;
  box-shadow:var(--shadow);padding:12px 14px;display:flex;align-items:center;gap:10px;
  font-size:13px;
}
.float-tss{top:-14px;left:-16px;animation:float 6s ease-in-out infinite}
.float-ai{bottom:-14px;right:-12px;animation:float 7s ease-in-out infinite reverse}
.float-ico{
  width:30px;height:30px;border-radius:8px;display:grid;place-items:center;
  background:var(--emerald-50);color:var(--emerald);flex:none;
}
.float-ai .float-ico{background:var(--primary-50);color:var(--primary)}
@keyframes float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-6px)}
}
@media (max-width: 540px){.float-card{display:none}}

/* Mockup wrapper for float positioning */
.mock-wrap{position:relative}

/* ────────────── Utilities ────────────── */
.text-emerald{color:var(--emerald)}
.text-primary{color:var(--primary)}
.text-ink-3{color:var(--ink-3)}
.spacer-xs{height:6px}
.divider-dot{width:3px;height:3px;border-radius:50%;background:currentColor;opacity:.4}

/* Focus rings */
:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:6px}
.btn:focus-visible{outline-offset:3px}

/* Reduce-motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important}
}
