@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=Space+Grotesk:wght@500;600;700&display=swap";:root,[data-theme=dark]{color-scheme:dark;--bg: #0f1117;--surface: #171a21;--surface-2: #1e222b;--surface-3: #262b36;--line: #2b313c;--line-soft: #232831;--ink: #eef1f6;--ink-2: #aab3c2;--ink-3: #6f7888;--brand: #6366f1;--brand-hi: #818cf8;--brand-dim: rgba(99, 102, 241, .14);--todo: #8b95a7;--todo-bg: rgba(139,149,167,.14);--prog: #3b82f6;--prog-bg: rgba(59,130,246,.15);--block: #f43f5e;--block-bg: rgba(244,63,94,.15);--done: #10b981;--done-bg: rgba(16,185,129,.15);--p-high: #fb7185;--p-med: #fbbf24;--p-low: #94a3b8;--overdue: #f43f5e;--soon: #fbbf24;--radius: 12px;--radius-sm: 8px;--shadow: 0 8px 24px rgba(0,0,0,.35);--overlay: rgba(8, 10, 14, .7);--error-text: #fda4af;--st-prog-text: #93c5fd;--st-block-text: #fda4af;--st-done-text: #6ee7b7;--shimmer: rgba(255, 255, 255, .03);--font-display: "Space Grotesk", system-ui, sans-serif;--font-body: "Inter", system-ui, sans-serif}[data-theme=light]{color-scheme:light;--bg: #f0f2f6;--surface: #ffffff;--surface-2: #f7f8fa;--surface-3: #eef0f4;--line: #dde1e8;--line-soft: #e8ebf0;--ink: #141820;--ink-2: #4a5160;--ink-3: #7a8394;--brand: #4f46e5;--brand-hi: #6366f1;--brand-dim: rgba(79, 70, 229, .12);--todo: #64748b;--todo-bg: rgba(100, 116, 139, .1);--prog: #2563eb;--prog-bg: rgba(37, 99, 235, .1);--block: #e11d48;--block-bg: rgba(225, 29, 72, .08);--done: #059669;--done-bg: rgba(5, 150, 105, .1);--p-high: #e11d48;--p-med: #d97706;--p-low: #64748b;--overdue: #e11d48;--soon: #d97706;--shadow: 0 8px 24px rgba(15, 23, 42, .08);--overlay: rgba(15, 20, 30, .45);--error-text: #be123c;--st-prog-text: #1d4ed8;--st-block-text: #be123c;--st-done-text: #047857;--shimmer: rgba(0, 0, 0, .04)}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;font-family:var(--font-body);background:var(--bg);color:var(--ink);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased}button{font-family:inherit}.app{max-width:1240px;margin:0 auto;padding:28px 24px 80px}.app-header{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:24px}.brand-row{display:flex;align-items:center;gap:12px}.brand-mark{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-hi) 100%);display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:18px;color:#fff;box-shadow:0 4px 14px #6366f166}.app-header h1{font-family:var(--font-display);font-weight:600;font-size:20px;margin:0;letter-spacing:-.01em}.subtitle{margin:2px 0 0;color:var(--ink-3);font-size:12.5px}.header-actions{display:flex;align-items:center;gap:10px}.synced{color:var(--ink-3);font-size:12px;display:flex;align-items:center;gap:6px}.synced .dot{width:6px;height:6px;border-radius:50%;background:var(--done)}.stats-wrap{margin-bottom:22px}.stats-scope{margin:0 0 8px;font-size:11.5px;color:var(--ink-3);letter-spacing:.02em}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.stat{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:16px 18px;position:relative;overflow:hidden}.stat:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px}.stat.s-open:before{background:var(--brand)}.stat.s-risk:before{background:var(--block)}.stat.s-soon:before{background:var(--soon)}.stat.s-shipped:before{background:var(--done)}.stat .num{font-family:var(--font-display);font-size:28px;font-weight:700;line-height:1;letter-spacing:-.02em}.stat .lbl{color:var(--ink-3);font-size:12px;margin-top:6px}.stat .sub{color:var(--ink-3);font-size:11px;margin-top:4px;line-height:1.35}.stat.alert .num{color:var(--block)}.stat.warn .num{color:var(--soon)}.stat-card{width:100%;text-align:left;cursor:pointer;transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease,background .14s ease}.stat-card:hover{transform:translateY(-2px);border-color:var(--line);box-shadow:var(--shadow)}.stat-card:focus-visible{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-dim)}.stat-card.active{border-color:var(--brand);background:var(--brand-dim);box-shadow:inset 0 0 0 1px #6366f133}.stat-card.active .stat-cta{color:var(--brand-hi)}.stat-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.stat-go{color:var(--ink-3);opacity:0;transform:translate(-4px);transition:opacity .14s ease,transform .14s ease,color .14s ease}.stat-card:hover .stat-go,.stat-card.active .stat-go{opacity:1;transform:translate(0);color:var(--brand-hi)}.stat-cta{display:block;margin-top:10px;font-size:10.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3)}.stat-bar{display:flex;height:5px;border-radius:3px;overflow:hidden;background:var(--surface-3);margin-top:10px}.stat-bar-seg{min-width:4px}.stat-bar-seg.seg-todo{background:var(--todo)}.stat-bar-seg.seg-prog{background:var(--prog)}.stat-bar-seg.seg-block{background:var(--block)}.stat-bar-shipped{position:relative}.stat-bar-fill{display:block;height:100%;background:linear-gradient(90deg,var(--done),#34d399);border-radius:3px;transition:width .35s ease}.stat-card.alert:not(.active){animation:stat-pulse 2.4s ease-in-out infinite}@keyframes stat-pulse{0%,to{box-shadow:none}50%{box-shadow:0 0 0 1px #f43f5e40}}.focus-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;padding:10px 14px;background:var(--brand-dim);border:1px solid rgba(99,102,241,.25);border-radius:var(--radius-sm);font-size:13px;color:var(--ink-2)}.focus-banner strong{color:var(--ink)}.tabs{display:inline-flex;background:var(--surface);border:1px solid var(--line-soft);border-radius:10px;padding:4px;margin-bottom:18px;gap:2px}.tabs button{background:none;border:none;padding:8px 16px;font-size:13px;font-weight:500;color:var(--ink-3);cursor:pointer;border-radius:7px;transition:all .14s ease}.tabs button:hover{color:var(--ink-2)}.tabs button.active{background:var(--surface-3);color:var(--ink)}.toolbar{display:flex;gap:10px;margin-bottom:14px;align-items:center;flex-wrap:wrap}.search{flex:1;min-width:200px;position:relative}.search input{width:100%;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:9px 12px 9px 34px;color:var(--ink);font-size:13px}.search input::placeholder{color:var(--ink-3)}.search input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-dim)}.search svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--ink-3)}.seg{display:inline-flex;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden}.seg button{background:none;border:none;padding:8px 12px;font-size:12.5px;color:var(--ink-3);cursor:pointer;border-right:1px solid var(--line)}.seg button:last-child{border-right:none}.seg button:hover{color:var(--ink-2);background:var(--surface-2)}.seg button.on{color:var(--ink);background:var(--surface-3)}.member-strip{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px;padding:4px 0}.member-chip{display:inline-flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:5px 12px 5px 5px;font-size:12.5px;color:var(--ink-2);cursor:pointer;transition:background .14s ease,border-color .14s ease,color .14s ease}.member-chip:first-child{padding-left:12px}.member-chip .avatar{width:24px;height:24px;font-size:10px}.member-chip:hover{background:var(--surface-2);color:var(--ink)}.member-chip.on{background:var(--brand-dim);border-color:var(--brand);color:var(--ink);box-shadow:0 0 0 1px #6366f126}.member-chip-label{font-weight:500}.btn-primary{background:var(--brand);color:#fff;border:none;border-radius:var(--radius-sm);padding:9px 16px;font-size:13px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:background .14s ease;white-space:nowrap}.btn-primary:hover{background:var(--brand-hi)}.btn-secondary{background:var(--surface-2);color:var(--ink-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:9px 16px;font-size:13px;cursor:pointer}.btn-secondary:hover{background:var(--surface-3);color:var(--ink)}.btn-ghost{background:none;border:1px solid var(--line);color:var(--ink-3);border-radius:var(--radius-sm);padding:8px 12px;font-size:12.5px;cursor:pointer}.btn-ghost:hover{color:var(--ink-2);border-color:var(--line);background:var(--surface)}.filter-select{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:8px 12px;color:var(--ink-2);font-size:12.5px;font-family:inherit;cursor:pointer;max-width:180px}.filter-select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-dim)}.theme-toggle{background:var(--surface);border:1px solid var(--line);color:var(--ink-2);border-radius:var(--radius-sm);padding:8px 12px;font-size:12.5px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:background .14s ease,color .14s ease,border-color .14s ease}.theme-toggle:hover{background:var(--surface-2);color:var(--ink);border-color:var(--line)}.theme-toggle svg{flex-shrink:0}.task-list{display:flex;flex-direction:column;gap:8px}.task-row{background:var(--surface);border:1px solid var(--line-soft);border-left-width:3px;border-radius:var(--radius);padding:13px 16px;display:grid;grid-template-columns:minmax(0,1fr) 150px 128px 200px 64px;gap:18px;align-items:center;transition:border-color .14s ease,background .14s ease;cursor:pointer}.task-row:hover{background:var(--surface-2);border-color:var(--line)}.task-row.expanded{align-items:start}.task-row .row-actions,.task-row .status-select-wrap{cursor:default}.task-row.b-todo{border-left-color:var(--todo)}.task-row.b-prog{border-left-color:var(--prog)}.task-row.b-block{border-left-color:var(--block)}.task-row.b-done{border-left-color:var(--done)}.task-row.b-done .task-title{color:var(--ink-2)}.task-main{min-width:0}.task-title{font-weight:500;font-size:13.5px;margin:0 0 4px;display:flex;align-items:flex-start;gap:6px;min-width:0}.task-title>span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1}.task-chevron{flex-shrink:0;margin-top:2px;color:var(--ink-3);transition:transform .15s ease,color .15s ease}.task-row:hover .task-chevron{color:var(--ink-2)}.task-chevron.open{transform:rotate(180deg);color:var(--brand-hi)}.task-description{grid-column:1 / -1;margin-top:2px;padding-top:12px;border-top:1px solid var(--line-soft)}.task-description-label{display:block;font-size:10px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);margin-bottom:6px}.task-description p{margin:0;font-size:13px;line-height:1.55;color:var(--ink-2);white-space:pre-wrap}.task-description-empty{color:var(--ink-3);font-style:italic}.task-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.chip{font-size:11px;color:var(--ink-3);background:var(--surface-3);padding:2px 7px;border-radius:5px}.chip.feature{color:var(--ink-2)}.chip.project{color:var(--brand-hi);background:var(--brand-dim)}.pri{font-size:11px;font-weight:600;display:inline-flex;align-items:center;gap:4px}.pri:before{content:"";width:6px;height:6px;border-radius:50%}.pri.high{color:var(--p-high)}.pri.high:before{background:var(--p-high)}.pri.medium{color:var(--p-med)}.pri.medium:before{background:var(--p-med)}.pri.low{color:var(--p-low)}.pri.low:before{background:var(--p-low)}.note-inline{font-size:11.5px;color:var(--ink-3);display:inline-flex;align-items:center;gap:5px}.note-inline.blocker{color:var(--block)}.task-row.solo-member{grid-template-columns:minmax(0,1fr) 128px 200px 64px}.assignee{display:flex;align-items:center;gap:8px;min-width:0}.avatar{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:600;color:#fff;flex-shrink:0}.assignee .name{font-size:12.5px;color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-select{border:1px solid transparent;border-radius:6px;padding:5px 24px 5px 8px;font-size:12px;font-weight:600;cursor:pointer;width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-position:right 8px center;background-repeat:no-repeat;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%236f7888' stroke-width='3'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E")}.status-select:focus{outline:none;box-shadow:0 0 0 3px var(--brand-dim)}.st-todo{background-color:var(--todo-bg);color:var(--todo)}.st-prog{background-color:var(--prog-bg);color:var(--st-prog-text)}.st-block{background-color:var(--block-bg);color:var(--st-block-text)}.st-done{background-color:var(--done-bg);color:var(--st-done-text)}.prog-col{display:flex;flex-direction:column;gap:5px;min-width:0}.prog-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.date-stack{display:flex;flex-direction:column;gap:2px;min-width:0}.assigned-date{font-size:10.5px;color:var(--ink-3);white-space:nowrap}.prog-pct{font-family:var(--font-display);font-size:12px;font-weight:600;color:var(--ink-2);flex-shrink:0}.due{font-size:11px;color:var(--ink-3);line-height:1.35}.due.overdue{color:var(--overdue);font-weight:600}.due.soon{color:var(--soon)}.due-sub{font-weight:600}.task-dates-row{display:flex;flex-wrap:wrap;gap:14px;font-size:12px;color:var(--ink-2);margin-bottom:10px}.task-dates-row strong{color:var(--ink-3);font-weight:600;margin-right:4px}.date-cell{font-size:12.5px;color:var(--ink-2);white-space:nowrap}.pct-cell.muted{color:var(--ink-3);font-size:12px}.progress-track{height:5px;background:var(--surface-3);border-radius:3px;overflow:hidden}.progress-fill{height:100%;border-radius:3px;transition:width .3s ease}.row-actions{display:flex;gap:4px;opacity:0;transition:opacity .14s ease}.task-row:hover .row-actions{opacity:1}.icon-btn{background:none;border:none;cursor:pointer;color:var(--ink-3);padding:6px;border-radius:6px;display:grid;place-items:center}.icon-btn:hover{color:var(--ink);background:var(--surface-3)}.icon-btn.danger:hover{color:var(--block);background:var(--block-bg)}.empty{text-align:center;padding:56px 20px;background:var(--surface);border:1px dashed var(--line);border-radius:var(--radius)}.empty .big{font-family:var(--font-display);font-size:15px;margin-bottom:6px}.empty .small{color:var(--ink-3);font-size:13px;margin-bottom:18px}.dashboard{display:flex;flex-direction:column;gap:18px}.perf-block{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:18px 20px}.perf-block h3{font-family:var(--font-display);font-weight:600;font-size:14px;margin:0;display:flex;align-items:center;gap:8px}.perf-block-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px}.perf-hint{margin:4px 0 0;color:var(--ink-3);font-size:12px}.perf-table{width:100%;border-collapse:collapse;font-size:13px}.perf-table th{text-align:left;padding:8px 10px;color:var(--ink-3);font-weight:500;font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--line)}.perf-table th.num,.perf-table td.num{text-align:right;font-variant-numeric:tabular-nums}.perf-table td{padding:10px;border-bottom:1px solid var(--line-soft)}.perf-table tr:last-child td{border-bottom:none}.perf-name{display:flex;align-items:center;gap:9px}.mini-bar{width:70px;height:6px;background:var(--surface-3);border-radius:3px;overflow:hidden;display:inline-block;vertical-align:middle}.mini-fill{height:100%;background:var(--brand);border-radius:3px}.totals-row td{font-weight:600;color:var(--ink);border-top:1px solid var(--line);background:var(--surface-2)}.pct-cell{font-family:var(--font-display);font-weight:600}.kpi-dashboard{gap:20px}.kpi-dashboard .perf-block{overflow-x:auto}.kpi-table tbody tr.kpi-row{cursor:pointer;transition:background .12s ease}.kpi-table tbody tr.kpi-row:hover{background:var(--surface-2)}.kpi-table tbody tr.kpi-row.selected{background:var(--brand-dim);box-shadow:inset 3px 0 0 var(--brand)}.kpi-score{font-family:var(--font-display);font-weight:700;font-size:15px}.kpi-grade{display:inline-grid;place-items:center;min-width:28px;height:28px;border-radius:7px;font-family:var(--font-display);font-weight:700;font-size:12px}.kpi-score.tone-good,.kpi-grade.tone-good{color:var(--done);background:var(--done-bg)}.kpi-score.tone-mid,.kpi-grade.tone-mid{color:var(--soon);background:#fbbf241f}.kpi-score.tone-low,.kpi-grade.tone-low{color:var(--block);background:var(--block-bg)}.kpi-grade.tone-good,.kpi-grade.tone-mid,.kpi-grade.tone-low{padding:0 6px}.perf-health-card{display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:center;background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:22px 24px}.perf-health-card.tone-good{border-color:color-mix(in srgb,var(--done) 35%,var(--line-soft))}.perf-health-card.tone-mid{border-color:color-mix(in srgb,var(--soon) 30%,var(--line-soft))}.perf-health-card.tone-low{border-color:color-mix(in srgb,var(--block) 35%,var(--line-soft))}.perf-health-gauge{position:relative;width:128px;height:128px;flex-shrink:0}.perf-health-ring{width:100%;height:100%;transform:rotate(-90deg)}.perf-health-ring-bg{fill:none;stroke:var(--surface-3);stroke-width:10}.perf-health-ring-fill{fill:none;stroke-width:10;stroke-linecap:round;transition:stroke-dashoffset .4s ease}.perf-health-gauge-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}.perf-health-score{font-family:var(--font-display);font-size:32px;font-weight:700;line-height:1;font-variant-numeric:tabular-nums}.perf-health-score.muted{font-size:28px;color:var(--ink-3)}.perf-health-grade{font-family:var(--font-display);font-size:13px;font-weight:700;letter-spacing:.04em}.perf-health-card.tone-good .perf-health-score,.perf-health-card.tone-good .perf-health-grade{color:var(--done)}.perf-health-card.tone-mid .perf-health-score,.perf-health-card.tone-mid .perf-health-grade{color:var(--soon)}.perf-health-card.tone-low .perf-health-score,.perf-health-card.tone-low .perf-health-grade{color:var(--block)}.perf-health-body{min-width:0}.perf-health-body h3{margin:0 0 6px;font-family:var(--font-display);font-weight:600;font-size:18px}.perf-health-sub{margin:0 0 16px;font-size:13px;color:var(--ink-3);line-height:1.45}.perf-health-stats{display:flex;flex-wrap:wrap;gap:20px}.perf-health-stat{display:flex;flex-direction:column;gap:2px}.perf-health-stat-val{font-family:var(--font-display);font-size:22px;font-weight:700;font-variant-numeric:tabular-nums;line-height:1}.perf-health-stat-label{font-size:11.5px;color:var(--ink-3)}.perf-health-stat.stat-good .perf-health-stat-val{color:var(--done)}.perf-health-stat.stat-warn .perf-health-stat-val{color:var(--block)}@media (max-width: 640px){.perf-health-card{grid-template-columns:1fr;justify-items:center;text-align:center}.perf-health-stats{justify-content:center}}.status-pill{display:inline-block;border-radius:6px;padding:4px 8px;font-size:11.5px;font-weight:600;white-space:nowrap}.task-detail-table tbody tr.task-detail-row{cursor:pointer;transition:background .12s ease}.task-detail-table tbody tr.task-detail-row:hover{background:var(--surface-2)}.task-detail-table .task-cell{font-weight:500;max-width:280px}.projects-panel{display:flex;flex-direction:column;gap:16px}.projects-add-project{display:flex;gap:10px;flex-wrap:wrap}.projects-add-project input{flex:1;min-width:200px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:9px 12px;color:var(--ink);font-size:13px}.projects-add-project input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-dim)}.project-cards{display:flex;flex-direction:column;gap:14px}.project-card{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:18px 20px}.project-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px}.project-card-head h3{font-family:var(--font-display);font-weight:600;font-size:16px;margin:0}.project-meta{margin:4px 0 0;color:var(--ink-3);font-size:12px}.project-card-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.feature-list{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.feature-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:10px;align-items:center;padding:8px 10px;background:var(--surface-2);border:1px solid var(--line-soft);border-radius:var(--radius-sm)}.feature-name{font-size:13px;font-weight:500}.feature-count{font-size:11.5px;color:var(--ink-3);white-space:nowrap}.feature-actions{display:flex;align-items:center;gap:2px}.feature-add{display:flex;gap:8px;flex-wrap:wrap}.feature-add input{flex:1;min-width:160px;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:8px 11px;color:var(--ink);font-size:13px}.feature-add input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-dim)}.inline-edit{display:flex;gap:8px;flex-wrap:wrap;align-items:center;width:100%}.inline-edit input{flex:1;min-width:140px;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:7px 10px;color:var(--ink);font-size:13px}.inline-edit input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-dim)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;animation:fade .12s ease}@keyframes fade{0%{opacity:0}}.modal{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:24px;width:540px;max-width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow);animation:pop .16s cubic-bezier(.2,.9,.3,1.2)}@keyframes pop{0%{transform:translateY(8px) scale(.98);opacity:0}}.modal h3{font-family:var(--font-display);font-weight:600;font-size:17px;margin:0 0 4px}.modal .modal-sub{color:var(--ink-3);font-size:12.5px;margin:0 0 18px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:12px;color:var(--ink-2);font-weight:500}.field input,.field select,.field textarea{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:9px 11px;color:var(--ink);font-size:13px;font-family:inherit}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-dim)}.field textarea{resize:vertical;min-height:56px}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.field-row.three{grid-template-columns:1fr 1fr 1fr}.range-row{display:flex;align-items:center;gap:12px}.range-row input[type=range]{flex:1;accent-color:var(--brand)}.range-val{font-family:var(--font-display);font-weight:600;font-size:14px;width:44px;text-align:right}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:8px}.error-banner{background:var(--block-bg);border:1px solid rgba(244,63,94,.3);color:var(--error-text);padding:10px 14px;border-radius:var(--radius-sm);margin-bottom:14px;font-size:13px;display:flex;align-items:center;gap:8px}.skel-row{height:64px;background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);margin-bottom:8px;position:relative;overflow:hidden}.skel-row:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,var(--shimmer),transparent);animation:shimmer 1.3s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@media (max-width: 860px){.stats{grid-template-columns:repeat(2,1fr)}.task-row{grid-template-columns:minmax(0,1fr) 150px;grid-template-areas:"main      status" "assignee  prog" "actions   actions";gap:12px 14px;align-items:start}.task-main{grid-area:main;min-width:0}.task-title>span{white-space:normal}.assignee{grid-area:assignee}.status-select-wrap{grid-area:status}.status-select{width:150px}.prog-col{grid-area:prog}.row-actions{grid-area:actions;opacity:1;justify-content:flex-end;gap:8px}.row-actions .icon-btn{border:1px solid var(--line)}}@media (max-width: 560px){.app{padding:18px 14px 60px}.app-header{flex-wrap:wrap}.stats{grid-template-columns:1fr 1fr;gap:10px}.stat{padding:13px 14px}.stat .num{font-size:24px}.field-row,.field-row.three{grid-template-columns:1fr}.modal{padding:18px}.task-row{grid-template-columns:minmax(0,1fr);grid-template-areas:"main" "meta-extra" "assignee" "status" "prog" "actions";gap:11px}.status-select{width:100%}.toolbar{gap:8px}.search{flex:1 1 100%;order:1}.seg{order:2;overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch}.seg::-webkit-scrollbar{display:none}.btn-primary{order:3;flex:1 1 100%;justify-content:center}}@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}.stat-card:hover{transform:none}}.auth-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;color:var(--ink-3);font-size:13px}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.login-card{background:var(--surface);border:1px solid var(--line-soft);border-radius:16px;padding:32px 28px;width:380px;max-width:100%;box-shadow:var(--shadow)}.login-card h2{font-family:var(--font-display);font-weight:600;font-size:19px;text-align:center;margin:0}.user-menu{display:flex;align-items:center;gap:8px;padding-left:10px;margin-left:2px;border-left:1px solid var(--line)}.user-name{font-size:12.5px;color:var(--ink-2);white-space:nowrap}@media (max-width: 560px){.header-actions{flex-wrap:wrap;gap:8px;row-gap:8px}.user-menu{border-left:none;padding-left:0;margin-left:0;width:100%;justify-content:space-between}}.summary-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:12px 16px;margin-bottom:10px}.summary-bar-text{font-size:13px;color:var(--ink-2)}.summary-bar-text strong{color:var(--ink)}.summary-bar-warn{color:var(--block);font-size:12px}.summary-success{background:var(--done-bg);border:1px solid rgba(16,185,129,.3);color:#6ee7b7;padding:10px 14px;border-radius:var(--radius-sm);margin-bottom:10px;font-size:13px}@media (max-width: 560px){.summary-bar{flex-direction:column;align-items:stretch}.summary-bar .btn-primary{width:100%;justify-content:center}}.people-panel{display:flex;flex-direction:column;gap:12px}.people-add{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:16px}.people-add-grid{display:grid;grid-template-columns:1.2fr 1.4fr 1fr 1fr auto auto;gap:10px;align-items:center}.people-add input,.people-add select{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:8px 10px;color:var(--ink);font-size:13px}.chk{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--ink-2);white-space:nowrap}.chk input{accent-color:var(--brand)}.people-list{display:flex;flex-direction:column;gap:8px}.person-card{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:12px 16px}.person-info{flex:1;min-width:0}.person-name-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.person-email{font-size:12.5px;color:var(--ink-3);margin-top:2px}.person-actions{display:flex;gap:4px}.danger-text:hover{color:var(--block)!important}.role-badge{font-size:10.5px;font-weight:600;padding:2px 7px;border-radius:5px;text-transform:uppercase;letter-spacing:.03em}.role-super{background:#a855f72e;color:#c4b5fd}.role-admin{background:#3b82f62e;color:#93c5fd}.role-member{background:#94a3b82e;color:#cbd5e1}.role-none{background:var(--surface-3);color:var(--ink-3)}.recipient-tag{font-size:11px;color:var(--done)}.recipient-tag.muted{color:var(--ink-3)}.people-add-hint{margin:0 0 10px;font-size:12.5px;color:var(--ink-3)}.person-edit{display:grid;grid-template-columns:1fr 1fr 1fr 1fr auto auto;gap:8px;align-items:center;width:100%}.person-edit input,.person-edit select{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:7px 9px;color:var(--ink);font-size:12.5px}.person-edit-actions{display:flex;gap:6px}@media (max-width: 760px){.people-add-grid,.person-edit{grid-template-columns:1fr}.person-card{flex-wrap:wrap}}.tasks-panel{min-width:0}.calendar-panel{display:flex;flex-direction:column;gap:16px}.calendar-filters{margin-bottom:-4px}.calendar-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}.calendar-nav-group{display:flex;align-items:center;gap:8px}.calendar-month-title{margin:0;min-width:170px;text-align:center;font-size:18px;font-family:var(--font-display);font-weight:600}.cal-nav{background:none;border:1px solid var(--line);color:var(--ink-2);width:30px;height:30px;border-radius:8px;cursor:pointer;font-size:18px;line-height:1}.cal-nav:hover{background:var(--surface-3);color:var(--ink)}.cal-today-btn{margin-left:4px}.calendar-scope{font-size:12.5px;color:var(--ink-3)}.calendar-stats{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.calendar-stat{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:12px 14px}.calendar-stat-val{display:block;font-size:22px;font-weight:700;font-family:var(--font-display);font-variant-numeric:tabular-nums;line-height:1.1}.calendar-stat-label{font-size:11.5px;color:var(--ink-3)}.cal-stat-warn .calendar-stat-val{color:var(--block)}.cal-stat-soon .calendar-stat-val{color:var(--warn, #f59e0b)}.cal-stat-done .calendar-stat-val{color:var(--done)}.calendar-body{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:16px;align-items:start}.calendar-month-card{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:16px 18px 14px}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.cal-grid-main{margin-top:6px}.cal-dow{margin-bottom:2px}.cal-dow-cell{text-align:center;font-size:11px;font-weight:600;color:var(--ink-3);padding:4px 0}.cal-cell{position:relative;min-height:72px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:8px 4px 6px;font-size:13px;color:var(--ink-2);border-radius:10px;border:1px solid transparent}.cal-cell-btn{background:var(--surface-2);cursor:pointer;text-align:center;transition:border-color .15s,background .15s,box-shadow .15s}.cal-cell-btn:hover{border-color:var(--line);background:var(--surface-3);color:var(--ink)}.cal-cell.empty{visibility:hidden;pointer-events:none}.cal-cell.today{box-shadow:inset 0 0 0 2px var(--brand)}.cal-cell.selected{border-color:var(--brand);background:var(--brand-dim);color:var(--ink)}.cal-cell.has-tasks{background:var(--surface-3)}.cal-num{line-height:1;font-weight:600;font-variant-numeric:tabular-nums}.cal-day-meta{margin-top:auto;display:flex;flex-direction:column;align-items:center;gap:4px;width:100%}.cal-count{font-size:10px;font-weight:700;color:var(--ink-3);font-variant-numeric:tabular-nums}.cal-dots{display:flex;gap:3px;justify-content:center;flex-wrap:wrap}.cal-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.cal-dot-todo{background:var(--todo)}.cal-dot-prog{background:var(--prog)}.cal-dot-block{background:var(--block)}.cal-dot-done{background:var(--done)}.cal-dot-deadline{background:#a78bfa}.cal-dot-overdue{background:var(--block)}.cal-dot-soon{background:var(--warn, #f59e0b)}.cal-tone-overdue.cal-cell-btn{border-color:color-mix(in srgb,var(--block) 40%,transparent)}.cal-tone-soon.cal-cell-btn{border-color:color-mix(in srgb,var(--warn, #f59e0b) 35%,transparent)}.cal-tone-done.cal-cell-btn{opacity:.72}.cal-legend{margin-top:12px;font-size:11px;color:var(--ink-3);display:flex;align-items:center;gap:6px}.cal-legend-wide{flex-wrap:wrap;gap:14px}.cal-legend-wide span{display:inline-flex;align-items:center;gap:6px}.cal-legend .cal-dot{position:static;transform:none}.calendar-detail{display:flex;flex-direction:column;gap:14px;position:sticky;top:16px}.calendar-detail-section{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:14px 16px}.calendar-detail-section h3{margin:0 0 10px;font-size:13px;font-family:var(--font-display);font-weight:600}.calendar-detail-empty{margin:0;font-size:12.5px;color:var(--ink-3)}.calendar-task-list,.calendar-upcoming-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.calendar-task-row,.calendar-upcoming-row{width:100%;display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:start;background:var(--surface-2);border:1px solid transparent;border-radius:8px;padding:8px 10px;cursor:pointer;text-align:left;color:inherit}.calendar-task-row:hover,.calendar-upcoming-row:hover{border-color:var(--line);background:var(--surface-3)}.calendar-task-main{min-width:0;display:flex;flex-direction:column;gap:2px}.calendar-task-main strong{font-size:12.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar-task-sub{font-size:11px;color:var(--ink-3)}.calendar-task-pct{font-size:11px;color:var(--ink-3);font-variant-numeric:tabular-nums}.calendar-upcoming-row{grid-template-columns:52px 1fr auto;align-items:center}.calendar-upcoming-date{font-size:11px;font-weight:700;font-variant-numeric:tabular-nums}.calendar-upcoming-date.tone-overdue{color:var(--block)}.calendar-upcoming-date.tone-soon{color:var(--warn, #f59e0b)}.calendar-upcoming-task{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar-upcoming-who{font-size:11px;color:var(--ink-3);white-space:nowrap}.calendar-more{margin:8px 0 0;font-size:11px;color:var(--ink-3)}.calendar-deadline-list,.calendar-deadline-upcoming{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.calendar-deadline-list-spaced{margin-top:10px}.calendar-deadline-row{display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:center;width:100%;padding:8px 10px;border:none;border-radius:8px;background:color-mix(in srgb,#a78bfa 12%,var(--surface-2));text-align:left;color:inherit;font:inherit;cursor:default}.calendar-deadline-row:not(:disabled){cursor:pointer}.calendar-deadline-row:not(:disabled):hover{background:color-mix(in srgb,#a78bfa 18%,var(--surface-3))}.calendar-deadline-main{min-width:0;display:flex;flex-direction:column;gap:2px}.calendar-deadline-main strong{font-size:12.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar-deadline-upcoming-row .calendar-upcoming-task{display:flex;align-items:center;gap:6px;min-width:0}.calendar-deadline-upcoming-row .deadline-item-type{flex-shrink:0}@media (max-width: 980px){.calendar-stats{grid-template-columns:repeat(3,minmax(0,1fr))}.calendar-body{grid-template-columns:1fr}.calendar-detail{position:static}}@media (max-width: 640px){.calendar-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.cal-cell{min-height:56px;padding-top:6px}.calendar-month-title{min-width:0;font-size:16px}}.gantt-wrap{display:flex;flex-direction:column;gap:16px}.gantt-card{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:16px 18px}.gantt-card-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:12px}.gantt-card-header h3{margin:0;font-size:15px;font-family:var(--font-display)}.gantt-range{font-size:12px;color:var(--ink-3)}.gantt-rows{display:flex;flex-direction:column;gap:6px}.gantt-row{display:grid;grid-template-columns:180px 1fr;gap:12px;align-items:center;background:none;border:none;cursor:pointer;padding:4px;border-radius:6px;text-align:left}.gantt-row:hover{background:var(--surface-2)}.gantt-label{font-size:12.5px;color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gantt-row:hover .gantt-label{color:var(--ink)}.gantt-track{position:relative;height:22px;background:var(--surface-3);border-radius:6px}.gantt-bar{position:absolute;top:0;bottom:0;border-radius:6px;min-width:8px;display:flex;align-items:center;padding:0 6px}.gantt-bar-pct{font-size:10px;color:#fff;font-weight:600;white-space:nowrap}@media (max-width: 640px){.gantt-row{grid-template-columns:110px 1fr}}.deadlines-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px}.deadlines-panel{display:flex;flex-direction:column;gap:16px}.deadlines-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.deadline-card{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:16px 18px;display:flex;flex-direction:column;gap:12px}.deadline-card.tone-overdue{border-color:color-mix(in srgb,var(--block) 40%,var(--line-soft))}.deadline-card.tone-soon{border-color:color-mix(in srgb,var(--warn, #f59e0b) 35%,var(--line-soft))}.deadline-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.deadline-card-title h3{margin:0;font-family:var(--font-display);font-size:16px;font-weight:600}.deadline-card-desc{margin:4px 0 0;font-size:12.5px;color:var(--ink-3);line-height:1.45}.deadline-card-due{margin:4px 0 0;font-family:var(--font-display);font-size:13px;font-weight:700}.deadline-card-due.tone-overdue{color:var(--block)}.deadline-card-due.tone-soon{color:var(--warn, #f59e0b)}.deadline-card-due.tone-done{color:var(--done)}.deadline-card-actions{display:flex;gap:4px;flex-shrink:0}.deadline-card-stats{display:flex;flex-wrap:wrap;gap:8px}.deadline-stat{font-size:11px;font-weight:600;padding:3px 8px;border-radius:5px;background:var(--surface-2);color:var(--ink-3)}.deadline-stat.stat-overdue{background:var(--block-bg);color:#fda4af}.deadline-stat.stat-soon{background:color-mix(in srgb,var(--warn, #f59e0b) 15%,transparent);color:var(--warn, #f59e0b)}.deadline-card-items{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.deadline-item-btn{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;width:100%;padding:8px 10px;border:none;border-radius:8px;background:var(--surface-2);text-align:left;color:inherit;font:inherit}.deadline-item-btn.clickable{cursor:pointer}.deadline-item-btn.clickable:hover{background:var(--surface-3)}.deadline-item-btn:disabled{cursor:default;opacity:1}.deadline-item-date{font-size:11px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--ink-2)}.deadline-item-date.tone-overdue{color:var(--block)}.deadline-item-date.tone-soon{color:var(--warn, #f59e0b)}.deadline-item-date.tone-done{color:var(--done)}.deadline-item-body{min-width:0;display:flex;flex-direction:column;gap:2px}.deadline-item-label{font-size:12.5px;font-weight:500;display:flex;align-items:center;gap:6px;min-width:0}.deadline-item-label>:not(.deadline-item-type){white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.deadline-item-sub{font-size:11px;color:var(--ink-3)}.deadline-item-type{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:2px 5px;border-radius:4px;flex-shrink:0}.deadline-item-type.type-feature{background:var(--prog-bg);color:#93c5fd}.deadline-item-type.type-task{background:var(--done-bg);color:#6ee7b7}.deadline-item-status{display:flex;align-items:center;gap:6px;flex-shrink:0}.deadline-item-badge{font-size:10.5px;font-weight:600;white-space:nowrap}.deadline-item-badge.tone-overdue{color:var(--block)}.deadline-item-badge.tone-soon{color:var(--warn, #f59e0b)}.deadlines-empty{margin-top:24px}.deadline-modal{width:min(560px,96vw)}.deadline-items-section{margin-bottom:16px}.deadline-items-label{display:block;font-size:12px;font-weight:600;margin-bottom:4px}.deadline-items-hint{margin:0 0 12px;font-size:12px;color:var(--ink-3)}.deadline-item-list{list-style:none;margin:0 0 12px;padding:0;display:flex;flex-direction:column;gap:4px}.deadline-item-row{display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:center;padding:8px 10px;background:var(--surface-2);border-radius:8px;font-size:12.5px}.deadline-item-row .deadline-item-name{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.deadline-item-row .deadline-item-date{font-size:11px;color:var(--ink-3);font-variant-numeric:tabular-nums}.deadline-add-row{display:grid;grid-template-columns:90px 1fr auto;gap:8px;align-items:center}.deadline-add-row select,.deadline-add-row input[type=date]{width:100%;padding:8px 10px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--ink);font-size:12.5px}@media (max-width: 640px){.deadlines-grid,.deadline-add-row{grid-template-columns:1fr}}.audit-panel{display:flex;flex-direction:column;gap:12px}.audit-toolbar{display:flex;align-items:center;justify-content:space-between}.audit-count{font-size:12px;color:var(--ink-3)}.audit-list{display:flex;flex-direction:column;gap:6px}.audit-entry{display:flex;gap:12px;align-items:flex-start;background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:12px 14px}.audit-badge{font-size:10.5px;font-weight:700;padding:3px 8px;border-radius:5px;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;flex-shrink:0}.audit-create{background:var(--done-bg);color:#6ee7b7}.audit-update{background:var(--prog-bg);color:#93c5fd}.audit-delete{background:var(--block-bg);color:#fda4af}.audit-body{min-width:0;flex:1}.audit-line{display:flex;align-items:baseline;gap:8px}.audit-entity{font-size:10.5px;text-transform:uppercase;color:var(--ink-3);letter-spacing:.03em}.audit-details{margin-top:4px;display:flex;flex-wrap:wrap;gap:4px 12px}.audit-detail{font-size:11.5px;color:var(--ink-2)}.audit-detail em{color:var(--ink-3);font-style:normal}.audit-meta{margin-top:5px;font-size:11px;color:var(--ink-3)}.task-desc{font-size:12px;color:var(--ink-3);margin-top:3px}
