:root{--bg:#070a10;--bg-elev:#0d121c;--bg-elev-2:#121926;--border:#ffffff21;--border-hi:#2fa4ff73;--panel-glass:#0d121cd1;--text:#f5f8ff;--text-dim:#a5b2c7;--text-dimmer:#738197;--blue:#2fa4ff;--blue-hi:#6ac6ff;--blue-deep:#1267d7;--green:#7be44a;--green-deep:#48a823;--orange:#ff8c2e;--gold:#ffb338;--red:#ff5b4d;--glow-blue:0 0 16px #2fa4ff73;--radius:16px;--tab-h:64px;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font-family:system-ui,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}body{overscroll-behavior:none;background:linear-gradient(180deg, #2fa4ff1f, transparent 330px), radial-gradient(circle at 78% 8%, #ffb3381a, transparent 300px), var(--bg);min-height:100svh;margin:0}#root{min-height:100svh}button{cursor:pointer;font-family:inherit}.shell{flex-direction:column;max-width:480px;min-height:100svh;margin:0 auto;display:flex}.shell-scroll{padding:0 16px calc(var(--tab-h) + 44px);flex:1}.app-header{justify-content:space-between;align-items:center;gap:12px;padding:14px 16px 10px;display:flex}.app-logo{height:26px;display:block}.chip-row{gap:8px;display:flex}.chip{border:1px solid var(--border);white-space:nowrap;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#080c12bd;border-radius:999px;align-items:center;gap:6px;padding:5px 12px 5px 7px;font-size:13px;font-weight:800;display:inline-flex}.chip img{width:18px;height:18px;display:block}.chip .chip-sub{color:var(--text-dim);letter-spacing:.5px;font-size:10px;font-weight:800}.tab-bar{bottom:calc(10px + env(safe-area-inset-bottom,0px));width:min(456px,100% - 24px);height:var(--tab-h);border:1px solid var(--border);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);z-index:40;background:#070a10db;border-radius:22px;padding:5px;display:flex;position:fixed;left:50%;transform:translate(-50%)}.tab-btn{color:var(--text-dim);letter-spacing:.6px;text-transform:uppercase;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:6px 2px;font-size:10px;font-weight:800;display:flex}.tab-btn svg{fill:currentColor;width:22px;height:22px}.tab-btn.active{color:#fff}.tab-btn.active .tab-ico{background:linear-gradient(180deg, var(--blue-hi), var(--blue-deep));box-shadow:var(--glow-blue)}.tab-ico{border-radius:9px;place-items:center;width:40px;height:26px;display:grid}.kicker{color:var(--gold);letter-spacing:1.1px;text-transform:uppercase;margin:14px 0 4px;font-size:11px;font-weight:900}.kicker.blue{color:var(--blue)}.kicker.lime{color:var(--green)}.kicker+.screen-title{margin-top:0}.screen-title{letter-spacing:0;text-transform:uppercase;margin:14px 0 2px;font-size:30px;font-style:italic;font-weight:900;line-height:.95}.notice{color:#d8ffd0;letter-spacing:.8px;text-transform:uppercase;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#091210c7;border:1px solid #7be44a70;border-radius:0;align-items:center;gap:9px;min-height:34px;margin:8px 0 16px;padding:7px 10px;font-size:11px;font-weight:900;display:flex}.notice.blue{color:#d9f0ff;background:#081019c7;border-color:#2fa4ff75}.notice.warn{color:#ffd9d4;background:#190a08c7;border-color:#ff5b4d8c}.checkmark{border:1px solid;flex:none;width:18px;height:18px;position:relative}.checkmark:before{content:"";border-bottom:3px solid;border-right:3px solid;width:8px;height:12px;position:absolute;top:2px;left:4px;transform:rotate(42deg)}.screen-sub{color:var(--text-dim);margin:0 0 16px;font-size:13px;line-height:1.5}.section-title{letter-spacing:1.2px;text-transform:uppercase;color:var(--text-dim);margin:22px 0 10px;font-size:13px;font-weight:900}.panel{background:linear-gradient(180deg, #ffffff12, #ffffff06), var(--panel-glass);border:1px solid var(--border);border-radius:var(--radius);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:inset 0 1px #ffffff0a}.panel.hot{border-color:var(--border-hi);box-shadow:0 0 22px #2fa4ff24,inset 0 1px #ffffff0f}.panel.lime{border-color:#7be44a61;box-shadow:0 0 22px #7be44a1f}.btn-cta{letter-spacing:1px;text-transform:uppercase;color:#06101f;background:linear-gradient(180deg, #6ac6ff, var(--blue) 52%, #116ade);border:1px solid #90dbffcc;border-radius:14px;justify-content:center;align-items:center;gap:8px;padding:14px 26px;font-size:16px;font-style:italic;font-weight:900;transition:transform 60ms,filter 60ms;display:inline-flex;box-shadow:0 0 22px #2fa4ff47,inset 0 1px #ffffff6b}.btn-cta:active{filter:brightness(.82)saturate(1.1);transform:translateY(1px)scale(.99)}.btn-cta:disabled{filter:grayscale(.7)brightness(.6);box-shadow:none;cursor:default}.btn-ghost{color:#d8f0ff;background:#2fa4ff1a;border:1px solid #2fa4ff73;border-radius:12px;padding:10px 16px;font-size:14px;font-weight:800}.btn-ghost:hover{border-color:#90dbffb3}.btn-subtle{color:var(--text-dim);background:#ffffff0f;border:1px solid #ffffff29;border-radius:12px;padding:9px 14px;font-size:13px;font-weight:800}.btn-back{background:var(--bg-elev);border:1px solid var(--border);width:38px;height:38px;color:var(--text);border-radius:12px;flex:none;font-size:16px}.meter{align-items:center;gap:8px;display:flex}.meter-ico{flex:none;width:26px;height:26px}.meter-track{border:1px solid var(--border);background:#060a13;border-radius:999px;flex:1;height:14px;overflow:hidden}.meter-fill{background:linear-gradient(180deg, #c9ff75, var(--green) 55%, var(--green-deep));border-radius:999px;height:100%;transition:width .3s;box-shadow:0 0 10px #7be44a80}.meter-fill.heat{background:linear-gradient(180deg, #ffc35e, var(--orange) 55%, #d96f00);box-shadow:0 0 10px #ff8c2e80}.meter-label{color:var(--text-dim);white-space:nowrap;font-size:12px;font-weight:800}.card{border:1px solid var(--border);width:100%;color:var(--text);text-align:left;background:#0c1018c7;border-radius:16px;align-items:center;gap:14px;padding:13px 15px;transition:border-color .12s,transform 80ms;display:flex}button.card:not(:disabled):hover{border-color:var(--blue)}button.card:not(:disabled):active{transform:scale(.99)}.card.locked{opacity:.45;cursor:default}.card.highlight{background:linear-gradient(#ffb3381a,#0c1018c7);border-color:#ffb33880}.card.me{background:linear-gradient(#2fa4ff26,#0c1018c7);border-color:#2fa4ff73}.card-main{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.card-title{font-size:15px;font-weight:800}.card-sub{color:var(--text-dim);font-size:12.5px;line-height:1.45}.card-side{white-space:nowrap;flex-direction:column;align-items:flex-end;gap:2px;display:flex}.card-metric{color:var(--gold);font-size:17px;font-weight:900}.card-metric.blue{color:var(--blue-hi)}.card-metric-label{color:var(--text-dim);letter-spacing:1px;text-transform:uppercase;font-size:10px;font-weight:800}.card-ico{object-fit:contain;flex:none;width:44px;height:44px}.stat-grid{gap:10px;margin-bottom:14px;display:flex}.stat-grid-2{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px;display:grid}.stat-card{border:1px solid var(--border);background:linear-gradient(#ffffff12,#ffffff05),#0c1018d1;border-radius:18px;flex-direction:column;justify-content:space-between;align-items:flex-start;gap:6px;min-height:112px;padding:14px;display:flex}.stat-card>img{object-fit:contain;width:28px;height:28px}.stat-card .pikto{width:30px;height:30px}.stat-card .stat-value{font-size:30px;line-height:.92}.chart-card{margin-bottom:12px;padding:14px}.chart{align-items:flex-end;gap:9px;height:92px;margin-top:12px;display:flex}.chart-col{flex-direction:column;flex:1;justify-content:flex-end;min-width:0;height:100%;display:flex}.bar-col{background:linear-gradient(#2fa4fff2,#2fa4ff33);border:1px solid #ffffff1a;min-height:2px;box-shadow:0 0 18px #2fa4ff29}.chart-days{gap:9px;margin-top:6px;display:flex}.chart-days span{text-align:center;color:var(--text-dimmer);text-transform:uppercase;flex:1;font-size:9px;font-weight:900}.stat-tile{text-align:center;flex-direction:column;flex:1;align-items:center;gap:3px;padding:13px 6px;display:flex}.stat-value{color:var(--blue-hi);font-size:22px;font-style:italic;font-weight:900}.stat-value.gold{color:var(--gold)}.stat-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;font-size:10px;font-weight:800}.stat-delta{font-size:11px;font-weight:800}.stat-delta.up{color:var(--green)}.stat-delta.down{color:var(--red)}.flame-tier{text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:800}.flame-tier.bronze{color:#cd7f32}.flame-tier.blue{color:var(--blue-hi)}.flame-tier.neon{color:var(--green)}.flame-tier.inferno{color:var(--orange)}.arena-backdrop{z-index:-1;pointer-events:none;opacity:.22;filter:saturate(.9)contrast(1.05);background-position:50%;background-size:cover;position:fixed;inset:0}.arena-backdrop:after{content:"";background:linear-gradient(180deg, #070a1073, #070a10f2 62%, var(--bg));position:absolute;inset:0}.arena-card{border:1px solid var(--border);background-position:50%;background-size:cover;border-radius:24px;min-height:215px;margin:2px 0 14px;position:relative;overflow:hidden}.arena-card:before{content:"";background:linear-gradient(#070a0f2e,#070a0fe0),linear-gradient(90deg,#070a0fd9,#0000 72%);position:absolute;inset:0}.arena-fighter{filter:drop-shadow(0 18px 20px #000000b8);pointer-events:none;height:205px;position:absolute;bottom:-8px;right:-12px}.arena-copy{flex-direction:column;align-items:flex-start;gap:10px;width:60%;display:flex;position:absolute;bottom:15px;left:15px}.badge-line{align-items:center;gap:8px;display:flex}.badge-line img{object-fit:contain;width:42px;height:42px}.micro{color:var(--text-dim);letter-spacing:.9px;text-transform:uppercase;font-size:10px;font-weight:900}.arena-title{text-transform:uppercase;text-shadow:0 2px 10px #000c;margin:2px 0 0;font-size:20px;font-style:italic;font-weight:900;line-height:.98}.hero{border-radius:var(--radius);border:1px solid var(--border);background:linear-gradient(180deg, #070b1540 0%, #070b15eb 78%), var(--hero-bg) center 30% / cover no-repeat, var(--bg-elev);align-items:flex-end;min-height:190px;margin-bottom:16px;display:flex;position:relative;overflow:hidden}.hero-char{object-fit:contain;filter:drop-shadow(0 10px 18px #0000008c);pointer-events:none;height:92%;position:absolute;bottom:0;right:6px}.hero-body{flex-direction:column;align-items:flex-start;gap:8px;max-width:62%;padding:16px;display:flex;position:relative}.hero-badge{height:64px}.hero-title{text-transform:uppercase;letter-spacing:.5px;text-shadow:0 2px 10px #000c;margin:0;font-size:20px;font-style:italic;font-weight:900}.hero-sub{color:var(--text-dim);text-shadow:0 1px 6px #000c;margin:0;font-size:12.5px}.quest-map{border:1px solid var(--border);background-position:50%;background-size:cover;border-radius:24px;margin-top:4px;position:relative;overflow:hidden}.quest-map:before{content:"";background:linear-gradient(#080b106b,#080b10e6);position:absolute;inset:0}.quest-map .path-svg{z-index:1;width:100%;height:100%;position:absolute;inset:0}.qm-station{z-index:2;filter:drop-shadow(0 12px 16px #0000008f);background:0 0;border:none;place-items:center;width:58px;height:58px;padding:0;display:grid;position:absolute}.qm-station img{object-fit:contain;max-width:57px;max-height:57px;transition:transform 80ms}.qm-station:disabled{cursor:default}.qm-station:not(:disabled):hover img{transform:scale(1.08)}.qm-station.champion{width:88px;height:70px}.qm-station.champion img{max-width:86px;max-height:68px}.qm-label{z-index:3;border:1px solid var(--border);pointer-events:none;background:#070a0fbd;border-radius:10px;width:118px;padding:6px 8px;font-size:10px;font-weight:900;line-height:1.25;position:absolute}.qm-label.right{text-align:right}.qm-label .qm-status{color:var(--text-dim);letter-spacing:.5px;text-transform:uppercase;font-size:9px;font-weight:800}.qm-label.open .qm-status{color:var(--blue)}.qm-label.won .qm-status{color:var(--green)}.node-stars{vertical-align:-3px;gap:2px;display:inline-flex}.node-stars img{width:13px;height:13px}.workout{background:#000;position:fixed;inset:0;overflow:hidden}.camera-view,.camera-mirror{position:absolute;inset:0}.camera-mirror{transform:scaleX(-1)}.camera-mirror video,.camera-mirror canvas{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.camera-overlay-msg{text-align:center;z-index:5;background:#070b15e0;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:24px;display:flex;position:absolute;inset:0}.camera-overlay-msg.error p{color:var(--red);max-width:420px}.spinner{border:4px solid var(--border);border-top-color:var(--blue);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}.battle-loading{min-height:100svh;color:var(--text-dim);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.loading-inline{text-align:center;color:var(--text-dim);flex-direction:column;align-items:center;gap:14px;padding:48px 16px;display:flex}@keyframes spin{to{transform:rotate(360deg)}}.hud{z-index:10;pointer-events:none;flex-direction:column;display:flex;position:absolute;inset:0}.hud button{pointer-events:auto}.hud-top{background:linear-gradient(#000000a6,#0000);align-items:center;gap:12px;padding:14px 16px;display:flex}.hud-exit{border:1px solid var(--border-hi);color:var(--text);background:#070b15b3;border-radius:12px;flex:none;width:40px;height:40px;font-size:16px}.hud-exercise{text-transform:uppercase;letter-spacing:.5px;border:1px solid var(--border);text-overflow:ellipsis;white-space:nowrap;background:#070b15b3;border-radius:999px;padding:7px 15px;font-size:16px;font-style:italic;font-weight:900;overflow:hidden}.hud-reps-pill{border:1px solid var(--blue);color:var(--blue-hi);box-shadow:var(--glow-blue);white-space:nowrap;background:#070b15bf;border-radius:999px;margin-left:auto;padding:8px 18px;font-size:24px;font-weight:900}.hud-reps-pill.urgent{border-color:var(--red);color:var(--red);animation:.6s infinite pulse;box-shadow:0 0 16px #ff5b4d80}.hud-hearts{border:1px solid var(--border);background:#070b15bf;border-radius:999px;gap:4px;margin-left:auto;padding:8px 14px;display:flex}.hud-hearts img{width:24px;height:24px}.hud-center{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:10px;padding:24px;display:flex}.hud-panel{border:1px solid var(--border-hi);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#090d18e0;border-radius:20px;flex-direction:column;align-items:center;gap:14px;max-width:min(600px,92vw);padding:26px 30px;display:flex;box-shadow:0 8px 40px #0000008c}.hud-panel.danger{border-color:var(--red);box-shadow:0 0 50px #ff5b4d40}.hud-msg{text-shadow:0 2px 8px #000000e6;margin:0;font-size:34px;font-weight:900}.hud-submsg{color:var(--text);text-shadow:0 1px 4px #000000e6;max-width:520px;margin:0;font-size:20px}.hud-hint{color:var(--text-dim);font-size:17px}.hold-bar{border:1px solid var(--border-hi);background:#0000008c;border-radius:999px;width:min(360px,78vw);height:16px;overflow:hidden}.hold-bar-fill{background:linear-gradient(180deg, #c9ff75, var(--green) 55%, var(--green-deep));height:100%;transition:width .1s linear;box-shadow:0 0 10px #7be44a99}.countdown{color:var(--blue-hi);text-shadow:0 0 40px #2fa4ff99,0 4px 24px #000000e6;margin:0;font-size:140px;font-style:italic;font-weight:900;animation:.3s pop}.hud-combo-pill{color:var(--gold);white-space:nowrap;background:#070b15bf;border:1px solid #ffb33866;border-radius:999px;padding:8px 14px;font-size:18px;font-style:italic;font-weight:900;animation:.25s pop}.battle-notice{-webkit-backdrop-filter:none;backdrop-filter:none;min-height:44px;margin:6px 14px 0}.battle-notice .notice-main{font-size:16px}.battle-notice .notice-sub{letter-spacing:.2px;text-transform:none;opacity:.85;margin-top:2px;font-size:13.5px;font-weight:600}.rep-readout{z-index:6;pointer-events:none;text-shadow:0 8px 28px #000000e6;align-items:flex-end;gap:10px;display:flex;position:absolute;bottom:132px;left:18px}.rep-number{font-size:clamp(84px,26vw,110px);font-style:italic;font-weight:900;line-height:.78;animation:.2s pop}.rep-label{color:var(--text-dim);letter-spacing:1px;text-transform:uppercase;margin-bottom:8px;font-size:13px;font-weight:900;line-height:1.3}.coach-banner{z-index:5;color:#d8ffd0;text-align:center;pointer-events:none;background:#070a0f9e;border:1px solid #7be44a52;border-radius:16px;padding:10px 12px;font-size:15px;font-weight:800;animation:.25s pop;position:absolute;bottom:252px;left:18px;right:18px}.coach-banner.warn{color:#ffd2cc;background:#1f0806c7;border-color:#ff5b4d80}.charge-notice{z-index:7;margin:0;font-size:16px;animation:.7s infinite pulse;position:absolute;bottom:120px;left:14px;right:14px}.form-panel{z-index:6;border:1px solid var(--border);pointer-events:none;background:#070a0fd1;border-radius:22px;grid-template-columns:38px 1fr 72px;align-items:center;gap:11px;min-height:88px;padding:14px;display:grid;position:absolute;bottom:16px;left:14px;right:14px}.form-panel .row-title{font-size:14px}.form-bar{border:1px solid var(--border);background:#0000008c;border-radius:999px;height:12px;margin-top:8px;overflow:hidden}.form-bar span{border-radius:inherit;background:linear-gradient(180deg, #c9ff75, var(--green));height:100%;transition:width .3s;display:block;box-shadow:0 0 16px #7be44a8c}.form-score{color:var(--green);text-align:right;font-size:34px;font-style:italic;font-weight:900}.pikto{border:1px solid var(--border);color:#fff;background:linear-gradient(#263548,#121a28);border-radius:8px;flex:none;place-items:center;width:36px;height:36px;display:grid;position:relative}.pikto:before{content:"";background:currentColor;width:18px;height:18px;display:block}.pikto.form:before{clip-path:polygon(50% 0,96% 25%,84% 82%,50% 100%,16% 82%,4% 25%)}.pikto.gym:before{clip-path:polygon(0 28%,14% 28%,14% 0,28% 0,28% 28%,72% 28%,72% 0,86% 0,86% 28%,100% 28%,100% 72%,86% 72%,86% 100%,72% 100%,72% 72%,28% 72%,28% 100%,14% 100%,14% 72%,0 72%);width:24px;height:13px}.pikto.stats:before{clip-path:polygon(0 50%,24% 50%,24% 100%,0 100%,0 50%,38% 24%,62% 24%,62% 100%,38% 100%,38% 24%,76% 0,100% 0,100% 100%,76% 100%)}.pikto.medal:before{clip-path:polygon(22% 0,42% 0,50% 22%,58% 0,78% 0,66% 35%,88% 62%,50% 100%,12% 62%,34% 35%)}.cheat-hint{opacity:.6;font-family:ui-monospace,Consolas,monospace;font-size:12px}.hud-debug{color:var(--text-dim);background:#00000080;border-radius:8px;align-self:flex-start;margin:0 12px 12px;padding:4px 10px;font-family:ui-monospace,Consolas,monospace;font-size:12px}@keyframes pop{0%{opacity:.4;transform:scale(1.6)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.victory-overlay{pointer-events:auto;background:#050810c7;justify-content:center;align-items:center;padding:24px;display:flex;position:absolute;inset:0}.victory-card{text-align:center;background:linear-gradient(#ffffff0f,#ffffff05),#0c111b;border:1px solid #2fa4ff99;border-radius:20px;width:100%;max-width:400px;max-height:calc(100svh - 32px);padding:20px 18px 22px;animation:.35s pop;overflow-y:auto;box-shadow:0 0 60px #2fa4ff4d}.victory-card .kicker{text-align:center;margin:6px 0 4px}.victory-notice{margin:0 0 10px}.victory-card.defeat{border-color:#ff5b4d80;box-shadow:0 0 60px #ff5b4d2e}.victory-char{object-fit:contain;filter:drop-shadow(0 8px 14px #0009);height:120px;margin:-10px auto 4px;display:block}.victory-title{text-transform:uppercase;margin:0;font-size:32px;font-style:italic;font-weight:900}.victory-sub{color:var(--text-dim);margin:6px 0 18px}.victory-stars{justify-content:center;gap:6px;margin:8px 0 0;display:flex}.victory-stars img{width:34px;height:34px}.reward-grid{text-align:left;grid-template-columns:1fr 1fr;gap:9px;margin-top:14px;display:grid}.reward-main{grid-column:1/-1;min-height:108px;padding:16px;position:relative;overflow:hidden}.reward-main:after{content:"";filter:blur(10px);background:#2fa4ff21;border-radius:50%;width:140px;height:140px;position:absolute;top:-50px;right:-30px}.reward-main-inner{z-index:1;grid-template-columns:52px 1fr;align-items:center;gap:12px;display:grid;position:relative}.reward-icon{object-fit:contain;filter:drop-shadow(0 0 18px #2fa4ff61);width:52px;height:52px}.reward-number{color:var(--blue);text-shadow:0 0 18px #2fa4ff5c;margin-top:4px;font-size:40px;font-style:italic;font-weight:900;line-height:.95}.mini-reward{flex-direction:column;justify-content:space-between;min-height:92px;padding:13px;display:flex}.mini-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.mini-head img{object-fit:contain;width:28px;height:28px}.mini-number{font-size:28px;font-style:italic;font-weight:900;line-height:.95}.comparison{text-align:left;grid-template-columns:36px 1fr auto;align-items:center;gap:10px;margin-top:9px;padding:12px;display:grid}.row-title{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:800;overflow:hidden}.row-sub{color:var(--text-dimmer);letter-spacing:.6px;text-transform:uppercase;margin-top:2px;font-size:10px;font-weight:800}.row-reward{text-align:right;color:var(--green);font-size:13px;font-style:italic;font-weight:900;line-height:1.25}.victory-actions{grid-template-columns:1fr 1fr;gap:10px;margin-top:16px;display:grid}.victory-actions .full{grid-column:1/-1}.onboarding{flex-direction:column;max-width:480px;min-height:100svh;margin:0 auto;padding:24px 20px 40px;display:flex}.onboarding-progress{justify-content:center;gap:8px;margin-bottom:28px;display:flex}.ob-dot{background:var(--border);border-radius:3px;width:28px;height:5px;transition:background .2s}.ob-dot.active{background:var(--blue);box-shadow:var(--glow-blue)}.onboarding-step{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;display:flex}.ob-logo{height:40px;margin-bottom:4px}.ob-emoji{font-size:52px}.ob-hero-char{object-fit:contain;filter:drop-shadow(0 10px 18px #0000008c);height:180px}.ob-title{text-transform:uppercase;margin:0;font-size:26px;font-style:italic;font-weight:900}.ob-title span{color:var(--blue-hi)}.ob-lead{color:var(--text-dim);max-width:340px;margin:0;font-size:15px;line-height:1.5}.ob-flow{flex-direction:column;gap:12px;width:100%;max-width:340px;margin:8px 0;padding:0;list-style:none;display:flex}.ob-flow li{background:var(--bg-elev);border:1px solid var(--border);text-align:left;border-radius:12px;align-items:center;gap:12px;padding:12px 16px;font-weight:600;display:flex}.ob-flow-icon{font-size:22px}.ob-privacy{color:var(--text-dim);background:var(--bg-elev);border:1px solid var(--border);border-radius:12px;max-width:340px;margin:0;padding:12px 16px;font-size:13px;line-height:1.5}.ob-cam-ok{color:var(--green);margin:0;font-weight:800}.ob-cam-denied{color:var(--text-dim);max-width:320px;margin:0;font-size:14px}.ob-cta,.ob-skip{width:100%;max-width:340px}.ob-cta{margin-top:8px}.ob-setup-list{flex-direction:column;gap:10px;width:100%;max-width:360px;display:flex}.ob-setup{background:var(--bg-elev);border:1px solid var(--border);text-align:left;border-radius:12px;flex-direction:column;gap:4px;padding:12px 16px;display:flex}.ob-setup-ex{font-weight:800}.ob-setup-hint{color:var(--text-dim);font-size:13px;line-height:1.45}.screen-header{align-items:center;gap:12px;margin:14px 0 16px;display:flex}.screen-header .screen-title{margin:0}.screen-header .screen-sub{margin:2px 0 0}.list{flex-direction:column;gap:8px;display:flex}.gym-origin{color:var(--text-dim);margin:0 0 12px;font-size:13px}.gym-distance{color:var(--blue-hi);text-align:center;flex:none;min-width:54px;font-size:13px;font-weight:900}.gym-expand{margin:16px auto 0;display:block}.gym-mock-note{color:var(--text-dim);opacity:.7;margin:10px 0 0;font-size:12px}.rank-num{color:var(--text-dim);text-align:center;flex:none;min-width:34px;font-weight:900}.card.me .rank-num{color:var(--blue-hi)}.lb-myrank{color:var(--text-dim);margin:4px 0 14px;font-size:14px}.lb-myrank strong{color:var(--blue-hi);font-size:18px}.profile-status{color:var(--text-dim);align-items:center;gap:8px;margin:4px 0 18px;font-size:13px;display:inline-flex}.profile-status-dot{background:var(--text-dim);border-radius:50%;width:9px;height:9px}.profile-status.ok .profile-status-dot{background:var(--green);box-shadow:0 0 8px #7be44ab3}.profile-status.sync .profile-status-dot{background:var(--gold)}.profile-status.off .profile-status-dot{background:var(--red)}.profile-card{flex-direction:column;gap:12px;margin-bottom:14px;padding:16px;display:flex}.profile-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;font-size:11px;font-weight:800}.profile-name-row{gap:8px;display:flex}.profile-input{border:1px solid var(--border);width:100%;color:var(--text);background:#060a13;border-radius:10px;padding:11px 13px;font-size:15px}.profile-input:focus{border-color:var(--blue);outline:none;box-shadow:0 0 0 3px #2fa4ff33}.profile-name-row .profile-input{flex:1}.profile-secured{font-size:14px;line-height:1.5}.profile-tabs{gap:8px;display:flex}.profile-tab{border:1px solid var(--border);color:var(--text-dim);background:0 0;border-radius:10px;flex:1;padding:9px;font-size:14px;font-weight:800}.profile-tab.active{border-color:var(--blue);color:var(--text);background:#2fa4ff1f}.profile-hint{color:var(--text-dim);margin:0;font-size:13px;line-height:1.45}.profile-error{color:var(--red);margin:0;font-size:13px}.badge-hero{grid-template-columns:88px 1fr;align-items:center;gap:14px;min-height:124px;margin-top:4px;padding:14px;display:grid}.badge-hero img{object-fit:contain;filter:drop-shadow(0 0 22px #2fa4ff61);width:82px;height:82px}.badge-hero img.badge-hero-locked{filter:saturate(.2)brightness(.6)}.badge-hero-name{text-transform:uppercase;margin:2px 0 4px;font-size:26px;font-style:italic;font-weight:900;line-height:.95}.badge-grid{grid-template-columns:repeat(3,1fr);gap:9px;display:grid}.badge-tile{border:1px solid var(--border);text-align:center;background:#ffffff0b;border-radius:14px;align-content:center;justify-items:center;gap:7px;min-height:98px;padding:10px 6px;display:grid}.badge-tile img{object-fit:contain;width:42px;height:42px}.badge-name{color:var(--text-dim);letter-spacing:.5px;text-transform:uppercase;font-size:9px;font-weight:900}.badge-tile.locked{opacity:.45;filter:saturate(.4)}.badge-task-icon{object-fit:contain;width:36px;height:36px}.progress{border:1px solid var(--border);background:#00000059;height:10px;margin-top:8px;overflow:hidden}.progress span{background:linear-gradient(90deg, var(--blue), #8bd8ff);height:100%;transition:width .3s;display:block;box-shadow:0 0 14px #2fa4ff6b}.unlock-row{text-align:left;margin-top:9px;padding:10px 12px}.unlock-badges{flex-wrap:wrap;gap:8px;margin-top:7px;display:flex}.unlock-badge{background:#7be44a14;border:1px solid #7be44a61;border-radius:999px;align-items:center;gap:6px;padding:4px 10px 4px 5px;font-size:12px;font-weight:900;display:inline-flex}.unlock-badge img{object-fit:contain;width:22px;height:22px}.stats-empty{text-align:center;flex-direction:column;align-items:center;gap:10px;padding:40px 16px;display:flex}.stats-empty-emoji{font-size:44px}.stats-best-val{color:var(--text-dim);font-size:13px}.stats-best-val strong{color:var(--text);font-size:17px}.stats-best-val.muted{opacity:.6}.stats-row-emoji{flex:none;font-size:22px}
