:root{--bg: #0b1120;--card: #111a2e;--card-2: #1a2540;--text: #f1f5f9;--muted: #94a3b8;--green: #16a34a;--green-2: #22c55e;--red: #ef4444;--border: #243049}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}input,button{font-family:inherit}.center{min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px}.muted{color:var(--muted)}.error{color:var(--red);margin-top:12px;font-size:14px}.card{width:100%;max-width:420px;background:var(--card);border:1px solid var(--border);border-radius:20px;padding:28px 24px}.card h1{margin:0 0 16px;font-size:24px}.login{text-align:center}.logo{font-size:56px;margin-bottom:8px}input[type=email],input[type=text],input[type=number]{width:100%;padding:16px;font-size:18px;background:var(--card-2);border:1px solid var(--border);border-radius:12px;color:var(--text);margin-top:8px}.field-label{display:block;margin-top:20px;font-size:14px;color:var(--muted)}.amount-input{display:flex;align-items:center;gap:8px;font-size:28px;margin-top:8px;background:var(--card-2);border:1px solid var(--border);border-radius:12px;padding:0 16px}.amount-input span{color:var(--muted)}.amount-input input{background:transparent;border:none;margin:0;padding:16px 0;font-size:28px}.amount-input input:focus{outline:none}.segment{display:flex;gap:8px;margin-top:8px}.segment button{flex:1;padding:14px;font-size:16px;background:var(--card-2);border:1px solid var(--border);border-radius:12px;color:var(--text)}.segment button.active{background:var(--green);border-color:var(--green);font-weight:600}button.primary{width:100%;margin-top:24px;padding:16px;font-size:18px;font-weight:600;background:var(--green);color:#fff;border:none;border-radius:12px;cursor:pointer}button.primary:disabled{opacity:.6}button.ghost{width:100%;margin-top:10px;padding:14px;font-size:16px;background:transparent;color:var(--muted);border:1px solid var(--border);border-radius:12px}button.link{background:none;border:none;color:var(--green-2);font-size:15px;cursor:pointer}button.danger{width:100%;margin-top:10px;padding:14px;font-size:16px;background:transparent;color:#fca5a5;border:1px solid #7f1d1d;border-radius:12px}.home{max-width:480px;margin:0 auto;padding:16px}.topbar{display:flex;justify-content:space-between;align-items:center;padding:8px 4px 16px}.brand{font-weight:600;font-size:18px}.topbar-actions{display:flex;gap:16px;align-items:center}.balance{background:linear-gradient(160deg,#14532d,#166534);border-radius:24px;padding:32px 24px;text-align:center}.balance.over{background:linear-gradient(160deg,#7f1d1d,#991b1b)}.balance-label{font-size:15px;opacity:.85}.balance-amount{font-size:56px;font-weight:700;margin:6px 0;letter-spacing:-1px}.balance-sub{font-size:14px;opacity:.85}.balance-sub .edit{margin-left:8px;color:#fff;text-decoration:underline}.big-add{font-size:20px;padding:20px;margin-top:20px}.cat-card{position:relative;background:linear-gradient(160deg,#14532d,#166534);border-radius:20px;padding:20px 22px;margin-top:14px}.cat-owner{position:absolute;right:20px;bottom:16px;font-size:12px;font-weight:600;opacity:.85}.cat-card.over{background:linear-gradient(160deg,#7f1d1d,#991b1b)}.cat-head{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.cat-name{font-size:18px;font-weight:600}.cat-tag{font-size:12px;opacity:.8;text-transform:capitalize}.cat-amount{font-size:40px;font-weight:700;letter-spacing:-1px;margin:4px 0 2px}.cat-sub{font-size:13px;opacity:.85}.alloc-list{list-style:none;margin:10px 0 0;padding:0}.alloc-list li{display:flex;justify-content:space-between;padding:6px 0;font-size:16px;border-top:1px solid rgba(255,255,255,.12)}.alloc-list li:first-child{border-top:none}.alloc-list small{opacity:.7;font-size:12px}.alloc-list .neg{color:#fecaca}.chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.chip{padding:8px 14px;border-radius:999px;background:var(--card-2);border:1px solid var(--border);color:var(--text);font-size:14px}.chip.active{background:var(--green);border-color:var(--green);font-weight:600}.chart{display:flex;align-items:flex-end;gap:8px;height:150px}.chart-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%}.chart .bar{width:100%;max-width:40px;min-height:2px;background:linear-gradient(180deg,#22c55e,#16a34a);border-radius:6px 6px 0 0}.chart .bar-amount{font-size:11px;color:var(--muted);margin-bottom:4px;min-height:14px}.chart .bar-label{font-size:11px;color:var(--muted);margin-top:6px}.leaderboard{list-style:none;margin:0;padding:0}.leaderboard li{display:flex;align-items:center;gap:12px;padding:16px 14px;border-bottom:1px solid var(--border)}.leaderboard li.me{background:var(--card-2);border-radius:12px}.leaderboard .rank{font-size:22px;min-width:34px;text-align:center}.leaderboard .lb-name{flex:1;font-size:16px}.leaderboard .lb-saved{font-size:18px;font-weight:700;color:var(--green-2)}.leaderboard .lb-saved.neg{color:#fca5a5}.select{width:100%;padding:14px 16px;font-size:16px;background:var(--card-2);border:1px solid var(--border);border-radius:12px;color:var(--text);margin-top:8px}.checkbox-row{display:flex;align-items:center;gap:10px;margin-top:18px;font-size:15px}.checkbox-row input{width:20px;height:20px;accent-color:var(--green)}.alloc-row{display:flex;align-items:center;gap:12px;margin-top:8px}.alloc-name{min-width:90px;font-size:15px}.list{margin-top:28px}.list h2{font-size:16px;color:var(--muted);font-weight:600;margin:0 0 8px}.list ul{list-style:none;margin:0;padding:0}.list li{display:flex;align-items:center;gap:8px;padding:14px 4px;border-bottom:1px solid var(--border)}.t-main{flex:1;display:flex;flex-direction:column}.t-note{font-size:16px}.t-date{font-size:13px;color:var(--muted)}.t-amount{font-size:16px;font-weight:600;color:#fca5a5}.del{background:none;border:none;color:var(--muted);font-size:16px;padding:8px;cursor:pointer}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:flex-end;z-index:50;touch-action:none;overscroll-behavior:contain}.sheet{width:100%;max-width:480px;margin:0 auto;background:var(--card);border-radius:24px 24px 0 0;padding:12px 20px calc(20px + env(safe-area-inset-bottom));animation:slideUp .2s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet-handle{width:40px;height:4px;background:var(--border);border-radius:2px;margin:0 auto 16px}.entry-amount{text-align:center;font-size:48px;font-weight:700;margin-bottom:12px}.entry-amount span{color:var(--muted);margin-right:4px}.note-input{margin-bottom:12px}.keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.key{padding:18px;font-size:24px;font-weight:600;background:var(--card-2);border:1px solid var(--border);border-radius:14px;color:var(--text);cursor:pointer}.key:active{background:var(--green)}.key-del{color:var(--muted)}.sheet-actions{display:flex;gap:12px;margin-top:16px}.sheet-actions .ghost,.sheet-actions .primary{margin-top:0}.home{padding-bottom:120px}.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(145deg,var(--card-2),#243049);border:1px solid #2c3a57;color:#86efac;font-weight:800;font-size:14px;display:flex;align-items:center;justify-content:center;cursor:pointer}.bottom-nav{position:fixed;left:0;right:0;bottom:0;height:90px;z-index:40;pointer-events:none;padding-bottom:env(safe-area-inset-bottom);background:linear-gradient(180deg,rgba(11,17,32,0),var(--bg) 38%)}.bottom-nav .bar{pointer-events:auto;position:absolute;left:14px;right:14px;bottom:14px;max-width:452px;margin:0 auto;height:62px;background:#111a2ed9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:24px;display:flex;align-items:center;justify-content:space-around;box-shadow:0 12px 30px -10px #000000b3}.bottom-nav .tab{background:none;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px;color:#64748b;font-size:10px;font-weight:700}.bottom-nav .tab.active{color:var(--green-2);filter:drop-shadow(0 0 6px rgba(34,197,94,.8))}.bottom-nav .slot{width:54px}.bottom-nav .fab{pointer-events:auto;position:absolute;left:50%;bottom:46px;transform:translate(-50%);width:58px;height:58px;border-radius:50%;border:none;cursor:pointer;background:linear-gradient(150deg,var(--green-2),#15803d);display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 5px var(--bg),0 0 24px #22c55eb3,0 8px 18px -4px #22c55e99}.menu-sheet .menu-item{width:100%;text-align:left;padding:16px;font-size:16px;background:var(--card-2);border:1px solid var(--border);border-radius:12px;color:var(--text);margin-top:10px;cursor:pointer}.sheet.closing{animation:slideDown .2s ease-in forwards}@keyframes slideDown{0%{transform:translateY(0)}to{transform:translateY(100%)}}.race-lane{margin-bottom:14px}.lane-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:7px;padding:0 2px}.lane-who{display:flex;align-items:center;gap:8px}.lane-pos{font-size:13px;font-weight:700;color:var(--muted)}.lane-name{font-size:15px;font-weight:800}.lane-saved{font-size:16px;font-weight:700;color:var(--green-2)}.lane-saved.neg{color:#fca5a5}.track{position:relative;height:62px;border-radius:16px;overflow:hidden;background:linear-gradient(180deg,#0e1626,var(--bg));border:1px solid var(--border)}.track .lane-line{position:absolute;top:50%;left:0;right:18px;height:2px;transform:translateY(-50%);background:repeating-linear-gradient(90deg,#2c3a57 0 10px,transparent 10px 20px)}.track .finish{position:absolute;top:0;bottom:0;right:0;width:16px;background:repeating-conic-gradient(#e5e7eb 0,#e5e7eb 25%,#1c2433 0,#1c2433 50%) 0 0 / 8px 8px}.car{position:absolute;bottom:11px;transform:translate(-50%);transition:left .8s cubic-bezier(.22,1,.36,1)}.car .wrap{position:relative;width:58px;height:30px}.car .body{position:absolute;bottom:6px;left:0;width:58px;height:15px;border-radius:8px 11px 6px 6px;background:var(--car);box-shadow:0 0 16px var(--car),0 4px 8px #00000080}.car .cabin{position:absolute;bottom:14px;left:15px;width:26px;height:12px;border-radius:9px 9px 0 0;background:var(--car)}.car .window{position:absolute;bottom:15px;left:18px;width:18px;height:8px;border-radius:6px 6px 0 0;background:#0b1120b8}.car .spoiler{position:absolute;bottom:10px;left:-3px;width:6px;height:11px;border-radius:2px;background:var(--car)}.car .wheel{position:absolute;bottom:0;width:14px;height:14px;border-radius:50%;background:var(--bg);border:3px solid #475569}.car .wheel.front{right:8px}.car .wheel.back{left:9px}.car.leader .body{animation:carPulse 1.6s ease-in-out infinite}@keyframes carPulse{0%,to{filter:brightness(1)}50%{filter:brightness(1.18)}}.swatch-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:10px}.swatch{width:40px;height:40px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0;box-shadow:0 0 10px -2px var(--sw, transparent)}.swatch.active{border-color:#fff;box-shadow:0 0 0 3px var(--bg),0 0 14px var(--sw)}.car-preview{position:relative;height:56px;margin-top:16px;border-radius:14px;background:linear-gradient(180deg,#0e1626,var(--bg));border:1px solid var(--border)}.car-preview .car{left:50%;bottom:8px}.finish-banner{display:flex;align-items:center;justify-content:center;gap:8px;text-align:center;margin:0 2px 16px;padding:14px 16px;border-radius:16px;font-weight:800;font-size:15px;color:#052e16;background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 0 22px #22c55e80;animation:bannerPop .4s ease-out}@keyframes bannerPop{0%{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}.list-head{display:flex;justify-content:space-between;align-items:center}.filters{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:14px;margin-bottom:12px}.filter-label{display:block;font-size:12px;color:var(--muted);margin:4px 0 2px;text-transform:uppercase;letter-spacing:.4px}.filters .chips{margin-bottom:8px}.filter-summary{font-size:13px;margin:0 0 8px}.pie{width:200px;height:200px;border-radius:50%;margin:10px auto 20px;position:relative}.pie-hole{position:absolute;top:26%;right:26%;bottom:26%;left:26%;border-radius:50%;background:var(--card);display:flex;flex-direction:column;align-items:center;justify-content:center}.pie-total{font-size:20px;font-weight:700}.pie-cap{font-size:12px;color:var(--muted)}.pie-legend{list-style:none;margin:0;padding:0}.pie-legend li{display:flex;align-items:center;gap:10px;padding:9px 0;border-top:1px solid var(--border)}.pie-legend li:first-child{border-top:none}.pie-legend .dot{width:14px;height:14px;border-radius:4px;flex:none}.pie-legend .leg-name{flex:1;font-size:15px}.pie-legend .leg-val{color:var(--muted);font-size:14px}.cat-card.warn{background:linear-gradient(160deg,#854d0e,#a16207)}.alloc-list.boxed li{border-top:none;border:1px solid #16a34a;background:#22c55e29;border-radius:10px;padding:10px 12px;margin-top:8px}.alloc-list.boxed li:first-child{margin-top:6px}.alloc-list.boxed li.warn{border-color:#facc15;background:#facc1529}.alloc-list.boxed li.over{border-color:#f87171;background:#ef444433}.cat-card.low{background:linear-gradient(160deg,#9a3412,#c2410c)}.alloc-list.boxed li.low{border-color:#fb923c;background:#fb923c2e}.cat-card.multi{background:var(--card);border:1px solid var(--border)}.ot-list{list-style:none;margin:4px 0 12px;padding:0}.ot-list li{display:flex;justify-content:space-between;padding:8px 0;border-top:1px solid var(--border);font-size:15px}.ot-list li:first-child{border-top:none}.ot-list small{color:var(--muted);font-size:12px}.ot-list .neg{color:#fca5a5}
