*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--brand-900:#0f1e4d;--brand-800:#162660;--brand-700:#1d3278;--brand-600:#2563eb;--brand-500:#3b82f6;--brand-100:#dbeafe;--brand-50:#eff6ff;--green:#22c55e;--orange:#f97316;--red:#ef4444;--purple:#a855f7;--cyan:#06b6d4;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--text:#1e293b;--text-sub:#64748b;--border:#e2e8f0;--sidebar-w:232px;--topbar-h:52px;--radius:8px;--radius-lg:12px;--shadow-sm:0 1px 2px #0000000f;--shadow:0 4px 16px #0000001a;--shadow-lg:0 8px 32px #00000024}body{color:var(--text);background:var(--gray-50);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,sans-serif;font-size:13px;line-height:1.5}.app-layout{grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--topbar-h) 1fr;height:100vh;display:grid;overflow:hidden}.sidebar{background:var(--brand-900);flex-direction:column;grid-area:1/1/-1;display:flex;overflow:hidden}.sidebar-logo{height:var(--topbar-h);flex-shrink:0;align-items:center;gap:10px;padding:0 18px;display:flex}.sidebar-logo-icon{background:linear-gradient(135deg, var(--brand-600), #7c3aed);border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.sidebar-logo-text{color:#fff;letter-spacing:-.3px;font-size:14px;font-weight:700}.sidebar-section{letter-spacing:.8px;text-transform:uppercase;color:#ffffff59;padding:20px 12px 4px;font-size:10px;font-weight:600}.sidebar-nav{flex-direction:column;flex:1;gap:1px;padding:8px;display:flex}.nav-item{cursor:pointer;color:#ffffffa6;border-radius:7px;align-items:center;gap:10px;padding:8px 10px;font-size:13px;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.nav-item:hover{color:#fff;background:#ffffff14}.nav-item.active{background:var(--brand-700);color:#fff}.nav-item-icon{opacity:.85;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;display:flex}.sidebar-footer{border-top:1px solid #ffffff14;flex-shrink:0;padding:12px}.user-menu{cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:8px;transition:background .15s;display:flex}.user-menu:hover{background:#ffffff14}.user-menu-name{color:#fff;text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;overflow:hidden}.user-menu-hint{color:#ffffff73;font-size:11px}.online-dot{background:var(--green);border:2px solid var(--brand-900);border-radius:50%;width:8px;height:8px;position:absolute;bottom:0;right:0}.main-area{flex-direction:column;grid-area:1/2/-1;display:flex;overflow:hidden}.topbar{height:var(--topbar-h);border-bottom:1px solid var(--border);background:#fff;flex-shrink:0;align-items:center;gap:12px;padding:0 20px;display:flex}.topbar-breadcrumb{color:var(--gray-500);align-items:center;gap:6px;font-size:13px;display:flex}.topbar-breadcrumb-sep{color:var(--gray-300)}.topbar-page{color:var(--text);font-size:14px;font-weight:600}.topbar-search{flex:1;max-width:320px;margin:0 8px;position:relative}.topbar-search-input{border:1px solid var(--border);width:100%;color:var(--text);background:var(--gray-50);border-radius:7px;outline:none;padding:6px 12px 6px 32px;font-family:inherit;font-size:13px;transition:border-color .15s,box-shadow .15s}.topbar-search-input:focus{border-color:var(--brand-500);background:#fff;box-shadow:0 0 0 3px #3b82f61f}.topbar-search-icon{color:var(--gray-400);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.topbar-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.topbar-icon-btn{cursor:pointer;width:32px;height:32px;color:var(--gray-500);background:0 0;border:none;border-radius:7px;justify-content:center;align-items:center;transition:background .15s;display:flex}.topbar-icon-btn:hover{background:var(--gray-100);color:var(--text)}.topbar-avatar-group{margin-left:4px;display:flex}.topbar-avatar-group .avatar{border:2px solid #fff;margin-left:-6px}.topbar-avatar-group .avatar:first-child{margin-left:0}.page-content{flex:1;padding:20px 24px;overflow-y:auto}.card{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px;font-size:13px;font-weight:600;display:flex}.card-body{padding:16px}.btn{cursor:pointer;white-space:nowrap;border:1px solid #0000;border-radius:7px;align-items:center;gap:5px;padding:6px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:background .15s,opacity .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--brand-600);color:#fff}.btn-primary:hover:not(:disabled){background:#1d4ed8}.btn-ghost{color:var(--text);border-color:var(--border);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--gray-100)}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover:not(:disabled){opacity:.88}.btn-sm{padding:4px 10px;font-size:12px}.filter-bar{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:16px;display:flex}.chip{cursor:pointer;border:1px solid var(--border);color:var(--gray-600);background:#fff;border-radius:100px;padding:4px 12px;font-size:12px;font-weight:500;transition:all .15s}.chip:hover{background:var(--gray-100)}.chip.active{background:var(--brand-600);color:#fff;border-color:var(--brand-600)}.form-group{flex-direction:column;gap:5px;display:flex}.form-label{color:var(--gray-600);font-size:12px;font-weight:500}.input,.select,.textarea{border:1px solid var(--border);width:100%;color:var(--text);background:#fff;border-radius:7px;outline:none;padding:7px 11px;font-family:inherit;font-size:13px;transition:border-color .15s}.input:focus,.select:focus,.textarea:focus{border-color:var(--brand-500);box-shadow:0 0 0 3px #3b82f61f}.textarea{resize:vertical;min-height:80px}.badge{border-radius:100px;align-items:center;padding:2px 7px;font-size:11px;font-weight:600;display:inline-flex}.badge-high{color:#dc2626;background:#fef2f2}.badge-medium{color:#d97706;background:#fffbeb}.badge-low{color:#16a34a;background:#f0fdf4}.badge-todo{background:var(--gray-100);color:var(--gray-600)}.badge-progress{color:#d97706;background:#fffbeb}.badge-review{background:var(--brand-50);color:var(--brand-600)}.badge-done{color:#16a34a;background:#f0fdf4}.avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:11px;font-weight:700;display:flex;position:relative;overflow:hidden}.avatar img{object-fit:cover;width:100%;height:100%}.avatar-sm{width:22px;height:22px;font-size:9px}.avatar-lg{width:36px;height:36px;font-size:13px}.avatar-xl{width:48px;height:48px;font-size:17px}.modal-backdrop{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a73;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);background:#fff;width:100%;max-width:520px;max-height:92vh;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 20px 14px;font-size:15px;font-weight:600;display:flex}.modal-body{flex-direction:column;gap:14px;padding:18px 20px;display:flex}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:14px 20px 18px;display:flex}.modal-close{width:28px;height:28px;color:var(--gray-400);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;font-size:16px;transition:background .15s;display:flex}.modal-close:hover{background:var(--gray-100);color:var(--text)}.auth-page{background:linear-gradient(135deg, var(--brand-900) 0%, #1a3a6b 50%, #1e293b 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{border:1px solid var(--border);box-shadow:var(--shadow-lg);background:#fff;border-radius:16px;width:100%;max-width:400px;padding:40px}.auth-logo{color:var(--text);align-items:center;gap:10px;margin-bottom:28px;font-size:18px;font-weight:700;display:flex}.auth-title{margin-bottom:6px;font-size:22px;font-weight:700}.auth-sub{color:var(--text-sub);margin-bottom:28px;font-size:13px}.auth-form{flex-direction:column;gap:14px;display:flex}.auth-link{color:var(--brand-600);font-weight:500;text-decoration:none}.auth-link:hover{text-decoration:underline}.auth-divider{text-align:center;color:var(--text-sub);margin-top:20px;font-size:12px}.alert{border-radius:7px;align-items:center;gap:7px;padding:9px 12px;font-size:12px;display:flex}.alert-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca}.alert-success{color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0}.alert-info{background:var(--brand-50);color:var(--brand-600);border:1px solid var(--brand-100)}.stats-grid{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px;display:grid}@media (width<=900px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.stat-card{flex-direction:column;gap:10px;padding:16px 18px;display:flex}.stat-card-top{justify-content:space-between;align-items:flex-start;display:flex}.stat-icon-wrap{border-radius:9px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.stat-delta{border-radius:100px;align-items:center;gap:2px;padding:2px 6px;font-size:11px;font-weight:600;display:flex}.stat-delta.up{color:#16a34a;background:#f0fdf4}.stat-delta.down{color:#dc2626;background:#fef2f2}.stat-value{font-size:26px;font-weight:700;line-height:1}.stat-label{color:var(--text-sub);font-size:12px}.agenda-item{border-bottom:1px solid var(--border);align-items:flex-start;gap:10px;padding:10px 0;display:flex}.agenda-item:last-child{border-bottom:none}.agenda-bar{border-radius:2px;flex-shrink:0;align-self:stretch;width:3px;min-height:36px}.agenda-title{font-size:13px;font-weight:500}.agenda-meta{color:var(--text-sub);margin-top:2px;font-size:11px}.kanban-board{align-items:flex-start;gap:14px;padding-bottom:16px;display:flex;overflow-x:auto}.kanban-col{background:var(--gray-50);border-radius:var(--radius-lg);border:1px solid var(--border);flex-direction:column;min-width:272px;max-width:272px;display:flex}.kanban-col-header{border-bottom:1px solid var(--border);align-items:center;gap:7px;padding:11px 14px;font-size:12px;font-weight:600;display:flex}.kanban-col-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.kanban-col-count{background:var(--gray-200);color:var(--gray-600);border-radius:100px;margin-left:auto;padding:1px 7px;font-size:11px;font-weight:600}.kanban-cards{flex-direction:column;flex:1;gap:7px;min-height:60px;padding:8px;display:flex}.task-card{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:9px;padding:11px 12px;transition:box-shadow .15s,border-color .15s}.task-card:hover{box-shadow:var(--shadow);border-color:var(--gray-300)}.task-card-id{color:var(--brand-500);letter-spacing:.3px;margin-bottom:5px;font-size:10px;font-weight:700}.task-card-title{margin-bottom:8px;font-size:13px;font-weight:500;line-height:1.4}.task-card-meta{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.task-card-due{color:var(--gray-500);align-items:center;gap:3px;font-size:11px;display:flex}.week-cal{flex-direction:column;flex:1;display:flex}.week-cal-header{border-bottom:1px solid var(--border);background:var(--gray-50);display:grid}.week-col-head{text-align:center;border-right:1px solid var(--border);padding:10px 8px;font-size:12px;font-weight:600}.week-col-head:last-child{border-right:none}.week-col-head-date{font-size:18px;font-weight:700;line-height:1.2;display:block}.week-col-head.today .week-col-head-date{color:var(--brand-600)}.week-body{flex:1;display:flex;overflow-y:auto}.week-time-col{border-right:1px solid var(--border);flex-shrink:0;width:52px}.week-time-slot{height:48px;color:var(--gray-400);border-bottom:1px solid var(--border);align-items:flex-start;padding:3px 6px 0;font-size:10px;font-weight:500;display:flex}.week-grid{flex:1;display:grid}.week-day-col{border-right:1px solid var(--border);position:relative}.week-day-col:last-child{border-right:none}.week-slot{border-bottom:1px solid var(--border);cursor:pointer;height:48px}.week-slot:hover{background:var(--brand-50)}.week-event{color:#fff;cursor:pointer;border-left:3px solid #0003;border-radius:5px;padding:3px 7px;font-size:11px;font-weight:500;line-height:1.3;position:absolute;left:3px;right:3px;overflow:hidden}.calendar-grid{background:var(--border);border:1px solid var(--border);border-radius:var(--radius-lg);grid-template-columns:repeat(7,1fr);gap:1px;display:grid;overflow:hidden}.cal-header-cell{background:var(--gray-50);text-align:center;color:var(--text-sub);text-transform:uppercase;letter-spacing:.5px;padding:8px;font-size:11px;font-weight:600}.cal-cell{cursor:pointer;background:#fff;min-height:88px;padding:7px;transition:background .1s}.cal-cell:hover{background:var(--gray-50)}.cal-cell.other-month .cal-day{color:var(--gray-300)}.cal-cell.today .cal-day-num{background:var(--brand-600);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.cal-day{margin-bottom:4px;font-size:12px;font-weight:600}.cal-event{color:#fff;text-overflow:ellipsis;white-space:nowrap;cursor:pointer;border-radius:4px;margin-bottom:2px;padding:2px 5px;font-size:10px;overflow:hidden}.member-card{padding:18px 20px}.member-workload-bar{background:var(--gray-200);border-radius:3px;height:6px;margin-top:8px;overflow:hidden}.member-workload-fill{border-radius:3px;height:100%;transition:width .4s}.divider{background:var(--border);height:1px;margin:4px 0}.spinner{border:2px solid var(--gray-200);border-top-color:var(--brand-600);border-radius:50%;width:22px;height:22px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{color:var(--text-sub);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:48px 20px;display:flex}.empty-icon{opacity:.6;font-size:36px;line-height:1}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--gray-200);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-300)}.color-dot{cursor:pointer;border:2px solid #0000;border-radius:50%;width:18px;height:18px;transition:border-color .15s}.color-dot.selected{border-color:var(--text);box-shadow:inset 0 0 0 2px #fff}
