:root{color-scheme:dark;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;--bg: #0a0e22;--bg-glow: #1b1746;--surface: #141a37;--surface-2: #1b2245;--surface-line: rgba(255, 255, 255, .07);--text: #f2f4ff;--muted: #97a0c8;--faint: #6b76a0;--brand-a: #8b5cf6;--brand-b: #d946ef;--brand-c: #6366f1;--accent-0: #7c6cff;--accent-1: #f59e0b;--accent-2: #14b8a6;--accent-3: #ec4899;--danger: #ff6b6b;--ok: #34d399;--radius: 18px;--maxw: 480px}*{box-sizing:border-box}body{margin:0;color:var(--text);background:radial-gradient(120% 70% at 80% -10%,var(--bg-glow) 0%,transparent 55%),radial-gradient(90% 60% at 0% 0%,#241a52 0%,transparent 45%),var(--bg);background-attachment:fixed;-webkit-font-smoothing:antialiased}.app{min-height:100vh;max-width:var(--maxw);margin:0 auto;padding:14px 13px calc(96px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:16px}.app.center{align-items:center;justify-content:center;text-align:center;min-height:100vh}.hero{display:flex;flex-direction:column;gap:14px}.hero-tagline{margin:2px 0 0;font-size:15px;font-weight:600;letter-spacing:.1px;color:var(--muted)}.hero-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.date-pill{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:14px;background:var(--surface);border:1px solid var(--surface-line);color:var(--text);font-size:14px;font-weight:600;cursor:default}.date-pill .chev{color:var(--faint);font-size:11px}.streak{display:inline-flex;align-items:center;gap:10px;padding:9px 14px;border-radius:14px;background:linear-gradient(135deg,rgba(139,92,246,.22),rgba(217,70,239,.16));border:1px solid rgba(217,70,239,.3)}.streak .heart{font-size:20px;line-height:1}.streak-text{display:flex;flex-direction:column;line-height:1.15}.streak-label{font-size:11px;color:var(--muted)}.streak-value{font-size:15px;font-weight:700}.gear-btn{flex:0 0 auto;width:40px;height:40px;display:grid;place-items:center;border:1px solid var(--surface-line);border-radius:12px;background:var(--surface);color:var(--muted);font-size:18px;cursor:pointer}.cards{display:flex;flex-direction:column;gap:12px}.card{position:relative;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:11px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--surface-line);overflow:hidden}.card:before{content:"";position:absolute;inset:0 auto 0 0;width:4px;background:var(--accent);opacity:.85}.card-thumb{position:relative;width:58px;height:58px;border-radius:14px;display:grid;place-items:center;background:radial-gradient(circle at 30% 25%,color-mix(in srgb,var(--accent) 55%,transparent),transparent 70%),var(--surface-2);overflow:hidden;flex:0 0 auto}.card-thumb img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.card-thumb-emoji{font-size:28px;line-height:1}.card-body{min-width:0;display:flex;flex-direction:column;gap:3px}.ex-name{font-size:16px;font-weight:700;line-height:1.15;overflow-wrap:anywhere}.card-target{font-size:12px;color:var(--muted)}.stepper{display:flex;align-items:center;gap:5px;flex:0 0 auto}.step{width:38px;height:38px;border:none;border-radius:11px;font-size:22px;font-weight:600;line-height:1;background:var(--surface-2);color:var(--text);cursor:pointer;transition:transform .05s ease,filter .15s ease}.step.plus{background:color-mix(in srgb,var(--accent) 30%,var(--surface-2));color:#fff;box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 50%,transparent) inset}.step:active{transform:scale(.92)}.step:disabled{opacity:.5}.value{font-size:23px;font-weight:800;min-width:32px;text-align:center;font-variant-numeric:tabular-nums}.value .unit{font-size:13px;font-weight:600;color:var(--muted);margin-left:1px}.link{align-self:center;background:none;border:none;color:var(--muted);font-size:14px;font-weight:600;cursor:pointer;padding:4px 8px}.save-wrap{position:relative;margin-top:2px}.primary{width:100%;padding:17px;border:none;border-radius:18px;font-size:18px;font-weight:800;letter-spacing:.2px;color:#fff;background:linear-gradient(135deg,var(--brand-a),var(--brand-b));box-shadow:0 10px 30px -8px rgba(139,92,246,.7);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px}.primary:active{filter:brightness(.95)}.primary:disabled{opacity:.6;box-shadow:none}.primary .check{width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.25);display:grid;place-items:center;font-size:15px}.privacy{margin:10px 0 0;text-align:center;font-size:12px;color:var(--faint)}.secondary-row{display:flex;gap:10px}.secondary{flex:1 1 0;padding:12px;border:1px solid var(--surface-line);border-radius:14px;font-size:14px;font-weight:600;background:var(--surface);color:var(--muted);cursor:pointer;white-space:nowrap}.secondary:active{filter:brightness(1.1)}.secondary:disabled{opacity:.5}.flash-area{display:flex;flex-direction:column;gap:4px;padding:12px 14px;border-radius:14px;background:var(--surface);border:1px solid var(--surface-line);text-align:center}.flash{margin:0;font-size:15px;font-weight:700;color:var(--text)}.flash-stat{margin:0;font-size:13px;color:var(--muted)}.flash-pr{margin:0;font-size:13px;font-weight:600;color:var(--accent-1)}.flash-opponent{margin:0;font-size:12px;color:var(--faint)}.error{color:var(--danger);font-size:13px;margin:0;white-space:pre-wrap;word-break:break-word}.hint{color:var(--muted);font-size:14px;margin:0}h1{font-size:24px;margin:0}.placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px;min-height:50vh;color:var(--muted)}.placeholder .ph-emoji{font-size:44px}.placeholder h2{margin:0;font-size:20px;color:var(--text)}.placeholder p{margin:0;font-size:14px;max-width:260px}.dash{display:flex;flex-direction:column;gap:14px}.dash-hero{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px;border-radius:var(--radius);background:linear-gradient(135deg,rgba(139,92,246,.18),rgba(99,102,241,.12));border:1px solid var(--surface-line)}.dash-hero-main{display:flex;flex-direction:column;gap:2px}.dash-level{font-size:20px;font-weight:800}.dash-pts{font-size:13px;color:var(--muted)}.section{padding:14px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--surface-line);display:flex;flex-direction:column;gap:10px}.section h3{margin:0;font-size:15px;font-weight:700}.section-cap{margin:0;font-size:12px;color:var(--muted)}.empty{margin:0;font-size:13px;color:var(--muted)}.chart{width:100%;height:auto;display:block}.legend{display:flex;flex-wrap:wrap;gap:8px 14px}.legend-item{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--muted)}.legend-dot{width:9px;height:9px;border-radius:50%;display:inline-block}.target-list,.target-row{display:flex;flex-direction:column;gap:8px}.target-row{flex-direction:row;align-items:center;justify-content:space-between;font-size:14px}.pr-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.pr-card{display:flex;flex-direction:column;gap:2px;padding:10px 12px;border-radius:12px;background:var(--surface-2)}.pr-emoji{font-size:20px}.pr-name{font-size:12px;color:var(--muted)}.pr-val{font-size:20px;font-weight:800}.pr-unit{font-size:12px;font-weight:600;color:var(--muted)}.home-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px}.home-stat{display:flex;flex-direction:column;gap:2px;padding:12px;border-radius:12px;background:var(--surface-2)}.home-stat-num{font-size:20px;font-weight:800}.home-stat-lbl{font-size:12px;color:var(--muted)}.level-bar{height:12px;border-radius:6px;background:var(--surface-2);overflow:hidden}.level-fill{height:100%;border-radius:6px;background:linear-gradient(90deg,var(--brand-a),var(--brand-b));transition:width .3s ease}.status-row,.rank-row{display:flex;align-items:center;gap:10px;font-size:14px}.status-name,.rank-name{flex:1;min-width:0;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-streak{font-size:13px;color:var(--muted)}.chip{font-size:12px;font-weight:600;padding:4px 10px;border-radius:999px;white-space:nowrap}.chip-ok{background:rgba(52,211,153,.16);color:var(--ok)}.chip-rest{background:rgba(151,160,200,.16);color:var(--muted)}.chip-wait{background:rgba(245,158,11,.16);color:var(--accent-1)}.rank-pos{width:22px;text-align:center}.rank-lvl{font-size:12px;color:var(--muted)}.rank-pts{font-size:13px;font-weight:700}.seg{display:flex;gap:4px;padding:4px;background:var(--surface-2);border-radius:12px}.seg-btn{flex:1;padding:8px;border:none;border-radius:9px;background:transparent;color:var(--muted);font-size:13px;font-weight:600;cursor:pointer}.seg-btn.active{background:var(--brand-a);color:#fff}.bar-row{display:flex;align-items:center;gap:10px;font-size:13px}.bar-name{width:96px;flex:0 0 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bar-track{flex:1;height:12px;border-radius:6px;background:var(--surface-2);overflow:hidden}.bar-fill{height:100%;border-radius:6px;min-width:2px;transition:width .25s ease}.bar-val{width:40px;flex:0 0 auto;text-align:right;font-weight:700;font-variant-numeric:tabular-nums}.nav{position:fixed;left:50%;bottom:0;transform:translate(-50%);width:100%;max-width:var(--maxw);display:flex;align-items:flex-end;justify-content:space-around;padding:8px 12px calc(8px + env(safe-area-inset-bottom));background:color-mix(in srgb,var(--surface) 92%,transparent);backdrop-filter:blur(12px);border-top:1px solid var(--surface-line);z-index:50}.nav-item{flex:1 1 0;display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:none;padding:6px 0;color:var(--faint);font-size:11px;font-weight:600;cursor:pointer}.nav-item.active{color:var(--text)}.nav-item svg{width:22px;height:22px}.nav-fab-wrap{flex:1 1 0;display:flex;flex-direction:column;align-items:center;gap:3px}.nav-fab{width:54px;height:54px;margin-top:-22px;border:none;border-radius:50%;background:linear-gradient(135deg,var(--brand-a),var(--brand-c));color:#fff;font-size:30px;font-weight:400;line-height:1;display:grid;place-items:center;box-shadow:0 8px 22px -6px rgba(99,102,241,.9);cursor:pointer}.nav-fab.active{outline:3px solid color-mix(in srgb,var(--brand-a) 40%,transparent)}.nav-fab-label{font-size:11px;font-weight:700;color:var(--text)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(4,6,18,.7);display:flex;align-items:flex-end;z-index:100;backdrop-filter:blur(2px)}.overlay-inner{background:var(--bg);border:1px solid var(--surface-line);border-radius:22px 22px 0 0;padding:20px 16px calc(28px + env(safe-area-inset-bottom));width:100%;max-width:var(--maxw);margin:0 auto;max-height:82vh;overflow-y:auto;display:flex;flex-direction:column;gap:14px}.overlay-header{display:flex;align-items:center;justify-content:space-between}.overlay-header h2{margin:0;font-size:18px}.close-btn{background:none;border:none;font-size:22px;cursor:pointer;padding:4px;color:var(--muted);line-height:1}.settings-list{display:flex;flex-direction:column;gap:10px}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 12px;border-radius:12px;background:var(--surface);border:1px solid var(--surface-line)}.settings-name{font-size:15px;flex:1;min-width:0}.stepper.small{gap:6px}.stepper.small .step{width:38px;height:38px;font-size:20px;border-radius:10px}.stepper.small .value{font-size:19px;min-width:40px}
