@import url(https://fonts.googleapis.com/css2?family=Golos+Text:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap);@keyframes skeleton-loading{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.skeleton{animation:skeleton-loading 1.5s ease-in-out infinite;background:linear-gradient(90deg,var(--surface-2) 0,var(--surface-3) 50%,var(--surface-2) 100%);background-size:200px 100%;display:inline-block;opacity:.7}[data-theme=dark] .skeleton{background:linear-gradient(90deg,#ffffff0d,#ffffff1a 50%,#ffffff0d);background-size:200px 100%}*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f5f4f0;--surface:#fff;--border:#00000017;--border-md:#00000026;--text-1:#1a1a18;--text-2:#6b6b67;--text-3:#a8a8a4;--accent:#2b5ce6;--accent-bg:#eef2fd;--green:#1a7a4a;--green-bg:#e8f5ee;--amber:#9a5700;--amber-bg:#fff4e0;--red:#c0392b;--red-bg:#fdeeec;--purple:#5b3fbe;--purple-bg:#f0ecfd;--radius-sm:6px;--radius:10px;--radius-lg:14px;--shadow:0 1px 3px #00000012,0 1px 2px #0000000d;--font:"Golos Text",system-ui,sans-serif;--mono:"JetBrains Mono",monospace;--nav-w:220px}[data-theme=dark]{--bg:#1a1a1a;--surface:#242424;--border:#ffffff14;--border-md:#ffffff1f;--text-1:#eee;--text-2:#a8a8a8;--text-3:#707070;--accent:#5b8eff;--accent-bg:#1e2a42;--green:#4ade80;--green-bg:#1a3a2a;--amber:#fbbf24;--amber-bg:#3a2e1a;--red:#fb7185;--red-bg:#3a1a1f;--purple:#a78bfa;--purple-bg:#2a2042;--shadow:0 1px 3px #0000004d,0 1px 2px #0003}body{transition:background-color .2s ease,color .2s ease}.btn,.card,.filter-pill,.form-input,.form-select,.form-textarea,.login-card,.modal,.nav-item,.sidebar,.stat-card,.task-row,.topbar,.user-chip{transition:background-color .2s ease,color .2s ease,border-color .2s ease}#root,body,html{height:100%}body{-webkit-font-smoothing:antialiased;background:#f5f4f0;background:var(--bg);color:#1a1a18;color:var(--text-1);font-family:Golos Text,system-ui,sans-serif;font-family:var(--font);font-size:14px;line-height:1.5}.app-shell{display:flex;height:100vh;overflow:hidden}.sidebar{background:#fff;background:var(--surface);border-right:1px solid #00000017;border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;width:220px;width:var(--nav-w)}.main-area{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.page-content{flex:1 1;overflow-y:auto;padding:24px}.sidebar-logo{border-bottom:1px solid #00000017;border-bottom:1px solid var(--border);padding:20px 16px 16px}.sidebar-logo-title{color:#1a1a18;color:var(--text-1);font-size:15px;font-weight:600;letter-spacing:-.2px}.sidebar-logo-sub{color:#a8a8a4;color:var(--text-3);font-size:11px;margin-top:2px}.nav-section{padding:12px 8px 4px}.nav-section-label{color:#a8a8a4;color:var(--text-3);font-size:10px;font-weight:600;letter-spacing:.06em;margin-bottom:4px;padding:0 8px;text-transform:uppercase}.nav-item{align-items:center;border-radius:6px;border-radius:var(--radius-sm);color:#6b6b67;color:var(--text-2);cursor:pointer;display:flex;font-size:13.5px;gap:9px;margin-bottom:1px;padding:8px 10px;text-decoration:none;transition:background .12s,color .12s}.nav-item:hover{background:#f5f4f0;background:var(--bg);color:#1a1a18;color:var(--text-1)}.nav-item.active{background:#eef2fd;background:var(--accent-bg);color:#2b5ce6;color:var(--accent);font-weight:500}.nav-item svg{flex-shrink:0;opacity:.7}.nav-item.active svg{opacity:1}.nav-badge{background:#fdeeec;background:var(--red-bg);border-radius:10px;color:#c0392b;color:var(--red);font-size:11px;font-weight:600;margin-left:auto;padding:1px 6px}.sidebar-footer{border-top:1px solid #00000017;border-top:1px solid var(--border);margin-top:auto;padding:12px 8px}.user-chip{align-items:center;border-radius:6px;border-radius:var(--radius-sm);cursor:pointer;display:flex;gap:9px;padding:8px 10px;transition:background .12s}.user-chip:hover{background:#f5f4f0;background:var(--bg)}.avatar{align-items:center;background:#eef2fd;background:var(--accent-bg);border-radius:50%;color:#2b5ce6;color:var(--accent);display:flex;flex-shrink:0;font-size:12px;font-weight:600;height:30px;justify-content:center;width:30px}.user-chip-name{color:#1a1a18;color:var(--text-1);font-size:13px;font-weight:500}.user-chip-role{color:#a8a8a4;color:var(--text-3);font-size:11px}.topbar{align-items:center;background:#fff;background:var(--surface);border-bottom:1px solid #00000017;border-bottom:1px solid var(--border);display:flex;flex-shrink:0;gap:12px;height:52px;padding:0 24px}.topbar-title{color:#1a1a18;color:var(--text-1);font-size:15px;font-weight:600}.topbar-spacer{flex:1 1}.card{background:#fff;background:var(--surface);border:1px solid #00000017;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #00000012,0 1px 2px #0000000d;box-shadow:var(--shadow)}.card-pad{padding:20px}.stat-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,1fr);margin-bottom:20px}.stat-card{background:#fff;background:var(--surface);border:1px solid #00000017;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #00000012,0 1px 2px #0000000d;box-shadow:var(--shadow);padding:16px 18px}.stat-num{color:#1a1a18;color:var(--text-1);font-size:28px;font-weight:600;line-height:1}.stat-num.green{color:#1a7a4a;color:var(--green)}.stat-num.amber{color:#9a5700;color:var(--amber)}.stat-num.red{color:#c0392b;color:var(--red)}.stat-num.accent{color:#2b5ce6;color:var(--accent)}.stat-label{color:#6b6b67;color:var(--text-2);font-size:12px;margin-top:5px}.badge{align-items:center;border-radius:20px;display:inline-flex;font-size:11px;font-weight:500;padding:2px 8px;white-space:nowrap}.badge-work{background:#eef2fd;background:var(--accent-bg);color:#2b5ce6;color:var(--accent)}.badge-done{background:#e8f5ee;background:var(--green-bg);color:#1a7a4a;color:var(--green)}.badge-review{background:#fff4e0;background:var(--amber-bg);color:#9a5700;color:var(--amber)}.badge-new{background:#f0ecfd;background:var(--purple-bg);color:#5b3fbe;color:var(--purple)}.badge-cancel{background:#f0f0ee;color:#6b6b67;color:var(--text-2)}.badge-high{background:#fdeeec;background:var(--red-bg);color:#c0392b;color:var(--red)}.badge-medium{background:#fff4e0;background:var(--amber-bg);color:#9a5700;color:var(--amber)}.badge-low{background:#f0f0ee}.badge-dept,.badge-low{color:#6b6b67;color:var(--text-2)}.badge-dept{background:#f5f4f0;background:var(--bg);border:1px solid #00000017;border:1px solid var(--border)}.badge-type{background:#f0ecfd;background:var(--purple-bg);color:#5b3fbe;color:var(--purple)}[data-theme=dark] .badge-cancel,[data-theme=dark] .badge-low{background:#2a2a2a}.btn{align-items:center;background:#fff;background:var(--surface);border:1px solid #00000026;border:1px solid var(--border-md);border-radius:6px;border-radius:var(--radius-sm);color:#1a1a18;color:var(--text-1);cursor:pointer;display:inline-flex;font-family:Golos Text,system-ui,sans-serif;font-family:var(--font);font-size:13.5px;font-weight:500;gap:6px;padding:8px 16px;text-decoration:none;transition:background .12s,transform .1s}.btn:hover{background:#f5f4f0;background:var(--bg)}.btn:active{transform:scale(.98)}.btn-primary{background:#2b5ce6;background:var(--accent);border-color:#2b5ce6;border-color:var(--accent);color:#fff}.btn-primary:hover{background:#2350cc}[data-theme=dark] .btn-primary:hover{background:#7aa7ff}.btn-sm{font-size:12.5px;padding:5px 12px}.btn-icon{border-radius:6px;border-radius:var(--radius-sm);padding:7px}.form-group{margin-bottom:16px}.form-label{color:#6b6b67;color:var(--text-2);display:block;font-size:12px;font-weight:500;margin-bottom:5px}.form-input,.form-select,.form-textarea{background:#fff;background:var(--surface);border:1px solid #00000026;border:1px solid var(--border-md);border-radius:6px;border-radius:var(--radius-sm);color:#1a1a18;color:var(--text-1);font-family:Golos Text,system-ui,sans-serif;font-family:var(--font);font-size:13.5px;outline:none;padding:8px 11px;transition:border-color .12s;width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#2b5ce6;border-color:var(--accent);box-shadow:0 0 0 3px #2b5ce61a}.form-textarea{min-height:80px;resize:vertical}.progress-bar{background:#f5f4f0;background:var(--bg);border-radius:3px;height:5px;overflow:hidden}.progress-fill{background:#2b5ce6;background:var(--accent);border-radius:3px;height:100%;transition:width .3s}.progress-fill.done{background:#1a7a4a;background:var(--green)}.task-list{display:flex;flex-direction:column;gap:8px}.task-row{background:#fff;background:var(--surface);border:1px solid #00000017;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);box-shadow:0 1px 3px #00000012,0 1px 2px #0000000d;box-shadow:var(--shadow);cursor:pointer;padding:14px 16px;transition:border-color .15s,box-shadow .15s}.task-row:hover{border-color:#00000026;border-color:var(--border-md);box-shadow:0 2px 8px #00000014}.task-row.expanded{border-color:#2b5ce6;border-color:var(--accent)}.task-row-top{align-items:flex-start;display:flex;gap:12px}.task-num{color:#a8a8a4;color:var(--text-3);flex-shrink:0;font-family:JetBrains Mono,monospace;font-family:var(--mono);font-size:11px;padding-top:2px}.task-body{flex:1 1;min-width:0}.task-title{color:#1a1a18;color:var(--text-1);font-size:13.5px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task-meta{flex-wrap:wrap;gap:6px;margin-top:6px}.task-meta,.task-progress{align-items:center;display:flex}.task-progress{gap:8px;margin-top:8px}.task-progress-pct{color:#a8a8a4;color:var(--text-3);font-family:JetBrains Mono,monospace;font-family:var(--mono);font-size:11px;min-width:28px}.task-due{font-size:11px}.task-due.ok{color:#a8a8a4;color:var(--text-3)}.task-due.soon{color:#9a5700;color:var(--amber);font-weight:500}.task-due.over{color:#c0392b;color:var(--red);font-weight:500}.task-expand{border-top:1px solid #00000017;border-top:1px solid var(--border);margin-top:14px;padding-top:14px}.expand-section-label{color:#a8a8a4;color:var(--text-3);font-size:11px;font-weight:600;letter-spacing:.05em;margin-bottom:8px;text-transform:uppercase}.blocker-box{background:#fdeeec;background:var(--red-bg);border-radius:6px;border-radius:var(--radius-sm);margin-bottom:14px;padding:10px 13px}.blocker-label{color:#c0392b;color:var(--red);font-size:11px;font-weight:600;margin-bottom:3px}.blocker-text{color:#8b2a20;font-size:12.5px}[data-theme=dark] .blocker-text{color:#ffb3c1}.comment-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.comment-item{background:#f5f4f0;background:var(--bg);border-radius:6px;border-radius:var(--radius-sm);padding:10px 12px}.comment-header{color:#a8a8a4;color:var(--text-3);font-size:11px;margin-bottom:4px}.comment-text{color:#1a1a18;color:var(--text-1);font-size:13px;line-height:1.5}.comment-input-row{display:flex;gap:8px}.comment-input-row .form-input{flex:1 1}.filter-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}.filter-pill{background:#fff;background:var(--surface);border:1px solid #00000026;border:1px solid var(--border-md);border-radius:20px;color:#6b6b67;color:var(--text-2);cursor:pointer;font-size:12.5px;font-weight:500;padding:5px 13px;transition:all .12s}.filter-pill:hover{color:#2b5ce6;color:var(--accent)}.filter-pill.active,.filter-pill:hover{border-color:#2b5ce6;border-color:var(--accent)}.filter-pill.active{background:#2b5ce6;background:var(--accent);color:#fff}.login-page{align-items:center;background:#f5f4f0;background:var(--bg);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;background:var(--surface);border:1px solid #00000017;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 4px 24px #00000012;max-width:380px;padding:36px 32px;width:100%}.login-title{color:#1a1a18;color:var(--text-1);font-size:20px;font-weight:600;margin-bottom:4px}.login-sub{color:#6b6b67;color:var(--text-2);font-size:13px;margin-bottom:28px}.error-msg{background:#fdeeec;background:var(--red-bg);border-radius:6px;border-radius:var(--radius-sm);color:#c0392b;color:var(--red);font-size:13px;margin-bottom:14px;padding:9px 12px}.modal-overlay{align-items:center;background:#00000059;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:100}[data-theme=dark] .modal-overlay{background:#0009}.modal{background:#fff;background:var(--surface);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 8px 40px #00000026;max-height:90vh;max-width:520px;overflow-y:auto;width:100%}.modal-header{align-items:center;display:flex;justify-content:space-between;padding:20px 22px 0}.modal-title{font-size:16px;font-weight:600}.modal-body{padding:20px 22px 24px}.modal-footer{display:flex;gap:8px;justify-content:flex-end;padding:0 22px 20px}.mobile-menu-btn{background:#fff;background:var(--surface);border:1px solid #00000017;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);color:#1a1a18;color:var(--text-1);cursor:pointer;display:none;padding:8px;transition:background .15s}.mobile-menu-btn:hover{background:#f5f4f0;background:var(--bg)}.mobile-menu-backdrop{animation:fadeIn .2s ease;background:#00000080;display:none;inset:0;position:fixed;z-index:998}@media (max-width:768px){:root{--nav-w:0px}.mobile-menu-btn{align-items:center;display:flex;flex-shrink:0;justify-content:center}.mobile-menu-backdrop{display:block}.sidebar{bottom:0;box-shadow:2px 0 20px #0003;left:0;position:fixed;top:0;transform:translateX(-100%);transition:transform .25s ease;width:260px;z-index:999}.sidebar-open{transform:translateX(0)}.stat-grid{grid-template-columns:repeat(2,1fr)}.page-content{padding:16px}.topbar{padding:0 16px}.topbar-title{display:none}.topbar .global-search{flex:1 1}}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.animate-in{animation:fadeIn .18s ease both}.flex{display:flex}.items-center{align-items:center}.gap-8{gap:8px}.gap-12{gap:12px}.mt-16{margin-top:16px}.text-sm{font-size:12px}.text-muted{color:#6b6b67;color:var(--text-2)}.mono{font-family:JetBrains Mono,monospace;font-family:var(--mono)}.w-full{width:100%}.overflow-hidden{overflow:hidden}.section-title{color:#6b6b67;color:var(--text-2);font-size:13px;font-weight:600;margin-bottom:12px}