/* =============================================================================
   SundayMarathon — App ("LinkedIn for marathons") — volt design system.
   Ported pixel-faithfully from the Claude Design handoff (SundayMarathon App.html).
   Self-contained: the app layout loads ONLY this file (+ fonts). No ds.css.
   Fonts: Archivo (display/numbers) · Hanken Grotesk (body) · Space Mono (data).
   ========================================================================== */

:root{
  --ink:oklch(0.20 0.012 95);--ink-2:oklch(0.30 0.012 95);
  --paper:oklch(0.965 0.006 95);--paper-2:oklch(0.945 0.008 95);
  --card:oklch(1 0 0);--line:oklch(0.90 0.01 95);--line-dk:oklch(0.34 0.012 95);
  --volt:oklch(0.87 0.20 128);--volt-deep:oklch(0.74 0.20 130);
  --muted:oklch(0.52 0.012 95);--muted-dk:oklch(0.70 0.01 95);
  --r:14px;--ease:cubic-bezier(.2,.7,.2,1);
  --shadow:0 24px 50px -34px rgba(0,0,0,.45);
}
*{box-sizing:border-box;margin:0;padding:0}
[hidden]{display:none!important} /* author rules (.modal-back/.onb display) must not defeat hidden */
html,body{height:100%}
body{font-family:"Hanken Grotesk",system-ui,sans-serif;background:var(--paper-2);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.5}
h1,h2,h3,h4{font-family:"Archivo",sans-serif;font-weight:800;line-height:1.0;letter-spacing:-0.02em}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea{font-family:inherit}
a{color:inherit;text-decoration:none}
.gi{font-family:"Space Mono",monospace;display:inline-block;line-height:1;font-weight:700}
.mono{font-family:"Space Mono",monospace}
.eyebrow{font-family:"Space Mono",monospace;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.eyebrow.volt{color:var(--volt-deep)}
.hl{color:var(--volt-deep)}
.row{display:flex;align-items:center}
.gap8{gap:8px}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:"Archivo";font-weight:700;font-size:15px;padding:12px 20px;border-radius:999px;border:1.5px solid transparent;transition:transform .14s var(--ease),background .2s,box-shadow .2s,color .2s,border-color .2s;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-sm{padding:8px 15px;font-size:13.5px}
.btn-full{width:100%}
.btn-volt{background:var(--volt);color:var(--ink);box-shadow:0 1px 0 var(--volt-deep)}
.btn-volt:hover{box-shadow:0 8px 22px -8px var(--volt-deep);transform:translateY(-1px)}
.btn-ink{background:var(--ink);color:var(--paper)}
.btn-ink:hover{transform:translateY(-1px);box-shadow:0 10px 24px -12px var(--ink)}
.btn-ghost{background:var(--card);color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--ink)}
.btn-ghost-d{background:transparent;color:var(--paper);border-color:var(--line-dk)}
.btn-ghost-d:hover{border-color:var(--paper)}
.btn .gi{font-size:.95em}

/* ---- avatar ---- */
.sm-ava{display:inline-grid;place-items:center;font-family:"Archivo";font-weight:900;color:var(--paper);flex:none;line-height:1}
.sm-ava[style*="0.87 0.20"]{color:var(--ink)}

/* ---- placeholder ---- */
.ph{position:relative;width:100%;height:100%;display:grid;place-items:center;overflow:hidden;
  background:repeating-linear-gradient(135deg,oklch(0.30 0.012 95) 0 2px,transparent 2px 11px),linear-gradient(160deg,oklch(0.27 0.012 95),oklch(0.22 0.012 95))}
.ph.light{background:repeating-linear-gradient(135deg,var(--line) 0 2px,transparent 2px 11px),linear-gradient(160deg,var(--paper-2),oklch(0.92 0.01 95))}
.ph-tag{font-family:"Space Mono";font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-dk);background:color-mix(in oklab,var(--ink) 66%,transparent);padding:5px 9px;border-radius:6px;text-align:center}
.ph.light .ph-tag{color:var(--muted);background:color-mix(in oklab,var(--paper) 70%,transparent)}

/* ---- card ---- */
.card{background:var(--card);border:1px solid var(--line);border-radius:16px}
.card-hover{cursor:pointer;transition:transform .2s var(--ease),box-shadow .2s,border-color .2s}
.card-hover:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--ink)}

/* ---- dist tag ---- */
.dist-tag{font-family:"Space Mono";font-weight:700;font-size:11px;letter-spacing:.07em;text-transform:uppercase;background:var(--paper-2);border:1px solid var(--line);padding:4px 9px;border-radius:7px}
.dist-tag.float{position:absolute;top:12px;right:12px;background:var(--volt);color:var(--ink);border:none}
.dist-tag.float.big{font-size:13px;padding:7px 12px;border-radius:9px}

/* ---- stat ---- */
.statblk .sn{font-family:"Archivo";font-weight:900;font-size:26px;letter-spacing:-.03em}
.statblk .sn.accent{color:var(--volt-deep)}
.statblk .sl{font-family:"Space Mono";font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:4px}

/* ---- avatar stack ---- */
.ava-stack{display:flex}
.ava-stack .sm-ava{margin-left:-8px}
.ava-stack .sm-ava:first-child{margin-left:0}
.ava-extra{font-family:"Space Mono";font-size:11px;color:var(--muted);align-self:center;margin-left:8px;font-weight:700}

/* ---- brand / mark ---- */
.brand{display:flex;align-items:center;gap:10px;font-family:"Archivo";font-weight:900;font-size:18px;letter-spacing:-.03em}
.mark{width:28px;height:28px;border-radius:50%;background:var(--ink);position:relative;flex:none}
.mark::before{content:"";position:absolute;inset:0;border-radius:50%;border:3px solid var(--volt);clip-path:polygon(50% 0,100% 0,100% 100%,50% 100%)}
.mark::after{content:"";position:absolute;width:7px;height:7px;border-radius:50%;background:var(--volt);top:5px;left:5px}

/* ====================== APP BAR ====================== */
.appbar{position:sticky;top:0;z-index:40;background:color-mix(in oklab,var(--paper) 88%,transparent);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.appbar-in{max-width:1180px;margin:0 auto;height:62px;display:flex;align-items:center;gap:20px;padding:0 24px}
.appbar .brand-tx{font-size:18px}
@media(max-width:720px){.appbar .brand-tx{display:none}}
.appbar-search{flex:1;max-width:360px;display:flex;align-items:center;gap:9px;background:var(--paper-2);border:1px solid var(--line);border-radius:11px;padding:9px 13px;color:var(--muted)}
.appbar-search input{border:none;background:none;outline:none;width:100%;font-size:14px;color:var(--ink);cursor:pointer}
.appbar-search .gi{font-size:15px}
.appbar-nav{margin-left:auto;display:flex;align-items:center;gap:4px}
.navitem{display:flex;flex-direction:column;align-items:center;gap:2px;padding:7px 14px;border-radius:10px;color:var(--muted);font-size:11px;font-weight:600;font-family:"Hanken Grotesk";transition:color .15s,background .15s}
.navitem .gi{font-size:18px}
.navitem:hover{color:var(--ink);background:var(--paper-2)}
.navitem.active{color:var(--ink)}
.navitem.active .gi{color:var(--volt-deep)}
@media(max-width:720px){.navitem span{display:none}.navitem{padding:8px}}
.upgrade-pill{display:flex;align-items:center;gap:6px;margin-left:8px;background:var(--volt);color:var(--ink);font-family:"Archivo";font-weight:800;font-size:13px;padding:9px 15px;border-radius:999px;transition:transform .14s,box-shadow .2s}
.upgrade-pill:hover{transform:translateY(-1px);box-shadow:0 8px 20px -8px var(--volt-deep)}
.upgrade-pill.pro{background:var(--ink);color:var(--volt)}
@media(max-width:560px){.upgrade-pill span span{display:none}}
.appbar-ava{margin-left:8px;border-radius:11px;transition:transform .14s}
.appbar-ava:hover{transform:translateY(-1px)}

.app-main{max-width:1180px;margin:0 auto;padding:26px 24px 90px}

/* mobile bottom nav */
.mobnav{display:none}
@media(max-width:720px){
  .appbar-nav .navitem{display:none}
  .mobnav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:40;background:var(--card);border-top:1px solid var(--line);justify-content:space-around;padding:8px 0 10px}
  .mobitem{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;color:var(--muted);font-weight:600}
  .mobitem .gi{font-size:19px}
  .mobitem.active{color:var(--ink)}.mobitem.active .gi{color:var(--volt-deep)}
}

/* ====================== FEED ====================== */
.feed-layout{display:grid;grid-template-columns:248px minmax(0,1fr) 300px;gap:22px;align-items:start}
.col-left,.col-right{position:sticky;top:84px;display:flex;flex-direction:column;gap:16px}
@media(max-width:980px){.feed-layout{grid-template-columns:minmax(0,1fr) 300px}.col-left{display:none}}
@media(max-width:760px){.feed-layout{grid-template-columns:1fr}.col-right{display:none}}

.mini-pf{overflow:hidden;cursor:pointer;transition:box-shadow .2s}
.mini-pf:hover{box-shadow:var(--shadow)}
.mp-cover{height:62px;background:linear-gradient(120deg,var(--ink),var(--ink-2));position:relative}
.mp-body{padding:0 18px 18px;text-align:center}
.mp-body .sm-ava{margin:-34px auto 0}
.mp-name{font-family:"Archivo";font-weight:800;font-size:18px;margin-top:10px;display:flex;align-items:center;justify-content:center;gap:6px}
.mp-role{font-size:13px;color:var(--muted);margin-top:2px}
.mp-stats{display:flex;justify-content:space-between;margin:16px 4px;padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.mp-stats div{display:flex;flex-direction:column}
.mp-stats b{font-family:"Archivo";font-weight:900;font-size:17px}
.mp-stats span{font-family:"Space Mono";font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.mp-link{font-family:"Archivo";font-weight:700;font-size:13px;color:var(--volt-deep);display:flex;align-items:center;justify-content:center;gap:4px}

.upsell{padding:18px;cursor:pointer}
.up-badge{font-family:"Space Mono";font-size:10px;letter-spacing:.14em;color:var(--volt-deep)}
.up-title{font-family:"Archivo";font-weight:800;font-size:18px;margin:8px 0 4px;letter-spacing:-.01em}
.up-text{font-size:13.5px;color:var(--muted);margin-bottom:14px}
.upsell.pro{cursor:default;background:var(--ink);color:var(--paper)}
.upsell.pro .up-title{color:var(--paper)}.upsell.pro .up-text{color:var(--muted-dk);margin-bottom:0}.upsell.pro .up-badge{color:var(--volt)}

.col-mid{display:flex;flex-direction:column;gap:16px;min-width:0}
.compose{padding:16px}
.compose-top{display:flex;align-items:center;gap:12px}
.compose-trigger{flex:1;text-align:left;background:var(--paper-2);border:1px solid var(--line);border-radius:999px;padding:13px 18px;color:var(--muted);font-size:14.5px;transition:border-color .15s}
.compose-trigger:hover{border-color:var(--ink)}
.compose-quick{display:flex;gap:18px;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.compose-quick span{font-family:"Archivo";font-weight:700;font-size:13px;color:var(--muted);display:flex;align-items:center;gap:7px}
.compose-quick .gi{color:var(--volt-deep);font-size:15px}
.compose-open{margin-top:14px}
.compose-open textarea{width:100%;min-height:96px;border:1px solid var(--line);border-radius:12px;padding:14px;font-size:15px;resize:vertical;outline:none;background:var(--paper)}
.compose-open textarea:focus{border-color:var(--ink)}
.compose-actions{display:flex;align-items:center;justify-content:space-between;margin-top:12px;gap:12px;flex-wrap:wrap}
.compose-chips{display:flex;gap:8px;flex-wrap:wrap}
.cchip{font-family:"Space Mono";font-size:11px;letter-spacing:.04em;text-transform:uppercase;background:var(--paper-2);border:1px solid var(--line);padding:6px 10px;border-radius:8px;color:var(--muted);display:flex;align-items:center;gap:6px}

.post{padding:18px}
.post-head{display:flex;align-items:flex-start;gap:12px}
.post-meta{flex:1;min-width:0}
.post-name{font-family:"Archivo";font-weight:800;font-size:16px;display:flex;align-items:center;gap:6px}
.post-sub{font-size:13px;color:var(--muted)}
.post-time{font-family:"Space Mono";font-size:11px;color:var(--muted);margin-top:2px}
.post-follow{font-family:"Archivo";font-weight:700;font-size:13px;color:var(--volt-deep);padding:6px 10px;border-radius:8px;transition:background .15s}
.post-follow:hover{background:var(--paper-2)}
.post-text{font-size:15.5px;line-height:1.55;margin:14px 0;color:var(--ink-2)}
.verified{width:20px;height:20px;border-radius:50%;background:var(--volt);color:var(--ink);display:inline-grid;place-items:center;font-family:"Archivo";font-weight:900;font-size:11px;flex:none}
.verified.sm{width:16px;height:16px;font-size:9px}
.post-stat{display:flex;align-items:center;gap:16px;flex-wrap:wrap;background:var(--ink);color:var(--paper);border-radius:13px;padding:16px 18px}
.ps-num{font-family:"Archivo";font-weight:900;font-size:34px;letter-spacing:-.04em;color:var(--volt)}
.ps-lab{font-family:"Space Mono";font-size:11px;letter-spacing:.12em;color:var(--muted-dk)}
.ps-race{margin-left:auto;font-family:"Archivo";font-weight:700;font-size:13px;color:var(--paper);background:oklch(0.30 0.012 95);padding:9px 13px;border-radius:9px;display:flex;align-items:center;gap:6px}
.ps-race:hover{background:oklch(0.36 0.012 95)}
.post-racecard{display:flex;align-items:center;gap:14px;width:100%;text-align:left;background:var(--paper-2);border:1px solid var(--line);border-radius:13px;padding:12px;transition:border-color .15s}
.post-racecard:hover{border-color:var(--ink)}
.prc-name{font-family:"Archivo";font-weight:800;font-size:16px}
.prc-meta{font-size:13px;color:var(--muted)}
.prc-go{margin-left:auto;color:var(--muted);font-size:20px}
.post-foot{display:flex;gap:8px;margin-top:14px;padding-top:12px;border-top:1px solid var(--line)}
.pf-btn{display:flex;align-items:center;gap:7px;font-family:"Archivo";font-weight:700;font-size:13.5px;color:var(--muted);padding:8px 14px;border-radius:9px;transition:background .15s,color .15s}
.pf-btn:hover{background:var(--paper-2);color:var(--ink)}
.pf-btn.on{color:var(--volt-deep)}

/* right rail */
.rail{display:flex;flex-direction:column;gap:16px}
.rail-card{padding:16px}
.rail-head{font-family:"Archivo";font-weight:800;font-size:14px;letter-spacing:-.01em;margin-bottom:12px}
.rail-race{display:flex;align-items:center;gap:11px;width:100%;text-align:left;padding:9px 0;border-bottom:1px solid var(--line);transition:opacity .15s}
.rail-race:hover{opacity:.65}
.rr-name{font-family:"Archivo";font-weight:700;font-size:14px;line-height:1.15}
.rr-meta{font-family:"Space Mono";font-size:10.5px;color:var(--muted);margin-top:2px}
.rail-person{display:flex;align-items:center;gap:11px;padding:9px 0;border-bottom:1px solid var(--line)}
.rp-info{flex:1;min-width:0}
.rp-name{font-family:"Archivo";font-weight:700;font-size:14px}
.rp-meta{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rp-follow{width:32px;height:32px;border-radius:50%;border:1.5px solid var(--line);font-family:"Archivo";font-weight:900;color:var(--ink-2);flex:none;transition:all .15s}
.rp-follow:hover{border-color:var(--ink)}
.rp-follow.on{background:var(--volt);border-color:var(--volt);color:var(--ink)}
.rail-all{font-family:"Archivo";font-weight:700;font-size:13px;color:var(--volt-deep);margin-top:12px;display:flex;align-items:center;gap:4px}
.rail-foot{font-family:"Space Mono";font-size:11px;color:var(--muted);padding:0 4px;line-height:1.6}

/* ====================== PAGES ====================== */
.page{max-width:1000px;margin:0 auto}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:26px;flex-wrap:wrap}
.page-head.center{justify-content:center;text-align:center}
.page-title{font-size:clamp(30px,4vw,46px);margin-top:10px}
.page-lede{font-size:17px;color:var(--muted);margin-top:14px;max-width:60ch}
.page-head.center .page-lede{margin-left:auto;margin-right:auto}
.dir-search{display:flex;align-items:center;gap:9px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:11px 15px;min-width:260px}
.dir-search input{border:none;outline:none;background:none;font-size:15px;width:100%}
.dir-search .gi{color:var(--muted);font-size:16px}
.net-count{font-family:"Space Mono";font-size:13px;color:var(--muted)}

.chips{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:24px}
.chip{font-family:"Archivo";font-weight:700;font-size:14px;padding:9px 16px;border-radius:999px;border:1.5px solid var(--line);background:var(--card);color:var(--ink-2);transition:all .15s var(--ease)}
.chip:hover{border-color:var(--ink)}
.chip.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.chip .c{font-family:"Space Mono";font-size:11px;opacity:.6;margin-left:5px}

.race-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:860px){.race-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.race-grid{grid-template-columns:1fr}}
.empty{font-family:"Space Mono";color:var(--muted);padding:40px 0;text-align:center}

/* race card */
.rcard{overflow:hidden;display:flex;flex-direction:column}
.rc-img{height:148px;position:relative}
.rc-date{position:absolute;top:11px;left:11px;background:var(--card);border-radius:10px;text-align:center;padding:6px 10px;box-shadow:0 6px 16px -10px rgba(0,0,0,.6);line-height:1}
.rc-date .d{font-family:"Archivo";font-weight:900;font-size:19px;letter-spacing:-.03em}
.rc-date .m{font-family:"Space Mono";font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.save{position:absolute;bottom:11px;right:11px;width:36px;height:36px;border-radius:50%;background:color-mix(in oklab,var(--ink) 52%,transparent);backdrop-filter:blur(6px);display:grid;place-items:center;color:var(--paper);font-size:16px;transition:transform .14s,background .2s}
.save:hover{transform:scale(1.1)}
.save.on{background:var(--volt);color:var(--ink)}
.rc-body{padding:16px;flex:1;display:flex;flex-direction:column}
.rc-name{font-family:"Archivo";font-weight:800;font-size:19px;letter-spacing:-.02em}
.rc-loc{font-size:13.5px;color:var(--muted);margin-top:4px;display:flex;align-items:center;gap:6px}
.rc-loc .gi{font-size:12px}
.rc-loc.big{font-size:16px;margin-top:8px}
.rc-foot{display:flex;align-items:center;justify-content:space-between;margin-top:14px;padding-top:13px;border-top:1px solid var(--line)}
.going{display:flex;align-items:center;gap:8px}
.going-t{font-family:"Space Mono";font-size:11px;color:var(--muted)}.going-t b{color:var(--ink);font-weight:700}
.rc-tag{font-family:"Space Mono";font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--volt-deep)}

.back{display:inline-flex;align-items:center;gap:7px;font-family:"Archivo";font-weight:700;font-size:14px;color:var(--muted);margin-bottom:18px;padding:7px 12px;border-radius:9px;transition:color .15s,background .15s}
.back:hover{color:var(--ink);background:var(--card)}

/* race detail */
.race-hero{margin-bottom:24px;position:relative}
.race-detail{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:30px;align-items:start}
@media(max-width:860px){.race-detail{grid-template-columns:1fr}}
.rd-blurb{font-size:17px;line-height:1.6;color:var(--ink-2);margin:18px 0 26px;max-width:60ch}
.fact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:30px}
.fact{display:flex;align-items:center;gap:13px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px}
.fact-ic{width:40px;height:40px;border-radius:10px;background:var(--paper-2);display:grid;place-items:center;color:var(--ink);font-size:16px;flex:none}
.fact-l{font-family:"Space Mono";font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.fact-v{font-family:"Archivo";font-weight:800;font-size:16px;margin-top:2px}
.rd-sec-head{font-family:"Archivo";font-weight:800;font-size:18px;margin-bottom:14px}
.going-list{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media(max-width:560px){.going-list{grid-template-columns:1fr}}
.gl-person{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:11px;cursor:pointer;transition:border-color .15s}
.gl-person:hover{border-color:var(--ink)}
.gl-name{font-family:"Archivo";font-weight:700;font-size:14.5px}
.gl-meta{font-size:12.5px;color:var(--muted)}
.rd-side{position:sticky;top:84px}
.rd-cta{padding:20px}
.rd-date-big{display:flex;align-items:baseline;gap:8px;margin-bottom:14px}
.rd-date-big .d{font-family:"Archivo";font-weight:900;font-size:44px;letter-spacing:-.04em}
.rd-date-big .rest{font-family:"Archivo";font-weight:800;font-size:18px;color:var(--muted)}
.rd-going{display:flex;align-items:center;gap:10px;font-family:"Space Mono";font-size:12px;color:var(--muted);margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.rd-cta .btn{margin-bottom:10px}
.rd-perk{font-size:13px;color:var(--muted);background:var(--paper-2);border-radius:10px;padding:12px;margin-top:6px;cursor:pointer;line-height:1.45}
.rd-perk b{color:var(--ink)}
.rd-perk.pro{cursor:default}.rd-perk.pro b{color:var(--volt-deep)}

/* ====================== NETWORK ====================== */
.people-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:860px){.people-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.people-grid{grid-template-columns:1fr}}
.pcard{padding:18px;display:flex;flex-direction:column;gap:14px}
.pcard-top{display:flex;gap:13px;cursor:pointer}
.pcard-name{font-family:"Archivo";font-weight:800;font-size:16px;display:flex;align-items:center;gap:8px}
.kind-tag{font-family:"Space Mono";font-size:9px;letter-spacing:.1em;text-transform:uppercase;background:var(--volt);color:var(--ink);padding:3px 7px;border-radius:6px}
.pcard-role{font-size:13.5px;color:var(--muted);margin-top:2px}
.pcard-city{font-family:"Space Mono";font-size:11px;color:var(--muted);margin-top:5px;display:flex;align-items:center;gap:5px}
.pcard-tags{display:flex;gap:6px;flex-wrap:wrap}
.pcard-tags span{font-family:"Space Mono";font-size:10px;letter-spacing:.04em;text-transform:uppercase;background:var(--paper-2);border:1px solid var(--line);padding:4px 8px;border-radius:6px;color:var(--muted)}

/* person profile */
.person-pf{overflow:hidden;margin-bottom:22px}
.pp-cover{height:120px;background:linear-gradient(120deg,var(--ink),var(--ink-2));position:relative;overflow:hidden}
.pp-cover-stripes{position:absolute;inset:0;background:repeating-linear-gradient(135deg,transparent 0 16px,oklch(0.30 0.012 95) 16px 17px)}
.pp-body{padding:0 28px 26px}
.pp-top{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:14px}
.pp-actions{display:flex;gap:10px;padding-bottom:4px}
.pp-name{font-family:"Archivo";font-weight:800;font-size:28px;letter-spacing:-.02em;margin-top:14px;display:flex;align-items:center;gap:9px}
.pp-role{font-size:15.5px;color:var(--muted);margin-top:3px}
.pp-city{font-family:"Space Mono";font-size:12px;color:var(--muted);margin-top:8px;display:flex;align-items:center;gap:6px}
.pp-tags{display:flex;gap:7px;flex-wrap:wrap;margin-top:14px}
.pp-tags span{font-family:"Space Mono";font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;background:var(--paper-2);border:1px solid var(--line);padding:5px 9px;border-radius:7px;color:var(--muted)}
.pp-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:22px;padding-top:20px;border-top:1px solid var(--line)}
.pp-stats.four{grid-template-columns:repeat(4,1fr)}
@media(max-width:560px){.pp-stats.four{grid-template-columns:repeat(2,1fr)}}

/* ====================== PROFILE ====================== */
.badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:22px;padding-top:20px;border-top:1px solid var(--line)}
.badge{font-family:"Archivo";font-weight:700;font-size:12.5px;background:var(--paper-2);border:1px solid var(--line);padding:7px 13px;border-radius:999px}
.badge.hot{background:var(--volt);border-color:var(--volt);color:var(--ink)}
.tabs{display:flex;gap:4px;margin-bottom:18px;border-bottom:1px solid var(--line)}
.tab{font-family:"Archivo";font-weight:700;font-size:14.5px;color:var(--muted);padding:12px 16px;border-bottom:2.5px solid transparent;margin-bottom:-1px;transition:color .15s}
.tab:hover{color:var(--ink)}
.tab.active{color:var(--ink);border-color:var(--volt)}
.tc{font-family:"Space Mono";font-size:11px;opacity:.6;margin-left:4px}
.timeline{padding:8px 20px}
.tl-row{display:flex;align-items:center;gap:15px;padding:16px 0;border-bottom:1px dashed var(--line);cursor:pointer;transition:opacity .15s}
.tl-row:last-child{border-bottom:none}
.tl-row:hover{opacity:.7}
.tl-medal{width:42px;height:42px;border-radius:11px;background:var(--paper-2);border:1px solid var(--line);display:grid;place-items:center;font-size:20px;flex:none}
.tl-main{flex:1;min-width:0}
.tl-name{font-family:"Archivo";font-weight:800;font-size:16.5px;display:flex;align-items:center;gap:9px}
.pr-flag{font-family:"Space Mono";font-size:9.5px;font-weight:700;color:var(--volt-deep);letter-spacing:.08em}
.tl-meta{font-family:"Space Mono";font-size:11.5px;color:var(--muted);margin-top:3px}
.tl-time{font-family:"Archivo";font-weight:800;font-size:19px;letter-spacing:-.02em}
.tl-go{color:var(--muted);font-size:20px}
.empty-card{padding:34px;display:flex;align-items:center;gap:18px;color:var(--muted);font-size:15px}
.ec-glyph{width:52px;height:52px;border-radius:13px;background:var(--paper-2);display:grid;place-items:center;font-size:22px;color:var(--ink);flex:none}
.link{color:var(--volt-deep);font-weight:700}
.link:hover{text-decoration:underline}
.progression{padding:24px}
.prog-head{font-family:"Archivo";font-weight:800;font-size:18px;margin-bottom:8px}
.prog-note{font-size:13.5px;color:var(--muted);margin-top:16px}
.chart{display:flex;align-items:flex-end;gap:30px;height:200px;padding:24px 10px 0}
.bar-col{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:8px}
.bar-val{font-family:"Archivo";font-weight:800;font-size:15px}
.bar{width:54px;border-radius:9px 9px 0 0;background:linear-gradient(var(--volt),var(--volt-deep));transition:height .6s var(--ease)}
.bar-col:last-child .bar{background:var(--ink)}
.bar-x{font-family:"Space Mono";font-size:12px;color:var(--muted)}

/* ====================== MEMBERSHIP ====================== */
.membership-page{max-width:1040px}
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch}
@media(max-width:860px){.price-grid{grid-template-columns:1fr}}
.tier{background:var(--ink);color:var(--paper);border:1px solid var(--line-dk);border-radius:20px;padding:30px;display:flex;flex-direction:column;position:relative}
.tier .t-list li{color:var(--muted-dk)}
.tier.feat{background:var(--volt);color:var(--ink);border-color:var(--volt);box-shadow:0 40px 80px -44px var(--volt-deep)}
.tier.feat .t-list li{color:var(--ink-2)}
.tier-badge{position:absolute;top:18px;right:18px;font-family:"Space Mono";font-size:10px;letter-spacing:.12em;text-transform:uppercase;background:var(--ink);color:var(--volt);padding:5px 10px;border-radius:999px}
.t-name{font-family:"Archivo";font-weight:800;font-size:14px;letter-spacing:.05em;text-transform:uppercase}
.t-price{font-family:"Archivo";font-weight:900;font-size:50px;letter-spacing:-.04em;margin-top:16px;line-height:1}
.t-price span{font-family:"Space Mono";font-size:13px;font-weight:400;letter-spacing:0;color:var(--muted-dk)}
.tier.feat .t-price span{color:var(--ink-2)}
.t-desc{font-size:14px;color:var(--muted-dk);margin-top:10px;min-height:42px}
.tier.feat .t-desc{color:var(--ink-2)}
.t-list{list-style:none;margin:22px 0;display:flex;flex-direction:column;gap:12px;flex:1}
.t-list li{display:flex;align-items:flex-start;gap:10px;font-size:14px}
.t-list li .ck{width:18px;height:18px;border-radius:50%;background:var(--volt);color:var(--ink);display:grid;place-items:center;font-size:10px;font-family:"Archivo";font-weight:900;flex:none;margin-top:1px}
.tier.feat .t-list li .ck{background:var(--ink);color:var(--volt)}

/* ====================== MODAL / CHECKOUT ====================== */
.modal-back{position:fixed;inset:0;z-index:60;background:color-mix(in oklab,var(--ink) 55%,transparent);backdrop-filter:blur(5px);display:grid;place-items:center;padding:24px}
.modal{background:var(--card);border-radius:20px;width:100%;max-width:420px;padding:30px;position:relative;box-shadow:0 50px 100px -30px rgba(0,0,0,.6);animation:pop .25s var(--ease)}
.modal-wide{max-width:620px}
@keyframes pop{from{transform:translateY(12px) scale(.985)}to{transform:none}}
.modal-x{position:absolute;top:16px;right:16px;width:34px;height:34px;border-radius:9px;display:grid;place-items:center;color:var(--muted);font-size:14px}
.modal-x:hover{background:var(--paper-2);color:var(--ink)}
.checkout.center{text-align:center}
.co-badge{font-family:"Space Mono";font-size:11px;letter-spacing:.14em;color:var(--volt-deep)}
.co-price{font-family:"Archivo";font-weight:900;font-size:48px;letter-spacing:-.04em;margin-top:6px}
.co-price span{font-family:"Space Mono";font-size:15px;font-weight:400;color:var(--muted)}
.co-sub{font-size:13.5px;color:var(--muted);margin:6px 0 22px}
.co-field{margin-bottom:14px}
.co-field label{font-family:"Space Mono";font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:6px}
.co-field input{width:100%;border:1px solid var(--line);border-radius:11px;padding:13px 14px;font-size:15px;outline:none;background:var(--paper)}
.co-field input:focus{border-color:var(--ink)}
.co-row{display:flex;gap:12px}.co-row .co-field{flex:1}
.checkout .btn{margin-top:6px}
.co-fine{font-family:"Space Mono";font-size:11px;color:var(--muted);text-align:center;margin-top:14px}
.spinner{width:44px;height:44px;border-radius:50%;border:4px solid var(--line);border-top-color:var(--volt-deep);margin:10px auto 18px;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.co-proc{font-family:"Archivo";font-weight:700;font-size:16px;color:var(--muted)}
.co-tick{width:64px;height:64px;border-radius:50%;background:var(--volt);color:var(--ink);display:grid;place-items:center;font-family:"Archivo";font-weight:900;font-size:30px;margin:6px auto 16px}
.co-done-t{font-family:"Archivo";font-weight:900;font-size:28px;letter-spacing:-.02em}
.co-done-s{font-size:14.5px;color:var(--muted);margin:8px 0 22px}

/* ====================== TOAST ====================== */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%);z-index:70;background:var(--ink);color:var(--paper);font-family:"Archivo";font-weight:700;font-size:14px;padding:13px 20px;border-radius:999px;display:flex;align-items:center;gap:9px;box-shadow:0 20px 40px -16px rgba(0,0,0,.6);opacity:0;pointer-events:none;transition:opacity .25s,transform .25s}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast .gi{color:var(--volt)}
@media(max-width:720px){.toast{bottom:80px}}

/* ====================== ONBOARDING ====================== */
.onb{min-height:100vh;background:var(--ink);color:var(--paper);display:flex;flex-direction:column}
.onb-bar{display:flex;align-items:center;justify-content:space-between;padding:20px 28px;max-width:1100px;margin:0 auto;width:100%}
.onb-bar .brand{color:var(--paper)}
.onb-skip{font-family:"Space Mono";font-size:12px;color:var(--muted-dk)}
.onb-skip:hover{color:var(--paper)}
.onb-stage{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px 24px 60px;width:100%}
.onb-dots{display:flex;gap:8px;margin-bottom:30px}
.odot{width:30px;height:4px;border-radius:2px;background:oklch(0.34 0.012 95);transition:background .3s}
.odot.on{background:var(--volt)}
.onb-card{width:100%;max-width:540px}
.onb-welcome{text-align:center}
.onb-welcome h1{font-size:clamp(38px,6vw,60px);font-weight:900;letter-spacing:-.035em;margin:16px 0}
.onb-welcome .hl{color:var(--volt)}
.onb-welcome p{font-size:17px;color:var(--muted-dk);max-width:42ch;margin:0 auto 28px;line-height:1.5}
.onb-login{font-size:14px;color:var(--muted-dk);margin-top:20px}
.link-volt{color:var(--volt);font-weight:700;white-space:nowrap}
.onb-step{font-family:"Space Mono";font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--volt)}
.onb-card h2{font-size:clamp(28px,4vw,40px);font-weight:900;letter-spacing:-.03em;margin-top:12px}
.onb-p{font-size:16px;color:var(--muted-dk);margin:12px 0 26px}
.onb-field{margin-bottom:18px}
.onb-field label{font-family:"Space Mono";font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-dk);display:block;margin-bottom:8px}
.onb-field input{width:100%;background:oklch(0.26 0.012 95);border:1.5px solid var(--line-dk);border-radius:12px;padding:15px 16px;font-size:16px;color:var(--paper);outline:none;transition:border-color .15s}
.onb-field input::placeholder{color:oklch(0.5 0.01 95)}
.onb-field input:focus{border-color:var(--volt)}
.onb-nav{display:flex;align-items:center;justify-content:space-between;margin-top:28px}
.onb-back{font-family:"Archivo";font-weight:700;font-size:14px;color:var(--muted-dk);display:flex;align-items:center;gap:6px}
.onb-back:hover{color:var(--paper)}
.goal-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:520px){.goal-grid{grid-template-columns:1fr}}
.goal-opt{position:relative;text-align:left;background:oklch(0.26 0.012 95);border:1.5px solid var(--line-dk);border-radius:14px;padding:18px;transition:border-color .15s,background .15s}
.goal-opt:hover{border-color:oklch(0.5 0.012 95)}
.goal-opt.on{border-color:var(--volt);background:oklch(0.30 0.04 128)}
.go-label{font-family:"Archivo";font-weight:800;font-size:16px}
.go-sub{font-size:13px;color:var(--muted-dk);margin-top:3px}
.go-check{position:absolute;top:16px;right:16px;width:22px;height:22px;border-radius:50%;background:var(--volt);color:var(--ink);display:grid;place-items:center;font-family:"Archivo";font-weight:900;font-size:11px;opacity:0;transform:scale(.6);transition:all .15s}
.goal-opt.on .go-check{opacity:1;transform:none}
.target-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:24px}
.target-opt{font-family:"Archivo";font-weight:700;font-size:14px;padding:11px 18px;border-radius:999px;background:oklch(0.26 0.012 95);border:1.5px solid var(--line-dk);color:var(--muted-dk);transition:all .15s}
.target-opt:hover{border-color:oklch(0.5 0.012 95)}
.target-opt.on{background:var(--volt);border-color:var(--volt);color:var(--ink)}
.onb-summary{background:oklch(0.24 0.012 95);border:1px solid var(--line-dk);border-radius:14px;padding:18px;display:flex;flex-direction:column;gap:10px}
.os-row{display:flex;justify-content:space-between;font-size:14px}
.os-row span{color:var(--muted-dk);font-family:"Space Mono";font-size:12px;letter-spacing:.06em;text-transform:uppercase}
.os-row b{font-family:"Archivo";font-weight:700}

/* utility */
.center{text-align:center}
.app-hidden{display:none!important}

/* ====================== MARATHON DETAIL (mockup-styled) ====================== */
/* Hero: dark striped banner with giant volt distance + save heart */
.mhero{position:relative;height:230px;border-radius:18px;overflow:hidden;display:grid;place-items:center;margin-bottom:26px;
  background:repeating-linear-gradient(135deg,oklch(0.30 0.012 95) 0 2px,transparent 2px 11px),linear-gradient(150deg,oklch(0.27 0.012 95),oklch(0.20 0.012 95))}
.mhero .dist-big{font-family:"Archivo";font-weight:900;font-size:64px;letter-spacing:-.05em;color:var(--volt);opacity:.92;line-height:1}
.mhero .ph-tag{position:absolute;left:16px;bottom:16px;font-family:"Space Mono";font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-dk);background:color-mix(in oklab,var(--ink) 66%,transparent);padding:6px 10px;border-radius:7px}
.mhero .save{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:50%;background:color-mix(in oklab,var(--ink) 52%,transparent);backdrop-filter:blur(6px);display:grid;place-items:center;color:var(--paper);font-size:17px;transition:transform .14s,background .2s;cursor:pointer;border:none}
.mhero .save:hover{transform:scale(1.08)}
.mhero .save.on{background:var(--volt);color:var(--ink)}

/* Title block + status chips */
.titlerow{margin-bottom:8px}
.titlerow .page-title{font-size:clamp(30px,4.4vw,50px);margin:12px 0 10px;max-width:18ch}
.loc-line{font-size:16px;color:var(--muted);display:flex;align-items:center;gap:7px}
.loc-line .gi{font-size:13px;color:var(--volt-deep)}
.chips-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}
.chip-st{display:inline-flex;align-items:center;gap:6px;font-family:"Space Mono";font-size:11px;letter-spacing:.05em;text-transform:uppercase;padding:6px 11px;border-radius:999px;border:1px solid var(--line);background:var(--card);color:var(--muted)}
.chip-st.ok{border-color:color-mix(in oklab,var(--volt-deep) 40%,transparent);background:color-mix(in oklab,var(--volt) 16%,var(--card));color:var(--ink)}
.chip-st .dot{width:7px;height:7px;border-radius:50%;background:var(--volt-deep)}

/* Detail grid (main + sticky sidebar) */
.mdetail{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:30px;align-items:start;margin-top:30px}
@media(max-width:900px){.mdetail{grid-template-columns:1fr}}
.lede{font-size:17px;line-height:1.6;color:var(--ink-2);max-width:62ch;margin-bottom:26px}

/* Sections */
.sec{margin-bottom:34px}
.sec-head{font-family:"Archivo";font-weight:800;font-size:22px;letter-spacing:-.02em;margin-bottom:14px}
.sec p{font-size:15.5px;line-height:1.62;color:var(--ink-2);max-width:64ch}
.sec p + p{margin-top:12px}

/* Definition rows (Key facts) */
.deflist{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.defrow{display:grid;grid-template-columns:200px 1fr;gap:16px;padding:14px 18px;border-top:1px solid var(--line)}
.defrow:first-child{border-top:none}
.defrow dt{font-family:"Space Mono";font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);padding-top:2px}
.defrow dd{font-size:15px;font-weight:500}
.defrow dd a{color:var(--volt-deep);font-weight:700;border-bottom:1px solid color-mix(in oklab,var(--volt-deep) 40%,transparent)}
.defrow dd a:hover{border-color:var(--volt-deep)}
@media(max-width:520px){.defrow{grid-template-columns:1fr;gap:4px}}

/* Planning checklist (Before you register) */
.checks{list-style:none;display:flex;flex-direction:column;gap:10px;padding:0;margin:0}
.checks li{display:flex;gap:13px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.checks .ck{width:24px;height:24px;border-radius:7px;background:var(--paper-2);border:1px solid var(--line);display:grid;place-items:center;color:var(--volt-deep);font-family:"Space Mono";font-weight:700;font-size:12px;flex:none;margin-top:1px}
.checks b{font-family:"Archivo";font-weight:800;font-size:14.5px;display:block;margin-bottom:3px}
.checks p{font-size:14px;color:var(--muted);line-height:1.5;margin:0;max-width:none}

/* Sidebar */
.mside{position:sticky;top:84px;display:flex;flex-direction:column;gap:16px}
@media(max-width:900px){.mside{position:static}}
.scard{padding:20px}
.scard-h{font-family:"Archivo";font-weight:800;font-size:15px;letter-spacing:-.01em;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.scard-h .gi{color:var(--volt-deep);font-size:15px}

/* Countdown */
.cd-date{display:flex;align-items:baseline;gap:8px;margin-bottom:16px}
.cd-date .d{font-family:"Archivo";font-weight:900;font-size:44px;letter-spacing:-.04em;line-height:1}
.cd-date .rest{font-family:"Archivo";font-weight:800;font-size:17px;color:var(--muted)}
.cd-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.cd-unit{background:var(--paper-2);border:1px solid var(--line);border-radius:10px;padding:11px 4px;text-align:center}
.cd-val{font-family:"Archivo";font-weight:900;font-size:24px;letter-spacing:-.03em;font-variant-numeric:tabular-nums;line-height:1}
.cd-lab{font-family:"Space Mono";font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:6px}

/* CTA stack */
.cta-btns{display:flex;flex-direction:column;gap:10px}
.cta-note{font-family:"Space Mono";font-size:11px;color:var(--muted);line-height:1.5;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}

/* Contact list */
.contact{list-style:none;display:flex;flex-direction:column;gap:12px;padding:0;margin:0}
.contact li{display:flex;align-items:center;gap:11px;font-size:14px}
.contact .ci{width:34px;height:34px;border-radius:9px;background:var(--paper-2);border:1px solid var(--line);display:grid;place-items:center;color:var(--ink);font-size:14px;flex:none}
.contact .cl{font-family:"Space Mono";font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.contact .cv{font-weight:600;margin-top:1px;word-break:break-word}
.contact .cv a{color:var(--volt-deep);font-weight:700}

/* For-organizers ink card */
.org-card{background:var(--ink);color:var(--paper);border-radius:16px;padding:20px}
.org-card .eyebrow{color:var(--volt)}
.org-card h3{color:var(--paper);font-family:"Archivo";font-weight:800;font-size:18px;margin:10px 0 8px;letter-spacing:-.01em}
.org-card p{font-size:13.5px;color:var(--muted-dk);line-height:1.5;margin-bottom:16px}
.org-card .btn-ghost{background:transparent;color:var(--paper);border-color:var(--line-dk)}
.org-card .btn-ghost:hover{border-color:var(--paper)}

/* Related races grid */
.mrace-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:860px){.mrace-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.mrace-grid{grid-template-columns:1fr}}
.mrcard{background:var(--card);border:1px solid var(--line);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;text-decoration:none;color:inherit;transition:transform .2s var(--ease),box-shadow .2s,border-color .2s}
.mrcard:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--ink)}
.mrcard .rc-img{height:130px;position:relative;display:grid;place-items:center;
  background:repeating-linear-gradient(135deg,oklch(0.30 0.012 95) 0 2px,transparent 2px 11px),linear-gradient(160deg,oklch(0.27 0.012 95),oklch(0.22 0.012 95))}
.mrcard .rc-img .em{font-family:"Archivo";font-weight:900;font-size:26px;color:var(--volt);opacity:.55;letter-spacing:-.04em}
.mrcard .rc-flag{position:absolute;top:11px;right:11px;font-family:"Space Mono";font-size:9px;letter-spacing:.06em;text-transform:uppercase;background:var(--volt);color:var(--ink);padding:4px 8px;border-radius:7px;font-weight:700}
.rc-dists{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px}
.rc-dists span{font-family:"Space Mono";font-size:10px;letter-spacing:.04em;text-transform:uppercase;background:var(--paper-2);border:1px solid var(--line);padding:4px 8px;border-radius:7px;color:var(--muted)}
.mrcard .rc-foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:14px;border-top:1px solid var(--line)}
.rc-src{font-family:"Space Mono";font-size:11px;color:var(--muted)}
.rc-src b{color:var(--ink);font-weight:700}
.rc-cd{font-family:"Space Mono";font-size:10.5px;color:var(--volt-deep);font-variant-numeric:tabular-nums}
