/* ============================================================================
   K2 HYROX — Home v2 (cinematic, conversion-first redesign).
   Ported from the Claude Design prototype "K2 Home v2.html".
   Homepage-only: this page does not load styles.css / site.js — the rest of
   the site keeps the original design system until the redesign rolls out.
   ========================================================================== */
:root{
  --bg:#0A0A0A;
  --bg-2:#060606;
  --surface:#111111;
  --surface-2:#0E0E0E;
  --border:#1A1A1A;
  --border-2:#222222;
  --acc:#FFD600;
  --acc-ink:#000000;
  --text:#EFEFEF;
  --text-2:#CCCCCC;
  --muted:#999999;
  --muted-2:#777777;
  --dim:#555555;
  --maxw:1380px;
  --font-head:'Bebas Neue','Arial Narrow',sans-serif;
  --font-cond:'Barlow Condensed',sans-serif;
  --font-body:'Inter',system-ui,sans-serif;
  --hero-shade:0.62;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);-webkit-font-smoothing:antialiased;overflow-x:hidden;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
h1,h2,h3{font-family:var(--font-head);font-weight:400;letter-spacing:0.03em;}

/* grain — whole page, very subtle */
.grain{position:fixed;inset:0;z-index:90;pointer-events:none;opacity:0.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E");}

/* ───────── buttons ───────── */
.btn{display:inline-flex;align-items:center;gap:10px;background:var(--acc);color:var(--acc-ink);
  padding:16px 30px;font-family:var(--font-cond);font-weight:800;font-size:16px;letter-spacing:0.08em;
  text-transform:uppercase;border:none;cursor:pointer;transition:transform 0.12s,box-shadow 0.12s;
  clip-path:polygon(0 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%);}
.btn:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,214,0,0.25);}
/* On desktop the CTAs are display-only (sms: links open blank tabs there) —
   don't pretend to be links. On touch devices index.html swaps these spans
   for real sms: anchors, which use the plain .btn styles above. */
span.btn{cursor:default;}
span.btn:hover{transform:none;box-shadow:none;}
.btn .sub{font-size:11px;font-weight:600;letter-spacing:0.14em;opacity:0.65;display:block;}
.btn--stack{flex-direction:column;align-items:flex-start;gap:2px;line-height:1.1;}
.btn--ghost{background:transparent;color:var(--text-2);border:1px solid #333;clip-path:none;font-weight:700;}
.btn--ghost:hover{border-color:#555;box-shadow:none;color:#fff;}

/* ───────── nav ───────── */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;
  transition:background-color 0.25s,border-color 0.25s;border-bottom:1px solid transparent;}
.nav.is-scrolled{background:rgba(10,10,10,0.92);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  border-bottom-color:#1C1C1C;}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:20px 28px;display:flex;align-items:center;gap:14px;}
.nav-logo{display:flex;align-items:center;gap:12px;}
.nav-logo img{width:46px;height:46px;object-fit:cover;}
.nav-logo .brand{font-family:var(--font-head);font-size:20px;letter-spacing:0.14em;line-height:1;color:#FFF;white-space:nowrap;}
.nav-logo .tagline{font-family:var(--font-cond);font-size:10px;font-weight:600;letter-spacing:0.2em;color:var(--muted);margin-top:3px;}
.nav-spacer{flex:1;}
.nav-links{display:flex;align-items:center;gap:4px;}
.nav-links a{font-family:var(--font-cond);font-size:13px;font-weight:700;letter-spacing:0.1em;
  color:var(--text-2);padding:10px 14px;text-transform:uppercase;transition:color 0.15s;}
.nav-links a:hover{color:var(--acc);}
.nav-cta{margin-left:10px;background:var(--acc);color:#000;padding:11px 20px;white-space:nowrap;font-family:var(--font-cond);
  font-size:13px;font-weight:800;letter-spacing:0.09em;text-transform:uppercase;
  clip-path:polygon(0 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%);transition:transform 0.12s;}
.nav-cta:hover{transform:translateY(-1px);}
span.nav-cta{cursor:default;}
span.nav-cta:hover{transform:none;}
/* On touch devices index.html swaps the span for an sms: anchor — without this,
   .nav-links a turns the label grey (and accent-on-accent on tap). */
.nav-links a.nav-cta,.nav-links a.nav-cta:hover{color:#000;}
/* iOS Safari wraps detected phone numbers in its own classless tel: anchor
   (disabled via the format-detection meta; fallback in case one slips in). */
.nav-links .nav-cta a,.nav-links .nav-cta a:hover{color:inherit;}
/* "The Gym" — all inner pages in one dropdown; opens on hover (click/tap on touch) */
.nav-gym{position:relative;}
.nav-gym-btn{font-family:var(--font-cond);font-size:13px;font-weight:700;letter-spacing:0.1em;
  color:var(--text-2);padding:10px 14px;text-transform:uppercase;transition:color 0.15s;white-space:nowrap;
  background:none;border:none;cursor:pointer;display:inline-flex;align-items:center;gap:6px;}
.nav-gym-btn .caret{font-size:9px;}
.nav-gym:hover .nav-gym-btn,.nav-gym:focus-within .nav-gym-btn,.nav-gym.is-open .nav-gym-btn{color:var(--acc);}
.nav-gym-menu{position:absolute;top:100%;left:8px;min-width:190px;display:none;flex-direction:column;
  background:#0B0B0B;border:1px solid var(--border);padding:6px 0;z-index:60;}
.nav-gym:hover .nav-gym-menu,.nav-gym:focus-within .nav-gym-menu,.nav-gym.is-open .nav-gym-menu{display:flex;}
.nav-gym-menu a{display:block;padding:10px 18px;}
@media (max-width:920px){.nav-links > a{display:none;}.nav-links .nav-cta{display:inline-flex;margin-left:0;}}
@media (max-width:640px){
  .nav-inner{padding:14px 18px;gap:10px;}
  /* !important: the tagline span carries an inline display:block */
  .nav-logo .tagline{display:none !important;}
  .nav-logo .brand{font-size:16px;}
  .nav-logo img{width:38px;height:38px;}
  .nav-gym-btn{padding:10px 8px;}
  .nav-cta{padding:10px 14px;}
}
@media (max-width:480px){
  .nav-logo > span{display:none;}
}

/* ───────── hero ───────── */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;background:var(--bg-2);overflow:hidden;}
.hero-media{position:absolute;inset:0;z-index:0;}
/* shifted right + slight zoom so the athlete sits clear of the headline */
.hero-media img{width:100%;height:100%;object-fit:cover;transform:translateX(9%) scale(1.22);transform-origin:center;}
.hero-scrim{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(to top, rgba(4,4,4,0.96) 0%, rgba(4,4,4,calc(var(--hero-shade) + 0.1)) 28%, rgba(4,4,4,calc(var(--hero-shade) - 0.25)) 60%, rgba(4,4,4,0.55) 100%);}
.hero-scrim::after{content:"";position:absolute;inset:0;
  background:radial-gradient(120% 90% at 50% 40%, transparent 40%, rgba(0,0,0,0.55) 100%);}
.hero-edge{position:absolute;top:0;bottom:0;right:7vw;width:1px;background:linear-gradient(to bottom,transparent,rgba(255,214,0,0.35) 40%,transparent 90%);z-index:2;pointer-events:none;}
.hero-content{position:relative;z-index:3;max-width:var(--maxw);width:100%;margin:0 auto;
  padding:160px 28px 56px;display:flex;flex-direction:column;gap:28px;}
.hero-kicker{display:flex;align-items:center;gap:14px;font-family:var(--font-cond);font-size:13px;
  font-weight:700;letter-spacing:0.32em;color:var(--acc);text-transform:uppercase;}
.hero-kicker::before{content:"";width:42px;height:2px;background:var(--acc);}
.hero h1{font-size:clamp(64px,10.5vw,164px);line-height:0.88;letter-spacing:0.015em;text-transform:uppercase;color:#FFF;
  text-wrap:balance;max-width:12ch;}
.hero h1 .yl{color:var(--acc);}
.hero-sub{font-family:var(--font-cond);font-size:clamp(17px,1.6vw,22px);font-weight:500;color:var(--text-2);
  max-width:560px;line-height:1.55;letter-spacing:0.01em;}
.hero-sub strong{color:#FFF;font-weight:700;}
.hero-cta-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:4px;}
.hero-foot{position:relative;z-index:3;border-top:1px solid rgba(255,255,255,0.12);}
.hero-foot-inner{max-width:var(--maxw);margin:0 auto;padding:18px 28px;display:flex;gap:32px;flex-wrap:wrap;}
.hero-foot-inner .item{font-family:var(--font-cond);font-size:13px;font-weight:600;letter-spacing:0.16em;
  color:var(--muted);text-transform:uppercase;display:flex;align-items:center;gap:10px;}
.hero-foot-inner .item::before{content:"";width:5px;height:5px;background:var(--acc);transform:rotate(45deg);flex-shrink:0;}

/* slide-up entrance */
@media (prefers-reduced-motion: no-preference){
  .hero-content > *{animation:rise 0.9s cubic-bezier(0.2,0.7,0.2,1) backwards;}
  .hero-content > *:nth-child(2){animation-delay:0.12s;}
  .hero-content > *:nth-child(3){animation-delay:0.24s;}
  .hero-content > *:nth-child(4){animation-delay:0.36s;}
  @keyframes rise{from{opacity:0;transform:translateY(26px);}to{opacity:1;transform:none;}}
}

/* ───────── ticker ───────── */
.ticker{background:var(--acc);overflow:hidden;padding:14px 0;border-top:3px solid #000;}
.ticker-track{display:flex;gap:0;width:max-content;}
@media (prefers-reduced-motion: no-preference){
  .ticker-track{animation:tick 26s linear infinite;}
  @keyframes tick{to{transform:translateX(-50%);}}
}
.ticker-seq{display:flex;align-items:center;white-space:nowrap;}
.ticker-seq span{font-family:var(--font-head);font-size:26px;letter-spacing:0.08em;color:#000;padding:0 26px;}
.ticker-seq i{font-style:normal;color:#000;font-size:14px;}

/* ───────── sections ───────── */
.section{max-width:var(--maxw);margin:0 auto;padding:110px 28px;}
.sec-head{display:flex;align-items:baseline;gap:22px;margin-bottom:54px;flex-wrap:wrap;}
.sec-num{font-family:var(--font-cond);font-weight:700;font-size:14px;letter-spacing:0.2em;color:var(--dim);}
.sec-head h2{font-size:clamp(44px,5.4vw,84px);line-height:0.92;color:#FFF;}
.sec-head h2 .yl{color:var(--acc);}
.sec-head .rule{flex:1;height:1px;background:var(--border-2);align-self:center;min-width:60px;}

/* two ways in */
.ways{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.way{position:relative;border:1px solid var(--border);background:var(--surface-2);display:flex;flex-direction:column;}
.way .photo{position:relative;height:380px;overflow:hidden;}
.way .photo img{width:100%;height:100%;object-fit:cover;}
/* awaiting a real photo — subtle striped dark panel (swap in an <img> when ready) */
.way .photo.is-empty{
  background:#101010 repeating-linear-gradient(135deg,rgba(255,255,255,0.035) 0 2px,transparent 2px 14px);}
.way .photo::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(to top,rgba(10,10,10,0.85),transparent 55%);}
.way .label{position:absolute;top:362px;left:28px;z-index:2;font-family:var(--font-head);
  font-size:clamp(36px,3.4vw,52px);line-height:0.9;color:#FFF;text-transform:uppercase;}
.way .label .yl{color:var(--acc);}
.way .body{padding:54px 28px 28px;display:flex;flex-direction:column;gap:16px;flex:1;}
.way .body p{font-size:15px;line-height:1.75;color:var(--muted);}
.way .list{display:flex;flex-wrap:wrap;gap:8px;}
.way .list span{font-family:var(--font-cond);font-size:13px;font-weight:700;letter-spacing:0.08em;
  text-transform:uppercase;color:var(--text-2);border:1px solid var(--border-2);padding:6px 12px;}
.way .go{margin-top:auto;padding-top:18px;font-family:var(--font-cond);font-size:14px;font-weight:800;
  letter-spacing:0.12em;text-transform:uppercase;color:var(--acc);display:inline-flex;gap:10px;align-items:center;}
@media (max-width:900px){.ways{grid-template-columns:1fr;}}

/* beginner promise */
.promise-wrap{background:var(--surface-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.promise-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);}
.promise{background:var(--bg);padding:40px 32px;display:flex;flex-direction:column;gap:14px;}
.promise .k{font-family:var(--font-head);font-size:44px;color:var(--acc);line-height:1;}
.promise h3{font-family:var(--font-cond);font-weight:800;font-size:19px;letter-spacing:0.06em;text-transform:uppercase;color:#FFF;}
.promise p{font-size:14px;line-height:1.75;color:var(--muted);}
.promise-cta{display:flex;align-items:center;gap:24px;margin-top:44px;flex-wrap:wrap;}
.promise-cta p{font-family:var(--font-cond);font-size:17px;color:var(--text-2);font-weight:600;letter-spacing:0.02em;}
@media (max-width:900px){.promise-grid{grid-template-columns:1fr;}}

/* coach */
.coach{display:grid;grid-template-columns:440px 1fr;gap:56px;align-items:start;}
.coach-photo{position:relative;}
.coach-photo img{width:100%;height:560px;object-fit:cover;object-position:center 5%;}
.coach-photo .frame{position:absolute;inset:auto -14px -14px auto;width:70%;height:70%;
  border-right:2px solid var(--acc);border-bottom:2px solid var(--acc);pointer-events:none;}
.coach-body{display:flex;flex-direction:column;gap:24px;}
.coach-body .lead{font-family:var(--font-cond);font-size:clamp(20px,2vw,26px);font-weight:600;line-height:1.45;color:var(--text-2);}
.coach-body .lead strong{color:var(--acc);font-weight:800;}
.coach-tags{display:flex;flex-wrap:wrap;gap:8px;}
.coach-tags span{font-family:var(--font-cond);font-size:13px;font-weight:700;letter-spacing:0.07em;
  text-transform:uppercase;color:var(--acc);background:rgba(255,214,0,0.08);border:1px solid rgba(255,214,0,0.3);padding:7px 14px;}
.coach-titles{border-top:1px solid var(--border);}
.coach-titles .row{display:grid;grid-template-columns:84px 1fr;padding:14px 0;border-bottom:1px solid var(--border);align-items:baseline;}
.coach-titles .yr{font-family:var(--font-head);font-size:22px;color:var(--acc);letter-spacing:0.06em;}
.coach-titles .ttl{font-family:var(--font-cond);font-size:16px;font-weight:600;color:var(--text-2);letter-spacing:0.02em;}
@media (max-width:980px){.coach{grid-template-columns:1fr;}.coach-photo img{height:420px;}}

/* final cta */
.final{position:relative;text-align:center;padding:130px 28px 120px;background:var(--bg-2);overflow:hidden;border-top:1px solid var(--border);}
.final::before{content:"";position:absolute;top:-180px;left:50%;transform:translateX(-50%);width:760px;height:760px;
  background:var(--acc);border-radius:50%;filter:blur(220px);opacity:0.05;pointer-events:none;}
.final .eyebrow{font-family:var(--font-cond);font-size:13px;font-weight:700;letter-spacing:0.32em;color:var(--acc);text-transform:uppercase;margin-bottom:22px;}
.final h2{font-size:clamp(56px,8.5vw,128px);line-height:0.9;color:#FFF;margin-bottom:18px;text-transform:uppercase;}
.final h2 .yl{color:var(--acc);}
.final p{font-family:var(--font-cond);font-size:19px;font-weight:500;color:var(--muted);max-width:540px;margin:0 auto 40px;line-height:1.6;}
.final .meta{margin-top:30px;display:flex;justify-content:center;gap:34px;flex-wrap:wrap;}
.final .meta span{font-family:var(--font-cond);font-size:13px;font-weight:600;letter-spacing:0.14em;color:var(--dim);text-transform:uppercase;}

/* footer */
.footer{border-top:1px solid var(--border);background:#070707;}
.footer-inner{max-width:var(--maxw);margin:0 auto;padding:28px;display:flex;align-items:center;gap:20px;flex-wrap:wrap;}
.footer-inner img{width:38px;height:38px;}
.footer-inner .b{font-family:var(--font-head);font-size:16px;letter-spacing:0.12em;color:var(--text-2);}
.footer-inner .spacer{flex:1;}
.footer-inner nav{display:flex;gap:22px;flex-wrap:wrap;}
.footer-inner nav a{font-family:var(--font-cond);font-size:12px;font-weight:700;letter-spacing:0.1em;color:var(--dim);text-transform:uppercase;}
.footer-inner nav a:hover{color:var(--text-2);}

/* floating text pill */
.float-text{position:fixed;right:22px;bottom:22px;z-index:80;display:flex;align-items:center;gap:12px;
  background:var(--acc);color:#000;padding:14px 22px;font-family:var(--font-cond);font-weight:800;
  font-size:14px;letter-spacing:0.08em;text-transform:uppercase;border-radius:999px;
  box-shadow:0 10px 36px rgba(0,0,0,0.55),0 2px 10px rgba(255,214,0,0.25);transition:transform 0.15s;}
.float-text{cursor:default;}
.float-text .dot{width:8px;height:8px;border-radius:50%;background:#000;position:relative;}
@media (prefers-reduced-motion: no-preference){
  .float-text .dot::after{content:"";position:absolute;inset:-5px;border-radius:50%;border:2px solid rgba(0,0,0,0.5);animation:ping 1.8s ease-out infinite;}
  @keyframes ping{0%{transform:scale(0.5);opacity:1;}100%{transform:scale(1.6);opacity:0;}}
}
body[data-float="off"] .float-text{display:none;}

@media (max-width:640px){
  .section{padding:72px 20px;}
  .hero-content{padding:140px 20px 44px;gap:22px;}
  .hero-foot-inner{padding:14px 20px;gap:16px;}
  .btn{padding:14px 22px;font-size:14px;}
  .final{padding:90px 20px;}
}
