:root{--bg:#0a0612;--fg:#f3f4f6;--muted:#9ca3af;--border:#ffffff1a;--accent:#ef4444;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:var(--fg);background:var(--bg);font-synthesis:none;-webkit-font-smoothing:antialiased;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{background:var(--bg);overscroll-behavior:none;-webkit-user-select:none;user-select:none}.app{width:100%;height:100%;position:relative}button{font:inherit;cursor:pointer}button.primary{background:var(--accent);color:#fff;border:none;border-radius:12px;padding:18px 44px;font-size:22px;font-weight:600;box-shadow:0 6px 24px #ef444473}button.primary:active{transform:translateY(1px)}button.secondary{color:var(--fg);border:1px solid var(--border);background:0 0;border-radius:10px;padding:12px 24px;font-size:16px}.idle{padding:32px 24px max(32px, calc(env(safe-area-inset-bottom,0px) + 24px));text-align:center;-webkit-overflow-scrolling:touch;flex-direction:column;justify-content:flex-start;align-items:center;gap:22px;min-height:100%;display:flex;overflow-y:auto}.idle h1{letter-spacing:-2px;background:linear-gradient(#fff,#fca5a5);color:#0000;-webkit-background-clip:text;background-clip:text;margin:0;font-size:64px;font-weight:700}.idle p{color:var(--muted);max-width:440px;margin:0;line-height:1.5}.idle ul{color:var(--muted);text-align:left;max-width:320px;margin:0;padding-left:22px;line-height:1.8}.exercise-picker{grid-template-columns:1fr 1fr;gap:12px;width:100%;max-width:380px;margin:4px auto 0;display:grid}.exercise-card{border:1px solid var(--border);color:var(--fg);font:inherit;cursor:pointer;background:#ffffff0a;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:18px 10px 14px;transition:transform .12s,background .18s,border-color .18s;display:flex}.exercise-card:hover{background:#ffffff0f;border-color:#ef444466}.exercise-card:active{transform:scale(.97)}.exercise-emoji{font-size:32px;line-height:1}.exercise-label{letter-spacing:.2px;font-size:16px;font-weight:600}.exercise-goal{color:var(--muted);text-transform:uppercase;letter-spacing:.6px;font-size:11px}.idle-secondary{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.active{background:#000;height:100%;position:relative;overflow:hidden}.fireball-pad{left:50%;bottom:calc(96px + env(safe-area-inset-bottom,0px));pointer-events:none;z-index:4;width:280px;height:360px;position:absolute;transform:translate(-50%)}.fireball-canvas{width:100%;height:100%;display:block}.ripple-origin{left:50%;bottom:calc(96px + env(safe-area-inset-bottom,0px) + 80px);pointer-events:none;z-index:5;width:0;height:0;position:absolute}.ripple{opacity:0;will-change:transform, opacity, border-width;border:3px solid #ffc864b3;border-radius:50%;width:60px;height:60px;margin:-30px 0 0 -30px;animation:1.4s cubic-bezier(0,0,.2,1) forwards rippleExpand;position:absolute;top:0;left:0;transform:scale(.4)}.ripple-1{border-color:#ffdc82d9;animation-delay:0s}.ripple-2{border-color:#ff823299;animation-delay:.13s}.ripple-3{border-color:#dc262673;animation-delay:.26s}@keyframes rippleExpand{0%{opacity:0;border-width:4px;transform:scale(.4)}10%{opacity:1}to{opacity:0;border-width:.5px;transform:scale(28)}}@media (prefers-reduced-motion:reduce){.ripple{opacity:0;animation:none}}.camera{position:absolute;inset:0}.camera video,.camera canvas{object-fit:cover;width:100%;height:100%;position:absolute;inset:0;transform:scaleX(-1)}.camera canvas{pointer-events:none}.camera-status{color:var(--fg);text-align:center;background:#0009;justify-content:center;align-items:center;padding:24px;font-size:16px;display:flex;position:absolute;inset:0}.camera-status.error{color:#ff8b8b}.status-pill{top:max(16px, env(safe-area-inset-top,16px));-webkit-backdrop-filter:blur(10px);border:1px solid var(--border);letter-spacing:.5px;text-transform:uppercase;background:#0a0612a6;border-radius:999px;align-items:center;gap:8px;padding:8px 14px;font-size:13px;display:flex;position:absolute;left:50%;transform:translate(-50%)}.dot{background:var(--accent);border-radius:50%;width:8px;height:8px}.status-pill.state-searching .dot{background:#f59e0b}.status-pill.state-calibrating .dot{background:#3b82f6}.status-pill.state-tracking .dot{background:#10b981}.dot.live{animation:1.4s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:.35}50%{opacity:1}}button.stop{left:50%;bottom:calc(20px + env(safe-area-inset-bottom,0px));color:#0a0612;letter-spacing:.5px;background:#fff;border:none;border-radius:999px;padding:16px 60px;font-size:22px;font-weight:700;position:absolute;transform:translate(-50%);box-shadow:0 6px 20px #0006}button.stop:active{transform:translate(-50%)translateY(1px)}.calibrate-card{left:16px;right:16px;bottom:calc(20px + env(safe-area-inset-bottom,0px));-webkit-backdrop-filter:blur(14px);border:1px solid var(--border);text-align:center;background:#0a0612c7;border-radius:16px;flex-direction:column;align-items:stretch;gap:10px;padding:18px 20px 16px;display:flex;position:absolute}.calibrate-card h2{letter-spacing:.3px;margin:0;font-size:18px;font-weight:600}.calibrate-card p{color:var(--muted);margin:0;font-size:14px;line-height:1.4}.calibrate-card .error{color:#ff8b8b}.cal-progress{justify-content:center;gap:12px;margin:10px 0 4px;display:flex}.cal-dot{border:1px solid var(--border);background:#ffffff14;border-radius:50%;width:16px;height:16px;transition:background .2s,transform .25s,box-shadow .25s}.cal-dot.filled{background:var(--accent);border-color:var(--accent);transform:scale(1.15);box-shadow:0 0 14px #ef444499}.cal-dot.done{background:#10b981;border-color:#10b981;box-shadow:0 0 14px #10b9818c}.cal-counter{color:var(--fg);font-variant-numeric:tabular-nums;letter-spacing:-.5px;margin-top:4px;font-size:32px;font-weight:700;line-height:1}.calibrate-secondary{justify-content:space-between;margin-top:2px;display:flex}button.link{color:var(--muted);font:inherit;text-underline-offset:3px;cursor:pointer;background:0 0;border:none;padding:4px 6px;font-size:13px;text-decoration:underline}button.link:hover{color:var(--fg)}.done{flex-direction:column;align-items:center;gap:14px;min-height:100%;padding:40px 20px;display:flex;overflow-y:auto}.done-exercise{letter-spacing:.6px;text-transform:uppercase;color:var(--muted);margin-bottom:6px;font-size:16px}.total{letter-spacing:-4px;background:linear-gradient(#fff,#fca5a5);color:#0000;-webkit-background-clip:text;background-clip:text;font-size:120px;font-weight:800;line-height:1}.total-label{color:var(--muted);letter-spacing:1px;text-transform:uppercase;font-size:16px}.stats{color:var(--muted);gap:28px;margin-top:8px;font-size:15px;display:flex}.stats strong{color:var(--fg);font-size:18px}.summary-graph{aspect-ratio:16/9;border:1px solid var(--border);background:#ffffff08;border-radius:14px;width:100%;max-width:540px;margin-top:12px;overflow:hidden}.summary-graph canvas{width:100%;height:100%;display:block}.done .primary{margin-top:18px}.celebration{z-index:50;text-align:center;background:#000000eb;flex-direction:column;justify-content:center;align-items:center;gap:22px;padding:24px;animation:.4s fadeIn;display:flex;position:fixed;inset:0}.celebration h1{letter-spacing:-1.5px;background:linear-gradient(#fff,#fca5a5);color:#0000;-webkit-background-clip:text;background-clip:text;margin:0;font-size:56px}.celebration p{color:var(--muted);margin:0;font-size:18px}.celebration img{border-radius:12px;max-width:90vw;max-height:60vh;box-shadow:0 12px 40px #ef444459}.dwight-fallback{border:1px dashed var(--border);color:var(--muted);border-radius:12px;padding:28px}.dwight-fallback code{background:#ffffff14;border-radius:4px;padding:2px 6px;font-family:ui-monospace,Menlo,monospace;font-size:14px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.profile-chip{top:max(16px, env(safe-area-inset-top,16px));border:1px solid var(--border);color:var(--fg);background:#ffffff0f;border-radius:999px;align-items:center;gap:8px;padding:8px 14px;font-size:14px;display:inline-flex;position:absolute;right:16px}.profile-chip .edit{opacity:.5;font-size:12px}.name-picker{text-align:center;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:340px;display:flex}.name-picker h2{margin:0;font-size:28px;font-weight:600}.name-picker p{color:var(--muted);margin:0}.name-picker form{flex-direction:column;gap:12px;width:100%;display:flex}.name-picker input{font:inherit;border:1px solid var(--border);color:var(--fg);text-align:center;background:#ffffff0f;border-radius:10px;outline:none;padding:14px 16px;font-size:18px}.name-picker input:focus{border-color:var(--accent)}.name-picker .row{justify-content:center;gap:10px;display:flex}.name-picker .error{color:#ff8b8b;font-size:14px}.modal-backdrop{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:60;background:#000000b3;justify-content:center;align-items:center;padding:24px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg);border:1px solid var(--border);border-radius:16px;width:100%;max-width:380px;padding:28px;box-shadow:0 20px 60px #00000080}.heatmap-modal{max-width:460px;max-height:85vh;overflow-y:auto}.heatmap-head{justify-content:space-between;align-items:baseline;margin-bottom:12px;display:flex}.heatmap-head h2{margin:0;font-size:22px;font-weight:600}.bodymap{flex-direction:column;align-items:center;gap:10px;display:flex}.bodymap svg{width:100%;max-width:280px;height:auto;display:block}.bodymap-legend{color:var(--muted);align-items:center;gap:6px;margin-top:4px;font-size:12px;display:flex}.bodymap-legend .swatch{border:1px solid #ffffff26;border-radius:3px;width:14px;height:14px}.bodymap-legend .legend-label{letter-spacing:.4px;text-transform:uppercase;margin-left:6px}.bodymap-list{flex-direction:column;gap:4px;width:100%;margin:12px 0 0;padding:0;list-style:none;display:flex}.bodymap-list li{grid-template-columns:14px 1fr auto;align-items:center;gap:10px;padding:6px 4px;font-size:14px;display:grid}.bodymap-list .dot{border-radius:50%;width:12px;height:12px}.bodymap-list .label{color:var(--fg)}.bodymap-list .value{color:var(--muted);font-variant-numeric:tabular-nums}.heatmap-breakdown{border-top:1px solid var(--border);flex-direction:column;gap:6px;margin-top:14px;padding-top:14px;display:flex}.heatmap-bd-row{grid-template-columns:24px 1fr auto;align-items:center;gap:10px;font-size:14px;display:grid}.heatmap-bd-row .emoji{font-size:18px}.heatmap-bd-row .label{color:var(--fg)}.heatmap-bd-row .value{color:var(--accent);font-variant-numeric:tabular-nums;font-weight:700}.leaderboard{border:1px solid var(--border);text-align:left;background:#ffffff0a;border-radius:14px;width:100%;max-width:420px;margin-top:16px;padding:18px 20px}.leaderboard.empty{text-align:center}.leaderboard.empty p{color:var(--muted);margin:8px 0 0;font-size:13px}.leaderboard.empty code{background:#ffffff14;border-radius:4px;padding:1px 5px;font-family:ui-monospace,Menlo,monospace;font-size:12px}.leaderboard-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;display:flex}.leaderboard-tabs{border:1px solid var(--border);background:#ffffff0d;border-radius:999px;gap:2px;padding:3px;display:inline-flex}.leaderboard-tabs .tab{color:var(--muted);font:inherit;letter-spacing:.4px;text-transform:uppercase;cursor:pointer;background:0 0;border:none;border-radius:999px;padding:6px 10px;font-size:11px;font-weight:600;transition:background .18s,color .18s}.leaderboard-tabs .tab.active{background:var(--accent);color:#fff}@media (width<=380px){.leaderboard-head{flex-direction:column;align-items:stretch;gap:8px}.leaderboard-tabs{justify-content:space-between}.leaderboard-tabs .tab{text-align:center;flex:1;padding:6px}}.leaderboard h3{letter-spacing:.5px;text-transform:uppercase;margin:0;font-size:16px;font-weight:600}.leaderboard .muted{color:var(--muted);font-size:12px}.leaderboard .small{font-size:14px}.leaderboard-list{-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#ffffff26 transparent;flex-direction:column;gap:4px;max-height:320px;margin:0;padding:0;list-style:none;display:flex;overflow-y:auto}.leaderboard-list::-webkit-scrollbar{width:6px}.leaderboard-list::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.leaderboard-list::-webkit-scrollbar-track{background:0 0}.leaderboard-row{border-radius:8px;grid-template-columns:24px minmax(0,1fr) minmax(56px,auto);align-items:center;gap:10px;padding:10px 6px;display:grid}.leaderboard-row .name-col{flex-direction:column;gap:4px;min-width:0;display:flex}.balance-bar{background:#ffffff0d;border-radius:3px;width:100%;height:6px;display:flex;overflow:hidden}.balance-bar .seg{height:100%;transition:width .25s}.balance-bar .seg.upper{background:#ef4444}.balance-bar .seg.core{background:#f97316}.balance-bar .seg.lower{background:#eab308}.balance-bar.empty{background:#ffffff0a}.balance-numbers{color:var(--muted);letter-spacing:.3px;font-variant-numeric:tabular-nums;font-size:11px}.balance-legend{color:var(--muted);letter-spacing:.4px;text-transform:uppercase;gap:12px;margin-bottom:10px;font-size:11px;display:flex}.balance-key{align-items:center;gap:5px;display:inline-flex}.balance-key .seg{border-radius:2px;width:10px;height:10px}.balance-key .seg.upper{background:#ef4444}.balance-key .seg.core{background:#f97316}.balance-key .seg.lower{background:#eab308}.leaderboard-row.header{border-bottom:1px solid var(--border);border-radius:0;margin-bottom:4px;padding:4px 6px 6px}.leaderboard-row.header .metric{letter-spacing:.5px;text-transform:uppercase;color:var(--muted);font-size:11px;font-weight:600}.leaderboard-row.header .metric.active{color:var(--accent)}.leaderboard-row.me{background:#ef44441f;border:1px solid #ef44444d}.leaderboard-row .rank{color:var(--muted);text-align:right;font-size:14px}.leaderboard-row .name{color:var(--fg);white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.leaderboard-row .badge{margin-left:4px}.leaderboard-row .metric{color:var(--muted);font-variant-numeric:tabular-nums;text-align:right;font-size:14px;font-weight:600;transition:color .18s}.leaderboard-row .metric.active{color:var(--fg);font-size:16px;font-weight:700}.saved-pill{letter-spacing:.3px;border-radius:999px;margin-top:-4px;padding:6px 12px;font-size:14px}.saved-pill--saving{color:var(--muted);border:1px solid var(--border);background:#ffffff0d}.saved-pill--saved{color:#10b981;background:#10b9811a;border:1px solid #10b9814d}.saved-pill--error{color:#ff8b8b;background:#ef44441a;border:1px solid #ef44444d}.saved-pill--error .link{color:var(--accent);-webkit-text-decoration-color:var(--accent);text-decoration-color:var(--accent)}button.stop:disabled{opacity:.55;cursor:default}
