:root{--bg: #0b0d12;--panel: #11141b;--panel-2: #161a23;--border: #232936;--text: #e6e9f0;--muted: #8a93a6;--accent: #6366f1;--accent-2: #818cf8;--green: #22c55e;--yellow: #eab308;--orange: #f97316;--red: #ef4444;--gray: #6b7280}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font:14px/1.5 -apple-system,BlinkMacSystemFont,Segoe UI,Inter,Roboto,sans-serif;background:var(--bg);color:var(--text)}button{font:inherit;cursor:pointer}input,textarea,select{font:inherit;background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:6px 8px}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent)}.app{display:grid;grid-template-columns:260px 1fr;height:100vh}.sidebar{background:var(--panel);border-right:1px solid var(--border);padding:16px;overflow-y:auto}.sidebar h1{font-size:18px;margin:0 0 16px;letter-spacing:-.01em}.sidebar .section-title{text-transform:uppercase;font-size:11px;color:var(--muted);letter-spacing:.08em;margin:16px 0 6px}.proj-list{list-style:none;margin:0;padding:0}.proj-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;cursor:pointer;color:var(--text)}.proj-item:hover,.proj-item.active{background:var(--panel-2)}.proj-dot{width:10px;height:10px;border-radius:50%;flex:0 0 auto}.proj-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn{display:inline-flex;align-items:center;gap:6px;background:var(--accent);color:#fff;border:0;padding:7px 12px;border-radius:6px;font-weight:500}.btn:hover{background:var(--accent-2)}.btn.ghost{background:transparent;color:var(--muted)}.btn.ghost:hover{background:var(--panel-2);color:var(--text)}.btn.danger{background:var(--red)}.btn.sm{padding:4px 8px;font-size:12px}.main{display:flex;flex-direction:column;min-width:0}.topbar{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid var(--border)}.topbar h2{margin:0;font-size:18px}.tabs{display:flex;gap:4px;margin-left:12px}.tab{background:transparent;border:0;color:var(--muted);padding:6px 10px;border-radius:6px}.tab.active{background:var(--panel-2);color:var(--text)}.spacer{flex:1}.content{flex:1;overflow:auto;padding:20px}.kanban{display:grid;grid-template-columns:repeat(4,minmax(260px,1fr));gap:16px}.col{background:var(--panel);border:1px solid var(--border);border-radius:10px;display:flex;flex-direction:column;min-height:200px}.col-head{display:flex;align-items:center;gap:8px;padding:12px;border-bottom:1px solid var(--border);font-weight:600}.col-count{color:var(--muted);font-weight:400;font-size:12px}.col-body{padding:10px;display:flex;flex-direction:column;gap:8px}.card{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;cursor:pointer}.card:hover{border-color:var(--accent)}.card-title{font-weight:500;margin:0 0 6px}.card-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap;font-size:12px;color:var(--muted)}.pill{display:inline-block;padding:2px 7px;border-radius:999px;font-size:11px;border:1px solid var(--border)}.pri-none{color:var(--gray)}.pri-low{color:#60a5fa;border-color:#60a5fa59}.pri-medium{color:var(--yellow);border-color:#eab30859}.pri-high{color:var(--orange);border-color:#f9731659}.pri-urgent{color:var(--red);border-color:#ef444473;background:#ef444414}.list-table{width:100%;border-collapse:collapse}.list-table th,.list-table td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--border);font-size:13px}.list-table th{color:var(--muted);font-weight:500;position:sticky;top:0;background:var(--bg)}.list-table tr:hover td{background:var(--panel);cursor:pointer}.gantt{background:var(--panel);border:1px solid var(--border);border-radius:10px;overflow:auto}.gantt-head,.gantt-row{display:grid;grid-template-columns:240px 1fr;border-bottom:1px solid var(--border)}.gantt-head{position:sticky;top:0;background:var(--panel);z-index:1}.gantt-label{padding:8px 12px;border-right:1px solid var(--border);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gantt-track{position:relative;height:32px}.gantt-day-grid{position:absolute;top:0;right:0;bottom:0;left:0;display:flex}.gantt-day{flex:1 0 24px;border-right:1px solid rgba(255,255,255,.04)}.gantt-day.weekend{background:#ffffff05}.gantt-bar{position:absolute;top:6px;bottom:6px;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:4px;padding:0 8px;color:#fff;font-size:11px;display:flex;align-items:center;overflow:hidden;white-space:nowrap;box-shadow:0 1px #0000004d}.gantt-bar.done{background:linear-gradient(90deg,#16a34a,#22c55e)}.gantt-bar.urgent{background:linear-gradient(90deg,#b91c1c,#ef4444)}.gantt-month-row{display:grid;grid-template-columns:240px 1fr;background:var(--panel-2);border-bottom:1px solid var(--border)}.gantt-month-label{padding:6px 12px;color:var(--muted);font-size:12px;border-right:1px solid var(--border)}.gantt-months{display:flex}.gantt-month{font-size:11px;color:var(--muted);padding:4px 8px;border-right:1px solid var(--border)}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:grid;place-items:center;z-index:50}.modal{background:var(--panel);border:1px solid var(--border);border-radius:10px;width:min(560px,92vw);max-height:86vh;overflow:auto}.modal-head{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center}.modal-head h3{margin:0;font-size:16px}.modal-body{padding:16px 18px;display:grid;gap:12px}.modal-foot{padding:12px 18px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end}.field{display:grid;gap:4px}.field label{font-size:12px;color:var(--muted)}.row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.empty{text-align:center;padding:60px 20px;color:var(--muted)}.error{color:var(--red);padding:10px}.subtask{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px dashed var(--border)}.subtask:last-child{border:0}.subtask input[type=text]{flex:1}.kv{display:flex;gap:8px;align-items:center}.kv input{flex:1}
