@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--brand-50:#ecfdf5;--brand-100:#d1fae5;--brand-400:#34d399;--brand-500:#10b981;--brand-600:#059669;--brand-700:#047857;--bg-base:#0f172a;--bg-surface:#1e293b;--bg-card:#1e293b;--bg-hover:#334155;--bg-active:#475569;--bg-glass:#ffffff08;--bg-nav:#0f172ae6;--border:#ffffff14;--border-hover:#ffffff26;--border-focus:#10b98180;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--shadow-card:0 10px 30px -10px #00000080;--shadow-glow:0 0 40px #10b9811a;--transition:.25s cubic-bezier(.4,0,.2,1);--sidebar-w:260px;--navbar-h:64px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px}html[data-theme=nordic]{--brand-500:#88c0d0;--brand-600:#81a1c1;--brand-400:#8fbcbb;--bg-base:#2e3440;--bg-surface:#3b4252;--bg-card:#3b4252;--bg-hover:#434c5e;--bg-active:#4c566a;--text-primary:#eceff4;--text-secondary:#d8dee9;--text-muted:#94a3b8;--border:#eceff414;--border-hover:#eceff426;--shadow-glow:0 0 40px #88c0d01a}html[data-theme=enterprise]{--brand-500:#6366f1;--brand-600:#4f46e5;--brand-400:#818cf8;--bg-base:#f1f5f9;--bg-surface:#fff;--bg-card:#fff;--bg-hover:#f8fafc;--bg-active:#e2e8f0;--bg-nav:#fffc;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--border:#00000014;--border-hover:#00000026;--shadow-card:0 4px 20px #0000000d}html[data-theme=sand]{--brand-500:#f59e0b;--brand-600:#d97706;--brand-400:#fbbf24;--bg-base:#fdfcfb;--bg-surface:#fff;--bg-card:#fff;--bg-hover:#fafaf9;--bg-active:#f3f4f6;--bg-nav:#fdfcfbcc;--text-primary:#45413e;--text-secondary:#78716c;--text-muted:#a8a29e;--border:#45413e1a;--border-hover:#45413e33;--shadow-card:0 4px 20px #00000008}@extend html[data-theme="enterprise"];*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,system-ui,sans-serif;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,textarea,select{font-family:inherit}img{max-width:100%}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#ffffff26}.app-shell{grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--navbar-h) 1fr;min-height:100vh;transition:grid-template-columns var(--transition);display:grid}.app-shell.sidebar-collapsed{grid-template-columns:72px 1fr}.sidebar{background:var(--bg-surface);border-right:1px solid var(--border);transition:width var(--transition);z-index:40;flex-direction:column;grid-row:1/-1;height:100vh;display:flex;position:sticky;top:0;overflow:hidden}.sidebar-logo{height:var(--navbar-h);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:12px;padding:0 20px;display:flex}.sidebar-logo-icon{background:linear-gradient(135deg, var(--brand-500), var(--brand-700));border-radius:var(--radius-md);color:#fff;letter-spacing:-.5px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:800;display:flex;box-shadow:0 4px 12px #6366f166}.sidebar-logo-text{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:700;overflow:hidden}.sidebar-nav{flex:1;padding:12px;overflow-y:auto}.sidebar-section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);white-space:nowrap;padding:8px 12px 4px;font-size:10px;font-weight:600;overflow:hidden}.nav-item{border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:background var(--transition), color var(--transition);white-space:nowrap;align-items:center;gap:12px;margin-bottom:2px;padding:10px 12px;font-size:14px;font-weight:500;text-decoration:none;display:flex;position:relative}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{color:var(--brand-400);background:#6366f126}.nav-item.active:before{content:"";background:var(--brand-500);border-radius:0 3px 3px 0;width:3px;position:absolute;top:20%;bottom:20%;left:0}.nav-icon{flex-shrink:0;width:20px;height:20px}.nav-badge{background:var(--critical);color:#fff;text-align:center;border-radius:99px;min-width:18px;margin-left:auto;padding:2px 6px;font-size:10px;font-weight:700}.sidebar-footer{border-top:1px solid var(--border);flex-shrink:0;padding:12px}.sidebar-user{border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition);align-items:center;gap:10px;padding:8px;display:flex}.sidebar-user:hover{background:var(--bg-hover)}.sidebar-user-info{flex:1;overflow:hidden}.sidebar-user-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.sidebar-user-role{color:var(--text-muted);text-transform:capitalize;font-size:11px}.navbar{background:var(--bg-nav,#12121acc);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);z-index:30;align-items:center;gap:16px;padding:0 24px;display:flex;position:sticky;top:0}.navbar-toggle{border-radius:var(--radius-md);width:36px;height:36px;color:var(--text-secondary);transition:background var(--transition), color var(--transition);justify-content:center;align-items:center;display:flex}.navbar-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.navbar-breadcrumbs{color:var(--text-muted);flex:1;align-items:center;gap:8px;font-size:14px;display:flex}.navbar-breadcrumbs .sep{opacity:.4}.navbar-breadcrumbs .current{color:var(--text-primary);font-weight:500}.navbar-actions{align-items:center;gap:8px;display:flex}.navbar-btn{border-radius:var(--radius-md);width:36px;height:36px;color:var(--text-secondary);background:var(--bg-glass);border:1px solid var(--border);cursor:pointer;transition:background var(--transition), color var(--transition), border-color var(--transition);justify-content:center;align-items:center;display:flex;position:relative}.navbar-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border)}.navbar-btn-badge{background:var(--critical);color:#fff;border-radius:99px;justify-content:center;align-items:center;width:16px;height:16px;font-size:9px;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px}.main-content{background:var(--bg-base);min-height:calc(100vh - var(--navbar-h));overflow-y:auto}.page-container{max-width:1400px;padding:28px 32px}.page-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:28px;display:flex}.page-title{font-size:26px;font-weight:700;line-height:1.2}.page-subtitle{color:var(--text-secondary);margin-top:4px;font-size:14px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition), box-shadow var(--transition);padding:20px}.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-card)}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{color:var(--text-primary);font-size:14px;font-weight:600}.stat-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:28px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:transform var(--transition), border-color var(--transition), box-shadow var(--transition);cursor:pointer;align-items:flex-start;gap:16px;padding:20px;display:flex}.stat-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-card);transform:translateY(-2px)}.stat-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;display:flex}.stat-info{flex:1;min-width:0}.stat-value{font-size:28px;font-weight:800;line-height:1}.stat-label{color:var(--text-secondary);margin-top:4px;font-size:12px}.stat-trend{font-size:12px;font-weight:600}.stat-trend.up{color:var(--done)}.stat-trend.down{color:var(--critical)}.btn{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:1px solid #0000;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;line-height:1.4;display:inline-flex}.btn-sm{padding:5px 10px;font-size:12px}.btn-lg{padding:11px 22px;font-size:15px}.btn-icon{padding:8px}.btn-primary{background:var(--brand-500);color:#fff;border-color:var(--brand-500)}.btn-primary:hover{background:var(--brand-600);border-color:var(--brand-600);box-shadow:0 0 20px #6366f159}.btn-secondary{background:var(--bg-glass);color:var(--text-primary);border-color:var(--border)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-hover)}.btn-danger{color:#ef4444;background:#ef44441a;border-color:#ef44444d}.btn-danger:hover{background:#ef444433}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.input-group{flex-direction:column;gap:6px;display:flex}.input-label{color:var(--text-secondary);font-size:13px;font-weight:500}.input{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);transition:border-color var(--transition), box-shadow var(--transition);width:100%;padding:9px 12px;font-size:14px}.input:focus{border-color:var(--brand-500);outline:none;box-shadow:0 0 0 3px #6366f126}.input::placeholder{color:var(--text-primary);opacity:.5}.input-search{padding-left:36px}.input-with-icon{position:relative}.input-with-icon .input-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}select.input option{background:var(--bg-card)}textarea.input{resize:vertical;min-height:80px}.badge{text-transform:uppercase;letter-spacing:.03em;border-radius:99px;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-todo{color:#94a3b8;background:#64748b26}.badge-in_progress{color:#60a5fa;background:#3b82f626}.badge-review{color:#fbbf24;background:#f59e0b26}.badge-done{color:#34d399;background:#10b98126}.badge-planning{color:#818cf8;background:#6366f126}.badge-active{color:#34d399;background:#10b98126}.badge-on_hold{color:#fbbf24;background:#f59e0b26}.badge-completed{color:#34d399;background:#10b98126}.badge-cancelled{color:#f87171;background:#ef444426}.badge-low{color:#94a3b8;background:#94a3b81f}.badge-medium{color:#60a5fa;background:#3b82f61f}.badge-high{color:#fbbf24;background:#f59e0b1f}.badge-critical{color:#f87171;background:#ef44441f}.badge-overdue{color:#f87171;background:#ef444426}.badge-super_admin{color:#a78bfa;background:#8b5cf626}.badge-admin{color:#818cf8;background:#6366f126}.badge-manager{color:#60a5fa;background:#3b82f626}.badge-employee{color:#34d399;background:#10b98126}.avatar{object-fit:cover;border:2px solid var(--border);border-radius:50%;flex-shrink:0}.avatar-xs{width:24px;height:24px}.avatar-sm{width:32px;height:32px}.avatar-md{width:40px;height:40px}.avatar-lg{width:56px;height:56px}.avatar-xl{width:80px;height:80px}.avatar-group{display:flex}.avatar-group .avatar{border-color:var(--bg-card);margin-left:-8px}.avatar-group .avatar:first-child{margin-left:0}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#000000b3;justify-content:center;align-items:center;padding:16px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:600px;max-height:90vh;box-shadow:0 24px 64px #0009, var(--shadow-glow);animation:.2s slideUp;overflow-y:auto}.modal-lg{max-width:820px}.modal-header{border-bottom:1px solid var(--border);background:var(--bg-card);z-index:1;justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex;position:sticky;top:0}.modal-title{font-size:17px;font-weight:700}.modal-body{padding:20px 24px}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:16px 24px;display:flex}.table-wrapper{overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:14px}.table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 14px;font-size:11px;font-weight:600}.table td{border-bottom:1px solid var(--border);color:var(--text-primary);vertical-align:middle;padding:12px 14px}.table tbody tr{transition:background var(--transition)}.table tbody tr:hover{background:var(--bg-hover)}.table tbody tr:last-child td{border-bottom:none}.progress-bar{background:var(--border);border-radius:99px;width:100%;height:6px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--brand-500), var(--brand-400));border-radius:99px;height:100%;transition:width .4s}.progress-fill.warning{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.progress-fill.success{background:linear-gradient(90deg,#10b981,#34d399)}.progress-fill.danger{background:linear-gradient(90deg,#ef4444,#f87171)}.kanban-board{gap:16px;min-height:calc(100vh - 200px);padding-bottom:16px;display:flex;overflow-x:auto}.kanban-column{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;flex-shrink:0;width:300px;display:flex;overflow:hidden}.kanban-column-header{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:10px;padding:14px 16px;display:flex}.kanban-column-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.kanban-column-title{flex:1;font-size:13px;font-weight:600}.kanban-column-count{background:var(--bg-active);color:var(--text-secondary);border-radius:99px;padding:2px 8px;font-size:11px;font-weight:600}.kanban-cards{flex-direction:column;flex:1;gap:10px;min-height:60px;padding:12px;display:flex;overflow-y:auto}.kanban-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);cursor:grab;transition:border-color var(--transition), box-shadow var(--transition), transform var(--transition);padding:12px 14px}.kanban-card:hover{border-color:var(--border-hover);box-shadow:0 4px 16px #0000004d}.kanban-card:active{cursor:grabbing}.kanban-card.dragging{opacity:.5;transform:scale(.98)}.kanban-card-title{margin-bottom:8px;font-size:13px;font-weight:500;line-height:1.4}.kanban-card-meta{justify-content:space-between;align-items:center;gap:8px;display:flex}.kanban-card-add{border-radius:var(--radius-md);border:1px dashed var(--border);width:100%;color:var(--text-muted);cursor:pointer;transition:all var(--transition);justify-content:center;align-items:center;gap:6px;padding:8px;font-size:13px;display:flex}.kanban-card-add:hover{border-color:var(--brand-500);color:var(--brand-400);background:#6366f10d}.navbar-avatar-btn{cursor:pointer;outline-offset:2px;transition:opacity var(--transition);background:0 0;border:none;border-radius:50%;align-items:center;padding:2px;display:flex}.navbar-avatar-btn:hover{opacity:.85}.navbar-avatar-btn:focus-visible{outline:2px solid var(--brand-500)}.profile-dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);z-index:60;width:260px;animation:.15s slideDown;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 16px 48px #00000080}.profile-dropdown-header{align-items:center;gap:12px;padding:16px;display:flex}.profile-dropdown-info{flex-direction:column;gap:2px;min-width:0;display:flex}.profile-dropdown-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.profile-dropdown-email{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.profile-dropdown-role{text-transform:uppercase;letter-spacing:.05em;color:var(--brand-400,#818cf8);margin-top:2px;font-size:10px;font-weight:600}.profile-dropdown-divider{background:var(--border);height:1px}.profile-dropdown-item{width:100%;color:var(--text-secondary);cursor:pointer;text-align:left;transition:background var(--transition), color var(--transition);background:0 0;border:none;align-items:center;gap:10px;padding:11px 16px;font-size:13px;display:flex}.profile-dropdown-item:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.profile-dropdown-item:disabled{opacity:.55;cursor:not-allowed}.profile-dropdown-item--danger{color:#ef4444}.profile-dropdown-item--danger:hover:not(:disabled){color:#ef4444;background:#ef444414}.profile-avatar-overlay{background:#00000080;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.profile-avatar-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}.notif-dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);z-index:60;width:360px;animation:.15s slideDown;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 16px 48px #00000080}.notif-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.notif-list{max-height:380px;overflow-y:auto}.notif-item{border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--transition);gap:10px;padding:12px 16px;display:flex}.notif-item:hover{background:var(--bg-hover)}.notif-item.unread{background:#6366f10f}.notif-item:last-child{border-bottom:none}.notif-dot{background:var(--brand-500);border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:6px}.notif-dot.read{border:1px solid var(--border);background:0 0}.notif-title{margin-bottom:2px;font-size:13px;font-weight:600}.notif-msg{color:var(--text-secondary);font-size:12px}.notif-time{color:var(--text-muted);margin-top:2px;font-size:11px}.empty-state{color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 24px;display:flex}.empty-state-icon{opacity:.4;font-size:48px}.empty-state-title{color:var(--text-secondary);font-size:16px;font-weight:600}.empty-state-desc{max-width:260px;font-size:13px}.grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}@media (width<=900px){.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:1fr 1fr}}@media (width<=600px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.page-container{padding:16px}}.form-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.form-stack{flex-direction:column;gap:14px;display:flex}.form-group{flex-direction:column;gap:6px;margin-bottom:0;display:flex}.form-label{color:var(--text-secondary);letter-spacing:.04em;text-transform:uppercase;font-size:12px;font-weight:600}.form-input{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);width:100%;transition:border-color var(--transition), box-shadow var(--transition), background var(--transition);padding:9px 12px;font-family:inherit;font-size:14px}.form-input:focus{border-color:var(--brand-500);background:var(--bg-card);outline:none;box-shadow:0 0 0 3px #6366f126}.form-input::placeholder{color:var(--text-primary);opacity:.35}.form-input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.5);cursor:pointer}html[data-theme=light] .form-input{color:#0f172a;background:#fff;border-color:#0000001f}html[data-theme=light] .form-input:focus{border-color:var(--brand-500);background:#fff}html[data-theme=light] .form-input::placeholder{color:#94a3b8;opacity:1}html[data-theme=light] .form-input[type=date]::-webkit-calendar-picker-indicator{filter:none}html[data-theme=light] .form-label{color:#334155}.spinner{border:3px solid var(--border);border-top-color:var(--brand-500);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}.spinner-sm{border-width:2px;width:20px;height:20px}.loading-screen{background:var(--bg-base);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-page{background:var(--bg-base);grid-template-columns:1fr 1fr;min-height:100vh;display:grid}.login-left{background:linear-gradient(135deg,#0a0a1a 0%,#1a0a2e 50%,#0a0a1a 100%);flex-direction:column;justify-content:center;align-items:center;padding:48px;display:flex;position:relative;overflow:hidden}.login-left:before{content:"";pointer-events:none;background:radial-gradient(circle,#6366f133 0%,#0000 70%);width:600px;height:600px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.login-hero-logo{background:linear-gradient(135deg, #fff 30%, var(--brand-400) 100%);-webkit-text-fill-color:transparent;z-index:1;-webkit-background-clip:text;margin-bottom:16px;font-size:80px;font-weight:900;line-height:1}.login-hero-title{text-align:center;z-index:1;font-size:28px;font-weight:700}.login-hero-sub{color:var(--text-secondary);text-align:center;z-index:1;margin-top:8px;font-size:15px}.login-features{z-index:1;flex-direction:column;gap:14px;width:100%;max-width:360px;margin-top:40px;display:flex}.login-feature{color:var(--text-secondary);align-items:center;gap:12px;font-size:14px;display:flex}.login-feature-icon{border-radius:var(--radius-md);background:#6366f126;border:1px solid #6366f14d;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;display:flex}.login-right{flex-direction:column;justify-content:center;align-items:center;padding:48px;display:flex}.login-form-box{width:100%;max-width:420px}.login-form-title{margin-bottom:8px;font-size:26px;font-weight:800}.login-form-sub{color:var(--text-secondary);margin-bottom:32px;font-size:14px}.login-form{flex-direction:column;gap:16px;display:flex}.login-creds{border-radius:var(--radius-md);color:var(--text-secondary);background:#6366f114;border:1px solid #6366f133;padding:12px 16px;font-size:13px}.login-creds strong{color:var(--brand-400)}@media (width<=768px){.login-page{grid-template-columns:1fr}.login-left{display:none}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.text-muted{color:var(--text-secondary)}.text-small{font-size:12px}.text-xs{font-size:11px}.font-semibold{font-weight:600}.font-bold{font-weight:700}.flex{display:flex}.flex-center{justify-content:center;align-items:center;display:flex}.items-center{align-items:center}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.w-full{width:100%}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.divider{border:none;border-top:1px solid var(--border);margin:16px 0}.overdue-dot{background:var(--critical);border-radius:50%;width:6px;height:6px;margin-right:4px;animation:2s infinite pulse;display:inline-block}.project-color-bar{border-radius:2px;height:4px;margin-bottom:14px}.module-switcher-btn{border:1px solid var(--border);background:var(--bg-surface);height:34px;color:var(--text-primary);cursor:pointer;transition:background var(--transition), border-color var(--transition), box-shadow var(--transition);white-space:nowrap;border-radius:8px;align-items:center;gap:7px;padding:0 12px;font-size:13px;font-weight:500;display:flex}.module-switcher-btn:hover{background:var(--bg-hover);border-color:var(--border-hover);box-shadow:0 0 0 3px color-mix(in srgb, var(--module-color,var(--brand-500)) 12%, transparent)}.module-switcher-icon{font-size:15px;line-height:1}.module-switcher-label{text-overflow:ellipsis;max-width:160px;overflow:hidden}.module-switcher-arrow{opacity:.6;flex-shrink:0}.module-switcher-dropdown{background:var(--bg-card);border:1px solid var(--border);z-index:200;border-radius:12px;width:280px;animation:.15s slideDown;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 8px 32px #0000004d}.module-switcher-dropdown-header{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);border-bottom:1px solid var(--border);padding:10px 14px 8px;font-size:11px;font-weight:600}.module-switcher-item{width:100%;color:var(--text-secondary);text-align:left;cursor:pointer;transition:background var(--transition), color var(--transition);background:0 0;border:none;align-items:center;gap:12px;padding:12px 14px;font-size:13px;display:flex}.module-switcher-item:hover{background:var(--bg-hover);color:var(--text-primary)}.module-switcher-item.active{background:var(--bg-active);color:var(--text-primary)}.module-switcher-item-icon{border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.module-switcher-item-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.module-switcher-item-label{color:var(--text-primary);font-size:13px;font-weight:600}.module-switcher-item-desc{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.module-switcher-check{flex-shrink:0;font-size:14px;font-weight:700}html[data-theme=light] .module-switcher-btn{color:#1e293b;background:#fff;border-color:#00000026}html[data-theme=light] .module-switcher-btn:hover{background:#f8fafc;border-color:#00000040}html[data-theme=light] .module-switcher-dropdown{box-shadow:0 8px 32px #0000001f}html[data-theme=light] .module-switcher-item-label{color:#0f172a}html[data-theme=light] .module-switcher-item:hover{background:#f1f5f9}html[data-theme=light] .module-switcher-item.active{background:#e2e8f0}.module-toggle{background:var(--bg-hover);cursor:pointer;border:none;border-radius:12px;outline:none;flex-shrink:0;width:44px;height:24px;padding:0;transition:background .25s;position:relative}.module-toggle:focus-visible{box-shadow:0 0 0 3px #6366f159}.module-toggle.on{background:var(--brand-500)}.module-toggle.locked{cursor:not-allowed;opacity:.6;background:#64748b33}.module-toggle-thumb{background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .25s;position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #00000040}.module-toggle.on .module-toggle-thumb{transform:translate(20px)}html[data-theme=light] .module-toggle{background:#e2e8f0}html[data-theme=light] .module-toggle.on{background:var(--brand-500)}html[data-theme=light] .module-toggle.locked{background:#cbd5e1}
