:root{--bg: #0f172a;--surface: #1e293b;--surface-2: #334155;--border: #334155;--text: #f1f5f9;--muted: #94a3b8;--accent: #10b981;--accent-d: #059669;--on-accent: #052e23;--danger: #ef4444;--warn: #f59e0b;--blue: #3b82f6;--radius: 14px;color-scheme:dark}[data-theme=light]{--bg: #eef2f7;--surface: #ffffff;--surface-2: #e3eaf2;--border: #d3dde8;--text: #0f172a;--muted: #5c6b7f;--accent: #10b981;--accent-d: #059669;--on-accent: #ffffff;--danger: #dc2626;--warn: #b45309;--blue: #2563eb;color-scheme:light}[data-theme=cozy]{--bg: #241b15;--surface: #33271f;--surface-2: #46362c;--border: #4b3a2f;--text: #f6ece2;--muted: #bda897;--accent: #e08e4f;--accent-d: #c1722f;--on-accent: #2c1a0d;--danger: #e06b5e;--warn: #e0a44b;--blue: #7fa68d;color-scheme:dark}[data-theme=pastel-light]{--bg: #f6f2ff;--surface: #ffffff;--surface-2: #eee7fb;--border: #e3d8f7;--text: #3a2f4a;--muted: #847798;--accent: #a78bfa;--accent-d: #8b6ee0;--on-accent: #2a1740;--danger: #ef7490;--warn: #d9933f;--blue: #5aa9e0;color-scheme:light}[data-theme=pastel-dark]{--bg: #1e1c2b;--surface: #2a2740;--surface-2: #393455;--border: #403b5e;--text: #ece9ff;--muted: #a59fcf;--accent: #b6a4f5;--accent-d: #9b86e8;--on-accent: #1b1633;--danger: #f2849b;--warn: #f0c987;--blue: #8fb8e8;color-scheme:dark}[data-theme=blue]{--bg: #eaf2fb;--surface: #ffffff;--surface-2: #dbe9f9;--border: #c7ddf4;--text: #102a43;--muted: #5a7a9a;--accent: #3b82f6;--accent-d: #2563eb;--on-accent: #ffffff;--danger: #ef4444;--warn: #d97706;--blue: #0ea5e9;color-scheme:light}[data-theme=midnight]{--bg: #0b1220;--surface: #141f33;--surface-2: #1f2d45;--border: #26374f;--text: #e6edf7;--muted: #8ea3bf;--accent: #38bdf8;--accent-d: #0ea5e9;--on-accent: #04121f;--danger: #f87171;--warn: #fbbf24;--blue: #60a5fa;color-scheme:dark}[data-theme=mint]{--bg: #e8f9f1;--surface: #ffffff;--surface-2: #d4f2e5;--border: #bdead7;--text: #0f3d2e;--muted: #5b8a78;--accent: #10b981;--accent-d: #059669;--on-accent: #ffffff;--danger: #ef4444;--warn: #d97706;--blue: #14b8a6;color-scheme:light}[data-theme=rose]{--bg: #fdeef4;--surface: #ffffff;--surface-2: #fad9e6;--border: #f6c6da;--text: #4a1f33;--muted: #a06a82;--accent: #ec4899;--accent-d: #db2777;--on-accent: #ffffff;--danger: #e11d48;--warn: #d97706;--blue: #c084fc;color-scheme:light}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{height:100%;background:var(--bg)}body{margin:0;min-height:100dvh;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px;overscroll-behavior-y:none;transition:background-color .2s ease,color .2s ease}#root{min-height:100dvh}.app{max-width:560px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column}.header{position:sticky;top:0;z-index:10;background:color-mix(in srgb,var(--bg) 85%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:calc(env(safe-area-inset-top) + 14px) 16px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.header h1{font-size:1.2rem;margin:0}.content{flex:1;padding:16px;padding-bottom:calc(80px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:14px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.row{display:flex;align-items:center;gap:12px}.between{justify-content:space-between}.col{display:flex;flex-direction:column;gap:4px}.grow{flex:1;min-width:0}.muted{color:var(--muted);font-size:.85rem}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;border-radius:12px;padding:12px 16px;font-size:1rem;font-weight:600;background:var(--surface-2);color:var(--text);cursor:pointer;min-height:48px;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5}.btn-primary{background:var(--accent);color:var(--on-accent)}.btn-danger{background:transparent;color:var(--danger);border:1px solid var(--danger)}.btn-ghost{background:transparent;border:1px solid var(--border)}.btn-sm{padding:8px 12px;min-height:40px;font-size:.9rem}.btn-block{width:100%}.btn-lg{padding:18px;font-size:1.15rem}input,select{width:100%;padding:13px 14px;border-radius:12px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:1rem}label{font-size:.85rem;color:var(--muted);margin-bottom:6px;display:block}.field{margin-bottom:14px}.pill{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;font-weight:600;padding:3px 8px;border-radius:999px;background:var(--surface-2);color:var(--muted)}.pill-due{background:color-mix(in srgb,var(--accent) 18%,transparent);color:var(--accent)}.pill-soon{background:color-mix(in srgb,var(--warn) 18%,transparent);color:var(--warn)}.pill-points{background:color-mix(in srgb,var(--blue) 18%,transparent);color:var(--blue)}.pill-onetime{background:color-mix(in srgb,var(--accent) 18%,transparent);color:var(--accent)}.nav{position:sticky;bottom:0;margin-top:auto;z-index:20;display:flex;background:color-mix(in srgb,var(--surface) 92%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom)}.nav a{flex:1;text-align:center;padding:10px 4px;color:var(--muted);text-decoration:none;font-size:.7rem;display:flex;flex-direction:column;align-items:center;gap:3px}.nav a.active{color:var(--accent)}.nav .ico{font-size:1.3rem;line-height:1}.center-screen{min-height:100dvh;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:24px;gap:16px;text-align:center}.leader-card{background:linear-gradient(135deg,var(--accent-d),var(--blue));border:none;color:#fff}.big-num{font-size:2.6rem;font-weight:800;line-height:1}.bar-track{height:10px;background:var(--bg);border-radius:999px;overflow:hidden}.bar-fill{height:100%;border-radius:999px}.toast{position:fixed;left:50%;bottom:calc(84px + env(safe-area-inset-bottom));transform:translate(-50%);background:var(--surface-2);border:1px solid var(--border);color:var(--text);padding:10px 16px;border-radius:12px;z-index:30;font-size:.9rem;box-shadow:0 8px 24px #0006}.error-text{color:var(--danger);font-size:.9rem}.list{display:flex;flex-direction:column;gap:10px}.spinner{color:var(--muted);text-align:center;padding:32px}a.link{color:var(--accent)}.seg{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:4px;gap:4px}.seg button{flex:1;background:transparent;border:none;color:var(--muted);padding:8px;border-radius:9px;font-weight:600}.seg button.active{background:var(--surface-2);color:var(--text)}code.tag{font-size:.75rem;word-break:break-all;color:var(--muted)}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;background:#0000008c;display:flex;align-items:flex-end;justify-content:center}.sheet{width:100%;max-width:560px;background:var(--surface);border-top-left-radius:20px;border-top-right-radius:20px;border:1px solid var(--border);padding:20px 16px calc(24px + env(safe-area-inset-bottom));animation:slideup .18s ease-out}@keyframes slideup{0%{transform:translateY(100%)}to{transform:translateY(0)}}.theme-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.theme-tile{background:transparent;border:2px solid var(--border);border-radius:12px;padding:8px;cursor:pointer;display:flex;flex-direction:column;gap:6px;align-items:center}.theme-tile.active{border-color:var(--accent)}.theme-preview{width:100%;height:38px;border-radius:8px;display:flex;align-items:flex-end;gap:4px;padding:5px;border:1px solid var(--border)}.theme-preview span{flex:1;height:14px;border-radius:4px}.theme-name{font-size:.75rem;color:var(--text)}.step-row{display:flex;align-items:center;gap:12px;width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface) 40%,transparent);color:var(--text);font-size:1rem;cursor:pointer;min-height:52px}.step-check{flex-shrink:0;width:28px;height:28px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:var(--muted)}.step-check.on{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip{padding:8px 14px;border-radius:999px;border:1px solid var(--border);background:transparent;color:var(--text);font-size:.9rem;cursor:pointer;min-height:40px}.chip-on{background:var(--accent);color:var(--on-accent);border-color:var(--accent);font-weight:600}.swatches{display:flex;flex-wrap:wrap;gap:10px}.swatch{width:36px;height:36px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0}.swatch.active{border-color:var(--text);box-shadow:0 0 0 2px var(--bg),0 0 0 4px var(--text)}input[type=color]{border:1px solid var(--border);border-radius:10px;background:var(--bg);cursor:pointer}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;background:radial-gradient(120% 80% at 8% -10%,color-mix(in srgb,var(--accent) 42%,transparent),transparent 55%),radial-gradient(120% 80% at 100% 0%,color-mix(in srgb,var(--blue) 44%,transparent),transparent 55%),radial-gradient(130% 90% at 50% 115%,color-mix(in srgb,var(--accent-d) 32%,transparent),transparent 60%)}.card{border-radius:22px;background:color-mix(in srgb,var(--surface) 52%,transparent);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);border:1px solid color-mix(in srgb,#fff 16%,transparent);box-shadow:0 10px 36px #0000004d}.header{background:color-mix(in srgb,var(--bg) 55%,transparent);border-bottom:1px solid color-mix(in srgb,#fff 10%,transparent)}.nav{background:color-mix(in srgb,var(--surface) 60%,transparent);border-top:1px solid color-mix(in srgb,#fff 12%,transparent)}.sheet{background:color-mix(in srgb,var(--surface) 72%,transparent);backdrop-filter:blur(22px) saturate(140%);-webkit-backdrop-filter:blur(22px) saturate(140%);border:1px solid color-mix(in srgb,#fff 16%,transparent)}.leader-card{border:none;box-shadow:0 14px 38px color-mix(in srgb,var(--accent) 28%,transparent)}.btn-primary{box-shadow:0 8px 24px color-mix(in srgb,var(--accent) 42%,transparent)}.btn-ghost{background:color-mix(in srgb,#fff 8%,transparent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-color:color-mix(in srgb,#fff 18%,transparent)}input,select{background:color-mix(in srgb,var(--surface) 42%,transparent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
