:root{--primary:#4f46e5;--primary-hover:#4338ca;--primary-light:#e0e7ff;--primary-glow:#4f46e526;--secondary:#64748b;--success:#10b981;--success-light:#d1fae5;--success-text:#065f46;--warning:#f59e0b;--warning-light:#fef3c7;--warning-text:#92400e;--danger:#f43f5e;--danger-light:#ffe4e6;--danger-text:#9f1239;--background:#fafbfe;--surface:#fff;--border:#f1f5f9;--border-hover:#e2e8f0;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--sidebar-bg:#fff;--sidebar-border:#e2e8f0;--sidebar-text:#475569;--sidebar-text-active:#4f46e5;--sidebar-hover-bg:#f8fafc;--sidebar-active-bg:#e0e7ff;--sidebar-active-border:#4f46e5;--sidebar-width:260px;--header-height:64px;--shadow-sm:0 1px 3px #0000000d;--shadow-md:0 4px 6px -1px #00000008,0 2px 4px -1px #00000005;--shadow-lg:0 10px 25px -3px #4f46e50a,0 4px 12px -2px #00000005;--shadow-premium:0 20px 25px -5px #00000005,0 10px 10px -5px #00000003;--shadow-focus:0 0 0 4px #4f46e526}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fafbfe;background-color:var(--background);color:#0f172a;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}.app-layout{display:flex;min-height:100vh}.sidebar{background:#fff;background:var(--sidebar-bg);border-right:1px solid #e2e8f0;border-right:1px solid var(--sidebar-border);display:flex;flex-direction:column;height:100vh;left:0;position:fixed;top:0;transition:transform .3s cubic-bezier(.4,0,.2,1);width:260px;width:var(--sidebar-width);z-index:100}.sidebar-header{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--sidebar-border);padding:24px 20px}.workspace-info{align-items:center;display:flex;gap:12px}.workspace-avatar{align-items:center;background:linear-gradient(135deg,#4f46e5,#818cf8);background:linear-gradient(135deg,var(--primary),#818cf8);border-radius:10px;box-shadow:0 4px 12px #4f46e54d;color:#fff;display:flex;font-size:16px;font-weight:700;height:36px;justify-content:center;width:36px}.workspace-details h2{color:#0f172a;color:var(--text-primary);font-size:15px;font-weight:600;letter-spacing:-.2px}.workspace-details span{color:#94a3b8;color:var(--text-muted);font-size:11px;font-weight:500}.sidebar-search{padding:16px 20px}.search-input{background:#fafbfe;background:var(--background);border:1px solid #e2e8f0;border:1px solid var(--border-hover);border-radius:10px;color:#0f172a;color:var(--text-primary);font-size:13px;padding:10px 14px;transition:all .2s ease;width:100%}.search-input::placeholder{color:#94a3b8;color:var(--text-muted);opacity:.8}.search-input:focus{background:#fff;background:var(--surface);border-color:#4f46e5;border-color:var(--primary);box-shadow:0 0 0 4px #4f46e526;box-shadow:var(--shadow-focus);outline:none}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:4px;overflow-y:auto;padding:12px}.nav-item{align-items:center;border:1px solid #0000;border-radius:10px;color:#475569;color:var(--sidebar-text);cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px;padding:10px 16px;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1)}.nav-item:hover{background:#f8fafc;background:var(--sidebar-hover-bg);transform:translateX(2px)}.nav-item.active,.nav-item:hover{color:#4f46e5;color:var(--sidebar-text-active)}.nav-item.active{background:#e0e7ff;background:var(--sidebar-active-bg);border-bottom-left-radius:4px;border-left:3px solid #4f46e5;border-left:3px solid var(--sidebar-active-border);border-top-left-radius:4px;font-weight:600}.nav-item svg{height:18px;transition:transform .2s ease;width:18px}.nav-item:hover svg{transform:scale(1.05)}.nav-section-title{color:#475569;font-size:10px;font-weight:700;letter-spacing:1.5px;padding:24px 16px 8px;text-transform:uppercase}.active-project-item{align-items:center;border-radius:8px;color:#475569;color:var(--sidebar-text);display:flex;font-size:13px;font-weight:500;gap:10px;padding:8px 16px;text-decoration:none;transition:all .2s ease}.active-project-item:hover{background:#f8fafc;background:var(--sidebar-hover-bg);color:#4f46e5;color:var(--sidebar-text-active);transform:translateX(2px)}.project-dot{background:#10b981;background:var(--success);border-radius:50%;box-shadow:0 0 8px #10b981;box-shadow:0 0 8px var(--success);height:6px;width:6px}.sidebar-footer{background:#fafbfe;background:var(--background);border-top:1px solid #e2e8f0;border-top:1px solid var(--sidebar-border);justify-content:space-between;padding:16px}.sidebar-footer,.user-info{align-items:center;display:flex}.user-info{gap:12px;overflow:hidden}.user-avatar{align-items:center;border-radius:50%;box-shadow:0 2px 8px #0000001a;color:#fff;display:flex;flex-shrink:0;font-size:13px;font-weight:600;height:36px;justify-content:center;width:36px}.user-details{overflow:hidden}.user-details h4{color:#0f172a;color:var(--text-primary);font-size:13px;font-weight:600}.user-details h4,.user-details span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-details span{color:#475569;color:var(--text-secondary);display:block;font-size:11px}button.nav-item{background:#0000;border:none;text-align:left;width:100%}button.nav-item.active{background:#e0e7ff;background:var(--sidebar-active-bg);color:#4f46e5;color:var(--sidebar-text-active)}.main-content{display:flex;flex:1 1;flex-direction:column;margin-left:260px;margin-left:var(--sidebar-width);min-height:100vh}.page-header{align-items:center;background:#fff;background:var(--surface);border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:24px 40px}.page-title{color:#0f172a;color:var(--text-primary);font-size:26px;font-weight:700;letter-spacing:-.5px}.page-content{flex:1 1;padding:32px 40px}.btn{align-items:center;border:1px solid #0000;border-radius:10px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:10px 20px;text-decoration:none;transition:all .25s cubic-bezier(.4,0,.2,1)}.btn-primary{background:#4f46e5;background:var(--primary);box-shadow:0 4px 14px #4f46e540;color:#fff}.btn-primary:hover{background:#4338ca;background:var(--primary-hover);box-shadow:0 6px 20px #4f46e559;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border-hover);box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm);color:#475569;color:var(--text-secondary)}.btn-secondary:hover{background:#fafbfe;background:var(--background);border-color:#94a3b8;border-color:var(--text-muted);color:#0f172a;color:var(--text-primary)}.btn-danger{background:#f43f5e;background:var(--danger);box-shadow:0 4px 14px #f43f5e40;color:#fff}.btn-danger:hover{background:#e11d48;box-shadow:0 6px 20px #f43f5e59;transform:translateY(-1px)}.btn-icon{align-items:center;background:#fff;background:var(--surface);border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:8px;box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm);color:#475569;color:var(--text-secondary);cursor:pointer;display:inline-flex;justify-content:center;padding:8px;transition:all .2s ease}.btn-icon:hover{background:#fafbfe;background:var(--background);border-color:#e2e8f0;border-color:var(--border-hover);color:#0f172a;color:var(--text-primary);transform:scale(1.05)}.card{background:#fff;background:var(--surface);border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:16px;box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm);padding:24px}.projects-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.project-card{background:#fff;background:var(--surface);border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:16px;box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm);cursor:pointer;display:flex;flex-direction:column;overflow:hidden;padding:24px;position:relative;transition:all .25s cubic-bezier(.4,0,.2,1)}.project-card:before{background:#0000;content:"";height:100%;left:0;position:absolute;top:0;transition:background-color .2s ease;width:4px}.project-card:hover{border-color:#e2e8f0;border-color:var(--border-hover);box-shadow:0 10px 25px -3px #4f46e50a,0 4px 12px -2px #00000005;box-shadow:var(--shadow-lg);transform:translateY(-4px)}.project-card:hover:before{background-color:#4f46e5;background-color:var(--primary)}.project-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.project-card h3{color:#0f172a;color:var(--text-primary);font-size:17px;font-weight:700;letter-spacing:-.3px;line-height:1.4;margin-bottom:6px}.project-card-meta{color:#475569;color:var(--text-secondary);font-size:13px;margin-bottom:20px}.project-card-footer{align-items:center;border-top:1px solid #f1f5f9;border-top:1px solid var(--border);display:flex;justify-content:space-between;margin-top:auto;padding-top:16px}.project-date{color:#475569;color:var(--text-secondary);font-weight:500}.project-date,.project-priority{align-items:center;display:flex;font-size:13px;gap:6px}.project-priority{font-weight:600}.project-team{align-items:center;border-top:1px dotted #f1f5f9;border-top:1px dotted var(--border);display:flex;gap:10px;margin-top:14px;padding-top:14px}.team-avatars{display:flex;margin-left:auto}.team-avatar{align-items:center;border:2px solid #fff;border:2px solid var(--surface);border-radius:50%;box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm);color:#fff;display:flex;font-size:10px;font-weight:700;height:28px;justify-content:center;margin-left:-6px;transition:transform .2s ease;width:28px}.team-avatar:hover{transform:translateY(-3px);z-index:10}.team-avatar:first-child{margin-left:0}.badge{align-items:center;border-radius:30px;display:inline-flex;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.badge-active{background:#d1fae5;background:var(--success-light);border:1px solid #10b98133;color:#065f46;color:var(--success-text)}.badge-planned{background:#e0e7ff;background:var(--primary-light);border:1px solid #4f46e533;color:#4f46e5;color:var(--primary)}.badge-completed{background:#d1fae5;border:1px solid #065f4633;color:#065f46}.badge-backlog{background:#fef3c7;background:var(--warning-light);border:1px solid #f59e0b33;color:#92400e;color:var(--warning-text)}.badge-onhold{background:#f1f5f9;border:1px solid #47556933;color:#475569}.badge-prospect{background:#f1f5f9;border:1px solid #64748b33;color:#64748b}.badge-archived{background:#e2e8f0;border:1px solid #64748b1a;color:#64748b}.priority-urgent{color:#f43f5e;color:var(--danger)}.priority-high{color:#f59e0b;color:var(--warning)}.priority-medium{color:#eab308}.priority-low{color:#10b981;color:var(--success)}.table-container{background:#fff;background:var(--surface);border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:16px;box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm);overflow:hidden}.table{border-collapse:collapse;width:100%}.table th{background:#fafbfe;font-size:11px;font-weight:700;letter-spacing:1px;padding:16px 24px;text-align:left;text-transform:uppercase}.table td,.table th{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border);color:#475569;color:var(--text-secondary)}.table td{font-size:14px;padding:18px 24px;vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tr{transition:background-color .2s ease}.table tr:hover{background:#fafbfe}.table td strong{color:#0f172a;color:var(--text-primary);font-weight:600}.filters-bar{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px}.filter-tabs{background:#fff;background:var(--surface);border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:10px;box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm);display:flex;padding:4px}.filter-tab{background:#0000;border:none;border-radius:8px;color:#475569;color:var(--text-secondary);cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:all .2s}.filter-tab:hover{background:#fafbfe;background:var(--background);color:#0f172a;color:var(--text-primary)}.filter-tab.active{background:#4f46e5;background:var(--primary);color:#fff}.filter-select,.filter-tab.active{box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm)}.filter-select{background:#fff;background:var(--surface);border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:10px;color:#0f172a;color:var(--text-primary);cursor:pointer;font-size:14px;font-weight:500;outline:none;padding:10px 16px;transition:all .2s ease}.filter-select:focus{border-color:#4f46e5;border-color:var(--primary);box-shadow:0 0 0 4px #4f46e526;box-shadow:var(--shadow-focus)}.pagination{align-items:center;background:#fafbfe;border-top:1px solid #f1f5f9;border-top:1px solid var(--border);display:flex;justify-content:space-between;padding:20px 24px}.pagination-info{color:#475569;color:var(--text-secondary);font-size:13px;font-weight:500}.pagination-buttons{display:flex;gap:6px}.pagination-btn{background:#fff;background:var(--surface);border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:8px;color:#475569;color:var(--text-secondary);cursor:pointer;font-size:13px;font-weight:600;padding:8px 14px;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background:#fafbfe;background:var(--background);border-color:#e2e8f0;border-color:var(--border-hover);color:#0f172a;color:var(--text-primary)}.pagination-btn:disabled{cursor:not-allowed;opacity:.4}.pagination-btn.active{background:#4f46e5;background:var(--primary);border-color:#4f46e5;border-color:var(--primary);box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm);color:#fff}.modal-overlay{align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172a66;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal{animation:scaleUp .3s cubic-bezier(.34,1.56,.64,1);background:#fff;background:var(--surface);border:1px solid #fffc;border-radius:20px;box-shadow:0 25px 50px -12px #0f172a26;max-height:90vh;max-width:640px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:24px 28px}.modal-header h2{color:#0f172a;color:var(--text-primary);font-size:20px;font-weight:700;letter-spacing:-.4px}.modal-body{padding:28px}.modal-footer{background:#fafbfe;border-bottom-left-radius:20px;border-bottom-right-radius:20px;border-top:1px solid #f1f5f9;border-top:1px solid var(--border);display:flex;gap:12px;justify-content:flex-end;padding:20px 28px}@keyframes scaleUp{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.form-group{margin-bottom:20px}.form-label{color:#475569;color:var(--text-secondary);display:block;font-size:13px;font-weight:600;margin-bottom:8px}.form-input,.form-select,.form-textarea{background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border-hover);border-radius:10px;color:#0f172a;color:var(--text-primary);font-size:14px;outline:none;padding:11px 16px;transition:all .25s ease;width:100%}.form-input::placeholder,.form-textarea::placeholder{color:#94a3b8;color:var(--text-muted)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#4f46e5;border-color:var(--primary);box-shadow:0 0 0 4px #4f46e526;box-shadow:var(--shadow-focus)}.form-textarea{min-height:110px;resize:vertical}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr)}.avatar{align-items:center;border-radius:50%;box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm);color:#fff;display:inline-flex;font-weight:700;justify-content:center}.avatar-sm{font-size:10px;height:28px;width:28px}.avatar-md{font-size:13px;height:36px;width:36px}.avatar-lg{font-size:16px;height:48px;width:48px}.loading{align-items:center;display:flex;justify-content:center;min-height:200px;width:100%}.spinner{animation:spin .8s cubic-bezier(.5,.1,.4,.9) infinite;border:3px solid #e2e8f0;border-top-color:#4f46e5;border:3px solid var(--border-hover);border-radius:50%;border-top-color:var(--primary);height:36px;width:36px}@keyframes spin{to{transform:rotate(1turn)}}.empty-state{background:#fff;background:var(--surface);border:1px dashed #e2e8f0;border:1px dashed var(--border-hover);border-radius:20px;color:#475569;color:var(--text-secondary);padding:80px 24px;text-align:center}.empty-state svg{color:#94a3b8;color:var(--text-muted);height:56px;margin-bottom:20px;width:56px}.empty-state h3{color:#0f172a;color:var(--text-primary);font-size:18px;font-weight:700;margin-bottom:8px}.empty-state p{font-size:14px;margin:0 auto;max-width:320px}.view-toggle{background:#fff;background:var(--surface);border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:10px;box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm);display:flex;padding:4px}.view-toggle-btn{align-items:center;background:#0000;border:none;border-radius:6px;color:#475569;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:8px 12px;transition:all .2s ease}.view-toggle-btn:hover{background:#fafbfe;background:var(--background);color:#0f172a;color:var(--text-primary)}.view-toggle-btn.active{background:#e0e7ff;background:var(--primary-light);color:#4f46e5;color:var(--primary)}.project-detail{grid-gap:32px;display:grid;gap:32px;grid-template-columns:1fr 340px}.project-detail-main{display:flex;flex-direction:column;gap:32px}.project-detail-sidebar{display:flex;flex-direction:column;gap:24px}.detail-card{background:#fff;background:var(--surface);border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:16px;box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm);padding:28px}.detail-card h3{color:#475569;color:var(--text-secondary);font-size:12px;font-weight:700;letter-spacing:1px;margin-bottom:20px;text-transform:uppercase}.detail-row{align-items:center;border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:12px 0}.detail-row:last-child{border-bottom:none}.detail-label{color:#475569;color:var(--text-secondary);font-size:14px;font-weight:500}.detail-value{color:#0f172a;color:var(--text-primary);font-size:14px;font-weight:600}.tabs{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border);display:flex;gap:8px;margin-bottom:32px;overflow-x:auto}.tab{background:#0000;border:none;color:#475569;color:var(--text-secondary);cursor:pointer;font-size:14px;font-weight:600;padding:12px 20px;position:relative;transition:color .2s ease;white-space:nowrap}.tab:hover{color:#0f172a;color:var(--text-primary)}.tab.active{color:#4f46e5;color:var(--primary)}.tab.active:after{background:#4f46e5;background:var(--primary);border-top-left-radius:3px;border-top-right-radius:3px;bottom:-1px;content:"";height:3px;left:0;position:absolute;right:0}.progress-bar{background:#e2e8f0;background:var(--border-hover);border-radius:6px;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#4f46e5,#818cf8);background:linear-gradient(90deg,var(--primary),#818cf8);border-radius:6px;height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}.checkbox-list{display:flex;flex-direction:column;gap:6px;max-height:220px;overflow-y:auto;padding-right:4px}.checkbox-item{align-items:center;border:1px solid #0000;border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:10px 14px;transition:all .2s}.checkbox-item:hover{background:#fafbfe;background:var(--background);border-color:#f1f5f9;border-color:var(--border)}.checkbox-item input[type=checkbox]{accent-color:#4f46e5;accent-color:var(--primary);cursor:pointer;height:18px;width:18px}.selected-items{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.selected-item{background:#e0e7ff;background:var(--primary-light);border-radius:30px;display:inline-flex;font-size:13px;font-weight:600;gap:6px;padding:6px 12px}.selected-item,.selected-item button{align-items:center;color:#4f46e5;color:var(--primary)}.selected-item button{background:#0000;border:none;border-radius:50%;cursor:pointer;display:flex;height:18px;justify-content:center;transition:background .2s;width:18px}.selected-item button:hover{background:#4f46e51a}.alert{align-items:center;border-radius:12px;display:flex;font-size:14px;font-weight:500;gap:12px;padding:16px 20px}.alert-info{background:#e0e7ff;background:var(--primary-light);border:1px solid #4f46e533;color:#4f46e5;color:var(--primary)}.alert-danger{background:#ffe4e6;background:var(--danger-light);border:1px solid #f43f5e33;color:#9f1239;color:var(--danger-text)}.toast{animation:slideIn .3s cubic-bezier(.34,1.56,.64,1);border-radius:12px;bottom:24px;box-shadow:0 10px 30px #00000026;color:#fff;font-size:14px;font-weight:600;padding:14px 24px;position:fixed;right:24px;z-index:2000}.toast-success{background:#10b981;background:var(--success)}.toast-error{background:#f43f5e;background:var(--danger)}@keyframes slideIn{0%{opacity:0;transform:translateY(100%) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.sidebar-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a66;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:99}@media (max-width:1200px){.page-header{padding:20px 32px}.page-content{padding:24px 32px}}@media (max-width:1024px){.sidebar{transform:translateX(-100%)}.sidebar.open{box-shadow:25px 0 50px -12px #0f172a40;transform:translateX(0)}.main-content{margin-left:0}.mobile-menu-btn{display:flex}.sidebar-overlay.open{display:block}.project-detail{grid-template-columns:1fr}}@media (max-width:768px){.page-header{align-items:flex-start;flex-direction:column;gap:16px}.page-content,.page-header{padding:20px 24px}.form-row{gap:0}.form-row,.projects-grid{grid-template-columns:1fr}.filters-bar{align-items:stretch;flex-direction:column}.filter-tabs{width:100%}.filter-tab{flex:1 1;text-align:center}.filter-select{width:100%}.pagination{flex-direction:column;gap:12px;text-align:center}}@media (max-width:480px){.page-title{font-size:22px}.btn{width:100%}.project-card{padding:20px}}.roadmap-container{display:flex;flex-direction:column;gap:24px}.roadmap-timeline-card{background:#fff;background:var(--surface);border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:16px;box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm);overflow:hidden;padding:24px}.roadmap-timeline-wrapper{background:#fff;border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:12px;overflow-x:auto;position:relative}.roadmap-timeline-grid{min-width:1000px;position:relative}.roadmap-header-row{background:#fafbfe;border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border);display:flex}.roadmap-project-col-header{align-items:center;border-right:1px solid #f1f5f9;border-right:1px solid var(--border);color:#475569;color:var(--text-secondary);display:flex;flex-shrink:0;font-size:11px;font-weight:700;letter-spacing:1px;padding:16px 20px;text-transform:uppercase;width:250px}.roadmap-timeline-cols-header{display:flex;flex:1 1;position:relative}.roadmap-header-tick{border-right:1px solid #f1f5f9;border-right:1px solid var(--border);color:#475569;color:var(--text-secondary);flex:1 1;font-size:11px;font-weight:700;letter-spacing:.5px;padding:16px 8px;text-align:center;text-transform:uppercase}.roadmap-header-tick:last-child{border-right:none}.roadmap-body-rows{display:flex;flex-direction:column}.roadmap-project-row{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border);display:flex;min-height:88px;transition:background-color .2s ease}.roadmap-project-row:last-child{border-bottom:none}.roadmap-project-row:hover{background:#fafbfe}.roadmap-project-info-cell{border-right:1px solid #f1f5f9;border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;gap:4px;justify-content:center;padding:16px 20px;width:250px}.roadmap-project-info-cell h4{color:#0f172a;color:var(--text-primary);cursor:pointer;font-size:14px;font-weight:700;letter-spacing:-.2px;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.roadmap-project-info-cell h4:hover{color:#4f46e5;color:var(--primary)}.roadmap-project-info-cell p{color:#475569;color:var(--text-secondary);font-size:12px;font-weight:500;margin:0}.roadmap-timeline-cell{align-items:center;background-image:linear-gradient(90deg,#f1f5f9 1px,#0000 0);background-image:linear-gradient(to right,var(--border) 1px,#0000 1px);background-size:calc(100%/var(--ticks-count)) 100%;display:flex;flex:1 1;padding:0;position:relative}.roadmap-project-bar{border-radius:12px;box-shadow:0 4px 10px #0000000d;color:#fff;cursor:pointer;display:flex;flex-direction:column;font-size:12px;gap:2px;height:52px;justify-content:center;overflow:hidden;padding:8px 14px;position:absolute;transition:transform .2s ease,box-shadow .2s ease}.roadmap-project-bar:hover{box-shadow:0 8px 16px #00000026;filter:brightness(1.05);transform:translateY(-1px);z-index:10}.roadmap-bar-title{font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.roadmap-bar-meta{align-items:center;display:flex;font-size:10px;font-weight:500;gap:8px;opacity:.9;overflow:hidden;white-space:nowrap}.roadmap-bar-priority{background:#fff3;border-radius:4px;font-size:9px;font-weight:700;letter-spacing:.5px;padding:1px 6px;text-transform:uppercase}.team-assign-container{display:flex;flex-direction:column;gap:16px}.team-assign-search-wrapper{position:relative}.team-filter-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.team-filter-chip{background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border-hover);border-radius:20px;color:#475569;color:var(--text-secondary);cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:all .2s ease}.team-filter-chip:hover{background:#fafbfe;background:var(--background);border-color:#94a3b8;border-color:var(--text-muted);color:#0f172a;color:var(--text-primary)}.team-filter-chip.active{background:#e0e7ff;background:var(--primary-light);border-color:#4f46e5;border-color:var(--primary);color:#4f46e5;color:var(--primary)}.team-assign-list{display:flex;flex-direction:column;gap:12px;max-height:380px;overflow-y:auto;padding-right:4px}.team-assign-card{background:#fff;background:var(--surface);border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:12px;cursor:pointer;display:flex;flex-direction:column;padding:16px;transition:all .2s ease}.team-assign-card:hover{background:#fafbfe;background:var(--background);border-color:#e2e8f0;border-color:var(--border-hover);box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm)}.team-assign-card.selected{background:#4f46e503;border-color:#4f46e5;border-color:var(--primary)}.team-assign-card.disabled{background:#fafbfe;background:var(--background);border-color:#f1f5f9;border-color:var(--border);cursor:not-allowed;opacity:.6}.team-assign-card.invalid-reason{background:#f43f5e03;border-color:#f43f5e;border-color:var(--danger)}.team-assign-row-main{align-items:center;display:flex;gap:16px;justify-content:space-between}.team-assign-left{align-items:center;display:flex;flex:1 1;gap:12px}.team-assign-checkbox{accent-color:#4f46e5;accent-color:var(--primary);cursor:pointer;height:18px;width:18px}.team-assign-checkbox:disabled{cursor:not-allowed}.team-assign-details{display:flex;flex-direction:column;gap:2px}.team-assign-name{align-items:center;color:#0f172a;color:var(--text-primary);display:flex;font-size:14px;font-weight:600;gap:6px}.team-assign-meta{color:#475569;color:var(--text-secondary);font-size:12px}.team-assign-mid{display:flex;flex-direction:column;gap:4px;width:180px}.capacity-bar-container{background-color:#f1f5f9;background-color:var(--border);border-radius:3px;height:6px;overflow:hidden;position:relative;width:100%}.capacity-bar{border-radius:3px;height:100%;transition:width .3s ease,background-color .3s ease}.capacity-bar.success{background-color:#10b981;background-color:var(--success)}.capacity-bar.warning{background-color:#f59e0b;background-color:var(--warning)}.capacity-bar.danger{background-color:#f43f5e;background-color:var(--danger)}.team-assign-right{align-items:center;display:flex}.role-toggle-group{background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border-hover);border-radius:8px;display:flex;overflow:hidden}.role-toggle-btn{background:#0000;border:none;color:#475569;color:var(--text-secondary);cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:all .2s ease}.role-toggle-btn:hover{background:#fafbfe;background:var(--background);color:#0f172a;color:var(--text-primary)}.role-toggle-btn.active{background:#4f46e5;background:var(--primary);color:#fff}.overload-reason-field{animation:fadeIn .2s ease;border-top:1px dashed #e2e8f0;border-top:1px dashed var(--border-hover);display:flex;flex-direction:column;gap:6px;margin-top:12px;padding-top:12px}.overload-reason-label{align-items:center;color:#9f1239;color:var(--danger-text);display:flex;font-size:11px;font-weight:600;gap:4px}.overload-reason-input{background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border-hover);border-radius:8px;color:#0f172a;color:var(--text-primary);font-size:12px;outline:none;padding:8px 12px;transition:border-color .2s ease;width:100%}.overload-reason-input:focus{border-color:#f43f5e;border-color:var(--danger);box-shadow:0 0 0 3px #f43f5e1a}.overload-reason-input.valid:focus{border-color:#10b981;border-color:var(--success);box-shadow:0 0 0 3px #10b9811a}.overload-reason-input.valid{border-color:#e2e8f0;border-color:var(--border-hover)}.validation-alert-footer{align-items:center;background:#ffe4e6;background:var(--danger-light);border-radius:8px;color:#9f1239;color:var(--danger-text);display:flex;font-size:12px;font-weight:500;gap:8px;margin-right:auto;padding:8px 12px}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.kanban-board{align-items:flex-start;display:flex;gap:20px;overflow-x:auto;padding:16px 0}.kanban-column{background:#f8fafc;border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:16px;display:flex;flex:1 1;flex-direction:column;gap:12px;max-height:70vh;max-width:320px;min-width:280px;overflow-y:auto;padding:16px}.kanban-column-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.kanban-column-title{align-items:center;color:#0f172a;color:var(--text-primary);display:flex;font-size:14px;font-weight:700;gap:8px;letter-spacing:.5px;text-transform:uppercase}.kanban-column-count{background:#e2e8f0;background:var(--border-hover);border-radius:20px;color:#475569;color:var(--text-secondary);font-size:11px;font-weight:600;padding:2px 8px}.kanban-card{background:#fff;background:var(--surface);border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:12px;box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm);cursor:pointer;display:flex;flex-direction:column;gap:12px;padding:16px;transition:all .2s ease}.kanban-card:hover{border-color:#e0e7ff;border-color:var(--primary-light);box-shadow:0 4px 6px -1px #00000008,0 2px 4px -1px #00000005;box-shadow:var(--shadow-md);transform:translateY(-2px)}.kanban-card-title{color:#0f172a;color:var(--text-primary);font-size:14px;font-weight:600;line-height:1.4}.kanban-card-meta{align-items:center;border-top:1px solid #f1f5f9;border-top:1px solid var(--border);display:flex;justify-content:space-between;margin-top:4px;padding-top:10px}.kanban-card-assignee{align-items:center;color:#475569;color:var(--text-secondary);display:flex;font-size:12px;gap:6px}.kanban-card-date{align-items:center;color:#94a3b8;color:var(--text-muted);display:flex;font-size:11px;gap:4px}.kanban-card-actions{display:flex;gap:8px;opacity:0;transition:opacity .2s ease}.kanban-card:hover .kanban-card-actions{opacity:1}.notes-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));padding:16px 0}.note-card{background:#fff;background:var(--surface);border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:16px;box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px;min-height:180px;padding:20px;position:relative;transition:all .2s ease}.note-card:hover{border-color:#e0e7ff;border-color:var(--primary-light);box-shadow:0 10px 25px -3px #4f46e50a,0 4px 12px -2px #00000005;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.note-card-title{color:#0f172a;color:var(--text-primary);font-size:16px;font-weight:700}.note-card-content{-webkit-line-clamp:4;-webkit-box-orient:vertical;color:#475569;color:var(--text-secondary);display:-webkit-box;flex:1 1;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:pre-wrap}.note-card-footer{align-items:center;border-top:1px solid #f1f5f9;border-top:1px solid var(--border);color:#94a3b8;color:var(--text-muted);display:flex;font-size:11px;justify-content:space-between;padding-top:12px}.note-card-actions{display:flex;gap:8px}.assets-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));padding:16px 0}.asset-card{background:#fff;background:var(--surface);border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:16px;box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px;padding:16px;position:relative;transition:all .2s ease}.asset-card:hover{border-color:#e0e7ff;border-color:var(--primary-light);box-shadow:0 4px 6px -1px #00000008,0 2px 4px -1px #00000005;box-shadow:var(--shadow-md);transform:translateY(-2px)}.asset-icon-wrapper{align-items:center;border-radius:12px;display:flex;font-size:20px;height:48px;justify-content:center;width:48px}.asset-icon-wrapper.pdf{background:#fef2f2;color:#ef4444}.asset-icon-wrapper.image{background:#ecfdf5;color:#10b981}.asset-icon-wrapper.excel{background:#f0fdf4;color:#22c55e}.asset-icon-wrapper.doc{background:#eff6ff;color:#3b82f6}.asset-icon-wrapper.other{background:#f8fafc;color:#64748b}.asset-details{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.asset-name{color:#0f172a;color:var(--text-primary);font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.asset-meta{color:#475569;color:var(--text-secondary);font-size:12px}.asset-footer{align-items:center;border-top:1px solid #f1f5f9;border-top:1px solid var(--border);display:flex;justify-content:space-between;padding-top:12px}.asset-date{color:#94a3b8;color:var(--text-muted);font-size:11px}.upload-dropzone{align-items:center;background:#fff;background:var(--surface);border:2px dashed #e2e8f0;border:2px dashed var(--border-hover);border-radius:16px;cursor:pointer;display:flex;flex-direction:column;gap:12px;justify-content:center;margin-bottom:24px;padding:32px;transition:all .2s ease}.upload-dropzone:hover{background:#4f46e503;border-color:#4f46e5;border-color:var(--primary)}.upload-icon{align-items:center;color:#4f46e5;color:var(--primary);display:flex;justify-content:center}.upload-text{color:#475569;color:var(--text-secondary);font-size:14px;text-align:center}.upload-text strong{color:#4f46e5;color:var(--primary)}.task-description-field{margin-top:16px}.task-comments-section{border-top:1px solid #f1f5f9;border-top:1px solid var(--border);margin-top:24px;padding-top:20px}.task-comments-section h3{align-items:center;color:#0f172a;color:var(--text-primary);display:flex;font-size:15px;font-weight:700;gap:8px;margin-bottom:12px}.task-comments-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px;max-height:250px;overflow-y:auto;padding-right:4px}.comment-item{align-items:flex-start;background:#fafbfe;background:var(--background);border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:12px;display:flex;gap:10px;padding:10px 12px;position:relative;transition:all .2s ease}.comment-item:hover{background:#fff;background:var(--surface);border-color:#e2e8f0;border-color:var(--border-hover)}.comment-avatar{flex-shrink:0}.comment-body{flex:1 1;min-width:0}.comment-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.comment-author{color:#0f172a;color:var(--text-primary);font-size:12px;font-weight:700}.comment-time{color:#94a3b8;color:var(--text-muted);font-size:11px}.comment-content{color:#475569;color:var(--text-secondary);font-size:13px;line-height:1.4;white-space:pre-wrap}.comment-delete-btn{align-items:center;background:none;border:none;border-radius:4px;color:#94a3b8;color:var(--text-muted);cursor:pointer;display:flex;justify-content:center;padding:2px;transition:all .2s ease}.comment-delete-btn:hover{background:#ffe4e6;background:var(--danger-light);color:#f43f5e;color:var(--danger)}.comment-form{align-items:flex-end;display:flex;gap:8px;margin-top:12px}.comment-form-input{background:#fff;background:var(--surface);border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:10px;color:#0f172a;color:var(--text-primary);flex:1 1;font-size:13px;max-height:100px;min-height:38px;padding:8px 12px;resize:vertical;transition:all .2s ease}.comment-form-input:focus{border-color:#4f46e5;border-color:var(--primary);box-shadow:0 0 0 2px #4f46e51a;outline:none}html[data-theme=dark]{--background:#0f172a;--surface:#1e293b;--border:#334155;--border-hover:#475569;--text-primary:#f8fafc;--text-secondary:#cbd5e1;--text-muted:#64748b;--primary-light:#1e293b;--primary-glow:#6366f133;--sidebar-bg:#0b0f19;--sidebar-border:#1e293b;--sidebar-text:#94a3b8;--sidebar-text-active:#818cf8;--sidebar-hover-bg:#1e293b;--sidebar-active-bg:#6366f126;--sidebar-active-border:#818cf8;--success-light:#10b98126;--success-text:#34d399;--warning-light:#f59e0b26;--warning-text:#fbbf24;--danger-light:#f43f5e26;--danger-text:#fb7185}html[data-theme=dark] .card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#1e293bb3;border:1px solid #ffffff0d}html[data-theme=dark] input,html[data-theme=dark] select,html[data-theme=dark] textarea{background-color:#1e293b!important;border-color:#334155!important;color:#f8fafc!important}html[data-theme=dark] input:focus,html[data-theme=dark] select:focus,html[data-theme=dark] textarea:focus{border-color:#818cf8!important;box-shadow:0 0 0 3px #818cf833!important}html[data-theme=dark] .table th{background-color:#1e293b!important;border-bottom:2px solid #334155!important;color:#94a3b8!important}html[data-theme=dark] .table td{border-bottom:1px solid #334155!important}html[data-theme=dark] .table tr:hover{background-color:#ffffff05!important}html[data-theme=dark] .modal{background-color:#1e293b!important;border:1px solid #334155!important;color:#f8fafc!important}html[data-theme=dark] .modal-header{border-bottom:1px solid #334155!important}html[data-theme=dark] .modal-footer{border-top:1px solid #334155!important}html[data-theme=dark] .empty-state{background:#0000;border:2px dashed #334155}html[data-theme=dark] .nav-item{color:#475569;color:var(--sidebar-text)}html[data-theme=dark] .nav-item.active{background:#e0e7ff;background:var(--sidebar-active-bg);color:#4f46e5;color:var(--sidebar-text-active)}html[data-theme=dark] .roadmap-timeline-wrapper{background:#fafbfe!important;background:var(--background)!important;border-color:#f1f5f9!important;border-color:var(--border)!important}html[data-theme=dark] .roadmap-header-row{background:#fff!important;background:var(--surface)!important;border-bottom:1px solid #f1f5f9!important;border-bottom:1px solid var(--border)!important}html[data-theme=dark] .roadmap-project-row:hover{background:#ffffff05!important}.workstream-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.workstream-title-group h2{color:#0f172a;color:var(--text-primary);font-size:20px;font-weight:700;margin:0}.workstream-title-group p{color:#475569;color:var(--text-secondary);font-size:14px;margin:4px 0 0}.phases-list{display:flex;flex-direction:column;gap:24px}.phase-card{background:#fff;background:var(--surface);border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:16px;box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm);overflow:hidden;transition:all .2s ease}.phase-card:hover{border-color:#e2e8f0;border-color:var(--border-hover);box-shadow:0 4px 6px -1px #00000008,0 2px 4px -1px #00000005;box-shadow:var(--shadow-md)}.phase-card-header{align-items:center;background:rgba(0,0,0,.015);border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:20px 24px}html[data-theme=dark] .phase-card-header{background:#ffffff03}.phase-title-info{display:flex;flex-direction:column;gap:6px}.phase-title-row{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.phase-name{color:#0f172a;color:var(--text-primary);font-size:16px;font-weight:700;margin:0}.phase-date-badge{align-items:center;background:#0000000a;border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:6px;color:#475569;color:var(--text-secondary);display:flex;font-size:11px;font-weight:600;gap:6px;padding:4px 8px}html[data-theme=dark] .phase-date-badge{background:#ffffff0a}.phase-progress-summary{align-items:center;color:#475569;color:var(--text-secondary);display:flex;font-size:12px;gap:8px}.phase-header-actions{align-items:center;display:flex;gap:12px}.phase-progress-bar-container{background:#00000014;border-radius:3px;height:6px;overflow:hidden;width:120px}html[data-theme=dark] .phase-progress-bar-container{background:#ffffff14}.phase-progress-bar-fill{background:#4f46e5;background:var(--primary);border-radius:3px;height:100%;transition:width .3s ease}.phase-card-body{padding:20px 24px}.phase-tasks-list{display:flex;flex-direction:column;gap:10px}.phase-task-row{align-items:center;background:#fafbfe;background:var(--background);border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:12px;cursor:pointer;display:flex;justify-content:space-between;padding:12px 16px;transition:all .2s ease}.phase-task-row:hover{border-color:#e2e8f0;border-color:var(--border-hover);box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm);transform:translateX(3px)}.phase-task-left{align-items:center;display:flex;flex:1 1;gap:12px;min-width:0}.phase-task-title{color:#0f172a;color:var(--text-primary);font-size:14px;font-weight:600}.phase-task-description,.phase-task-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.phase-task-description{color:#475569;color:var(--text-secondary);font-size:12px;max-width:250px}.phase-task-right{align-items:center;display:flex;flex-shrink:0;gap:16px}.phase-task-meta{align-items:center;display:flex;gap:12px}.phase-task-assignee{align-items:center;display:flex;gap:8px}.phase-task-assignee-name{color:#475569;color:var(--text-secondary);font-size:12px;font-weight:500}.phase-task-due-date{align-items:center;background:#0000000a;border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:6px;color:#475569;color:var(--text-secondary);display:flex;font-size:11px;font-weight:600;gap:4px;padding:4px 8px}html[data-theme=dark] .phase-task-due-date{background:#ffffff0a}.phase-empty-state{align-items:center;background:rgba(0,0,0,.005);border:1px dashed #f1f5f9;border:1px dashed var(--border);border-radius:12px;color:#475569;color:var(--text-secondary);display:flex;flex-direction:column;justify-content:center;padding:24px 0;text-align:center}html[data-theme=dark] .phase-empty-state{background:hsla(0,0%,100%,.002)}.phase-empty-state p{font-size:13px;margin:6px 0 0}.unassigned-section{border-top:2px dashed #f1f5f9;border-top:2px dashed var(--border);margin-top:36px;padding-top:24px}.unassigned-section-header{margin-bottom:16px}.unassigned-section-header h3{color:#0f172a;color:var(--text-primary);font-size:16px;font-weight:700;margin:0}.unassigned-section-header p{color:#475569;color:var(--text-secondary);font-size:13px;margin:4px 0 0}.dashboard-container{display:flex;flex-direction:column;gap:24px}.kpi-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.kpi-card{align-items:center;background:#fff;background:var(--surface);border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:16px;box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm);display:flex;gap:16px;padding:24px;transition:all .2s ease}.kpi-card:hover{border-color:#e2e8f0;border-color:var(--border-hover);box-shadow:0 4px 6px -1px #00000008,0 2px 4px -1px #00000005;box-shadow:var(--shadow-md);transform:translateY(-2px)}.kpi-icon-wrapper{align-items:center;border-radius:12px;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.kpi-details{display:flex;flex-direction:column;gap:4px;min-width:0}.kpi-value{color:#0f172a;color:var(--text-primary);font-size:24px;font-weight:800;line-height:1}.kpi-label{color:#475569;color:var(--text-secondary);font-size:13px;font-weight:500}.kpi-trend{align-items:center;display:flex;font-size:11px;font-weight:700;gap:2px;margin-top:2px}.kpi-trend.up{color:#065f46;color:var(--success-text)}.kpi-trend.down{color:#9f1239;color:var(--danger-text)}.dashboard-row{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr}@media (max-width:1024px){.dashboard-row{grid-template-columns:1fr}}.dashboard-card{background:#fff;background:var(--surface);border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:16px;box-shadow:0 1px 3px #0000000d;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;min-width:0;padding:24px}.dashboard-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.dashboard-card-title{color:#0f172a;color:var(--text-primary);font-size:16px;font-weight:700;margin:0}.chart-container-donut{align-items:center;display:flex;flex:1 1;gap:32px;justify-content:center;padding:12px 0}@media (max-width:480px){.chart-container-donut{flex-direction:column;gap:16px}}.donut-svg-wrapper{height:160px;position:relative;width:160px}.donut-center-text{left:50%;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%)}.donut-center-num{color:#0f172a;color:var(--text-primary);font-size:28px;font-weight:800;line-height:1}.donut-center-lbl{color:#475569;color:var(--text-secondary);font-size:11px;margin-top:2px}.chart-legend{display:flex;flex:1 1;flex-direction:column;gap:10px}.legend-item{align-items:center;color:#475569;color:var(--text-secondary);display:flex;font-size:13px;justify-content:space-between}.legend-label-group{align-items:center;display:flex;gap:8px}.legend-dot{border-radius:50%;height:8px;width:8px}.legend-value{color:#0f172a;color:var(--text-primary);font-weight:600}.bar-chart-list{display:flex;flex:1 1;flex-direction:column;gap:16px}.bar-chart-item{display:flex;flex-direction:column;gap:8px}.bar-chart-label-row{display:flex;font-size:13px;font-weight:600;justify-content:space-between}.bar-chart-name{color:#0f172a;color:var(--text-primary)}.bar-chart-count{color:#475569;color:var(--text-secondary)}.bar-track{background:#0000000d;border-radius:5px;height:10px;overflow:hidden;width:100%}html[data-theme=dark] .bar-track{background:#ffffff0d}.bar-fill{border-radius:5px;height:100%;transition:width .4s ease}.workload-avatar-cell{align-items:center;display:flex;gap:10px}.workload-badge{border-radius:4px;font-size:10px;font-weight:700;padding:2px 6px;text-transform:uppercase}.workload-under{background:#6366f126;color:#818cf8}.workload-balanced{background:#10b98126;color:#34d399}.workload-over{background:#ef444426;color:#f87171}.critical-deadlines-list{display:flex;flex-direction:column;gap:14px}.critical-deadline-item{align-items:center;background:#fafbfe;background:var(--background);border:1px solid #f1f5f9;border:1px solid var(--border);border-radius:12px;display:flex;justify-content:space-between;padding:12px 16px;transition:all .2s ease}.critical-deadline-item:hover{border-color:#e2e8f0;border-color:var(--border-hover);transform:translateX(2px)}.critical-project-info{display:flex;flex-direction:column;gap:4px;min-width:0}.critical-project-name{color:#0f172a;color:var(--text-primary);font-size:14px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.critical-project-client{color:#475569;color:var(--text-secondary);font-size:12px}.critical-deadline-date{align-items:center;background:#ef44440d;border:1px solid #ef444433;border-radius:6px;color:#f87171;display:flex;font-size:11px;font-weight:700;gap:4px;padding:4px 8px}.critical-deadline-date.warning{background:#f59e0b0d;border-color:#f59e0b33;color:#fbbf24}.critical-progress-circle{height:36px;position:relative;width:36px}.critical-pct-text{color:#0f172a;color:var(--text-primary);font-size:10px;font-weight:700;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}:root{--status-active:var(--primary);--status-planned:#818cf8;--status-completed:var(--success);--status-onhold:var(--secondary);--status-backlog:var(--text-muted);--size-xs:#38bdf8;--size-s:#10b981;--size-m:#3b82f6;--size-l:#6366f1;--size-xl:#8b5cf6}.badge-pill{align-items:center;background:#4f46e526;background:var(--pill-bg,var(--primary-glow));border:1px solid #4f46e526;border:1px solid var(--pill-border,#4f46e526);border-radius:12px;color:#4f46e5;color:var(--pill-color,var(--primary));display:inline-flex;font-size:11px;font-weight:600;padding:3px 10px;transition:all .2s ease}.badge-pill:hover{transform:scale(1.05)}.search-wrapper{position:relative}.search-icon-left{color:#94a3b8;color:var(--text-muted);left:12px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.search-input-with-icon{padding-left:40px!important;width:280px}.login-container{align-items:center;background:radial-gradient(circle at 10% 20%,#4f46e526 0,#0000 40%),radial-gradient(circle at 90% 80%,#ec48990d 0,#0000 40%),#fafbfe;background:radial-gradient(circle at 10% 20%,var(--primary-glow) 0,#0000 40%),radial-gradient(circle at 90% 80%,#ec48990d 0,#0000 40%),var(--background);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:24px;position:relative;width:100vw}.login-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffffbf;border:1px solid #fffc;border-radius:24px;box-shadow:0 20px 25px -5px #00000005,0 10px 10px -5px #00000003,0 20px 40px -15px #0f172a0d;box-shadow:var(--shadow-premium),0 20px 40px -15px #0f172a0d;max-width:420px;padding:40px;transition:all .3s ease;width:100%;z-index:1}html[data-theme=dark] .login-card{background:#1e293bb3!important;border:1px solid #ffffff0d!important;box-shadow:0 20px 40px -15px #00000080!important}.login-input{background:#fff9!important;border:1px solid #e2e8f0!important;border:1px solid var(--border-hover)!important}html[data-theme=dark] .login-input{background:#1e293b!important;border:1px solid #334155!important;color:#f8fafc!important}.flex-spacer{flex:1 1}
/*# sourceMappingURL=main.d6acd412.css.map*/