:root{--bg: #f6f7f5;--surface: #ffffff;--ink: #1a2421;--ink-soft: #5d6b66;--muted: #97a39e;--line: #e6e9e6;--accent: #1c7a5c;--accent-soft: #e4f1ec;--warn: #c1462b;--warn-soft: #fbe9e5;--today: #b07d12;--today-soft: #faf2dd;--radius: 12px;--shadow: 0 1px 2px rgba(26, 36, 33, .06), 0 8px 24px rgba(26, 36, 33, .05)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--ink);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;min-height:100%}.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;background:var(--surface);border-bottom:1px solid var(--line)}.brand{display:flex;align-items:baseline;gap:8px}.brand-mark{font-weight:700;font-size:20px;letter-spacing:-.02em;color:var(--accent)}.brand-sub{color:var(--muted);font-size:13px;letter-spacing:.06em;text-transform:uppercase}.due-pill{background:var(--warn-soft);color:var(--warn);padding:5px 11px;border-radius:999px;font-weight:600;font-size:12.5px}.main{width:100%;max-width:860px;margin:0 auto;padding:22px}.row,.add-card,.row-head{display:grid;grid-template-columns:1.1fr 1.8fr 230px 28px;gap:10px;align-items:center}.add-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:12px;box-shadow:var(--shadow);margin-bottom:8px}.add-card .btn{grid-column:3 / 5;justify-self:stretch}.add-hint{color:var(--muted);font-size:12px;margin:0 4px 18px}.rows{list-style:none;margin:0;padding:0}.row-head{padding:4px 12px 8px}.row-head .cell{color:var(--muted);font-size:11.5px;text-transform:uppercase;letter-spacing:.05em}.row{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:8px 12px;margin-bottom:8px}.row.is-overdue{border-left:3px solid var(--warn)}.row.is-today{border-left:3px solid var(--today)}.cell{font:inherit;color:var(--ink)}input.cell,.add-card input,.cell-reminder input,.cell-reminder-input{background:transparent;border:1px solid transparent;border-radius:8px;padding:8px 10px;width:100%;font:inherit;color:inherit}input.cell:hover,.cell-reminder input:hover,.cell-reminder-input:hover{border-color:var(--line)}input:focus,.cell-reminder-input:focus{outline:none;border-color:var(--accent);background:var(--bg);box-shadow:0 0 0 3px #1c7a5c1f}.add-card input{background:var(--bg);border-color:var(--line)}.cell-name{font-weight:600}.cell-status::placeholder,.cell-name::placeholder{color:var(--muted);font-weight:400}.cell-reminder{display:flex;flex-direction:column;gap:1px}.cell-reminder .due{font-size:11px;color:var(--muted);padding-left:11px}.cell-reminder .due.is-overdue{color:var(--warn);font-weight:600}.cell-reminder .due.is-today{color:var(--today);font-weight:600}.row-remove{border:none;background:transparent;color:var(--muted);cursor:pointer;font-size:20px;line-height:1;border-radius:6px;width:28px;height:28px}.row-remove:hover{background:var(--warn-soft);color:var(--warn)}.cell-name-wrap{display:flex;flex-direction:column;gap:4px;align-items:flex-start}.cell-name-wrap .cell-name{width:100%}.cats{display:flex;flex-wrap:wrap;gap:5px;padding-left:10px;align-items:center}.chip{font:inherit;font-size:11.5px;cursor:pointer;border:1px solid transparent;border-radius:999px;padding:2px 8px;line-height:1.5}.chip-on{background:var(--accent-soft, #e4f1ec);color:var(--accent)}.chip-on:hover{background:#d6e9e1}.chip-x{opacity:.6}.chip-add{background:var(--bg);color:var(--ink-soft);border-color:var(--line)}.chip-add:hover{border-color:var(--accent);color:var(--accent)}.cat-menu{position:relative;display:inline-block}.cat-menu summary{list-style:none}.cat-menu summary::-webkit-details-marker{display:none}.cat-pop{position:absolute;z-index:20;top:calc(100% + 4px);left:0;background:var(--surface);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);padding:6px;min-width:180px;display:flex;flex-direction:column;gap:2px}.cat-opt{text-align:left;font:inherit;font-size:13px;cursor:pointer;border:none;background:transparent;color:var(--ink);padding:6px 8px;border-radius:6px}.cat-opt:hover{background:var(--bg)}.cat-custom{display:flex;gap:4px;margin-top:4px;border-top:1px solid var(--line);padding-top:6px}.cat-custom input{background:var(--bg);border:1px solid var(--line);border-radius:6px;padding:5px 8px;font:inherit;font-size:13px;width:100%}.cat-add-btn{font:inherit;font-size:12px;font-weight:600;cursor:pointer;border:none;background:var(--accent);color:#fff;border-radius:6px;padding:0 10px}.cat-add-btn:disabled{opacity:.45;cursor:not-allowed}.filterbar{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}.fchip{font:inherit;font-size:12.5px;cursor:pointer;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:5px 11px;color:var(--ink-soft)}.fchip:hover:not(:disabled){border-color:#cfd6d2}.fchip.is-active{background:var(--accent);border-color:var(--accent);color:#fff}.fchip:disabled{opacity:.4;cursor:default}.fcount{opacity:.7;font-size:11px;margin-left:2px}.btn{font:inherit;cursor:pointer;border:1px solid var(--line);background:var(--surface);color:var(--ink);padding:9px 16px;border-radius:9px;font-weight:600}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:#176349;border-color:#176349}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.empty{text-align:center;padding:48px 20px;color:var(--muted)}.empty-title{font-weight:600;font-size:16px;color:var(--ink);margin:0 0 4px}.empty-sub{margin:0}.topbar-right{display:flex;align-items:center;gap:10px}.btn-ghost{background:transparent;border-color:transparent;color:var(--ink-soft)}.btn-ghost:hover{background:var(--bg);border-color:transparent}.btn-sm{padding:5px 10px;font-size:12.5px}.btn-block{width:100%}.gate{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg)}.gate-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:28px;max-width:380px;width:100%;text-align:center}.gate-card-wide{max-width:520px;text-align:left}.brand-center{justify-content:center;margin-bottom:14px}.gate-text{color:var(--ink);margin:0 0 18px}.gate-card .form{width:100%;gap:14px}.gate-card .form input{width:100%;background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:10px 12px;font:inherit}.gate-card .form .gate-text{margin:0}.setup-steps{text-align:left;color:var(--ink-soft);padding-left:20px;line-height:1.7}.setup-steps code{background:var(--bg);padding:1px 5px;border-radius:4px;font-size:12.5px}.error-banner{background:var(--warn-soft);color:var(--warn);border-radius:10px;padding:10px 14px;margin:0 0 14px;font-size:13px}.attribution{font-size:11px;color:var(--muted);padding-left:11px}.bar-row{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-start;justify-content:space-between;margin-bottom:14px}.bar-row .filterbar{margin-bottom:0;flex:1}.allowlist{position:relative}.allowlist-summary{list-style:none;cursor:pointer;font-size:12.5px;font-weight:600;color:var(--ink-soft);background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:5px 12px}.allowlist-summary::-webkit-details-marker{display:none}.allowlist-body{position:absolute;right:0;top:calc(100% + 6px);z-index:30;background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:12px;width:280px}.allowlist-note{font-size:11.5px;margin:0 0 8px}.allowlist-list{list-style:none;margin:0 0 8px;padding:0;display:flex;flex-direction:column;gap:2px;max-height:200px;overflow-y:auto}.allowlist-row{display:flex;align-items:center;justify-content:space-between;font-size:13px;padding:3px 0}.allowlist-add{display:flex;gap:6px;border-top:1px solid var(--line);padding-top:8px}.allowlist-add input{background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:7px 9px;font:inherit;font-size:13px;width:100%}@media(max-width:680px){.row,.add-card,.row-head{grid-template-columns:1fr 1fr}.row-head{display:none}.add-card .btn{grid-column:1 / 3}}
