:root{color-scheme:dark;--bg: #0f1115;--bg-elev: #161a21;--bg-elev-2: #1d222b;--line: #262c37;--line-strong: #323a48;--text: #e6e9ef;--text-dim: #9aa3b2;--text-faint: #6b7280;--accent: #7fb069;--accent-dim: #5f8a4f;--warn: #d49a3a;--danger: #c0524b;--info: #6ea8d1;--radius: 10px;--radius-lg: 14px;--pad: 14px;--pad-lg: 18px;--font: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--mono: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;--shadow: 0 1px 0 rgba(255,255,255,.02) inset, 0 1px 2px rgba(0,0,0,.3);--tap: 44px}*,*:before,*:after{box-sizing:border-box}html,body,#app{height:100%}body{margin:0;font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-size:16px;line-height:1.45}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4{font-weight:600;letter-spacing:-.01em;margin:0 0 8px}h1{font-size:22px}h2{font-size:18px}h3{font-size:16px}p{margin:0 0 10px}small,.small{font-size:13px;color:var(--text-dim)}.muted{color:var(--text-dim)}.faint{color:var(--text-faint)}hr{border:none;border-top:1px solid var(--line);margin:14px 0}.app{display:flex;flex-direction:column;min-height:100dvh;padding-bottom:calc(72px + env(safe-area-inset-bottom))}.container{width:100%;max-width:720px;margin:0 auto;padding:14px 14px 0}.topbar{position:sticky;top:0;z-index:10;background:linear-gradient(to bottom,var(--bg) 70%,transparent);padding:14px 14px 8px;display:flex;align-items:baseline;justify-content:space-between}.topbar h1{margin:0}.topbar .sub{color:var(--text-dim);font-size:13px}.card{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius-lg);padding:var(--pad-lg);box-shadow:var(--shadow);margin-bottom:12px}.card.tight{padding:var(--pad)}.card h2{font-size:15px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);margin-bottom:10px}.card .row{display:flex;align-items:center;justify-content:space-between;gap:10px}.row{display:flex;align-items:center;gap:10px}.row.wrap{flex-wrap:wrap}.row.between{justify-content:space-between}.row.tight{gap:6px}.col{display:flex;flex-direction:column;gap:10px}.grow,.spacer{flex:1}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:var(--tap);padding:10px 14px;border-radius:var(--radius);background:var(--bg-elev-2);border:1px solid var(--line-strong);color:var(--text);font:inherit;font-weight:500;cursor:pointer;transition:transform .05s ease,background .15s ease,border-color .15s ease}.btn:active{transform:translateY(1px)}.btn:hover{background:#232936}.btn.primary{background:var(--accent-dim);border-color:var(--accent-dim);color:#0f1115}.btn.primary:hover{background:var(--accent);border-color:var(--accent)}.btn.ghost{background:transparent;border-color:transparent}.btn.danger{background:transparent;border-color:var(--line-strong);color:var(--danger)}.btn.danger:hover{background:#c0524b1f}.btn.sm{min-height:34px;padding:6px 10px;font-size:13px}.btn.block{width:100%}.btn[disabled]{opacity:.5;cursor:not-allowed}input,select,textarea{width:100%;font:inherit;color:var(--text);background:var(--bg-elev-2);border:1px solid var(--line-strong);border-radius:var(--radius);padding:10px 12px;min-height:var(--tap)}textarea{min-height:80px;resize:vertical}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent-dim)}label{display:block;font-size:13px;color:var(--text-dim);margin-bottom:4px}.field{margin-bottom:12px}.field.inline{display:flex;align-items:center;gap:10px}.field.inline input[type=checkbox]{width:auto;min-height:auto}.tag{display:inline-block;font-size:11px;letter-spacing:.05em;text-transform:uppercase;padding:2px 8px;border-radius:999px;background:var(--bg-elev-2);border:1px solid var(--line);color:var(--text-dim)}.tag.on{color:var(--accent);border-color:var(--accent-dim)}.tag.warn{color:var(--warn);border-color:#d49a3a66}.tag.danger{color:var(--danger);border-color:#c0524b66}.list{display:flex;flex-direction:column;gap:8px}.item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius)}.item .title{font-weight:500}.item .meta{color:var(--text-dim);font-size:13px}.item .actions{display:flex;gap:6px}.item.done .title{color:var(--text-faint);text-decoration:line-through}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--bg-elev);border-top:1px solid var(--line);display:grid;grid-template-columns:repeat(6,1fr);padding:6px 2px calc(6px + env(safe-area-inset-bottom));z-index:20}.bottom-nav a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:6px 4px;color:var(--text-dim);font-size:11px;letter-spacing:.04em;text-decoration:none;border-radius:8px;min-height:var(--tap)}.bottom-nav a.active{color:var(--accent)}.bottom-nav .ico{font-size:18px;line-height:1}.progress{width:100%;height:6px;background:var(--bg-elev-2);border-radius:999px;overflow:hidden}.progress>div{height:100%;background:var(--accent);transition:width .2s ease}.empty{text-align:center;color:var(--text-dim);padding:28px 14px;border:1px dashed var(--line);border-radius:var(--radius)}.checkbox{width:22px;height:22px;border-radius:6px;border:1px solid var(--line-strong);background:var(--bg-elev-2);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.checkbox.checked{background:var(--accent);border-color:var(--accent);color:#0f1115}.checkbox svg{width:14px;height:14px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:flex-end;justify-content:center;z-index:50}.modal{width:100%;max-width:540px;background:var(--bg-elev);border:1px solid var(--line);border-top-left-radius:16px;border-top-right-radius:16px;padding:16px 14px calc(16px + env(safe-area-inset-bottom));max-height:90dvh;overflow-y:auto}@media (min-width: 600px){.modal-backdrop{align-items:center}.modal{border-radius:16px}}.banner{background:var(--bg-elev-2);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:var(--radius);padding:10px 12px;margin-bottom:12px;font-size:14px;color:var(--text-dim)}.banner.warn{border-left-color:var(--warn)}.banner.danger{border-left-color:var(--danger)}.streak{font-variant-numeric:tabular-nums;font-weight:600;color:var(--accent)}
