:root{--bg-0:#09090b;--bg-1:#0f0f12;--bg-2:#18181b;--bg-3:#1e1e24;--bg-4:#27272a;--bg-hover:#2a2a30;--text-0:#fafafa;--text-1:#d4d4d8;--text-2:#a1a1aa;--text-3:#8b8b95;--accent:#ef4444;--accent-hover:#dc2626;--accent-soft:#ef44441f;--accent-glow:#ef444440;--green:#22c55e;--green-soft:#22c55e1f;--blue:#3b82f6;--blue-soft:#3b82f61f;--yellow:#eab308;--yellow-soft:#eab3081f;--orange:#f97316;--purple:#a855f7;--border:#27272a;--border-light:#3f3f46;--radius:10px;--radius-sm:6px;--radius-lg:14px;--radius-full:9999px;--shadow:0 4px 24px #0000004d;--shadow-lg:0 12px 40px #00000080;--transition:.15s ease;--tier-jogger:#cd7f32;--tier-pacer:#d4d4d8;--tier-racer:gold;--tier-sprinter:#22d3ee;--tier-champion:#b9f2ff;--gold:gold;--danger:#ef4444;--primary:#ef4444;--red:#ef4444;--text-muted:#8b8b95;--premium:#a855f7;--cooldown:#60a5fa;--hr-color:#ff4d6a;--space-xs:4px;--space-sm:8px;--space-md:12px;--space-lg:16px;--space-xl:20px;--space-2xl:24px;--sab:env(safe-area-inset-bottom,0px);--sat:env(safe-area-inset-top,0px);--sal:env(safe-area-inset-left,0px);--sar:env(safe-area-inset-right,0px)}*{box-sizing:border-box;margin:0;padding:0}img{max-width:100%}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.skip-link{z-index:10000;background:var(--accent);color:#fff;border-radius:var(--radius-sm);padding:8px 16px;font-size:14px;font-weight:600;text-decoration:none;transition:top .15s;position:absolute;top:-100%;left:16px}.skip-link:focus{top:8px}.flex-between{justify-content:space-between;align-items:center;display:flex}.flex-center{justify-content:center;align-items:center;display:flex}.flex-row{align-items:center;display:flex}.flex-col{flex-direction:column;display:flex}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.gap-xs{gap:4px}.gap-sm{gap:8px}.gap-md{gap:12px}.gap-lg{gap:16px}.gap-xl{gap:20px}.w-full{width:100%}.text-center{text-align:center}.text-left{text-align:left}.text-muted,.text-subtle{color:var(--text-3)}.text-accent{color:var(--accent)}.text-danger{color:var(--danger,#ef4444)}.text-sm{font-size:13px}.text-xs{font-size:12px}.text-xxs{font-size:11px}.font-bold{font-weight:700}.font-semibold{font-weight:600}.mt-0{margin-top:0}.mt-sm{margin-top:8px}.mt-md{margin-top:12px}.mt-lg{margin-top:16px}.mt-xl{margin-top:20px}.mb-0{margin-bottom:0}.mb-sm{margin-bottom:8px}.mb-md{margin-bottom:12px}.mb-lg{margin-bottom:16px}.mb-xl{margin-bottom:24px}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg, var(--bg-2) 25%, var(--bg-3) 50%, var(--bg-2) 75%);border-radius:var(--radius-sm);-webkit-user-select:none;user-select:none;pointer-events:none;background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer;color:#0000!important}.skeleton *{visibility:hidden}.skeleton-text{height:14px;margin-bottom:8px}.skeleton-text-sm{width:60%;height:10px;margin-bottom:6px}.skeleton-avatar{border-radius:50%}.skeleton-card{border-radius:var(--radius);border:1px solid var(--border);background:linear-gradient(90deg, var(--bg-2) 25%, var(--bg-3) 50%, var(--bg-2) 75%);background-size:200% 100%;height:88px;animation:1.5s ease-in-out infinite shimmer}.skeleton-stat{border-radius:var(--radius-sm);height:48px}.skeleton-row{align-items:center;gap:12px;padding:10px 0;display:flex}.skeleton-circle{border-radius:50%;flex-shrink:0;width:36px;height:36px}.skeleton-lines{flex:1}.btn-loading{pointer-events:none;position:relative;color:#0000!important}.btn-loading:after{content:"";border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;margin:-9px 0 0 -9px;animation:.6s linear infinite btn-spin;position:absolute;top:50%;left:50%}.btn-loading.btn-outline:after,.btn-loading.btn-ghost:after{border-color:#ffffff26;border-top-color:var(--text-1)}@keyframes btn-spin{to{transform:rotate(360deg)}}.toast.warning{border-left:3px solid var(--yellow)}@keyframes toast-shrink{0%{width:100%}to{width:0%}}.confirm-overlay{z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;justify-content:center;align-items:center;padding:20px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.confirm-card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:360px;box-shadow:var(--shadow-lg);padding:24px}.confirm-card h3{margin-bottom:8px;font-size:16px}.confirm-card p{color:var(--text-2);margin-bottom:20px;font-size:13px;line-height:1.5}.confirm-actions{justify-content:flex-end;gap:8px;display:flex}.confirm-actions .btn{min-width:80px}body{background:var(--bg-0);color:var(--text-0);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;min-height:100dvh;padding-bottom:calc(64px + var(--sab));font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;overflow-x:hidden}#navbar{height:calc(48px + var(--sat));border-bottom:1px solid var(--border);z-index:100;-webkit-backdrop-filter:blur(12px);padding:0 12px;padding-top:var(--sat);background:#0f0f12eb;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.nav-left{align-items:center;gap:12px;display:flex}.logo{cursor:pointer;align-items:center;gap:2px;display:flex}.logo-mark-img{width:22px;height:14px}.logo-text{letter-spacing:2.5px;font-size:16px;font-weight:300}.nav-links{display:none}.nav-right{align-items:center;gap:6px;display:flex}.nav-user-btn{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-full);cursor:pointer;transition:var(--transition);align-items:center;gap:6px;padding:3px 10px 3px 3px;display:flex}.nav-user-btn:hover{border-color:var(--border-light)}.nav-avatar{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:10px;font-weight:700;display:flex}.nav-name{font-size:12px;font-weight:600;display:none}.nav-rating{color:var(--text-2);font-family:JetBrains Mono,monospace;font-size:10px;display:none}.nav-icon-btn{background:var(--bg-2);border:1px solid var(--border);cursor:pointer;width:36px;height:36px;transition:var(--transition);color:var(--text-2);border-radius:50%;justify-content:center;align-items:center;min-width:36px;min-height:36px;font-size:14px;display:flex;position:relative}.nav-icon-btn:hover{background:var(--bg-3);color:var(--text-0)}.notif-badge{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:9px;font-weight:700;display:flex;position:absolute;top:-2px;right:-2px}.bottom-tabs{z-index:120;border-top:1px solid var(--border);-webkit-backdrop-filter:blur(16px);padding-bottom:var(--sab);height:calc(60px + var(--sab));background:#0f0f12f2;align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-tab{color:var(--text-3);cursor:pointer;transition:var(--transition);-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;min-height:44px;padding:6px 0;font-family:inherit;font-size:10px;font-weight:600;display:flex}.bottom-tab svg{opacity:.6;width:20px;height:20px;transition:var(--transition)}.bottom-tab.active{color:var(--accent);position:relative}.bottom-tab.active svg{opacity:1;stroke:var(--accent)}.bottom-tab.active:after{content:"";background:var(--accent);border-radius:2px;width:20px;height:3px;position:absolute;top:2px;left:50%;transform:translate(-50%)}.bottom-tab:active{transform:scale(.92)}.bottom-tab-fab{padding:0;position:relative}.bottom-tab-fab .fab-circle{background:var(--accent);border:3px solid var(--bg-1);border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;transition:transform .15s,box-shadow .15s;display:flex;transform:translateY(-12px);box-shadow:0 4px 20px #ef444466}.bottom-tab-fab:active .fab-circle{transform:translateY(-12px)scale(.93)}.bottom-tab-fab.active .fab-circle{box-shadow:0 4px 24px #ef44448c}.bottom-tab-fab .fab-circle svg{fill:#fff}.bottom-tab-fab.active:after{display:none}.bottom-tab-fab.active svg{stroke:none}.bottom-tab-fab.active{color:var(--text-3)}.create-race-fab{bottom:calc(72px + var(--sab));z-index:121;background:var(--accent);color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;transition:transform .15s,box-shadow .15s;display:flex;position:fixed;right:16px;box-shadow:0 4px 20px #ef444466}.create-race-fab:hover{transform:scale(1.05);box-shadow:0 6px 28px #ef444480}.create-race-fab:active{transform:scale(.93)}.create-race-fab.hidden,body.in-race .create-race-fab{display:none}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);white-space:nowrap;-webkit-tap-highlight-color:transparent;border:none;justify-content:center;align-items:center;gap:6px;min-height:44px;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:600;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:active:not(:disabled){transform:scale(.97)}.btn-secondary{background:var(--bg-3);color:var(--text-0)}.btn-secondary:hover{background:var(--bg-4)}.btn-outline{color:var(--text-1);border:1px solid var(--border);background:0 0}.btn-outline:hover{background:var(--bg-3);border-color:var(--border-light)}.btn-ghost{color:var(--text-2);background:0 0;padding:8px}.btn-ghost:hover{color:var(--text-0)}.btn-sm{min-height:36px;padding:6px 12px;font-size:12px}.btn-lg{width:100%;padding:14px 24px;font-size:15px}.btn-close{color:var(--text-3);cursor:pointer;background:0 0;border:none;min-width:44px;min-height:44px;padding:8px;font-size:22px;line-height:1}.btn-close:hover{color:var(--text-0)}.social-login-buttons{flex-direction:column;gap:10px;margin-bottom:16px;display:flex}.btn-social{border-radius:var(--radius-sm);cursor:pointer;border:1px solid var(--border);width:100%;transition:var(--transition);justify-content:center;align-items:center;gap:10px;min-height:44px;padding:12px 16px;font-size:15px;font-weight:500;text-decoration:none;display:flex}.btn-apple{color:#000;background:#fff}.btn-apple:hover{background:#f0f0f0}.btn-facebook{color:#fff;background:#1877f2;border-color:#1877f2}.btn-facebook:hover{background:#166fe5}.btn-strava{background:#fc5200;border-color:#fc5200;padding:0;overflow:hidden}.btn-strava:hover{background:#e04a00;border-color:#e04a00}.btn-strava img{width:auto;height:40px;display:block}.strava-attribution{text-align:center;margin-top:12px}.onboarding-overlay{z-index:9999;background:#000000d9;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0;overflow-y:auto}.onboarding-card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:400px;padding:24px 20px}.onboarding-header{text-align:center;margin-bottom:24px}.onboarding-header h2{color:var(--text-0);margin:0 0 6px}.onboarding-header p{color:var(--text-2);margin:0;font-size:14px}.form-group .onboarding-toggle-label{cursor:pointer;justify-content:space-between;align-items:center;margin-bottom:0;display:flex}.toggle-switch{flex-shrink:0;width:44px;height:24px;position:relative}.form-feedback{min-height:16px;margin-top:4px;font-size:12px;display:block}.form-hint{color:var(--text-3);margin-top:4px;font-size:12px;display:block}.btn-back{min-width:44px;min-height:44px;font-size:18px}.form-group{margin-bottom:12px}.form-group label{color:var(--text-2);margin-bottom:5px;font-size:12px;font-weight:500;display:block}.form-group input,.form-group select,.form-group textarea{background:var(--bg-0);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-0);transition:var(--transition);min-height:44px;padding:12px 14px;font-family:inherit;font-size:16px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}.form-group input::placeholder{color:var(--text-3)}.form-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.checkbox-label{cursor:pointer;align-items:center;gap:8px;min-height:44px;color:var(--text-1)!important;font-size:14px!important;display:flex!important}.checkbox-label input{accent-color:var(--accent);width:20px!important;height:20px!important}.error-text{color:var(--accent);text-align:center;margin-top:10px;font-size:13px}.badge{border-radius:var(--radius-full);background:var(--bg-3);color:var(--text-2);align-items:center;gap:4px;padding:3px 9px;font-size:11px;font-weight:600;display:inline-flex}.badge-live{background:var(--green-soft);color:var(--green)}.badge-live:before{content:"";background:var(--green);border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite pulse}.badge-accent{background:var(--accent-soft);color:var(--accent)}.badge-outline{border:1px solid var(--border);background:0 0}.badge-blue{background:var(--blue-soft);color:var(--blue)}.badge-sm{padding:1px 6px;font-size:9px}.badge-dnf{background:var(--text-3);color:var(--bg-0);font-size:9px}.count-badge{background:var(--bg-4);border-radius:var(--radius-full);color:var(--text-2);padding:2px 8px;font-size:12px}.tier-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:700}.tier-jogger{color:var(--tier-jogger);background:#cd7f3226}.tier-pacer{color:var(--tier-pacer);background:#c0c0c026}.tier-racer{color:var(--tier-racer);background:#ffd70026}.tier-sprinter{color:var(--tier-sprinter);background:#00ced126}.tier-champion{color:var(--tier-champion);background:#b9f2ff26}.tab-bar-wrap,.profile-tabs-wrap{position:relative}.tab-bar-wrap:after,.profile-tabs-wrap:after{content:"";background:linear-gradient(90deg, transparent, var(--bg-0));pointer-events:none;border-radius:0 var(--radius) var(--radius) 0;opacity:0;width:32px;transition:opacity .15s;position:absolute;top:0;bottom:0;right:0}.tab-bar-wrap.scrollable:after,.profile-tabs-wrap.scrollable:after{opacity:1}.tab-bar,.profile-tabs{background:var(--bg-2);border-radius:var(--radius);border:1px solid var(--border);-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:2px;margin-bottom:16px;padding:3px;display:flex;overflow-x:auto}.tab-bar::-webkit-scrollbar{display:none}.profile-tabs::-webkit-scrollbar{display:none}.tab-btn{color:var(--text-2);cursor:pointer;transition:var(--transition);white-space:nowrap;background:0 0;border:none;border-radius:7px;flex:1;min-height:36px;padding:8px 10px;font-family:inherit;font-size:12px;font-weight:600}.tab-btn.active{background:var(--bg-4);color:var(--text-0)}.tab-btn:hover:not(.active){color:var(--text-1)}.page{padding:12px;padding-bottom:calc(80px + var(--sab,0px));max-width:1100px;margin:0 auto;display:none;overflow-x:hidden}.page.active{animation:.2s pageIn;display:block}@keyframes pageIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.hidden{display:none!important}.subtitle{color:var(--text-2);margin-top:3px;font-size:13px}.section-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.section-header h2{font-size:18px}.section-header .subtitle{margin-top:2px;font-size:12px}.section-header .page-header-actions{flex:100%}.section-header .page-header-actions .btn{flex:1}.mono-sm{color:var(--text-2);font-family:JetBrains Mono,monospace;font-size:12px}.empty-state{text-align:center;color:var(--text-2);padding:32px 16px;font-size:14px}.empty-state-sm{text-align:center;color:var(--text-3);padding:12px;font-size:13px}.flex-row-sm{align-items:center;gap:6px;display:flex}.empty-state .empty-icon{opacity:.7;margin-bottom:10px;font-size:36px;display:block}.empty-state .empty-title{color:var(--text-1);margin-bottom:4px;font-size:15px;font-weight:600}.empty-state .empty-subtitle{color:var(--text-3);margin-bottom:14px;font-size:13px}.empty-state .btn{margin-top:8px}.login-page{min-height:100dvh;padding-top:max(env(safe-area-inset-top,20px), 40px);justify-content:center;align-items:flex-start;display:flex;position:relative;overflow:hidden}.login-hero-glow{pointer-events:none;background:radial-gradient(circle,#ef444414 0%,#0000 70%);border-radius:50%;width:600px;height:600px;position:absolute;top:-40%;left:50%;transform:translate(-50%)}.login-container{z-index:1;width:100%;max-width:420px;padding:20px 16px;position:relative}.login-brand{text-align:center;margin-bottom:32px}.login-logo-img{border-radius:14px;width:56px;height:56px;margin-bottom:16px}.login-brand h1{letter-spacing:-1.5px;font-size:32px;font-weight:900}.login-logo-wordmark{justify-content:center;align-items:center;gap:2px;margin-bottom:12px;display:flex}.login-logo-mark{width:46px;height:29px}.login-logo-text{letter-spacing:5px;font-size:28px;font-weight:300}.tagline{color:var(--text-1);margin-top:6px;font-size:15px;font-weight:400}.login-features{flex-direction:column;gap:12px;margin-bottom:28px;display:flex}.feature-highlight{background:var(--bg-1);border:1px solid var(--bg-4);border-radius:var(--radius);transition:var(--transition);align-items:center;gap:12px;padding:12px 14px;display:flex}.feature-highlight-icon{background:var(--bg-2);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.feature-highlight-title{color:var(--text-0);font-size:13px;font-weight:600}.feature-highlight-desc{color:var(--text-3);margin-top:1px;font-size:12px}.login-card{background:var(--bg-1);border-radius:var(--radius-lg);border:none;padding:20px}#google-signin-button:empty{display:none}.login-divider{color:var(--text-3);align-items:center;gap:12px;margin:16px 0;font-size:13px;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-tabs{background:var(--bg-0);border-radius:var(--radius-sm);gap:4px;margin-bottom:16px;padding:3px;display:flex}.auth-tab{color:var(--text-3);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);background:0 0;border:none;flex:1;min-height:44px;padding:10px 12px;font-family:inherit;font-size:14px;font-weight:600}.auth-tab.active{background:var(--bg-2);color:var(--text-0)}.auth-form{flex-direction:column;gap:0;display:flex}.auth-form .form-group{margin-bottom:10px}.auth-form .btn-lg{margin-top:6px}.auth-form-error{color:#ef4444;text-align:center;margin:4px 0 0;font-size:13px}.auth-form-success{color:#22c55e;text-align:center;margin:4px 0 0;font-size:13px}.auth-form-hint{color:var(--text-2);text-align:center;margin:0 0 12px;font-size:13px}.auth-form-title{color:var(--text-0);text-align:center;margin:0 0 16px;font-size:16px;font-weight:700}.auth-link-btn{color:var(--text-2);cursor:pointer;text-align:center;min-height:44px;transition:var(--transition);background:0 0;border:none;margin-top:4px;padding:10px;font-family:inherit;font-size:13px}.auth-link-btn:hover{color:var(--text-0)}.auth-verification-box{text-align:center;padding:16px 0 12px}.auth-verification-box svg{margin-bottom:8px}.auth-verification-box h3{color:var(--text-0);margin:0 0 8px;font-size:16px}.auth-verification-box p{color:var(--text-2);margin:0;font-size:13px;line-height:1.5}.login-footer{flex-direction:column;align-items:center;gap:12px;margin-top:20px;display:flex}.login-pricing-link{color:var(--text-1);cursor:pointer;transition:var(--transition);align-items:center;min-height:44px;padding:10px 20px;font-size:14px;font-weight:600;text-decoration:none;display:inline-flex}.login-pricing-link:hover{color:var(--text-0)}.login-legal{gap:4px;font-size:12px;display:flex}.login-legal a{color:var(--text-3);align-items:center;min-height:44px;padding:12px 10px;text-decoration:none;display:inline-flex}.login-legal a:hover{color:var(--text-1)}.divider{color:var(--text-3);align-items:center;gap:12px;margin:12px 0;font-size:12px;display:flex}.divider:before,.divider:after{content:"";background:var(--border);flex:1;height:1px}.race-grid{flex-direction:column;gap:10px;display:flex}.race-card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;flex-direction:column;padding:14px;transition:transform .15s,box-shadow .15s,background .15s;display:flex;position:relative}.race-card:hover{border-color:var(--bg-4);box-shadow:0 2px 8px #00000026}.race-card:active{background:var(--bg-2);transform:scale(.98)}.race-card-header{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px;display:flex}.race-card-title{font-size:15px;font-weight:700}.race-card-meta{flex-wrap:wrap;gap:5px;margin-bottom:10px;display:flex}.race-card-footer{border-top:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding-top:10px;display:flex}.race-card-participants{color:var(--text-2);font-size:12px}.race-card-time{color:var(--text-3);font-family:JetBrains Mono,monospace;font-size:12px}.race-card.active-race{border-color:#22c55e59}#page-feed{padding:0;overflow:visible}#page-feed .feed-container{padding-bottom:calc(80px + var(--sab,0px))}.feed-container{max-width:480px;margin:0 auto}.feed-list{flex-direction:column;gap:0;display:flex}.feed-tabs{border-bottom:1px solid var(--border);top:calc(48px + var(--sat));z-index:20;background:var(--bg-0);gap:0;display:flex;position:sticky}.feed-tab{text-align:center;color:var(--text-3);cursor:pointer;background:0 0;border:none;flex:1;min-height:44px;padding:11px 0;font-family:inherit;font-size:13px;font-weight:600;transition:color .15s;position:relative}.feed-tab:active{color:var(--text-1)}.feed-tab.active{color:var(--text-0)}.feed-tab.active:after{content:"";background:var(--accent);border-radius:1px;height:2px;position:absolute;bottom:0;left:20%;right:20%}.feed-card{border-bottom:8px solid var(--bg-2);cursor:pointer;position:relative}.feed-card:active{background:#ffffff05}.feed-list .feed-card{opacity:0;transform:translateY(16px)}.feed-list .feed-card.rc-visible{opacity:1;transition:opacity .4s,transform .4s;transform:translateY(0)}.fc-header{align-items:flex-start;gap:10px;padding:14px 16px 10px;display:flex}.fc-avatar{width:36px;height:36px;color:var(--text-2);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.fc-user{flex:1;min-width:0}.fc-name{align-items:center;gap:6px;font-size:14px;font-weight:600;display:flex}.fc-name-time{color:var(--text-3);margin-left:auto;font-size:11px;font-weight:400}.fc-title{margin-top:3px;font-size:16px;font-weight:700}.fc-desc{color:var(--text-2);margin-top:2px;font-size:13px;line-height:1.4}.fc-stats{border-top:1px solid var(--border);border-bottom:1px solid var(--border);grid-template-columns:repeat(4,1fr);margin:0 16px;display:grid}.fc-stat{text-align:center;padding:10px 4px}.fc-stat+.fc-stat{border-left:1px solid var(--border)}.fc-stat-value{font-family:JetBrains Mono,monospace;font-size:15px;font-weight:700}.fc-stat-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;margin-top:2px;font-size:9px}.fc-stat-up{color:var(--green)}.fc-stat-down{color:var(--accent)}.fc-stat-gold{color:var(--yellow)}.fc-stat-silver{color:#a8a29e}.fc-stat-bronze{color:#cd7f32}.fc-route{border-radius:var(--radius);border:1px solid var(--border);background:#1c1c24;height:160px;margin:10px 16px 0;position:relative;overflow:hidden}.fc-route canvas,.fc-route .maplibregl-canvas-container{border-radius:var(--radius)}.fc-route-badge{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text-1);letter-spacing:.2px;z-index:2;background:#000000a6;border-radius:5px;padding:3px 9px;font-size:11px;font-weight:600;position:absolute;top:8px;left:10px}.fc-segments{gap:8px;margin:10px 16px 0;display:flex}.fc-seg{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-sm);flex:1;padding:10px;position:relative;overflow:hidden}.fc-seg:before{content:"";height:2px;position:absolute;top:0;left:0;right:0}.fc-seg-warmup:before{background:var(--orange)}.fc-seg-race:before{background:var(--accent)}.fc-seg-cooldown:before{background:var(--blue)}.fc-seg-top{align-items:center;gap:5px;margin-bottom:4px;display:flex}.fc-seg-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.fc-seg-warmup .fc-seg-dot{background:var(--orange)}.fc-seg-race .fc-seg-dot{background:var(--accent)}.fc-seg-cooldown .fc-seg-dot{background:var(--blue)}.fc-seg-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.3px;font-size:9px}.fc-seg-value{font-family:JetBrains Mono,monospace;font-size:13px;font-weight:700}.fc-seg-sub{color:var(--text-3);margin-top:1px;font-size:11px}.fc-social{align-items:center;gap:6px;padding:8px 16px;display:flex}.fc-react-btn{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-full);cursor:pointer;color:var(--text-2);align-items:center;gap:4px;padding:5px 10px;font-family:inherit;font-size:13px;transition:all .12s;display:flex}.fc-react-btn:active{transform:scale(.95)}.fc-react-btn.active{border-color:var(--border-light);background:var(--bg-3)}.fc-react-emoji{font-size:15px;line-height:1}.fc-react-count{font-size:12px;font-weight:600}.fc-react-add{background:var(--bg-2);border:1px dashed var(--border);cursor:pointer;width:30px;height:30px;color:var(--text-3);border-radius:50%;justify-content:center;align-items:center;font-size:14px;transition:all .12s;display:flex}.fc-react-add:active{background:var(--bg-3);transform:scale(.95)}.fc-comment-btn{color:var(--text-3);cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;margin-left:2px;padding:4px 0;font-family:inherit;font-size:12px;display:flex}.fc-comment-btn svg{width:16px;height:16px}.fc-react-btn.bump-anim{animation:.3s bumpPop}@keyframes bumpPop{0%{transform:scale(1)}40%{transform:scale(1.25)}to{transform:scale(1)}}.fc-bump-overlay{pointer-events:none;z-index:10;opacity:0;font-size:64px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(0)}.fc-bump-overlay.bump-overlay-anim{animation:.8s forwards bumpOverlay}@keyframes bumpOverlay{0%{opacity:0;transform:translate(-50%,-50%)scale(0)}15%{opacity:1;transform:translate(-50%,-50%)scale(1.2)}30%{opacity:1;transform:translate(-50%,-50%)scale(1)}70%{opacity:1;transform:translate(-50%,-50%)scale(1)}to{opacity:0;transform:translate(-50%,-50%)scale(1.5)}}.fc-comments{padding:0 16px 6px}.fc-comment{margin-bottom:3px;font-size:13px;line-height:1.4}.fc-comment strong{font-weight:600}.fc-comment-more{color:var(--text-3);cursor:pointer;margin-top:2px;font-size:12px}.fc-comment-input{align-items:center;gap:8px;padding:6px 16px 12px;display:flex}.fc-comment-avatar{background:var(--bg-3);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:9px;font-weight:700;display:flex}.fc-comment-field{color:var(--text-3);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:13px}.fc-comment-field::placeholder{color:var(--text-3)}.fc-comment-field:focus{color:var(--text-0)}.fc-emoji-picker{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);z-index:30;gap:4px;padding:8px;display:flex;position:absolute;bottom:100%;left:0;box-shadow:0 -4px 16px #0006}.fc-emoji-picker button{cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;min-width:40px;min-height:40px;padding:6px;font-size:22px}.fc-emoji-picker button:active{background:var(--bg-3)}.feed-list .race-card,#profile-races .race-card{opacity:0;transform:translateY(16px)}.feed-list .race-card.rc-visible,#profile-races .race-card.rc-visible{opacity:1;transition:opacity .4s,transform .4s;transform:translateY(0)}.race-card.gold{border-left:3px solid gold}.race-card.silver{border-left:3px solid silver}.race-card.bronze{border-left:3px solid #cd7f32}.feed-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:700;display:flex}.feed-content{flex:1;min-width:0}.feed-user-name{color:var(--text-0);font-size:14px;font-weight:700}.feed-user-action{color:var(--text-2);margin-top:1px;font-size:13px}.feed-user-action strong{color:var(--text-1);font-weight:600}.feed-distance-badge{background:var(--bg-2);color:var(--text-2);border-radius:4px;margin-left:2px;padding:1px 6px;font-size:11px;font-weight:600}.feed-time{color:var(--text-3);margin-top:2px;font-size:11px}.rc-badges{flex-wrap:wrap;gap:6px;padding:8px 0 4px;display:flex}.rc-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:700}.rc-badge-gold{color:gold;background:#ffd70026}.rc-badge-podium{color:silver;background:#c0c0c01f}.rc-stats-grid{background:var(--bg-2);border-radius:8px;gap:2px;margin-top:8px;padding:10px 0 6px;display:flex}.rc-stat{text-align:center;flex:1;padding:6px 4px;position:relative}.rc-stat:not(:last-child):after{content:"";background:var(--border);width:1px;height:50%;position:absolute;top:25%;right:0}.rc-stat-value{color:var(--text-0);font-variant-numeric:tabular-nums;font-size:16px;font-weight:700}.rc-stat-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;margin-top:2px;font-size:10px}.rc-rating-up{color:var(--green)}.rc-rating-down{color:var(--accent)}.rc-route-preview{min-height:0;margin-top:8px}.rc-route-preview svg{background:var(--bg-2);border-radius:8px;width:100%;height:110px}.rc-social-bar{justify-content:space-between;align-items:center;padding:8px 0 4px;display:flex}.rc-social-left{gap:6px;display:flex}.feed-bump-btn,.feed-comment-btn{border:1px solid var(--border);color:var(--text-3);cursor:pointer;background:0 0;border-radius:20px;align-items:center;gap:5px;padding:5px 14px;font-size:14px;transition:all .15s;display:flex}.feed-bump-btn:hover,.feed-comment-btn:hover{background:var(--bg-2);color:var(--text-1)}.feed-bump-btn.bumped{color:var(--orange);border-color:var(--orange);background:#ff6b001a}.feed-bump-btn .bump-count,.feed-comment-btn .comment-count{min-width:8px;font-size:13px;font-weight:600}.rc-bump-overlay{pointer-events:none;z-index:10;opacity:0;font-size:64px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(0)}.rc-bump-overlay.bump-overlay-anim{animation:.8s forwards bumpOverlay}.rc-preview-comment{color:var(--text-1);padding:2px 0;font-size:13px;line-height:1.4}.rc-preview-comment strong{color:var(--text-0);margin-right:4px;font-weight:600}.rc-view-all{color:var(--text-3);cursor:pointer;padding:2px 0;font-size:12px}.rc-view-all:hover{color:var(--text-2)}.rc-comment-quick{padding:6px 0 0}.rc-comment-quick input{border:none;border-top:1px solid var(--border);width:100%;color:var(--text-2);background:0 0;outline:none;padding:8px 0 2px;font-size:13px}.rc-comment-quick input::placeholder{color:var(--text-3)}.rc-comment-quick input:focus{color:var(--text-0);border-top-color:var(--orange)}.feed-segments{flex-wrap:wrap;gap:6px;padding:8px 0;display:flex}.feed-segment{background:var(--bg-2);color:var(--text-2);border-radius:6px;padding:6px 10px;font-size:11px;line-height:1.5}.feed-segment .seg-label{color:var(--text-1);margin-bottom:2px;font-weight:600;display:block}.feed-comments{padding:4px 0 0}.feed-comments-list{flex-direction:column;gap:6px;max-height:200px;margin-bottom:8px;display:flex;overflow-y:auto}.feed-comment{align-items:flex-start;gap:8px;display:flex}.feed-comment-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:9px;font-weight:700;display:flex}.feed-comment-body{flex:1;min-width:0}.feed-comment-body strong{color:var(--text-0);font-size:12px;font-weight:600}.feed-comment-body span{color:var(--text-1);margin-left:4px;font-size:12px}.feed-comment-time{color:var(--text-3);margin-top:1px;font-size:10px}.feed-detail{overflow:hidden}.feed-detail.hidden{display:none}.modal{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:480px;max-height:90vh;margin:16px;padding:20px;animation:.2s modalIn;overflow-y:auto}.modal-sm{max-width:400px}.modal-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.modal-header h3{font-size:16px}@keyframes modalIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.slide-panel{background:var(--bg-1);border-left:1px solid var(--border);z-index:200;width:100%;max-width:100%;box-shadow:var(--shadow-lg);animation:.2s slideIn;position:fixed;top:0;bottom:0;right:0;overflow-y:auto}.panel-header{border-bottom:1px solid var(--border);padding:14px 16px;padding-top:calc(14px + var(--sat));justify-content:space-between;align-items:center;display:flex}.panel-header h3{font-size:15px}.notifications-list{padding:8px}.notif-item{border-radius:var(--radius-sm);transition:var(--transition);cursor:pointer;gap:10px;padding:12px;display:flex}.notif-item:hover{background:var(--bg-2)}.notif-item:active{background:var(--bg-3)}.notif-item.unread{background:var(--accent-soft)}.notif-icon{background:var(--bg-3);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;display:flex}.notif-content{flex:1}.notif-title{font-size:13px;font-weight:600}.notif-body{color:var(--text-2);margin-top:2px;font-size:12px}.notif-time{color:var(--text-3);margin-top:3px;font-size:11px}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.search-results{max-height:300px;overflow-y:auto}.search-result-item{border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);align-items:center;gap:10px;min-height:44px;padding:10px;display:flex}.search-result-item:active{background:var(--bg-3)}.page-lobby.active{height:calc(100vh - var(--sat,0px));height:calc(100dvh - var(--sat,0px));flex-direction:column;padding-bottom:0;display:flex}.lobby-container{flex-direction:column;flex:1;width:100%;max-width:800px;min-height:0;margin:0 auto;display:flex}.lobby-header{flex-shrink:0;align-items:center;gap:10px;margin-bottom:12px;display:flex}.lobby-info{flex:1}.lobby-info h2{font-size:17px}.lobby-meta{flex-wrap:wrap;gap:5px;margin-top:4px;display:flex}.lobby-tabs{flex-shrink:0;gap:0;padding:0 0 8px;display:flex}.lobby-tab{text-align:center;color:var(--text-3);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:8px 0;font-size:13px;font-weight:600;transition:color .2s,border-color .2s}.lobby-tab.active{color:var(--text-0);border-bottom-color:var(--green)}.lobby-tab .count-badge{font-size:11px}.lobby-content{flex:1;min-height:0;overflow-y:auto}.lobby-participants{background:0 0;border:none;padding:0}.runner-list{flex-direction:column;gap:2px;display:flex}.runner-list:empty:after{content:"No runners yet — be the first to sign up!";text-align:center;color:var(--text-3);padding:16px 0;font-size:13px;display:block}.runner-item{border-bottom:1px solid #ffffff08;border-radius:0;align-items:center;gap:10px;padding:8px 10px;display:flex}.runner-item.runner-item-me{border-radius:var(--radius-sm);background:#22c55e0a}.runner-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:12px;font-weight:700;display:flex}.runner-info{flex:1;min-width:0}.runner-name{flex-wrap:wrap;align-items:center;gap:4px;font-size:13px;font-weight:600;display:flex}.runner-sub{color:var(--text-3);margin-top:1px;font-size:11px}.runner-rating-val{color:var(--text-2);text-align:right;font-variant-numeric:tabular-nums;flex-shrink:0;font-family:JetBrains Mono,monospace;font-size:12px;font-weight:600}.runner-rating{color:var(--text-3);font-family:JetBrains Mono,monospace;font-size:11px}.bot-badge{background:var(--bg-3);color:var(--text-3);border:1px solid var(--border);vertical-align:middle;letter-spacing:.5px;border-radius:3px;margin-left:4px;padding:1px 4px;font-size:9px;font-weight:700;display:inline-block}.league-divider{align-items:center;gap:8px;padding:12px 10px 6px;display:flex}.league-divider-line{flex:1;height:1px}.league-divider-label{text-transform:uppercase;letter-spacing:.8px;white-space:nowrap;font-size:11px;font-weight:700}.league-divider-you{color:var(--green);text-transform:none;letter-spacing:0;margin-left:4px;font-size:9px;font-weight:600}.warmup-sub{color:#eab308}.you-marker{color:var(--green);font-size:10px;font-weight:700}.lobby-bottom-bar{padding:8px 20px;padding-bottom:calc(8px + var(--sab,0px));-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0a0a0ce6;border-top:1px solid #ffffff0f;flex-shrink:0;justify-content:center;align-items:center;gap:10px;display:flex}.lobby-chat-panel{z-index:50;background:var(--bg-1);border-top:1px solid var(--border);flex-direction:column;max-height:50vh;transition:transform .3s;display:flex;position:fixed;bottom:0;left:0;right:0;transform:translateY(100%)}.lobby-chat-panel.expanded{transform:translateY(0)}.lobby-chat-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 14px;font-size:14px;font-weight:600;display:flex}.lobby-chat-panel .chat-messages{flex-direction:column;flex:1;gap:3px;min-height:120px;max-height:35vh;padding:8px 14px;display:flex;overflow-y:auto}.lobby-chat-panel .chat-input{padding:8px 14px;padding-bottom:calc(8px + var(--sab,0px))}.lobby-chat{flex-direction:column;display:flex}.chat-messages{background:var(--bg-0);border-radius:var(--radius-sm);flex-direction:column;flex:1;gap:3px;min-height:140px;max-height:250px;margin-bottom:8px;padding:8px;display:flex;overflow-y:auto}.chat-msg{padding:3px 0;font-size:13px}.chat-msg .chat-user{color:var(--blue);font-weight:600}.chat-msg .chat-text{color:var(--text-2)}.chat-input{gap:6px;display:flex}.chat-input input{background:var(--bg-0);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-0);flex:1;min-height:44px;padding:10px 12px;font-family:inherit;font-size:16px}.chat-input input:focus{border-color:var(--accent);outline:none}.lobby-action-area{flex-direction:column;flex-shrink:0;align-items:center;gap:8px;margin-bottom:12px;display:flex}.lobby-action-area .btn{width:100%}.leave-warmup-link{color:var(--danger,#e74c3c);cursor:pointer;background:0 0;border:none;padding:4px 0;font-size:13px;width:auto!important}.chat-filter-bar{align-items:center;gap:6px;margin-bottom:4px;padding:6px 0;font-size:12px;display:flex}.chat-filter-btn{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-2);cursor:pointer;min-height:44px;padding:10px 16px;font-size:11px;font-weight:600;transition:all .15s}.chat-filter-btn.active{background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}.chat-mute-toggle{color:var(--text-3);cursor:pointer;align-items:center;gap:6px;min-height:36px;margin-left:auto;padding:8px 0;font-size:11px;display:flex}.chat-mute-toggle input{width:18px;height:18px;accent-color:var(--accent)}.chat-msg-bot{opacity:.5;border-left:2px solid var(--border);padding-left:8px}.chat-msg-bot.hidden-bot{display:none}.chat-msg-user{border-left:2px solid var(--blue);padding-left:8px}.chat-msg.league-hidden{display:none}.lobby-league-group{margin-bottom:12px}.lobby-league-header{color:var(--text-2);background:var(--bg-2);border-radius:var(--radius-sm);align-items:center;gap:8px;margin-bottom:4px;padding:6px 10px;font-size:12px;font-weight:600;display:flex}.lobby-league-header.my-league{color:var(--accent);background:var(--accent-soft)}.lobby-league-toggle{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-2);cursor:pointer;background:0 0;width:100%;min-height:44px;margin-top:4px;padding:8px 12px;font-size:12px}.lobby-league-toggle:hover{background:var(--bg-2)}.lobby-other-leagues{margin-top:8px}.lobby-other-leagues.collapsed{display:none}.countdown-overlay{z-index:300;background:#000000eb;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;inset:0}.countdown-number{color:var(--accent);text-shadow:0 0 80px var(--accent-glow);font-variant-numeric:tabular-nums;font-size:100px;font-weight:900;animation:1s ease-in-out infinite pulse}.countdown-text{color:var(--text-2);margin-top:10px;font-size:16px;font-weight:500}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.page-race{padding:0!important}.race-view{height:100dvh;position:relative;overflow:hidden}.race-map-fullscreen{z-index:0;background:var(--bg-1);position:absolute;inset:0}.maplibregl-canvas{outline:none}.race-hud-top{z-index:10;padding:10px 14px;padding-top:calc(10px + var(--sat));pointer-events:none;background:linear-gradient(#000000d9 0%,#00000080 70%,#0000 100%);justify-content:space-between;align-items:flex-start;display:flex;position:absolute;top:0;left:0;right:0}.race-hud-top>*{pointer-events:auto}.hud-left{align-items:center;gap:8px;display:flex}.hud-icon-btn{color:var(--text-1);cursor:pointer;background:#ffffff1a;border:1px solid #ffffff26;border-radius:10px;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:8px;display:flex}.hud-timer-group{flex-direction:column;align-items:flex-start;display:flex}.hud-phase-row{align-items:center;gap:5px;margin-bottom:3px;display:flex}.hud-timer-value{color:var(--green);letter-spacing:-1px;text-shadow:0 0 24px #22c55e40;font-family:JetBrains Mono,monospace;font-size:36px;font-weight:700;line-height:1}.hud-timer-value.warmup-timer{color:var(--yellow);text-shadow:0 0 24px #eab30833}.hud-countdown-sub{color:#eab30899;margin-top:2px;font-family:JetBrains Mono,monospace;font-size:11px}.hud-right{cursor:pointer;align-items:center;gap:10px;display:flex}.hud-stat-stack{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.hud-stat-row{align-items:baseline;gap:5px;display:flex}.hud-stat-val{color:var(--text-0);font-family:JetBrains Mono,monospace;font-size:16px;font-weight:700;line-height:1}.hud-stat-dim{color:#fff6}.hud-stat-slash{color:#fff3;font-family:JetBrains Mono,monospace;font-size:12px;font-weight:400}.hud-stat-unit{color:#ffffff59;text-transform:uppercase;letter-spacing:.3px;font-size:9px;font-weight:600}.hud-divider{background:#ffffff1a;width:1px;height:36px}.hud-position{flex-direction:column;align-items:center;display:flex}.hud-position-value{color:var(--yellow);text-shadow:0 0 16px #eab3084d;font-size:30px;font-weight:900;line-height:1}.hud-position-label{text-transform:uppercase;color:#eab30880;letter-spacing:1px;font-size:8px;font-weight:700}.hud-warmup-info{flex-direction:column;align-items:center;display:flex}.hud-warmup-count{color:#ffffffb3;font-size:16px;font-weight:700;line-height:1}.hud-warmup-label{color:#ffffff59;text-transform:uppercase;letter-spacing:.5px;font-size:8px;font-weight:600}.race-phase-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:3px;padding:2px 7px;font-size:8px;font-weight:700;display:inline-block}.race-phase-badge.warmup{color:#eab308;background:#eab30833;animation:2s ease-in-out infinite badge-pulse}.race-phase-badge.racing{color:#22c55e;background:#22c55e33}.race-phase-badge.cooldown{color:#60a5fa;background:#60a5fa33}@keyframes badge-pulse{0%,to{opacity:1}50%{opacity:.6}}.hud-gap-badge{text-transform:uppercase;letter-spacing:.5px;color:#22d3ee;background:#22d3ee26;border-radius:3px;padding:2px 6px;font-size:8px;font-weight:700}.hud-hr-pill.visible{display:block}.hr-zone-badge{vertical-align:middle;border-radius:3px;margin-left:2px;padding:1px 4px;font-size:8px;font-weight:700;display:inline-block}.hr-zone-1{color:#22c55e;background:#22c55e33}.hr-zone-2{color:#3b82f6;background:#3b82f633}.hr-zone-3{color:#eab308;background:#eab30833}.hr-zone-4{color:#f97316;background:#f9731633}.hr-zone-5{color:#ef4444;background:#ef444433}.race-bottom-stack{z-index:10;pointer-events:none;flex-direction:column;display:flex;position:absolute;bottom:0;left:0;right:0}.race-bottom-stack>*{pointer-events:auto}.race-line{pointer-events:none;padding:0 14px 6px}.race-line-track{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0a0a0ccc;border:1px solid #ffffff1a;border-radius:14px;height:28px;position:relative;overflow:visible}.race-line-fill{background:linear-gradient(90deg, var(--accent), var(--orange));opacity:.25;border-radius:14px;height:100%;transition:width .8s;position:absolute;top:0;left:0}.race-line-runners{position:absolute;inset:0;overflow:visible}.race-line-labels{justify-content:space-between;padding:4px 4px 0;display:flex}.race-line-pct{color:#fff9;text-shadow:0 1px 3px #00000080;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600}.race-line-metric{color:#ffffff73;text-transform:uppercase;letter-spacing:.5px;font-size:10px}.progress-runner-dot{color:#fff;text-shadow:0 1px 2px #00000080;border:2px solid #ffffff26;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:9px;font-weight:800;transition:left .8s;display:flex;position:absolute;top:50%;transform:translate(-50%,-50%)}.progress-runner-dot.me{background:var(--accent);box-shadow:0 0 12px var(--accent-glow);z-index:2;border-color:#fff6;width:28px;height:28px;font-size:11px}.progress-runner-dot.other{background:var(--bg-3);font-size:9px}.race-standings-panel,.race-chat-panel{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#0a0a0cf2;border-top:1px solid #0000;max-height:0;transition:max-height .35s,border-color .2s;overflow:hidden}.race-standings-panel.expanded,.race-chat-panel.expanded{border-top-color:#ffffff1a;max-height:45vh}.race-standings-panel.expanded{-webkit-overflow-scrolling:touch;overflow-y:auto}.race-chat-panel{flex-direction:column;display:flex}.standings-panel-handle{cursor:pointer;-webkit-tap-highlight-color:transparent;justify-content:center;min-height:44px;padding:12px 0;display:flex}.handle-bar{background:#fff3;border-radius:2px;width:36px;height:4px}.standings-panel-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:0 16px 10px;display:flex}.standings-panel-header h4{margin:0;font-size:13px;font-weight:700}.standings-count{color:var(--text-3);font-size:11px}.race-standings-panel .standings-list{padding:8px 12px 16px}.race-chat-messages{flex-direction:column;flex:1;gap:3px;min-height:80px;padding:8px 12px;display:flex;overflow-y:auto}.race-chat-input{border-top:1px solid #ffffff0f;gap:6px;padding:8px 12px;display:flex}.race-chat-input input{border-radius:var(--radius-sm);color:var(--text-0);background:#ffffff0f;border:1px solid #ffffff1a;flex:1;min-height:44px;padding:10px 12px;font-family:inherit;font-size:16px}.race-chat-input input:focus{border-color:#ffffff40;outline:none}.race-hud-bottom{padding:6px 20px;padding-bottom:calc(6px + var(--sab,0px));-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0a0a0cd9;border-top:1px solid #ffffff14;justify-content:center;align-items:center;gap:10px;display:flex}.hud-action-btn{color:var(--text-1);cursor:pointer;pointer-events:auto;text-transform:uppercase;letter-spacing:.3px;background:#ffffff14;border:1px solid #ffffff1f;border-radius:14px;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;min-width:64px;min-height:48px;padding:8px 16px;font-size:10px;font-weight:600;transition:background .2s;display:flex}.hud-action-btn:active{background:#ffffff26}.hud-action-btn svg{opacity:.8}.hud-action-btn.muted{opacity:.4}.hud-action-btn.active{color:var(--accent);background:#38bdf81f;border-color:#38bdf840}.hud-action-btn.has-unread{position:relative}.hud-action-btn.has-unread:after{content:"";background:var(--accent);width:8px;height:8px;box-shadow:0 0 6px var(--accent-glow);border-radius:50%;position:absolute;top:6px;right:6px}#btn-dnf{color:#ef444480}#btn-dnf:active{color:var(--red);border-color:var(--red)}.race-stats-sheet{bottom:calc(56px + var(--sab,0px));z-index:14;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#0a0a0cf2;border-top:1px solid #ffffff1a;border-radius:18px 18px 0 0;padding-bottom:8px;animation:.3s ease-out slideUp;position:absolute;left:0;right:0}.stats-sheet-handle{cursor:pointer;justify-content:center;padding:10px 0 6px;display:flex}.stats-sheet-grid{grid-template-columns:repeat(3,1fr);gap:2px;padding:0 12px 8px;display:grid}.stats-sheet-grid .stat{text-align:center;padding:8px 4px}.stats-sheet-grid .stat-value{color:var(--text-0);font-family:JetBrains Mono,monospace;font-size:15px;font-weight:700;line-height:1.2;display:block}.stats-sheet-grid .stat-label{text-transform:uppercase;color:var(--text-3);letter-spacing:.3px;font-size:9px}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.phase-transition-overlay{z-index:50;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000b3;justify-content:center;align-items:center;animation:.3s ease-out fadeIn;display:flex;position:absolute;inset:0}.phase-transition-overlay.hidden{display:none}.phase-transition-content{text-align:center;animation:.4s cubic-bezier(.34,1.56,.64,1) scaleIn}.phase-icon{margin-bottom:8px;font-size:48px}.phase-name{letter-spacing:2px;text-transform:uppercase;color:var(--text-0);text-shadow:0 0 40px #ffffff4d;font-size:42px;font-weight:900}.phase-subtitle{color:var(--text-2);margin-top:8px;font-size:14px}@keyframes scaleIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.standing-item{border-radius:var(--radius-sm);transition:var(--transition);background:#ffffff0a;align-items:center;gap:6px;padding:7px 8px;font-size:13px;display:flex}.standing-hr{color:var(--text-3);margin-left:4px;font-size:11px}.map-marker{pointer-events:none;flex-direction:column;align-items:center;display:flex}.map-marker-dot{border:2px solid #fff6;border-radius:50%;width:14px;height:14px;position:relative}.map-marker-me .map-marker-dot{width:18px;height:18px;box-shadow:0 0 12px #ef444466}.map-marker-dot[data-pos="1"]:after,.map-marker-dot[data-pos="2"]:after,.map-marker-dot[data-pos="3"]:after{content:attr(data-pos);color:#000;background:#eab308;border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;font-size:8px;font-weight:800;display:flex;position:absolute;top:-8px;right:-8px}.map-marker-label{color:#fafafa;text-shadow:0 1px 3px #000c;white-space:nowrap;margin-top:2px;font-size:10px;font-weight:600}.map-marker-me .map-marker-label{font-size:12px}.results-map-container{border-radius:var(--radius);margin:16px 0;overflow:hidden}.results-map-heading{color:var(--text-0);background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius) var(--radius) 0 0;text-align:center;letter-spacing:.5px;border-bottom:none;padding:10px 12px 8px;font-size:14px;font-weight:700}.results-map{border-radius:var(--radius);height:200px}.results-map.results-map-tall{border-radius:0;height:300px}.results-map-stats{background:var(--bg-1);border:1px solid var(--border);border-radius:0 0 var(--radius) var(--radius);border-top:none;grid-template-columns:repeat(2,1fr);gap:4px;padding:8px;display:grid}.map-stat{text-align:center}.map-stat-value{color:var(--text-0);font-family:JetBrains Mono,monospace;font-size:14px;font-weight:700;display:block}.map-stat-label{color:var(--text-3);font-size:10px}.map-overlay{display:none}.race-standings{background:var(--bg-1);border-top:1px solid var(--border);flex-shrink:0;max-height:180px;padding:10px 12px;overflow-y:auto}.race-standings-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.race-standings h4{font-size:12px}.standings-list{flex-direction:column;gap:3px;display:flex}.standing-item{background:var(--bg-0);border-radius:var(--radius-sm);transition:var(--transition);align-items:center;gap:6px;padding:7px 8px;font-size:13px;display:flex}.standing-item.me{background:var(--accent-soft);border:1px solid #ef444466}.standing-pos{text-align:center;min-width:22px;font-size:14px;font-weight:800}.standing-pos.pos-1{color:var(--yellow)}.standing-pos.pos-2{color:var(--tier-pacer)}.standing-pos.pos-3{color:var(--tier-jogger)}.standing-info{flex:1;min-width:0}.standing-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.standing-dist{color:var(--text-2);font-family:JetBrains Mono,monospace;font-size:11px}.standing-pace{color:var(--text-2);text-align:right;white-space:nowrap;font-family:JetBrains Mono,monospace;font-size:12px}.standing-trend{margin-left:3px;font-size:10px;display:inline-block}.standing-trend.up{color:#22c55e}.standing-trend.down{color:#ef4444}.standing-separator{text-align:center;color:var(--text-3);letter-spacing:4px;padding:2px 0;font-size:14px}.standing-total{text-align:center;color:var(--text-3);border-top:1px solid var(--border);margin-top:4px;padding:6px 0 2px;font-size:11px}.audio-controls{border-top:1px solid var(--border);margin-top:10px;padding-top:10px}.results-container{text-align:center;max-width:650px;margin:0 auto}.results-header{margin-bottom:20px}.results-header h2{font-size:24px;font-weight:900}.finish-celebration{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#000000d9;justify-content:center;align-items:center;animation:.3s ease-out fadeIn;display:flex;position:fixed;inset:0}.finish-celebration-content{text-align:center;animation:.6s cubic-bezier(.34,1.56,.64,1) celebrationBounce}.finish-position-reveal{background:linear-gradient(135deg, var(--yellow), var(--orange));-webkit-text-fill-color:transparent;text-shadow:none;filter:drop-shadow(0 0 30px #eab30866);-webkit-background-clip:text;font-size:96px;font-weight:900;line-height:1}.finish-position-label{color:var(--text-2);margin-top:8px;font-size:18px;font-weight:600}.finish-message{color:var(--text-0);margin-top:16px;font-size:24px;font-weight:800}@keyframes celebrationBounce{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.podium{justify-content:center;align-items:flex-end;gap:8px;margin-bottom:20px;display:flex}.podium-place{flex-direction:column;align-items:center;gap:4px;animation:.6s ease-out both podiumRise;display:flex}.podium-1{animation-delay:.6s}.podium-2{animation-delay:.4s}.podium-3{animation-delay:.2s}@keyframes podiumRise{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.podium-avatar{color:#fff;border:2px solid;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:15px;font-weight:800;display:flex}.podium-1 .podium-avatar{border-color:var(--yellow);width:64px;height:64px;font-size:18px;animation:2s ease-in-out infinite winnerGlow}.podium-2 .podium-avatar{border-color:var(--tier-pacer)}.podium-3 .podium-avatar{border-color:var(--tier-jogger)}.podium-avatar-me{box-shadow:0 0 12px #ef44444d;border-color:var(--accent)!important}.podium-name-me{color:var(--accent)}@keyframes winnerGlow{0%,to{box-shadow:0 0 12px #eab3084d}50%{box-shadow:0 0 28px #eab30899}}.podium-stand{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-sm) var(--radius-sm) 0 0;text-align:center;min-width:80px;padding:8px 14px}.podium-1 .podium-stand{background:linear-gradient(180deg, var(--yellow-soft), var(--bg-1));height:100px}.podium-2 .podium-stand{height:75px}.podium-3 .podium-stand{height:55px}.podium-name{white-space:nowrap;text-overflow:ellipsis;max-width:80px;font-size:12px;font-weight:700;overflow:hidden}.podium-time{color:var(--text-2);margin-top:2px;font-family:JetBrains Mono,monospace;font-size:11px}.podium-medal{font-size:18px;font-weight:900}.podium-medal.gold{color:var(--yellow)}.podium-medal.silver{color:var(--tier-pacer)}.podium-medal.bronze{color:var(--tier-jogger)}.percentile-badge{color:#22c55e;background:#22c55e26;border:1px solid #22c55e4d;border-radius:20px;margin-top:8px;padding:4px 12px;font-size:12px;font-weight:700;display:inline-block}.percentile-badge.top10{color:#eab308;background:#eab30826;border-color:#eab3084d}.pb-message{border-radius:var(--radius);color:var(--yellow);background:linear-gradient(135deg,#eab30826,#f9731626);border:1px solid #eab3084d;margin-top:12px;padding:12px 16px;font-weight:700;animation:1.5s ease-in-out pbShine}@keyframes pbShine{0%{box-shadow:0 0 #eab30800}50%{box-shadow:0 0 20px #eab3084d}to{box-shadow:0 0 #eab30800}}.streak-callout{color:var(--orange);background:#f973161a;border:1px solid #f9731640;border-radius:12px;align-items:center;gap:6px;margin-top:6px;padding:4px 10px;font-size:12px;font-weight:700;display:inline-flex}.league-hero{flex-direction:column;align-items:center;margin:20px 0 16px;animation:.8s cubic-bezier(.34,1.56,.64,1) both leagueHeroIn;display:flex}@keyframes leagueHeroIn{0%{opacity:0;transform:scale(.3)}to{opacity:1;transform:scale(1)}}.league-hero .league-badge{text-transform:uppercase;letter-spacing:.8px;border-radius:16px;align-items:center;gap:6px;margin-bottom:14px;padding:4px 12px;font-size:10px;font-weight:700;display:inline-flex}.league-hero .league-badge-dot{border-radius:50%;width:6px;height:6px}.league-hero .hero-circle{border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:120px;height:120px;display:flex}.league-hero .hero-pos-number{font-size:48px;font-weight:900;line-height:1}.league-hero .hero-pos-suffix{margin-top:-4px;font-size:16px;font-weight:700}.league-hero .hero-of{color:var(--text-3);margin-top:10px;font-size:13px}.league-hero .hero-of span{color:var(--text-1);font-weight:600}.league-hero .hero-time{color:var(--text-2);margin-top:6px;font-family:JetBrains Mono,monospace;font-size:18px;font-weight:600}.rating-tier-card{border-top:1px solid var(--border);margin-top:12px;padding-top:12px}.tier-bar-wrap{margin-top:10px}.tier-bar-label{color:var(--text-3);justify-content:space-between;margin-bottom:4px;font-size:10px;display:flex}.tier-bar-label span:first-child{font-weight:700}.tier-bar{background:var(--bg-3);border-radius:3px;height:6px;overflow:hidden}.tier-bar-fill{border-radius:3px;height:100%;transition:width 1s}.results-podium-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-3);text-align:center;justify-content:center;align-items:center;gap:8px;margin-bottom:10px;font-size:11px;font-weight:700;display:flex}.results-podium-label .podium-label-dot{border-radius:50%;width:8px;height:8px}.splits-card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;padding:16px}.splits-heading{text-transform:uppercase;letter-spacing:.8px;color:var(--text-3);align-items:center;gap:8px;margin-bottom:10px;font-size:10px;font-weight:700;display:flex}.splits-heading:after{content:"";background:var(--border);flex:1;height:1px}.splits-list{flex-direction:column;gap:8px;display:flex}.split-row{align-items:center;gap:10px;display:flex}.split-km{color:var(--text-3);width:36px;font-size:12px;font-weight:600}.split-bar-wrap{background:var(--bg-3);border-radius:4px;flex:1;height:18px;overflow:hidden}.split-bar{background:linear-gradient(90deg, var(--accent), var(--orange));border-radius:4px;height:100%;transition:width .8s}.split-bar.fastest{background:linear-gradient(90deg, var(--green), #34d399)}.split-pace{text-align:right;width:44px;font-family:JetBrains Mono,monospace;font-size:13px;font-weight:600}.split-pace.fastest{color:var(--green)}.splits-legend{color:var(--text-3);gap:16px;margin-top:8px;font-size:10px;display:flex}.splits-legend-dot{border-radius:2px;width:8px;height:8px;margin-right:4px;display:inline-block}.splits-legend-dot.normal{background:var(--accent)}.splits-legend-dot.fast{background:var(--green)}.results-table-container{background:var(--bg-1);border-radius:var(--radius);border:1px solid var(--border);text-align:left;-webkit-overflow-scrolling:touch;margin-bottom:16px;overflow-x:auto}.results-table{border-collapse:collapse;white-space:nowrap;width:100%}.results-table th{text-transform:uppercase;letter-spacing:.5px;color:var(--text-3);background:var(--bg-2);border-bottom:1px solid var(--border);padding:8px 10px;font-size:10px}.results-table td{border-bottom:1px solid var(--border);padding:8px 10px;font-size:13px}.results-table tr:last-child td{border-bottom:none}.results-runner-cell{align-items:center;gap:6px;display:flex}.results-table .me-row{background:var(--accent-soft)}.results-table .dimmed-row{opacity:.5}.results-table .still-racing-row{opacity:.55}.tier-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px;display:inline-block}.time-delta{font-family:JetBrains Mono,monospace;font-size:12px}.time-delta.ahead{color:var(--green)}.time-delta.behind{color:var(--accent)}.time-delta.me{color:var(--text-0);font-size:13px;font-weight:700}.live-gap{color:var(--text-3);font-family:JetBrains Mono,monospace;font-size:12px}.racing-indicator{color:var(--green);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:4px;font-size:10px;font-weight:600;display:inline-flex}.racing-dot{background:var(--green);border-radius:50%;width:5px;height:5px;animation:1.5s infinite racingPulse}@keyframes racingPulse{0%,to{opacity:1}50%{opacity:.4}}.rating-pending{color:var(--text-3);justify-content:center;align-items:center;gap:8px;padding:10px;font-size:13px;display:flex}.rating-spinner{border:2px solid var(--bg-4);border-top-color:var(--text-3);border-radius:50%;width:14px;height:14px;animation:1s linear infinite ratingSpinAnim}@keyframes ratingSpinAnim{to{transform:rotate(360deg)}}.route-map-header{text-transform:uppercase;letter-spacing:.5px;color:var(--text-3);background:var(--bg-1);justify-content:space-between;align-items:center;padding:10px 14px;font-size:10px;font-weight:700;display:flex}.route-map-header .route-map-count{letter-spacing:0;text-transform:none;font-weight:400}.results-scope-tabs{gap:8px;margin-bottom:8px;padding:8px 0;display:flex}.scope-tab{border:1px solid var(--border);background:var(--bg-1);color:var(--text-2);cursor:pointer;border-radius:20px;padding:6px 16px;font-size:13px;transition:all .2s}.scope-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.rating-change{font-family:JetBrains Mono,monospace;font-weight:600}.rating-change.positive{color:var(--green)}.rating-change.negative{color:var(--accent)}.results-actions{flex-direction:column;gap:8px;display:flex}.results-actions .btn{width:100%}.leaderboard-container{max-width:650px;margin:0 auto}.leaderboard-container h2{margin-bottom:12px;font-size:18px}.league-info-bar{background:var(--bg-2);border-radius:var(--radius);color:var(--text-2);margin-bottom:12px;padding:8px 12px;font-size:13px}.leaderboard-list{flex-direction:column;gap:4px;display:flex}.lb-item{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);align-items:center;gap:8px;min-height:52px;padding:10px 12px;display:flex}.lb-item:hover{background:var(--bg-2);border-color:var(--border-light)}.lb-item:active{background:var(--bg-2)}.lb-item.me{border-left:3px solid var(--accent);background:var(--accent-soft)}.lb-rank{text-align:center;min-width:24px;color:var(--text-3);font-size:15px;font-weight:800}.lb-rank.rank-1{color:var(--yellow)}.lb-rank.rank-2{color:var(--tier-pacer)}.lb-rank.rank-3{color:var(--tier-jogger)}.lb-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:12px;font-weight:700;display:flex}.lb-info{flex:1;min-width:0}.lb-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.lb-stats{color:var(--text-3);gap:8px;margin-top:1px;font-size:11px;display:flex}.lb-value{text-align:right;flex-shrink:0;font-family:JetBrains Mono,monospace;font-size:14px;font-weight:700}.profile-container{max-width:650px;margin:0 auto}.profile-header{background:var(--bg-1);border-radius:var(--radius-lg);border:1px solid var(--border);align-items:flex-start;gap:14px;margin-bottom:12px;padding:16px;display:flex;position:relative}.profile-header.founder{background-image:linear-gradient(var(--bg-1), var(--bg-1)), linear-gradient(135deg, gold, #ff6b35, gold, #fff4a3, gold);background-size:100% 100%,300% 300%;background-origin:border-box;background-clip:padding-box,border-box;border:2px solid #0000;animation:4s infinite founder-border;box-shadow:0 0 12px #ffd70026,0 0 4px #ff6b351a}@keyframes founder-border{0%,to{background-position:0 0,0%}50%{background-position:0 0,100%}}.pro-badge{text-transform:uppercase;letter-spacing:.5px;vertical-align:middle;color:#fff;background:linear-gradient(135deg,#ff6b35,gold);border-radius:4px;margin-left:6px;padding:2px 7px;font-size:10px;font-weight:800;display:inline-block}.elite-badge-inline{text-transform:uppercase;letter-spacing:.5px;vertical-align:middle;color:#fff;background:linear-gradient(135deg,#9b59b6,#e91e63);border-radius:4px;margin-left:6px;padding:2px 7px;font-size:10px;font-weight:800;display:inline-block}.founder-badge{color:gold;background:#ffd70026;border:1px solid #ffd7004d;border-radius:4px;align-items:center;gap:3px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-flex}.profile-strava-corner{z-index:10;align-items:center;gap:6px;display:flex;position:absolute;top:12px;right:12px}.profile-strava-corner .btn{min-height:36px;padding:8px 12px;font-size:12px}.profile-avatar-container{flex-shrink:0;position:relative}.profile-avatar-container.editable{cursor:pointer}.avatar-edit-overlay{background:var(--bg-0);border:1.5px solid var(--border);width:32px;height:32px;color:var(--text-2);opacity:0;border-radius:50%;justify-content:center;align-items:center;transition:opacity .15s;display:flex;position:absolute;bottom:-4px;right:-4px}.profile-avatar-container.editable:hover .avatar-edit-overlay{opacity:1}@media (hover:none){.profile-avatar-container.editable .avatar-edit-overlay{opacity:1}}.profile-avatar{color:#fff;border:2px solid;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:20px;font-weight:800;display:flex}.profile-details{flex:1;min-width:0}.profile-name{font-size:18px;font-weight:800}.profile-username{color:var(--text-3);font-size:13px}.profile-bio{color:var(--text-2);text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:3px;font-size:13px;display:-webkit-box;overflow:hidden}.profile-tier-rating{flex-wrap:wrap;align-items:center;gap:8px;margin-top:5px;display:flex}.profile-rating-num{font-family:JetBrains Mono,monospace;font-size:15px;font-weight:700}.profile-level{color:var(--purple);font-family:JetBrains Mono,monospace;font-size:12px;font-weight:600}.profile-social{color:var(--text-2);gap:12px;margin-top:5px;font-size:12px;display:flex}.profile-social strong{color:var(--text-0);font-weight:700}.profile-social span{cursor:pointer}.profile-social span:hover{color:var(--text-0)}.profile-actions{gap:8px;margin-top:8px;display:flex}.profile-stats{grid-template-columns:repeat(2,1fr);gap:6px;margin-bottom:12px;display:grid}.profile-stat-card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);text-align:center;padding:12px}.profile-stat-value{font-family:JetBrains Mono,monospace;font-size:18px;font-weight:700;display:block}.profile-stat-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;margin-top:2px;font-size:10px}.pr-section{margin-top:16px;margin-bottom:12px}.pr-title{color:var(--text-2);margin-bottom:8px;font-size:14px;font-weight:600}.pr-grid{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:8px;display:grid}.pr-card{background:var(--bg-2);border-radius:var(--radius);text-align:center;padding:12px}.pr-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;font-size:11px}.pr-value{color:var(--text-0);margin-top:2px;font-family:JetBrains Mono,monospace;font-size:18px;font-weight:700}.pr-gap{color:var(--orange);margin-top:2px;font-size:11px}.profile-tab-content{margin-top:0}.social-tab-buttons{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.social-tab-btn{flex:1;min-width:0}.profile-race-list{flex-direction:column;gap:4px;display:flex}.profile-race-item{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;gap:8px;padding:10px 12px;display:flex}.profile-race-title{font-size:13px;font-weight:600}.profile-race-detail{color:var(--text-3);margin-top:2px;font-size:11px}.profile-race-result{text-align:right;flex-shrink:0}.profile-race-pos{font-size:14px;font-weight:700}.race-history-pos{text-align:center;min-width:36px;color:var(--text-2);flex-shrink:0;font-size:18px;font-weight:700}.race-history-pos.gold{color:gold}.race-history-pos.silver{color:silver}.race-history-pos.bronze{color:#cd7f32}.race-history-center{flex:1;min-width:0}.race-history-title{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.race-history-meta{color:var(--text-3);flex-wrap:wrap;align-items:center;gap:8px;margin-top:4px;font-size:12px;display:flex}.race-history-meta .badge-sm{background:var(--bg-2);border-radius:4px;padding:1px 6px;font-size:11px;font-weight:600}.race-history-date{opacity:.6}.race-history-rating{text-align:right;flex-shrink:0;min-width:40px;font-size:14px;font-weight:700}.achievements-grid{flex-direction:column;gap:6px;display:flex}.achievement-card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);transition:var(--transition);align-items:center;gap:10px;padding:12px;display:flex}.achievement-card.locked{opacity:.4}.achievement-icon{border-radius:var(--radius-sm);background:var(--bg-3);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;display:flex}.achievement-info{flex:1;min-width:0}.achievement-name{font-size:13px;font-weight:700}.achievement-desc{color:var(--text-3);margin-top:1px;font-size:11px}.milestone-heading{color:var(--text-2);margin-bottom:8px;font-size:14px}.milestone-bar{height:4px;margin-top:4px}#toast-container{bottom:calc(68px + var(--sab));z-index:500;flex-direction:column;gap:6px;display:flex;position:fixed;left:12px;right:12px}.toast{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);padding:12px 16px;font-size:13px;animation:.2s toastIn}.toast.success{border-left:3px solid var(--green)}.toast.error{border-left:3px solid var(--accent)}.toast.info{border-left:3px solid var(--blue)}@keyframes toastIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.history-container{max-width:650px;margin:0 auto}.history-container h2{font-size:18px}.history-container .subtitle{margin-bottom:12px}.history-summary{grid-template-columns:repeat(2,1fr);gap:6px;margin-bottom:12px;display:grid}.history-summary:empty{display:none}.history-stat-card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;padding:10px}.history-stat-card .stat-value{color:var(--text-0);font-family:JetBrains Mono,monospace;font-size:16px;font-weight:700}.history-stat-card .stat-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;margin-top:2px;font-size:10px}.history-list{flex-direction:column;gap:6px;margin-bottom:12px;display:flex}.history-item{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-sm);transition:var(--transition);flex-direction:column;gap:6px;padding:12px;display:flex}.history-item:hover{background:var(--bg-2);border-color:var(--border-light)}.history-item:active{background:var(--bg-2)}.history-item-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.history-item-name{color:var(--text-0);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.history-item-date{color:var(--text-3);flex-shrink:0;font-size:12px}.history-item-stats{grid-template-columns:repeat(2,1fr);gap:6px;display:grid}.history-stat{flex-direction:column;gap:1px;display:flex}.history-stat .value{color:var(--text-0);font-family:JetBrains Mono,monospace;font-size:14px;font-weight:600}.history-stat .label{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;font-size:10px}.history-item-extra{color:var(--text-3);flex-wrap:wrap;gap:10px;font-size:11px;display:flex}.history-item-extra span{align-items:center;gap:3px;display:flex}#history-load-more{width:100%;margin-top:8px}.history-empty{text-align:center;color:var(--text-3);padding:32px 16px}.history-empty .connect-btn{margin-top:12px}.race-tabs{border-bottom:1px solid var(--border);gap:4px;margin-bottom:1rem;padding-bottom:0;display:flex}.race-tab{color:var(--text-2);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:8px 16px;font-size:13px;font-weight:600;transition:color .15s,border-color .15s}.race-tab:hover{color:var(--text-1)}.race-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.race-tab-content{display:none}.race-tab-content.active{display:block}.race-section-grid{flex-direction:column;gap:.75rem;display:flex}.history-item-clickable{cursor:pointer;transition:background .15s,transform .1s;position:relative}.history-item-clickable:hover{background:var(--bg-2);transform:translate(2px)}.history-item-clickable:active{transform:translate(0)}.history-item-arrow{color:var(--text-3);font-size:1.2rem;font-weight:300;position:absolute;top:50%;right:.75rem;transform:translateY(-50%)}.community-race-banner{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;gap:12px;padding:18px;display:flex;position:relative;overflow:hidden}.community-race-banner:before{content:"";pointer-events:none;background:radial-gradient(circle,#ef444414,#0000 70%);width:140px;height:140px;position:absolute;top:0;right:0}.next-race-label{text-transform:uppercase;letter-spacing:1.5px;color:var(--text-3);font-size:11px;font-weight:600}.next-race-top-row{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.next-race-info{flex:1;min-width:0}.community-race-title{margin-bottom:6px;font-size:17px;font-weight:700}.next-race-badges{flex-wrap:wrap;gap:6px;display:flex}.next-race-start{text-align:right;flex-shrink:0}.next-race-start-time{font-family:JetBrains Mono,monospace;font-size:22px;font-weight:700}.next-race-start-label{color:var(--text-3);text-transform:uppercase;margin-top:2px;font-size:11px}.next-race-countdown-row{background:var(--bg-2);border-radius:var(--radius-sm);color:var(--accent);align-items:center;gap:8px;padding:8px 12px;display:flex}.next-race-countdown-row span{color:var(--text-1);font-size:13px}.next-race-countdown-row span strong{color:var(--text-0);font-family:JetBrains Mono,monospace;font-weight:700}.next-race-runners{align-items:center;gap:8px;display:flex}.runner-count{color:var(--text-2);font-size:13px}.community-race-banner .btn{z-index:1;width:100%}.race-card.signed-up-race{background:#3b82f60d;border-color:#3b82f680}.race-card-live{border-left:none;border-color:var(--green)!important}.race-card-live .race-card-title{color:var(--text-0)}.race-card-time-display{flex-direction:column;align-items:flex-end;display:flex}.race-card-start-time{color:var(--text-0);font-family:JetBrains Mono,monospace;font-size:14px;font-weight:700}.race-card-until{color:var(--text-3);font-size:10px}.race-card-countdown{color:var(--accent);font-family:JetBrains Mono,monospace;font-size:13px;font-weight:600;animation:2s ease-in-out infinite pulse}.race-card-row{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;-webkit-tap-highlight-color:transparent;align-items:center;gap:12px;padding:14px;transition:transform .15s,border-color .15s;display:flex}.race-card-row:hover{border-color:var(--bg-4)}.race-card-row:active{transform:scale(.98)}.race-card-row.race-card-live{border-color:var(--green)}.race-card-row.signed-up-race{background:#3b82f60d;border-color:#3b82f680}.race-time-block{text-align:center;flex-shrink:0;min-width:52px}.race-time-value{font-family:JetBrains Mono,monospace;font-size:15px;font-weight:600}.race-time-label{color:var(--text-3);text-transform:uppercase;font-size:10px}.race-card-row .race-info{flex:1;min-width:0}.race-card-row .race-title{margin-bottom:4px;font-size:14px;font-weight:600}.race-card-row .race-meta{flex-wrap:wrap;gap:4px;display:flex}.race-card-row .race-runners{color:var(--text-3);margin-top:4px;font-size:12px}.race-card-row .race-action{flex-shrink:0}.dashboard-layout{flex-direction:column;gap:14px;display:flex}.dashboard-sidebar{display:contents}.dashboard-feed{display:none}.dashboard-main{min-width:0}.your-status-card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;gap:0;margin-bottom:0;padding:18px;display:flex}.status-header{align-items:center;gap:14px;margin-bottom:14px;display:flex}.status-avatar{flex-shrink:0}.status-avatar .status-avatar-img{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;font-weight:800;display:flex}.status-info{flex:1;min-width:0}.status-name{margin-bottom:2px;font-size:17px;font-weight:700}.status-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.status-division{color:var(--text-3);font-size:12px}.status-chevron{flex-shrink:0}.stats-grid-4{border-top:1px solid var(--border);grid-template-columns:repeat(4,1fr);padding-top:14px;display:grid}.stats-grid-4 .dash-stat{text-align:center;padding:0 4px;position:relative}.stats-grid-4 .dash-stat+.dash-stat:before{content:"";background:var(--border);width:1px;position:absolute;top:0;bottom:0;left:0}.dash-stat{text-align:center}.dash-stat-value{font-family:JetBrains Mono,monospace;font-size:16px;font-weight:700;display:block}.dash-stat-change{margin-top:1px;font-size:10px;font-weight:600;display:block}.dash-stat-change.dash-stat-up{color:var(--green)}.dash-stat-change.dash-stat-down{color:var(--accent)}.dash-stat-change.dash-stat-change-muted{color:var(--text-3)}.dash-stat-change.dash-stat-streak{color:var(--yellow)}.dash-stat-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;margin-top:2px;font-size:10px}.tier-progress-section{margin-top:12px}.tier-progress-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.tier-progress-label{color:var(--text-3);font-size:11px}.tier-progress-target{color:var(--text-2);font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600}.status-clubs{border-top:1px solid var(--border);flex-direction:column;gap:6px;margin-top:12px;padding-top:8px;display:flex}.status-club-link{color:var(--text-1);cursor:pointer;align-items:center;gap:8px;padding:4px 0;font-size:13px;transition:color .15s;display:flex}.status-club-link:hover{color:var(--text-0)}.status-club-link .club-tag{flex-shrink:0;padding:1px 5px;font-size:10px}.status-stats{display:none}.status-progression{color:var(--text-2);font-size:11px}.status-progression strong{color:var(--text-0)}.rating-chips{flex-wrap:wrap;justify-content:center;gap:3px;display:flex}.rating-chip{border-radius:4px;padding:1px 5px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600}.rating-chip.positive{color:var(--green);background:var(--green-soft)}.rating-chip.negative{color:var(--accent);background:var(--accent-soft)}.streak-warning{font-size:10px}.streak-expired{color:var(--accent)}.streak-expiring{color:var(--orange)}.results-personal{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);text-align:center;margin-bottom:16px;padding:16px}.results-personal h3{color:var(--text-2);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;font-size:12px}.personal-stats-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:12px;display:grid}.personal-stat-value{font-family:JetBrains Mono,monospace;font-size:18px;font-weight:700;display:block}.personal-stat-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;margin-top:2px;font-size:10px}.rating-change-display{border-top:1px solid var(--border);margin-top:12px;padding-top:12px}.rating-change-visual{justify-content:center;align-items:center;gap:12px;font-family:JetBrains Mono,monospace;display:flex}.rating-change-visual.animate-in{animation:.6s ease-out fadeSlideUp}.rating-before{color:var(--text-3);font-size:16px}.rating-arrow{border-radius:var(--radius-sm);padding:4px 10px;font-size:20px;font-weight:800}.rating-arrow.positive{color:var(--green);background:var(--green-soft)}.rating-arrow.negative{color:var(--accent);background:var(--accent-soft)}.rating-after{font-size:22px;font-weight:800}.rating-after.positive{color:var(--green)}.rating-after.negative{color:var(--accent)}.rating-breakdown{flex-wrap:wrap;justify-content:center;gap:8px;margin-top:6px;display:flex}.breakdown-item{color:var(--text-2);background:var(--bg-2);border-radius:var(--radius-sm);padding:2px 8px;font-size:11px}.breakdown-item strong{color:var(--text-0)}.tier-progress-track{background:var(--bg-3);border-radius:3px;width:100%;height:5px;margin-top:6px;overflow:hidden}.tier-progress-fill{background:var(--blue);border-radius:2px;height:100%;transition:width .6s}.tier-progress-fill.near-promotion{background:var(--green);animation:1.5s ease-in-out infinite progressPulse}.near-promotion{font-weight:600;color:var(--green)!important}@keyframes progressPulse{0%,to{opacity:.8}50%{opacity:1}}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.achievement-toast{align-items:center;gap:10px;animation:.5s cubic-bezier(.175,.885,.32,1.275) achievementPop;background:linear-gradient(135deg, var(--bg-3), #eab30814)!important;border:1px solid var(--yellow)!important;border-left:4px solid var(--yellow)!important;padding:12px 14px!important;display:flex!important}.ach-toast-icon{flex-shrink:0;font-size:24px}.ach-toast-title{text-transform:uppercase;letter-spacing:1px;color:var(--yellow);font-size:10px;font-weight:700}.ach-toast-name{margin-top:2px;font-size:13px;font-weight:700}.ach-toast-desc{color:var(--text-2);margin-top:1px;font-size:11px}@keyframes achievementPop{0%{opacity:0;transform:translateY(20px)scale(.8)}60%{transform:translateY(-3px)scale(1.02)}to{opacity:1;transform:translateY(0)scale(1)}}.btn-pulse{animation:1.5s ease-in-out infinite btnPulse}@keyframes btnPulse{0%,to{box-shadow:0 0 0 0 var(--accent-glow)}50%{box-shadow:0 0 0 8px #0000}}.warmup-timer-display{color:var(--orange);padding:8px 0;font-family:JetBrains Mono,monospace;font-size:18px;font-weight:700}.badge-warmup{color:#fff;letter-spacing:.5px;background:linear-gradient(135deg,#f97316,#ea580c);font-weight:700}.warmup-announcement{color:#fff;text-align:center;pointer-events:none;opacity:0;z-index:1000;text-shadow:0 0 40px #000c;letter-spacing:2px;width:100%;padding:0 20px;font-size:32px;font-weight:900;transition:all .4s cubic-bezier(.34,1.56,.64,1);position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)scale(.5)}.warmup-announcement.show{opacity:1;transform:translate(-50%,-50%)scale(1)}.warmup-announcement.milestone{color:var(--text-1);font-size:28px}.warmup-announcement.urgent{color:var(--orange);text-shadow:0 0 30px #f9731680;font-size:36px}.warmup-announcement.final{color:var(--accent);text-shadow:0 0 40px #ef444499;font-size:48px;animation:.5s ease-in-out infinite alternate announcePulse}@keyframes announcePulse{0%{transform:translate(-50%,-50%)scale(1)}to{transform:translate(-50%,-50%)scale(1.05)}}.btn-signed-up{color:var(--green)!important;background:#22c55e1a!important;border:1px solid #22c55e4d!important}.cooldown-pill{color:#60a5fa;background:#60a5fa1a;border:1px solid #60a5fa33;border-radius:20px;align-items:center;gap:8px;margin-bottom:12px;padding:6px 14px;font-size:13px;font-weight:600;display:inline-flex}.cooldown-pill-timer{font-family:JetBrains Mono,monospace;font-weight:700}.results-cooldown-bar{z-index:100;padding:12px 16px calc(12px + var(--sab,0px));-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0a0a0cf2;border-top:1px solid #ffffff14;gap:10px;display:flex;position:fixed;bottom:0;left:0;right:0}.results-cooldown-bar .btn{flex:1}.results-cooldown-end{border-color:var(--border-light);color:var(--text-2)}.results-container:has(~.results-cooldown-bar:not(.hidden)){padding-bottom:80px}.cooldown-dot{background:#60a5fa;border-radius:50%;width:10px;height:10px;animation:1.5s ease-in-out infinite cooldownPulse}@keyframes cooldownPulse{0%,to{opacity:.4}50%{opacity:1}}.cooldown-hud{z-index:20;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(165deg,#0f172aeb 0%,#0a0a12f2 100%);flex-direction:column;display:flex;position:absolute;inset:0}.cooldown-hud-header{padding:14px 16px;padding-top:calc(14px + var(--sat));justify-content:space-between;align-items:center;display:flex}.cooldown-back-btn{color:var(--text-1);cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:10px;align-items:center;gap:6px;padding:8px 14px;font-size:14px;font-weight:500;transition:background .2s;display:flex}.cooldown-back-btn:active{background:#ffffff1f}.cooldown-phase-pill{color:#60a5fa;letter-spacing:.3px;background:#60a5fa1a;border:1px solid #60a5fa33;border-radius:20px;align-items:center;gap:8px;padding:6px 14px;font-size:13px;font-weight:600;display:flex}.cooldown-phase-dot{background:#60a5fa;border-radius:50%;width:8px;height:8px;animation:1.5s ease-in-out infinite cooldownPulse}.cooldown-hud-center{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:32px;padding:0 24px;display:flex}.cooldown-timer-block{text-align:center}.cooldown-timer-value{color:var(--text-0);letter-spacing:-2px;font-family:JetBrains Mono,monospace;font-size:64px;font-weight:700;line-height:1;display:block}.cooldown-timer-label{text-transform:uppercase;letter-spacing:1px;color:#fff6;margin-top:6px;font-size:12px;display:block}.cooldown-stats-row{background:#ffffff0a;border:1px solid #ffffff14;border-radius:16px;align-items:center;gap:0;width:100%;max-width:340px;padding:16px 0;display:flex}.cooldown-stat{text-align:center;flex:1}.cooldown-stat-value{color:var(--text-0);font-family:JetBrains Mono,monospace;font-size:22px;font-weight:700;line-height:1.2;display:block}.cooldown-stat-label{text-transform:uppercase;letter-spacing:.5px;color:#fff6;margin-top:4px;font-size:11px;display:block}.cooldown-stat-divider{background:#ffffff1a;width:1px;height:32px}.cooldown-hud-footer{padding:16px 24px;padding-bottom:calc(16px + var(--sab,0px));display:flex}.cooldown-end-btn{color:var(--text-2);border-color:#ffffff26;flex:1}.race-summary{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-1);margin-bottom:16px;padding:16px 20px;font-size:15px;line-height:1.5;animation:.4s fadeInUp}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.segment-stats{grid-template-columns:1fr;gap:8px;margin:12px 0;display:grid}.segment{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);text-align:center;padding:12px}.warmup-segment{border-left:3px solid var(--orange)}.race-segment{border-left:3px solid var(--green)}.cooldown-segment{border-left:3px solid #60a5fa}.segment-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-3);margin-bottom:6px;font-size:11px;font-weight:700}.segment-value{color:var(--text-1);margin-bottom:3px;font-family:JetBrains Mono,monospace;font-size:18px;font-weight:700}.segment-detail{color:var(--text-3);font-family:JetBrains Mono,monospace;font-size:12px}.lobby-countdowns{text-align:center;flex-shrink:0;gap:10px;margin-bottom:0;padding:12px 16px 16px;display:flex}.countdown-item{text-align:center;flex:1}.countdown-label-text{text-transform:uppercase;letter-spacing:.5px;color:var(--text-3);margin-bottom:2px;font-size:12px;display:block}.countdown-value{color:var(--text-0);font-variant-numeric:tabular-nums;font-family:JetBrains Mono,monospace;font-size:36px;font-weight:700}.countdown-item.active-status .countdown-value{color:var(--green);font-size:14px}.countdown-item.elapsed .countdown-value{color:var(--text-2)}.countdown-value.lobby-loading{color:var(--text-3);font-size:16px}.lobby-warmup-info{display:none}.btn-warmup{color:#eab308;border-radius:var(--radius);cursor:pointer;background:#eab3081f;border:1px solid #eab3084d;width:100%;padding:14px 0;font-family:inherit;font-size:16px;font-weight:700;transition:background .15s,border-color .15s}.btn-warmup:active{background:#eab30833;border-color:#eab30880}.spectate-container{padding:16px;padding-top:calc(16px + var(--sat));max-width:600px;margin:0 auto}.spectate-header{align-items:center;gap:10px;margin-bottom:16px;display:flex}.spectate-info{flex:1}.spectate-info h2{font-size:17px}.spectate-meta{gap:6px;margin-top:4px;display:flex}.spectate-timer-area{text-align:center;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;padding:20px}.spectate-elapsed{color:var(--accent);font-family:JetBrains Mono,monospace;font-size:36px;font-weight:700}.spectate-runner-count{color:var(--text-3);margin-top:4px;font-size:13px}.spectate-standings{flex-direction:column;gap:2px;display:flex}.active-race-banner{z-index:150;padding:6px 12px;padding-top:calc(6px + var(--sat));background:linear-gradient(135deg, var(--accent), #dc2626);color:#fff;justify-content:space-between;align-items:center;min-height:36px;font-size:12px;font-weight:600;animation:.3s ease-out slideDown;display:flex;position:fixed;top:0;left:0;right:0}.active-race-banner.urgent{background:linear-gradient(135deg,#dc2626,#b91c1c);animation:.3s ease-out slideDown,1s ease-in-out infinite urgentPulse}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}@keyframes urgentPulse{0%,to{opacity:1}50%{opacity:.85}}body.has-active-banner #navbar{top:calc(36px + var(--sat))}body.has-active-banner main{padding-top:calc(36px + var(--sat))}.page-race.active~#bottom-tabs,body.in-race .bottom-tabs{display:none}body.in-race{padding-bottom:0}body.in-race #navbar{display:none}body.in-race .page{max-width:none;padding:0;padding-top:var(--sat)}@media (width>=768px){body{padding-bottom:0}#navbar{height:calc(56px + var(--sat));padding:0 20px}.nav-left{gap:28px}.logo-mark-img{width:24px;height:15px}.logo-text{font-size:17px}.nav-links{gap:2px;display:flex}.nav-link{border-radius:var(--radius-full);color:var(--text-2);cursor:pointer;transition:var(--transition);padding:6px 14px;font-size:13px;font-weight:500;text-decoration:none;position:relative}.nav-link:hover,.nav-link.active{color:var(--text-0);background:var(--bg-3)}.nav-link.active:after{content:"";background:var(--accent);border-radius:1px;width:16px;height:2px;position:absolute;bottom:2px;left:50%;transform:translate(-50%)}.nav-right{gap:8px}.nav-avatar{width:28px;height:28px;font-size:11px}.nav-name{font-size:13px;display:block}.nav-rating{font-size:11px;display:block}.bottom-tabs,.create-race-fab{display:none!important}.page{padding:20px}.section-header h2{font-size:22px}.dashboard-layout{flex-direction:row;align-items:flex-start;gap:20px}.dashboard-sidebar{flex-direction:column;flex-shrink:0;gap:14px;width:280px;display:flex;position:sticky;top:76px}.dashboard-feed{flex:1;min-width:0;display:block}.dashboard-feed .feed-list{max-height:calc(100vh - 160px);overflow-y:auto}.dashboard-main{flex-shrink:0;width:360px}.your-status-card{cursor:pointer;margin-bottom:0;transition:border-color .15s}.your-status-card:hover{border-color:var(--border-light)}.status-avatar .status-avatar-img{width:56px;height:56px}.dash-stat-value{font-size:18px}.race-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:12px;display:grid}.race-card:hover{border-color:var(--border-light);background:var(--bg-2);box-shadow:var(--shadow);transform:translateY(-1px)}.lobby-info h2{font-size:18px}.lobby-action-area .btn{width:auto}.lobby-action-area{margin-bottom:16px}.chat-messages{min-height:180px;max-height:350px}.race-view{border-radius:var(--radius);height:calc(100vh - 56px);margin:10px;overflow:hidden}.hud-timer-value{font-size:40px}.hud-position-value{font-size:34px}.hud-stat-val{font-size:18px}.race-standings-panel,.race-chat-panel{border-left:1px solid var(--border);z-index:15;border-top:none;border-radius:0;width:300px;transition:transform .35s;position:fixed;inset:0 0 0 auto;overflow-y:auto;transform:translate(100%);max-height:none!important}.race-standings-panel.expanded,.race-chat-panel.expanded{transform:translate(0);max-height:none!important}.standings-panel-handle{display:none}.race-hud-bottom{padding:12px 24px}.hud-action-btn{min-width:80px;padding:10px 20px}.race-stats-sheet{border-radius:18px 18px 0 0;max-width:500px;left:50%;right:auto;transform:translate(-50%)}.stats-sheet-grid{grid-template-columns:repeat(4,1fr)}.results-header h2{font-size:28px}.podium{gap:12px}.podium-avatar{width:48px;height:48px;font-size:18px}.podium-1 .podium-avatar{width:56px;height:56px}.podium-stand{min-width:90px;padding:10px 20px}.podium-1 .podium-stand{height:100px}.podium-2 .podium-stand{height:75px}.podium-3 .podium-stand{height:55px}.results-actions{flex-direction:row;justify-content:center}.results-actions .btn{width:auto}.profile-stats{grid-template-columns:repeat(4,1fr)}.profile-header{gap:20px;padding:24px}.profile-avatar{width:68px;height:68px;font-size:24px}.profile-name{font-size:20px}.personal-stats-grid{grid-template-columns:repeat(4,1fr)}.achievements-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:8px;display:grid}.history-summary,.history-item-stats{grid-template-columns:repeat(4,1fr)}.community-race-banner{padding:16px}.countdown-digits{font-size:28px}.segment-stats{grid-template-columns:1fr 1fr 1fr;gap:12px}.lobby-countdowns{gap:20px;padding:16px}.countdown-value{font-size:28px}.modal-content{padding:24px}.slide-panel{width:380px;max-width:380px}#toast-container{max-width:320px;bottom:20px;left:auto;right:20px}}#page-pricing{overflow-x:visible}.pricing-container{text-align:center;max-width:100%;margin:0 auto;padding:16px}.pricing-header{text-align:center;margin-bottom:24px}.pricing-header h1{letter-spacing:-.5px;font-size:24px;font-weight:900}.billing-toggle{background:var(--bg-2);border-radius:var(--radius);gap:2px;width:fit-content;margin:0 auto 24px;padding:3px;display:flex}.toggle-btn{color:var(--text-2);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);text-align:center;background:0 0;border:none;min-width:110px;padding:8px 20px;font-family:inherit;font-size:13px;font-weight:600}.toggle-btn.active{background:var(--bg-4);color:var(--text-0)}.save-badge{background:var(--green-soft);color:var(--green);border-radius:var(--radius-full);margin-left:4px;padding:1px 6px;font-size:10px;font-weight:700;display:inline-block}.pricing-cards{flex-direction:column;gap:16px;display:flex}.pricing-card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;position:relative}.pricing-card-pro{border-color:#ef444466}.pricing-card-premium{border-color:#9b59b6}.pricing-card-featured{border-width:2px;box-shadow:0 0 30px #9b59b633,0 8px 32px #0000004d}.popular-badge{background:var(--accent);color:#fff;border-radius:var(--radius-full);padding:2px 10px;font-size:11px;font-weight:700;position:absolute;top:-10px;right:16px}.premium-popular-badge{background:linear-gradient(135deg,#9b59b6,#e91e63)}.pricing-card-header{text-align:center;margin-bottom:20px}.pricing-card-header h3{margin-bottom:8px;font-size:18px;font-weight:800}.pricing-price{justify-content:center;align-items:baseline;gap:2px;margin-bottom:4px;display:flex}.price-amount{letter-spacing:-1px;font-size:36px;font-weight:900}.price-period{color:var(--text-3);font-size:14px}.pricing-desc{color:var(--text-2);text-align:center;font-size:13px}.pricing-features{text-align:left;border-top:1px solid var(--border);margin-bottom:20px;padding-top:16px;list-style:none}.pricing-features li{color:var(--text-1);align-items:center;gap:8px;padding:6px 0;font-size:13px;display:flex}.feature-excluded{color:var(--text-3)}.feat-check{color:var(--green);text-align:center;width:18px;font-size:14px;font-weight:700}.feat-x{color:var(--text-3);text-align:center;width:18px;font-size:14px}.pricing-consent{color:var(--text-3);cursor:pointer;align-items:flex-start;gap:8px;margin-bottom:12px;font-size:11px;line-height:1.4;display:flex}.pricing-consent input{accent-color:var(--accent);flex-shrink:0;margin-top:2px}.pricing-consent a{color:var(--accent)}.pricing-cta{width:100%}.pricing-footer{text-align:center;color:var(--text-3);margin-top:24px;font-size:12px}@media (width>=900px){.pricing-cards{flex-direction:row;align-items:stretch;max-width:100%;margin:0 auto}.pricing-card{flex:1;min-width:0}#pricing-card-free{order:1}.pricing-card-featured{flex:1.15;order:2;margin:-12px 0;padding:32px 24px}#pricing-card-pro{order:3}}.onboarding-plans-container{width:100%;max-width:860px;max-height:100vh;padding:24px 12px;overflow-y:auto}.onboarding-plans-cards{flex-direction:column;gap:12px;display:flex}.ob-plan-card{padding:20px}.ob-plan-card .pricing-price{justify-content:center}.ob-plan-card .pricing-card-header{text-align:center}.ob-plan-card .pricing-features{margin-bottom:16px}@media (width>=768px){.onboarding-plans-cards{flex-direction:row;align-items:flex-start}.ob-plan-card{flex:1}.ob-plan-featured{z-index:1;transform:scale(1.05)}}@media (width>=1024px){.page{max-width:1100px}.login-brand h1{font-size:36px}.login-container{max-width:440px}.community-race-title{font-size:18px}}.welcome-card{background:linear-gradient(135deg, var(--bg-2), var(--bg-3));border-radius:var(--radius-lg);border:1px solid #ef44444d;margin:0 0 12px;padding:24px}.welcome-card h2{margin-bottom:4px;font-size:20px}.welcome-header{margin-bottom:16px}.welcome-header p,.welcome-card>p{color:var(--text-2);margin-bottom:0;font-size:13px}.welcome-steps{flex-direction:column;gap:12px;margin-bottom:16px;display:flex}.welcome-step{color:var(--text-1);align-items:flex-start;gap:12px;font-size:13px;display:flex}.welcome-step-num{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:700;display:flex}.welcome-step strong{color:var(--text-0)}.free-race-counter{background:var(--bg-2);border-radius:var(--radius-sm);color:var(--text-2);justify-content:space-between;align-items:center;margin:0 0 8px;padding:8px 16px;font-size:12px;display:flex}.free-race-link{color:var(--accent);cursor:pointer;font-weight:600}.btn-accent{background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition);border:none;padding:8px 16px;font-size:13px;font-weight:600}.btn-accent:hover{background:var(--accent-hover)}.user-search-results{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);max-height:180px;overflow-y:auto}.user-search-results:empty{display:none}.user-search-item{cursor:pointer;border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:8px 12px;font-size:13px;display:flex}.user-search-item:hover{background:var(--bg-3)}.user-search-item:last-child{border-bottom:none}.war-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;padding:16px}.war-card-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:6px;margin-bottom:8px;display:flex}.war-score{background:var(--bg-1);border-radius:var(--radius);justify-content:center;align-items:center;gap:12px;margin:8px 0;padding:12px;font-family:JetBrains Mono,monospace;font-size:20px;font-weight:700;display:flex}.war-score-us{color:var(--accent)}.war-score-them{color:var(--text-2)}.war-card-meta{color:var(--text-3);flex-wrap:wrap;gap:12px;font-size:11px;display:flex}@keyframes firework-spark{0%{opacity:1;transform:translate(0)scale(1)}to{transform:translate(var(--dx), var(--dy)) scale(.2);opacity:0}}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.page-header h2{margin:0}.page-header .subtitle{margin-top:2px}.page-header-actions{flex-shrink:0;gap:8px;display:flex}.btn-back{min-width:44px;min-height:44px;color:var(--text-2);cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition);background:0 0;border:none;justify-content:center;align-items:center;padding:8px;font-size:18px;display:inline-flex}.btn-back:hover{color:var(--text-0);background:var(--bg-3)}.btn-back svg{width:20px;height:20px}.modal-close{color:var(--text-3);cursor:pointer;border-radius:var(--radius-sm);min-width:44px;min-height:44px;transition:var(--transition);background:0 0;border:none;justify-content:center;align-items:center;padding:8px;font-size:22px;line-height:1;display:inline-flex}.modal-close:hover{color:var(--text-0);background:var(--bg-3)}.onboard-5k-presets{flex-wrap:wrap;gap:8px;margin-bottom:8px;display:flex}.btn-5k-preset{border:1px solid var(--border);background:var(--bg-2);color:var(--text-1);cursor:pointer;white-space:nowrap;border-radius:8px;padding:8px 12px;font-family:inherit;font-size:13px;transition:all .15s}.btn-5k-preset:hover{border-color:var(--accent);color:var(--text-0)}.btn-5k-preset.selected{border-color:var(--accent);background:var(--accent-soft);color:var(--accent);font-weight:600}.onboard-label{margin-bottom:8px;font-weight:600;display:block}.onboard-label .optional{color:var(--text-3);font-weight:400}.onboard-nationality-display{color:var(--text-2);font-size:15px}.onboard-strava-box{text-align:center;background:#fc520014;border:1px solid #fc520033;border-radius:10px;margin-top:16px;padding:14px}.onboard-strava-header{justify-content:center;align-items:center;gap:8px;margin-bottom:6px;display:flex}.onboard-strava-header img{opacity:.9;height:18px}.btn-strava{color:#fff;background:#fc5200;border-color:#fc5200}.onboard-strava-connected{color:#4caf50;font-size:13px;font-weight:600}.strava-compat-img{opacity:.6;height:24px}.early-adopter-card{text-align:center}.early-adopter-emoji{margin-bottom:8px;font-size:48px}.early-adopter-features{text-align:left;max-width:280px;margin:0 auto 20px}.onboarding-plans-heading{text-align:center;margin-bottom:4px}.onboarding-plans-subtext{text-align:center;color:var(--text-2);margin-bottom:20px}.onboarding-plans-footer{text-align:center;color:var(--text-3);margin-top:16px;font-size:12px}.onboard-logo{width:48px;height:48px;margin:0 auto 12px;font-size:24px}.onboard-logo-wordmark{justify-content:center;align-items:center;gap:3px;margin:0 auto 12px;display:flex}.onboard-logo-mark{width:36px;height:23px}.onboard-logo-text{letter-spacing:2px;font-size:28px;font-weight:300}.club-tab-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.club-tab-header h3{color:var(--text-1);margin:0}.club-recent-label{color:var(--text-2);margin-top:16px}.club-leaderboard-filters{gap:8px;margin-bottom:12px;display:flex}.invite-link-row{gap:8px;display:flex}.invite-link-row input{flex:1}.invite-divider{text-align:center;color:var(--text-3);margin:12px 0}.invite-search-row{gap:8px;display:flex}.invite-search-row input{flex:1}.input-uppercase{text-transform:uppercase}.btn-share{width:100%}.delete-confirm-text{color:var(--danger,#ef4444);margin-bottom:8px;font-size:13px}.settings-danger-title{color:var(--danger,#ef4444)}.modal-centered{text-align:center}.tips-list{flex-direction:column;gap:12px;display:flex}.tip-item{color:var(--text-1);gap:10px;font-size:13px;display:flex}.tip-icon{flex-shrink:0;font-size:20px}.tip-item strong{color:var(--text-0)}.gps-indicator{border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-left:8px}.gps-good{background:var(--green);box-shadow:0 0 6px var(--green)}.gps-ok{background:var(--yellow);box-shadow:0 0 6px var(--yellow)}.gps-poor{background:var(--accent);box-shadow:0 0 6px var(--accent);animation:1s infinite gps-blink}.gps-searching{background:var(--text-muted);box-shadow:0 0 6px var(--text-muted);animation:1s infinite gps-blink}@keyframes gps-blink{50%{opacity:.4}}.connection-banner{z-index:9999;text-align:center;padding:6px 16px;font-size:12px;font-weight:600;transition:all .3s;position:fixed;top:0;left:0;right:0}body.has-active-banner .connection-banner{top:calc(36px + var(--sat))}.connection-banner.disconnected{background:var(--accent);color:#fff}.connection-banner.reconnected{background:var(--green);color:#fff}.connection-banner.hidden{transform:translateY(-100%)}.whats-next-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);margin:16px 0;padding:16px}.whats-next-card h3{color:var(--text-2);margin-bottom:10px;font-size:14px}.wn-item{color:var(--text-1);border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:6px 0;font-size:13px;display:flex}.wn-item:last-child{border-bottom:none}.wn-icon{flex-shrink:0;font-size:16px}.wn-clickable{cursor:pointer;border-radius:var(--radius-sm)}.wn-clickable:hover{background:var(--bg-3)}.achievement-progress-section{border-bottom:1px solid var(--border);margin-bottom:16px;padding-bottom:12px}.achievement-progress-item{padding:6px 0}.achievement-progress-info{color:var(--text-1);justify-content:space-between;font-size:12px;display:flex}.achievement-progress-pct{color:var(--text-2)}.bot-badge{background:var(--bg-4);color:var(--text-3);vertical-align:middle;letter-spacing:.03em;border-radius:3px;margin-left:4px;padding:1px 4px;font-size:9px;font-weight:700;display:inline-block}.voice-settings-body{flex-direction:column;gap:12px;display:flex}.voice-settings-hint{color:var(--text-3);margin:0 0 4px;font-size:13px}.voice-setting-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.voice-setting-row label{color:var(--text-2);white-space:nowrap;font-size:13px;font-weight:600}.voice-select-group{flex:1;align-items:center;gap:6px;display:flex}.voice-select{border-radius:var(--radius);border:1px solid var(--bg-4);background:var(--bg-2);color:var(--text-1);flex:1;padding:8px 10px;font-size:13px}.voice-preview-btn{justify-content:center;align-items:center;min-width:44px;height:44px;padding:0;font-size:14px;display:flex}.sound-pack-label{color:var(--text-2);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;overflow:hidden}.settings-slider{appearance:none;background:var(--bg-4);border-radius:3px;outline:none;flex:1;width:100%;min-width:120px;height:6px}.settings-slider::-webkit-slider-thumb{appearance:none;background:var(--accent);cursor:pointer;border:2px solid var(--bg-1);border-radius:50%;width:28px;height:28px;box-shadow:0 1px 4px #0000004d}.settings-slider::-moz-range-thumb{background:var(--accent);cursor:pointer;border:2px solid var(--bg-1);border-radius:50%;width:28px;height:28px;box-shadow:0 1px 4px #0000004d}.toggle-switch{flex-shrink:0;width:44px;height:24px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background:var(--bg-4);border-radius:24px;transition:all .2s;position:absolute;inset:0}.toggle-slider:before{content:"";background:var(--text-3);border-radius:50%;width:18px;height:18px;transition:all .2s;position:absolute;bottom:3px;left:3px}.toggle-switch input:checked+.toggle-slider{background:var(--accent)}.toggle-switch input:checked+.toggle-slider:before{background:#fff;transform:translate(20px)}.profile-dropdown{z-index:300;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:180px;padding:4px 0;animation:.1s dropdownIn;position:fixed}@keyframes dropdownIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.profile-dropdown-item{color:var(--text-1);cursor:pointer;transition:var(--transition);align-items:center;gap:10px;padding:10px 16px;font-size:14px;display:flex}.profile-dropdown-item:hover{background:var(--bg-2)}.profile-dropdown-item svg{color:var(--text-3);flex-shrink:0}.profile-dropdown-danger,.profile-dropdown-danger svg{color:var(--danger)}.profile-dropdown-divider{background:var(--border);height:1px;margin:4px 0}.settings-body{flex-direction:column;gap:4px;display:flex}.settings-section{border-bottom:1px solid var(--bg-4);padding:16px 0}.settings-section:last-child{border-bottom:none}.settings-section-title{color:var(--text-1);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:14px;font-weight:700}.settings-collapsible{cursor:pointer;width:100%;color:var(--text-1);text-transform:uppercase;letter-spacing:.5px;background:0 0;border:none;justify-content:space-between;align-items:center;padding:0;font-family:inherit;font-size:14px;font-weight:700;display:flex}.settings-chevron{transition:transform .2s}.settings-collapsible.open .settings-chevron{transform:rotate(180deg)}.settings-field{margin-bottom:10px}.settings-field label{color:var(--text-2);margin-bottom:4px;font-size:13px;font-weight:600;display:block}.settings-field .input{border-radius:var(--radius);border:1px solid var(--bg-4);background:var(--bg-2);width:100%;color:var(--text-1);padding:8px 10px;font-size:14px}.settings-field textarea.input{resize:vertical;font-family:inherit}.settings-field select.input{appearance:auto}.settings-field-row{justify-content:space-between;align-items:center;display:flex}.settings-field-row label{margin-bottom:0}.settings-hint{color:var(--text-3);margin:2px 0 8px;font-size:12px}.settings-danger-zone{border-bottom:none;border-top:2px solid var(--danger);margin-top:8px;padding-top:16px}.btn-danger{background:var(--danger);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;min-height:44px;padding:10px 16px;font-size:13px;font-weight:600}.btn-danger:hover{opacity:.9}.empty-state-cta{text-align:center;padding:40px 20px}.empty-state-cta .empty-icon{margin-bottom:12px;font-size:40px;display:block}.empty-state-cta .empty-title{margin-bottom:4px;font-size:16px;font-weight:700}.empty-state-cta .empty-text{color:var(--text-3);margin-bottom:16px;font-size:13px}.create-race-presets{flex-wrap:wrap;gap:6px;margin-bottom:14px;display:flex}.preset-btn{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-2);cursor:pointer;min-height:44px;padding:10px 14px;font-size:12px;font-weight:600;transition:all .15s}.preset-btn:hover{background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}.form-helper{color:var(--text-3);margin-top:2px;font-size:11px}@media (width<=480px){.status-avatar .status-avatar-img{width:44px;height:44px}.dash-stat-value{font-size:15px}.empty-state-cta{padding:24px 16px}.empty-state{padding:20px 12px}.modal-content{margin:8px;padding:16px}.community-race-banner{padding:12px}.countdown-digits{font-size:24px}.form-row{grid-template-columns:1fr}.race-card-start-time{font-size:13px}.profile-header{gap:10px;padding:12px}.profile-avatar{width:52px;height:52px}.race-timer,.race-position{min-width:48px}.timer-value,.position-value{font-size:18px}.race-title-bar h3{font-size:12px}.mini-name{max-width:100px}.tab-btn{padding:6px 10px;font-size:12px}.page-header{flex-direction:column;align-items:flex-start;gap:8px}.page-header-actions{width:100%}.page-header-actions .btn{flex:1}}.club-tag{letter-spacing:.5px;background:var(--accent);color:#fff;vertical-align:middle;border-radius:3px;margin-left:4px;padding:1px 5px;font-size:10px;font-weight:700;display:inline-block}.club-tag-sm{padding:0 4px;font-size:9px}.club-tag-clickable{cursor:pointer;transition:transform .15s,box-shadow .15s}.club-tag-clickable:hover{box-shadow:0 0 8px var(--accent);transform:scale(1.1)}.profile-clubs-tags{flex-wrap:wrap;gap:6px;margin-top:6px;display:flex}.club-online-dot{vertical-align:middle;background:#2ecc71;border-radius:50%;width:7px;height:7px;margin-left:2px;display:inline-block}.club-member-avatar.online{box-shadow:0 0 0 2px #2ecc71}.dashboard-clubs{background:var(--bg-2);border:1px solid var(--border);border-radius:12px;margin-bottom:16px;padding:12px 16px}.dashboard-clubs-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.dashboard-clubs-header h3{margin:0;font-size:14px}.dashboard-clubs-list{gap:8px;padding-bottom:4px;display:flex;overflow-x:auto}.dashboard-club-card{background:var(--bg-1);border:1px solid var(--border);cursor:pointer;white-space:nowrap;border-radius:8px;align-items:center;gap:8px;padding:8px 12px;transition:border-color .15s;display:flex}.dashboard-club-card:hover{border-color:var(--accent)}.dashboard-club-tag{background:var(--accent);color:#fff;border-radius:4px;padding:2px 6px;font-size:12px;font-weight:700}.clubs-container{max-width:700px;margin:0 auto;padding:16px}.clubs-search{margin-bottom:16px}.clubs-search input{border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-2);width:100%;color:var(--text-1);transition:var(--transition);min-height:44px;padding:10px 14px;font-family:inherit;font-size:16px}.clubs-search input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}.my-clubs-section{margin-bottom:20px}.my-clubs-section h2{margin-bottom:8px;font-size:16px}.my-clubs-grid,.clubs-grid{flex-direction:column;gap:8px;display:flex}.club-card{background:var(--bg-2);border:1px solid var(--border);cursor:pointer;border-radius:10px;align-items:center;gap:12px;padding:12px 16px;transition:border-color .15s,transform .1s;display:flex}.club-card:hover{border-color:var(--border-light);transform:translateY(-1px);box-shadow:0 2px 8px #00000026}.club-card:active{transform:scale(.98)}.club-card-past{opacity:.7}.club-card-tag{background:var(--accent);color:#fff;text-align:center;border-radius:6px;min-width:42px;padding:6px 10px;font-size:14px;font-weight:800}.club-card-info{flex:1;min-width:0}.club-card-name{color:var(--text-1);font-size:15px;font-weight:600}.club-card-meta{color:var(--text-3);margin-top:2px;font-size:12px}.club-card-desc{color:var(--text-2);text-overflow:ellipsis;white-space:nowrap;margin-top:2px;font-size:12px;overflow:hidden}.club-card-badge{border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.club-card-badge.open{color:#4caf50;background:#4caf5026}.club-card-badge.closed{color:#ff9800;background:#ff980026}.club-container{max-width:700px;margin:0 auto;padding:16px}.club-header{background:var(--bg-2);border:1px solid var(--border);border-radius:12px;margin-bottom:12px;padding:16px}.club-header-top{align-items:center;gap:12px;margin-bottom:8px;display:flex}.club-header-tag{background:var(--accent);color:#fff;border-radius:8px;padding:8px 14px;font-size:22px;font-weight:800}.club-header-info h2{margin:0;font-size:20px}.club-header-meta{color:var(--text-3);margin-top:2px;font-size:13px}.club-header-desc{color:var(--text-2);margin:8px 0;font-size:14px}.club-header-stats{color:var(--text-2);gap:16px;margin:10px 0;font-size:13px;display:flex}.club-header-stat{flex-direction:column;align-items:center;display:flex}.club-header-stat-value{color:var(--text-1);font-size:18px;font-weight:700}.club-header-stat-label{color:var(--text-3);font-size:11px}.club-header-actions{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.club-tabs{border-bottom:1px solid var(--border);-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:2px;margin-bottom:12px;padding-bottom:0;display:flex;overflow-x:auto}.club-tabs::-webkit-scrollbar{display:none}.club-tabs .tab-btn{color:var(--text-3);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;flex-shrink:0;min-height:44px;padding:10px 12px;font-size:13px;font-weight:600;transition:all .15s}.club-tabs .tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.club-chat{flex-direction:column;height:calc(100vh - 320px);min-height:300px;display:flex}.club-chat-messages{flex-direction:column;flex:1;gap:4px;padding:8px 0;display:flex;overflow-y:auto}.club-chat-msg{border-radius:8px;padding:8px 12px;font-size:13px;line-height:1.4}.club-chat-msg:hover{background:var(--bg-2)}.club-chat-msg-header{align-items:center;gap:6px;margin-bottom:2px;display:flex}.club-chat-msg-name{color:var(--text-1);font-size:12px;font-weight:600}.club-chat-msg-time{color:var(--text-3);font-size:10px}.club-chat-msg-body{color:var(--text-2);word-break:break-word}.club-chat-msg.system{text-align:center;color:var(--text-3);padding:4px 0;font-size:12px;font-style:italic}.club-chat-input{border-top:1px solid var(--border);gap:8px;padding:8px 0;display:flex}.club-chat-input input{border:1px solid var(--border);background:var(--bg-2);color:var(--text-1);border-radius:8px;flex:1;min-height:44px;padding:10px 12px;font-size:13px}.club-members-list{flex-direction:column;gap:4px;display:flex}.club-member-row{border-radius:8px;align-items:center;gap:10px;min-height:44px;padding:10px 12px;transition:background .1s;display:flex}.club-member-row:hover{background:var(--bg-2)}.club-member-avatar{background:var(--bg-3);width:36px;height:36px;color:var(--text-2);border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.club-member-info{flex:1}.club-member-name{color:var(--text-1);font-size:14px;font-weight:600}.club-member-meta{color:var(--text-3);font-size:11px}.club-member-role{text-transform:uppercase;border-radius:4px;padding:2px 6px;font-size:11px;font-weight:600}.club-member-role.owner{color:#ffc107;background:#ffc10733}.club-member-role.admin{color:#ce93d8;background:#9c27b040}.club-member-role.moderator{color:#64b5f6;background:#2196f340}.club-member-actions{gap:4px;display:flex}.race-club-badge{background:rgba(var(--accent-rgb), .12);color:var(--accent);border-radius:4px;align-items:center;gap:4px;margin-left:6px;padding:2px 6px;font-size:11px;font-weight:600;display:inline-flex}@media (width<=480px){.clubs-grid{grid-template-columns:1fr;gap:10px}.club-header-top{flex-direction:column;align-items:flex-start;gap:8px}.club-header-tag{font-size:28px}.club-header-stats{grid-template-columns:repeat(2,1fr);gap:8px}.club-header-actions{flex-wrap:wrap}.club-chat-container{height:350px}.club-tabs{gap:4px}.club-tabs .tab-btn{padding:6px 10px;font-size:12px}.club-member-actions .btn{min-height:36px;padding:6px 10px;font-size:11px}}.confetti-container{pointer-events:none;z-index:400;width:100%;height:100%;position:fixed;top:0;left:0;overflow:hidden}.confetti-piece{width:10px;height:10px;animation:3s ease-in forwards confetti-fall;position:absolute;top:-20px}@keyframes confetti-fall{0%{opacity:1;transform:translateY(0)rotate(0)}to{opacity:0;transform:translateY(100vh)rotate(720deg)}}.mini-standings{border:1px solid #ffffff1a;display:none}.mini-standings .ms-row{align-items:center;gap:6px;padding:2px 0;display:flex}.mini-standings .ms-pos{width:16px;font-weight:700}.mini-standings .ms-pos.pos-1{color:var(--yellow)}.mini-standings .ms-pos.pos-2{color:var(--tier-pacer)}.mini-standings .ms-pos.pos-3{color:var(--tier-jogger)}.mini-standings .ms-name{white-space:nowrap;text-overflow:ellipsis;flex:1;max-width:80px;overflow:hidden}.mini-standings .ms-dist{color:var(--text-2);font-family:JetBrains Mono,monospace;font-size:10px}.mini-standings .ms-sep{text-align:center;color:var(--text-3);padding:1px 0;font-size:9px}.mini-standings .ms-you{color:var(--accent);font-weight:600}@media (width>=1024px){.mini-standings{opacity:.8;font-size:10px}}.advanced-toggle{cursor:pointer;color:var(--text-2);border-top:1px solid var(--border);align-items:center;gap:8px;margin-top:8px;padding:12px 0;font-size:13px;font-weight:600;display:flex}.advanced-toggle:hover{color:var(--text-1)}.toggle-arrow{font-size:10px;transition:transform .2s}.toggle-arrow.open{transform:rotate(90deg)}.advanced-options{padding-top:8px}.form-help{color:var(--text-3);margin-top:4px;font-size:11px;display:block}.cooldown-explainer{color:var(--text-3);padding:0 16px 12px;font-size:12px}.standing-hr{color:#ff4d6a;margin-left:6px;font-size:11px;font-weight:600;display:inline-block}.standing-hr:before{content:"";vertical-align:-1px;background:currentColor;width:11px;height:11px;margin-right:3px;display:inline-block;-webkit-mask:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20.84 4.61a5.5 5.5 0 0 0-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 0 0-7.78 7.78L12 21.23l8.84-8.84a5.5 5.5 0 0 0 0-7.78z'/%3E%3C/svg%3E") 0 0/contain;mask:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20.84 4.61a5.5 5.5 0 0 0-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 0 0-7.78 7.78L12 21.23l8.84-8.84a5.5 5.5 0 0 0 0-7.78z'/%3E%3C/svg%3E") 0 0/contain}.hr-settings-status{flex-wrap:wrap;align-items:center;gap:8px;margin-top:4px;display:flex}.hr-status-row{align-items:center;gap:6px;width:100%;font-size:13px;display:flex}.hr-status-label{color:var(--text-3)}.hr-live-bpm{color:#ff4d6a;margin-left:auto;font-size:14px;font-weight:600}.lobby-hr-indicator{color:var(--text-3);cursor:pointer;justify-content:center;align-items:center;gap:6px;min-height:44px;margin-top:6px;padding:8px 0;font-size:12px;display:flex}.hr-dot{background:var(--text-3);border-radius:50%;width:8px;height:8px;display:inline-block}.hr-dot.connected{background:#ff4d6a;animation:1s infinite hr-pulse;box-shadow:0 0 6px #ff4d6a80}@keyframes hr-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.3)}}.hr-stat .personal-stat-value{color:#ff4d6a}.lobby-commentary-toggle{flex-direction:column;align-items:center;gap:6px;width:100%;margin-top:10px;display:flex}.commentary-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.commentary-options{gap:8px;width:100%;display:flex}.commentary-opt{border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--bg-0);color:var(--text-2);cursor:pointer;flex:1;justify-content:center;align-items:center;gap:6px;min-height:44px;padding:10px 12px;font-size:13px;font-weight:600;transition:all .15s;display:flex}.commentary-opt:active{transform:scale(.97)}.commentary-opt.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.commentary-opt.locked{opacity:.45;cursor:not-allowed;position:relative}.commentary-opt.locked:after{content:"";position:absolute;inset:0}.commentary-opt-icon{background:var(--bg-2);border-radius:4px;padding:2px 5px;font-size:11px;font-weight:800;line-height:1}.commentary-opt.active .commentary-opt-icon{background:var(--accent);color:#fff}.commentary-lock-hint{color:var(--accent);cursor:pointer;font-size:11px}.commentary-slider-row{align-items:center;gap:10px;width:100%;margin-top:4px;padding:8px 0;display:flex}.commentary-slider-label{color:var(--text-2);white-space:nowrap;text-align:right;min-width:48px;font-size:12px;font-weight:600}.cosmetics-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px;margin-bottom:12px;display:grid}.cosmetic-item{background:var(--bg-2);border:2px solid var(--border);border-radius:var(--radius);text-align:center;cursor:pointer;flex-direction:column;align-items:center;gap:3px;padding:10px;transition:border-color .2s,transform .2s;display:flex}.cosmetic-item:hover:not(.locked){transform:translateY(-2px)}.cosmetic-item.equipped{border-color:var(--accent)}.cosmetic-item.locked{cursor:default}.personality-selector{padding:0 16px 8px}.personality-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:8px;font-size:.75rem;font-weight:600}.personality-options{grid-template-columns:1fr 1fr;gap:8px;display:grid}.personality-btn{border:2px solid var(--border);background:var(--card-bg);color:var(--text-primary);cursor:pointer;text-align:center;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;min-height:54px;padding:10px 8px;transition:border-color .2s,background .2s,transform .15s;display:flex}.personality-btn strong{font-size:.85rem;line-height:1.2}.personality-btn span{color:var(--text-secondary);margin-top:2px;font-size:.7rem}.personality-btn.active strong{color:var(--accent)}.coach-run-card{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;align-items:center;gap:12px;margin-bottom:16px;padding:16px;transition:background .15s,border-color .15s;display:flex}.coach-run-card:hover{background:var(--bg-2);border-color:var(--border-light)}.coach-run-card:active{transform:scale(.99)}.coach-run-icon{background:var(--accent-soft);width:44px;height:44px;color:var(--accent);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.coach-run-text{flex-direction:column;flex:1;gap:2px;display:flex}.coach-run-text strong{color:var(--text-1);font-size:15px}.coach-run-text span{color:var(--text-3);font-size:13px}.coach-run-chevron{color:var(--text-3);flex-shrink:0}.coach-setup{max-width:480px;margin:0 auto;padding:16px}.coach-setup-header{align-items:center;gap:12px;margin-bottom:24px;display:flex}.coach-setup-header h2{margin:0;font-size:20px}.btn-back{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;width:36px;height:36px;color:var(--text-1);justify-content:center;align-items:center;display:flex}.btn-back:hover{background:var(--bg-2)}.coach-setup-section{margin-bottom:24px}.coach-setup-section>label{color:var(--text-2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:13px;font-weight:600;display:block}.training-type-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.training-type-btn{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;color:var(--text-2);flex-direction:column;justify-content:center;align-items:center;gap:6px;min-height:72px;padding:16px 12px;font-size:14px;font-weight:600;transition:border-color .15s,background .15s;display:flex}.training-type-btn:hover{background:var(--bg-2);border-color:var(--border-light)}.training-type-btn:active{transform:scale(.97)}.training-type-btn.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.distance-presets{flex-wrap:wrap;gap:8px;display:flex}.distance-preset-btn{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-2);cursor:pointer;min-height:44px;padding:10px 16px;font-size:14px;font-weight:600;transition:border-color .15s}.distance-preset-btn:hover{border-color:var(--border-light)}.distance-preset-btn.active{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.personality-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.personality-btn{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;flex-direction:column;gap:4px;padding:14px 12px;transition:border-color .15s;display:flex}.personality-btn:hover{border-color:var(--border-light)}.personality-btn:active{transform:scale(.97)}.personality-btn.active{border-color:var(--accent);background:var(--accent-soft)}.personality-name{color:var(--text-1);font-size:14px;font-weight:600}.personality-btn.active .personality-name{color:var(--accent)}.personality-desc{color:var(--text-3);font-size:12px}.page-coach{padding:0!important}.page-coach.active{flex-direction:column;display:flex}.coach-hud{min-height:0;padding:16px;padding-top:env(safe-area-inset-top,16px);background:var(--bg-1);flex-direction:column;flex:1;display:flex}.coach-hud-top{justify-content:space-between;align-items:center;margin-bottom:16px;padding:8px 0;display:flex}.coach-type-badge{letter-spacing:1px;color:var(--accent);background:var(--accent-soft);border-radius:4px;padding:4px 10px;font-size:12px;font-weight:700}.coach-elapsed{color:var(--text-1);font-variant-numeric:tabular-nums;font-size:32px;font-weight:700}.coach-stats-grid{flex:1;grid-template-columns:1fr 1fr;align-content:center;gap:16px;display:grid}.coach-stat{background:var(--bg-2);border-radius:var(--radius);flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:24px 16px;display:flex}.coach-stat-value{color:var(--text-1);font-variant-numeric:tabular-nums;font-size:36px;font-weight:700;line-height:1}.coach-stat-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.coach-split-toast{text-align:center;background:var(--accent-soft);color:var(--accent);border-radius:var(--radius);margin:12px 0;padding:12px 16px;font-size:15px;font-weight:600;animation:.3s coachSplitIn}@keyframes coachSplitIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.coach-controls{padding:16px 0;padding-bottom:env(safe-area-inset-bottom,16px);gap:12px;display:flex}.coach-controls .btn{flex:1;min-height:52px;font-size:16px;font-weight:600}.coach-summary{text-align:center;max-width:480px;margin:0 auto;padding:24px 16px}.coach-summary h2{color:var(--text-1);margin-bottom:24px;font-size:24px}.coach-summary-stats{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;display:grid}.coach-summary-stat{background:var(--bg-2);border-radius:var(--radius);flex-direction:column;align-items:center;gap:4px;padding:20px 12px;display:flex}.coach-summary-value{color:var(--text-1);font-variant-numeric:tabular-nums;font-size:28px;font-weight:700}.coach-summary-stat label{color:var(--text-3);text-transform:uppercase;font-size:12px;font-weight:600}.coach-splits-container{margin-bottom:24px}.splits-table-inner{border-collapse:collapse;text-align:center;width:100%}.splits-table-inner th{color:var(--text-3);text-transform:uppercase;border-bottom:1px solid var(--border);padding:8px 4px;font-size:11px;font-weight:600}.splits-table-inner td{color:var(--text-1);border-bottom:1px solid var(--border);font-variant-numeric:tabular-nums;padding:10px 4px;font-size:14px}.coach-summary-actions{flex-direction:column;gap:8px;display:flex}.coach-history{max-width:480px;margin:0 auto;padding:16px}.coach-history-item{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;padding:14px 16px}.coach-history-top{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.coach-history-type{color:var(--accent);background:var(--accent-soft);border-radius:4px;padding:2px 8px;font-size:13px;font-weight:600}.coach-history-date{color:var(--text-3);font-size:12px}.coach-history-stats{color:var(--text-2);gap:16px;font-size:14px;display:flex}
