:root{--bg: #0e0e10;--card: #1a1a1e;--line: #2c2c33;--fg: #f4f4f5;--muted: #9a9aa3;--accent: #e63946;--ok: #2ecc71;--p-urgent: #e63946;--p-high: #f3a712;--p-normal: #5b8def;--p-low: #6b6b73}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--fg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:15px}button{font-family:inherit;cursor:pointer}input,textarea,select{width:100%;padding:10px 12px;background:#101014;color:var(--fg);border:1px solid var(--line);border-radius:9px;font-size:15px;font-family:inherit}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent)}textarea{resize:vertical;min-height:70px}a{color:var(--p-normal)}.center{min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px}.card{width:100%;max-width:420px;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:28px}.card h1{margin:0 0 4px;font-size:22px}.card .sub{margin:0 0 20px;color:var(--muted);font-size:14px}label{display:block;margin:14px 0 6px;font-size:13px;font-weight:600;color:var(--muted)}.btn{width:100%;margin-top:22px;padding:12px;background:var(--accent);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600}.btn:disabled{opacity:.55;cursor:default}.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--fg)}.btn.sm{width:auto;margin:0;padding:8px 14px;font-size:14px}.err{margin-top:14px;padding:10px 12px;border-radius:9px;font-size:14px;background:#e639461f;border:1px solid var(--accent);color:#f7a8ae}.note{margin-top:14px;padding:10px 12px;border-radius:9px;font-size:14px;background:#2ecc711f;border:1px solid var(--ok);color:#9ff0c2}.layout{display:grid;grid-template-columns:260px 1fr;height:100%}.sidebar{border-right:1px solid var(--line);padding:18px 14px;overflow-y:auto;background:#131316}.topbar,.nav-backdrop{display:none}.brand{font-weight:700;font-size:17px;padding:0 8px 14px}.nav-item{display:flex;align-items:center;gap:8px;width:100%;text-align:left;padding:9px 10px;border:none;background:transparent;color:var(--fg);border-radius:8px;font-size:14px}.nav-item:hover{background:#1d1d22}.nav-item.active{background:#25252b;font-weight:600}.nav-section{margin-top:16px;padding:0 10px 6px;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.sidebar-footer{margin-top:18px;padding:12px 8px 0;border-top:1px solid var(--line);color:var(--muted);font-size:13px}.main{overflow-y:auto;padding:28px 32px}.main-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.main-head h2{margin:0;font-size:22px}.quickadd{display:flex;gap:10px;margin-bottom:18px}.quickadd input{flex:1}.task{display:flex;align-items:flex-start;gap:12px;padding:12px 4px;border-bottom:1px solid var(--line)}.task .check{flex:none;width:20px;height:20px;margin-top:1px;border-radius:50%;border:2px solid var(--muted);background:transparent;cursor:pointer;padding:0}.task .check.p4{border-color:var(--p-urgent)}.task .check.p3{border-color:var(--p-high)}.task .check.p2{border-color:var(--p-normal)}.task .check:hover{background:#ffffff14}.task-body{flex:1;min-width:0}.task-title{font-size:15px}.task-desc{color:var(--muted);font-size:13px;margin-top:3px;white-space:pre-wrap}.task-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}.chip{font-size:12px;padding:2px 8px;border-radius:20px;background:#25252b;color:var(--muted)}.chip.due{color:#f3c7a0}.chip.overdue{color:#f7a8ae;background:#e6394624}.task-actions{display:flex;gap:6px;opacity:0;transition:opacity .12s}.task:hover .task-actions{opacity:1}.icon-btn{background:transparent;border:none;color:var(--muted);font-size:14px;padding:4px 6px;border-radius:6px}.icon-btn:hover{background:#25252b;color:var(--fg)}.empty{color:var(--muted);padding:30px 0;text-align:center}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000a;display:flex;align-items:center;justify-content:center;padding:20px;z-index:50}.modal{width:100%;max-width:520px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:22px}.modal h3{margin:0 0 16px}.row{display:flex;gap:12px}.row>div{flex:1}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:22px}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:10px 8px;border-bottom:1px solid var(--line);font-size:14px}th{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.05em}.badge{font-size:12px;padding:2px 8px;border-radius:20px}.badge.on{background:#2ecc7124;color:#9ff0c2}.badge.off{background:#25252b;color:var(--muted)}.settings-block{max-width:560px}.settings-block h4{font-size:15px}.muted{color:var(--muted)}.spinner{color:var(--muted);padding:40px;text-align:center}@media (max-width: 760px){.layout{display:block;height:100%}.topbar{display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:30;padding:calc(10px + env(safe-area-inset-top)) 16px 10px;background:#131316;border-bottom:1px solid var(--line)}.hamburger{background:transparent;border:none;color:var(--fg);font-size:22px;line-height:1;padding:4px 8px;border-radius:8px}.topbar-title{font-weight:700;font-size:17px}.sidebar{position:fixed;top:0;left:0;bottom:0;width:82%;max-width:300px;z-index:50;transform:translate(-100%);transition:transform .22s ease;padding-top:calc(18px + env(safe-area-inset-top));box-shadow:2px 0 24px #0008}.layout.nav-open .sidebar{transform:translate(0)}.nav-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;background:#0009}.main{padding:18px 16px calc(28px + env(safe-area-inset-bottom));height:auto}.main-head h2{font-size:19px}.nav-item{padding:12px;font-size:15px}.row{flex-direction:column;gap:0}.modal{border-radius:14px 14px 0 0;align-self:flex-end}.overlay{align-items:flex-end;padding:0}.task-actions{opacity:1}.board,.people{grid-auto-columns:84%}.toolbar{flex-direction:column;align-items:stretch;gap:10px}.mode-tab .mode-lbl{display:none}.calendar .cal-cell{min-height:64px}}.dot{display:inline-block;width:9px;height:9px;border-radius:50%;flex:none}.nav-item .dot{margin-right:2px}.screen-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.screen-head h2{margin:0;font-size:22px}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px;flex-wrap:wrap}.mode-tabs{display:flex;gap:4px;background:#131316;border:1px solid var(--line);border-radius:10px;padding:3px}.mode-tab{display:flex;align-items:center;gap:6px;padding:6px 12px;border:none;background:transparent;color:var(--muted);border-radius:7px;font-size:14px}.mode-tab:hover{color:var(--fg)}.mode-tab.active{background:#2a2a31;color:var(--fg);font-weight:600}.toolbar-filters{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.toolbar-filters .search{width:180px}.toolbar-filters select{width:auto}.chk{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);margin:0}.chk input{width:auto}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;color:#fff;font-weight:700;flex:none;line-height:1}.avatar.more{background:#3a3a42;color:var(--fg)}.avatar-stack{display:inline-flex}.avatar-stack .avatar{margin-left:-6px;border:2px solid var(--bg)}.avatar-stack .avatar:first-child{margin-left:0}.chip.proj{background:#25252b;color:#cdd2e0}.chip.label{background:#25252b}.chip.prio.p4{background:#e6394629;color:#f7a8ae}.chip.prio.p3{background:#f3a71229;color:#f3c98a}.chip.due.soon{color:#9ff0c2}.list-group{margin-bottom:22px}.list-group-head{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:4px;padding:0 4px}.task-right{display:flex;align-items:center;gap:10px}.task.done .task-title{text-decoration:line-through;color:var(--muted)}.check.on{background:var(--ok);border-color:var(--ok);position:relative}.check.on:after{content:"✓";color:#fff;font-size:12px;position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.task-body{cursor:pointer}.board{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(240px,1fr);gap:14px;overflow-x:auto;padding-bottom:8px;align-items:start}.board-col{background:#131316;border:1px solid var(--line);border-radius:12px;padding:10px;display:flex;flex-direction:column;min-height:120px}.board-col.over{border-color:var(--accent);background:#16161b}.board-col-head{display:flex;align-items:center;gap:8px;justify-content:space-between;font-weight:600;padding:4px 6px 10px}.board-col-head.person{justify-content:flex-start}.board-col-head.person .muted{margin-left:auto}.board-col-body{display:flex;flex-direction:column;gap:8px;min-height:20px}.board-empty{color:var(--muted);font-size:13px;text-align:center;padding:14px 0}.board-add{margin-top:8px;background:transparent;border:1px dashed var(--line);color:var(--muted);border-radius:8px;padding:8px;font-size:13px}.board-add:hover{color:var(--fg);border-color:var(--muted)}.card-task{background:var(--card);border:1px solid var(--line);border-left:3px solid var(--p-low);border-radius:9px;padding:10px;cursor:pointer}.card-task:hover{border-color:#3a3a42}.card-task.p4{border-left-color:var(--p-urgent)}.card-task.p3{border-left-color:var(--p-high)}.card-task.p2{border-left-color:var(--p-normal)}.card-task-title{font-size:14px;margin-bottom:6px}.card-task-meta{display:flex;flex-wrap:wrap;gap:6px}.card-task-foot{display:flex;justify-content:flex-end;margin-top:8px;min-height:22px}.cal-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}.cal-title{font-size:18px;font-weight:700;min-width:160px}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:10px;overflow:hidden}.cal-wd{background:#131316;color:var(--muted);font-size:12px;text-align:center;padding:6px 0;font-weight:600}.cal-cell{background:var(--bg);min-height:96px;padding:4px 5px;cursor:pointer}.cal-cell:hover{background:#131316}.cal-cell.dim{opacity:.4}.cal-cell.today{background:#16161b;box-shadow:inset 0 0 0 2px var(--p-normal)}.cal-day{font-size:12px;color:var(--muted);margin-bottom:3px}.cal-tasks{display:flex;flex-direction:column;gap:3px}.cal-task{font-size:11px;padding:2px 6px;border-radius:5px;background:#25252b;border-left:3px solid var(--p-low);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer}.cal-task.p4{border-left-color:var(--p-urgent)}.cal-task.p3{border-left-color:var(--p-high)}.cal-task.p2{border-left-color:var(--p-normal)}.cal-task.done{text-decoration:line-through;color:var(--muted)}.cal-undated{margin-top:18px}.cal-undated-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.modal.wide{max-width:620px;max-height:90vh;overflow-y:auto}.picker{display:flex;flex-wrap:wrap;gap:6px}.pick-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;background:#131316;border:1px solid var(--line);border-radius:20px;color:var(--fg);font-size:13px}.pick-chip:hover{border-color:var(--muted)}.pick-chip.on{border-color:var(--accent);background:#e639461f}.comments{margin-top:22px;padding-top:16px;border-top:1px solid var(--line)}.comment{display:flex;gap:10px;margin-bottom:12px}.comment-body{flex:1}.comment-head{display:flex;align-items:center;gap:8px;font-size:13px}.comment-head .muted{font-size:12px}.comment-text{font-size:14px;margin-top:2px;white-space:pre-wrap}.comment-add{display:flex;gap:8px;margin-top:10px}.comment-add input{flex:1}.chip-list{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.manage-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 8px 5px 10px;background:#131316;border:1px solid var(--line);border-radius:20px;font-size:14px}.inline-add{display:flex;gap:8px;align-items:center}.inline-add input{flex:1}.inline-add select{width:auto}
