.access-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:40px}.denied-icon{font-size:64px;margin-bottom:24px;opacity:.8}.access-denied h2{font-size:24px;font-weight:600;color:var(--text-primary);margin:0 0 12px}.access-denied p{font-size:15px;color:var(--text-secondary);margin:0 0 8px}.denied-hint{font-size:13px;color:var(--text-tertiary);margin-bottom:24px}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh}.loading-state p{color:var(--text-secondary);font-size:14px}.logo-icon{flex-shrink:0}.logo-text{font-weight:700;background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.logo-sm .logo-text{font-size:var(--text-sm)}.logo-md .logo-text{font-size:var(--text-lg)}.logo-lg .logo-text{font-size:var(--text-2xl)}.notification-center-panel{display:flex;flex-direction:column;min-height:200px;max-height:500px}.notification-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-primary);flex-shrink:0}.notification-header h3{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.notification-header-actions{display:flex;align-items:center;gap:var(--space-3)}.mark-all-btn{font-size:var(--text-sm);color:var(--color-brand);background:none;border:none;cursor:pointer;padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);transition:all var(--duration-fast) var(--ease-default)}.mark-all-btn:hover{background-color:var(--color-brand-alpha-10)}.close-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-tertiary);cursor:pointer;font-size:var(--text-base);transition:all var(--duration-fast) var(--ease-default)}.notification-list{flex:1;overflow-y:auto}.notification-loading,.notification-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);text-align:center;color:var(--text-secondary)}.notification-loading .loading-spinner{width:32px;height:32px;border:3px solid var(--border-primary);border-top-color:var(--color-brand);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:var(--space-3)}.empty-icon{font-size:48px;display:block;margin-bottom:var(--space-3);opacity:.5}.notification-item{display:flex;gap:var(--space-3);padding:var(--space-4);border-bottom:1px solid var(--border-primary);transition:background-color var(--duration-fast) var(--ease-default)}.notification-item:last-child{border-bottom:none}.notification-item:hover{background-color:var(--bg-hover)}.notification-item.unread{background-color:var(--color-brand-alpha-10)}.notification-item.unread:hover{background-color:var(--bg-hover)}.notification-icon{font-size:20px;flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background-color:var(--bg-hover);border-radius:var(--radius-lg)}.notification-content{flex:1;min-width:0}.notification-title{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);margin-bottom:var(--space-1)}.notification-message{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notification-meta{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-2)}.notification-time{font-size:var(--text-xs);color:var(--text-tertiary)}.notification-link{font-size:var(--text-xs);color:var(--color-brand);text-decoration:none}.notification-link:hover{text-decoration:underline}.notification-actions{display:flex;gap:var(--space-1);opacity:0;transition:opacity var(--duration-fast) var(--ease-default);flex-shrink:0}.notification-item:hover .notification-actions{opacity:1}.action-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border:none;background-color:var(--bg-surface-secondary);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-sm);color:var(--text-secondary);transition:all var(--duration-fast) var(--ease-default)}.action-btn:hover{background-color:var(--color-success-alpha-10);color:var(--color-success)}.action-btn.delete:hover{background-color:var(--color-danger-alpha-10);color:var(--color-danger)}.mobile-nav{display:none}@media (max-width: 768px){.mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background-color:var(--nav-bg);border-top:1px solid var(--nav-border);padding:8px 0;padding-bottom:calc(8px + env(safe-area-inset-bottom,0));z-index:100;justify-content:space-around}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 16px;border:none;background:none;color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:pointer;min-width:60px}.mobile-nav-item:hover,.mobile-nav-item.active{color:var(--accent-primary);background-color:var(--accent-light)}.mobile-nav-icon{font-size:22px;line-height:1}.mobile-nav-label{font-size:10px;font-weight:500}.mobile-menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;z-index:200;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-menu{position:fixed;bottom:0;left:0;right:0;background-color:var(--card-bg);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:20px;padding-bottom:calc(20px + env(safe-area-inset-bottom,0));z-index:201;animation:slideUp .3s ease;max-height:60vh;overflow-y:auto}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mobile-menu-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-primary)}.mobile-menu-header h3{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.close-btn{width:32px;height:32px;border:none;background-color:var(--bg-secondary);border-radius:var(--radius-md);font-size:16px;cursor:pointer;color:var(--text-secondary);transition:all var(--transition-fast)}.close-btn:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.mobile-menu-items{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.mobile-menu-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 8px;background-color:var(--bg-secondary);border-radius:var(--radius-lg);text-decoration:none;color:var(--text-primary);transition:all var(--transition-fast)}.mobile-menu-item:hover,.mobile-menu-item.active{background-color:var(--accent-light);color:var(--accent-primary)}.menu-icon{font-size:28px;line-height:1}.menu-label{font-size:12px;font-weight:500;text-align:center}}@media (max-width: 375px){.mobile-nav-item{padding:8px 10px;min-width:50px}.mobile-nav-icon{font-size:20px}.mobile-nav-label{font-size:9px}.mobile-menu-items{grid-template-columns:repeat(3,1fr)}.menu-icon{font-size:24px}.menu-label{font-size:11px}}.app-layout{display:grid;grid-template-columns:260px 1fr;min-height:100vh;background-color:var(--bg-base);transition:grid-template-columns var(--duration-normal) var(--ease-default)}.app-layout[data-sidebar-collapsed=true]{grid-template-columns:72px 1fr}.sidebar{display:flex;flex-direction:column;height:100vh;background-color:var(--bg-surface);border-right:1px solid var(--border-primary);position:sticky;top:0;overflow:hidden;transition:width var(--duration-normal) var(--ease-default)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;height:60px;padding:0 var(--space-4);border-bottom:1px solid var(--border-primary);flex-shrink:0}.logo{display:flex;align-items:center;gap:var(--space-3)}.logo-icon{font-size:24px}.logo-text{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--text-primary);letter-spacing:var(--tracking-tight)}.sidebar-toggle{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-tertiary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-default)}.sidebar-toggle:hover{background-color:var(--bg-hover);color:var(--text-primary)}.workspace-selector{padding:var(--space-4);border-bottom:1px solid var(--border-primary)}.workspace-select{width:100%;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--text-primary);background-color:var(--bg-surface-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-default)}.workspace-select:hover{border-color:var(--border-secondary)}.workspace-select:focus{outline:none;border-color:var(--color-brand);box-shadow:var(--glow-brand)}.workspace-role{display:inline-block;margin-top:var(--space-2);padding:var(--space-0-5) var(--space-2);font-size:var(--text-xs);font-weight:var(--font-medium);border-radius:var(--radius-full)}.sidebar-nav{flex:1;overflow-y:auto;padding:var(--space-3)}.nav-section{margin-bottom:var(--space-6)}.nav-section:last-child{margin-bottom:0}.nav-section-title{display:block;padding:var(--space-2) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.nav-item{display:flex;align-items:center;gap:var(--space-2-5);padding:var(--space-2) var(--space-3);font-size:14px;font-weight:500;color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-md);transition:all .15s;position:relative;margin:2px 0}.nav-item:hover{color:var(--text-primary);background-color:var(--bg-hover)}.nav-item.active{color:var(--text-primary);background-color:transparent}.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:16px;background-color:var(--text-primary);border-radius:0 2px 2px 0}.nav-icon{width:18px;height:18px;flex-shrink:0;color:inherit;stroke-width:1.5}.nav-item:hover .nav-icon{color:inherit}.nav-item.active .nav-icon{color:var(--text-primary)}.nav-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-footer{padding:var(--space-3);border-top:1px solid var(--border-primary)}.main-container{display:flex;flex-direction:column;min-height:100vh;overflow:hidden}.topbar{display:flex;align-items:center;justify-content:space-between;height:60px;padding:0 var(--space-6);background-color:var(--bg-surface);border-bottom:1px solid var(--border-primary);flex-shrink:0}.topbar-left{display:flex;align-items:center;gap:var(--space-4)}.current-workspace-name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary)}.topbar-right{display:flex;align-items:center;gap:var(--space-2)}.topbar-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-default)}.topbar-btn:hover{background-color:var(--bg-hover)}.notification-wrapper,.notification-btn{position:relative}.notification-badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:var(--font-bold);color:#fff;background-color:var(--color-danger);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.notification-wrapper .notification-center-panel{position:absolute;top:calc(100% + var(--space-2));right:0;width:380px;min-height:200px;max-height:calc(100vh - 100px);background-color:var(--bg-surface);border:1px solid var(--border-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);z-index:1000;animation:slideDown .2s var(--ease-out);overflow:hidden}.notification-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999}.theme-switcher{display:flex;align-items:center;background-color:var(--bg-surface-secondary);border-radius:var(--radius-lg);padding:var(--space-0-5)}.theme-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;border-radius:var(--radius-md);cursor:pointer;font-size:14px;transition:all var(--duration-fast) var(--ease-default)}.theme-btn:hover{background-color:var(--bg-hover)}.theme-btn.active{background-color:var(--bg-surface);box-shadow:var(--shadow-sm)}.user-menu-wrapper{position:relative}.user-avatar-btn{border:none;background:transparent;cursor:pointer;padding:0}.user-avatar{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-brand),#8B5CF6);color:#fff;font-size:var(--text-sm);font-weight:var(--font-semibold);border-radius:var(--radius-full);transition:transform var(--duration-fast) var(--ease-default)}.user-avatar:hover{transform:scale(1.05)}.user-avatar-lg{width:48px;height:48px;font-size:var(--text-lg)}.user-menu{position:absolute;top:calc(100% + 8px);right:0;width:280px;background-color:var(--bg-surface);border:1px solid var(--border-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);z-index:var(--z-dropdown);animation:slideDown var(--duration-fast) var(--ease-out)}.user-menu-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4)}.user-info{flex:1;min-width:0}.user-name{display:block;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{display:block;font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-menu-divider{height:1px;background-color:var(--divider);margin:0 var(--space-2)}.user-menu-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--text-primary);text-decoration:none;border:none;background:transparent;width:100%;cursor:pointer;transition:background-color var(--duration-fast) var(--ease-default)}.user-menu-item:hover{background-color:var(--bg-hover)}.user-menu-item.danger{color:var(--color-danger)}.user-menu-item.danger:hover{background-color:var(--color-danger-alpha-10)}.main-content{flex:1;padding:var(--space-6);overflow-y:auto;max-width:1400px;width:100%;margin:0 auto}@media (max-width: 1024px){.app-layout{grid-template-columns:72px 1fr}.logo-text,.workspace-selector,.nav-section-title,.nav-label,.sidebar-footer{display:none}.nav-item{justify-content:center;padding:var(--space-3)}.nav-item.active:before{display:none}}@media (max-width: 768px){.app-layout{grid-template-columns:1fr}.sidebar{display:none}.topbar{padding:0 var(--space-4)}.main-content{padding:var(--space-4);padding-bottom:calc(var(--space-4) + 80px)}.theme-switcher{display:none}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);padding:1rem}.login-container{width:100%;max-width:420px}.login-header{text-align:center;margin-bottom:2rem}.login-logo{font-size:2rem;font-weight:700;color:#e94560;margin-bottom:.5rem;font-family:SF Pro Display,-apple-system,BlinkMacSystemFont,sans-serif;letter-spacing:-.5px}.login-subtitle{color:#fff9;font-size:.95rem}.login-form{background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:2rem}.form-title{font-size:1.5rem;font-weight:600;color:#fff;margin-bottom:1.5rem;text-align:center}.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.875rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;color:#ffffffb3;font-size:.875rem;margin-bottom:.5rem}.form-group input{width:100%;padding:.875rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#fff;font-size:1rem;transition:all .2s}.form-group input::placeholder{color:#ffffff4d}.form-group input:focus{outline:none;border-color:#e94560;background:#ffffff14}.submit-btn{width:100%;padding:.875rem;background:linear-gradient(135deg,#e94560,#ff6b6b);border:none;border-radius:8px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:.5rem}.submit-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 20px #e9456066}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.form-footer{margin-top:1.5rem;text-align:center}.toggle-btn{background:none;border:none;color:#fff9;font-size:.875rem;cursor:pointer;transition:color .2s}.toggle-btn:hover{color:#e94560}.dashboard{max-width:1000px;margin:0 auto;padding:48px 24px}.dashboard-loading{display:flex;align-items:center;justify-content:center;height:400px;color:var(--text-tertiary)}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:48px}.dashboard-greeting{font-size:32px;font-weight:600;color:var(--text-primary);letter-spacing:-.02em;margin:0}.dashboard-date{font-size:14px;color:var(--text-tertiary);margin-top:4px}.dashboard-actions{display:flex;gap:12px}.btn-primary{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;background:var(--text-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:opacity .15s}.btn-primary:hover{opacity:.85}.btn-ghost{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;background:transparent;color:var(--text-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s}.btn-ghost:hover{border-color:var(--text-tertiary);color:var(--text-primary)}.btn-text{display:inline-flex;align-items:center;gap:4px;padding:0;background:none;border:none;color:var(--text-tertiary);font-size:13px;cursor:pointer;transition:color .15s}.btn-text:hover{color:var(--text-primary)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:48px}.stat-card{background:var(--bg-surface);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:20px}.stat-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.stat-label{font-size:13px;color:var(--text-tertiary);font-weight:500}.stat-icon{color:var(--text-tertiary);stroke-width:1.5}.stat-value{font-size:32px;font-weight:500;color:var(--text-primary);letter-spacing:-.02em}.stat-danger{color:var(--color-danger)}.section-header{display:flex;align-items:center;gap:8px;margin-bottom:16px}.section-icon{color:var(--accent-primary);stroke-width:1.5}.section-title{font-size:14px;font-weight:600;color:var(--text-primary);margin:0;flex:1}.ai-section{margin-bottom:48px}.ai-insights-list{display:flex;flex-direction:column}.insight-item{display:flex;gap:12px;padding:16px 0;border-bottom:1px solid var(--border-secondary)}.insight-item:last-child{border-bottom:none}.insight-indicator{width:3px;border-radius:2px;background:var(--text-tertiary);flex-shrink:0}.insight-focus .insight-indicator{background:var(--accent-primary)}.insight-tip .insight-indicator{background:var(--color-success)}.insight-warning .insight-indicator{background:var(--color-warning)}.insight-content{flex:1}.insight-label{font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.insight-text{font-size:14px;color:var(--text-primary);margin:4px 0 0;line-height:1.5}.insight-reason{font-size:13px;color:var(--text-tertiary);margin-top:4px}.recent-section{margin-bottom:48px}.task-list{display:flex;flex-direction:column}.task-item{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--border-secondary);cursor:pointer;transition:background .15s}.task-item:hover{background:var(--bg-hover);margin:0 -16px;padding-left:16px;padding-right:16px}.task-item:last-child{border-bottom:none}.task-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.task-status-dot.status-todo{background:var(--text-tertiary)}.task-status-dot.status-in_progress{background:var(--accent-primary)}.task-status-dot.status-done{background:var(--color-success)}.task-status-dot.status-blocked{background:var(--color-danger)}.task-status-dot.status-review{background:var(--color-warning)}.task-info{flex:1;min-width:0}.task-title{display:block;font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-project{display:block;font-size:12px;color:var(--text-tertiary);margin-top:2px}.task-priority{font-size:11px;font-weight:500;padding:2px 8px;border-radius:4px;text-transform:uppercase}.task-priority.priority-urgent{background:#fee2e2;color:#dc2626}.task-priority.priority-high{background:#ffedd5;color:#ea580c}.task-priority.priority-medium{background:#dbeafe;color:#2563eb}.task-priority.priority-low{background:#f3f4f6;color:#6b7280}.empty-state{padding:40px;text-align:center;color:var(--text-tertiary);font-size:14px}@media (max-width: 768px){.dashboard{padding:24px 16px}.dashboard-header{flex-direction:column;gap:16px}.stats-grid{grid-template-columns:repeat(2,1fr)}}.my-tasks-page{display:flex;flex-direction:column;gap:var(--space-5)}.quick-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-4)}.quick-stat-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background-color:var(--bg-surface);border:1px solid var(--border-primary);border-radius:var(--radius-xl);transition:all var(--duration-fast) var(--ease-default)}.quick-stat-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.quick-stat-icon{font-size:20px}.quick-stat-content{display:flex;flex-direction:column}.quick-stat-value{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);line-height:1}.quick-stat-value.danger{color:var(--color-danger)}.quick-stat-value.warning{color:var(--color-warning)}.quick-stat-value.info{color:var(--color-info)}.quick-stat-value.success{color:var(--color-success)}.quick-stat-label{font-size:var(--text-xs);color:var(--text-secondary);margin-top:var(--space-0-5)}.tabs-container{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);border-bottom:1px solid var(--divider);padding-bottom:var(--space-1)}.tabs{display:flex;gap:var(--space-1)}.tab{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary);background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;transition:all var(--duration-fast) var(--ease-default);white-space:nowrap}.tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 var(--space-1-5);font-size:var(--text-xs);font-weight:var(--font-semibold);background-color:var(--bg-surface-secondary);border-radius:var(--radius-full)}.filter-select{height:32px;padding:0 var(--space-3);font-size:var(--text-sm);color:var(--text-primary);background-color:var(--bg-surface);border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer}.task-groups{display:flex;flex-direction:column;gap:var(--space-6)}.task-group{display:flex;flex-direction:column;gap:var(--space-3)}.group-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-secondary);margin:0}.group-title.highlight{color:var(--text-primary)}.group-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 var(--space-1-5);font-size:var(--text-xs);background-color:var(--bg-surface-secondary);border-radius:var(--radius-full)}.task-card{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-4);background-color:var(--bg-surface);border:1px solid var(--border-primary);border-left-width:4px;border-radius:var(--radius-lg);text-decoration:none;transition:all var(--duration-fast) var(--ease-default)}.task-card:hover{border-color:var(--border-secondary);box-shadow:var(--shadow-sm);transform:translate(2px)}.task-card-content{display:flex;align-items:center;gap:var(--space-3);flex:1;min-width:0}.task-priority-icon{font-size:14px;flex-shrink:0}.task-info{display:flex;flex-direction:column;gap:var(--space-0-5);min-width:0}.task-project{font-size:var(--text-xs);color:var(--text-secondary)}.task-card-meta{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.task-due{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap}.task-due.overdue{color:var(--color-danger);font-weight:var(--font-medium)}.task-due.today{color:var(--color-warning);font-weight:var(--font-medium)}.task-status{padding:var(--space-0-5) var(--space-2);font-size:var(--text-xs);font-weight:var(--font-medium);border-radius:var(--radius-full);white-space:nowrap}@media (max-width: 1200px){.quick-stats{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.quick-stats{grid-template-columns:repeat(2,1fr)}.tabs-container{flex-direction:column;align-items:stretch;gap:var(--space-3)}.tabs{overflow-x:auto;padding-bottom:var(--space-2);-webkit-overflow-scrolling:touch}.filters{flex-direction:column}.filter-select{width:100%}.task-card{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.task-card-meta{width:100%;justify-content:space-between}}@media (max-width: 480px){.quick-stats{grid-template-columns:1fr}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;overflow-y:auto;animation:fadeIn .2s ease}@media (max-height: 700px){.modal-overlay{align-items:flex-start;padding-top:40px}}.modal-container{background-color:var(--bg-surface);border:1px solid var(--border-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-sm{width:400px}.modal-md{width:520px}.modal-lg{width:700px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-primary)}.modal-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.modal-close{background:none;border:none;font-size:18px;color:var(--text-tertiary);cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.modal-close:hover{background-color:var(--bg-hover);color:var(--text-primary)}.modal-body{padding:24px;overflow-y:auto;display:block}.modal-body>form{display:block}.modal-body>form>.form-group:first-child{margin-top:0}.form-group{margin-bottom:20px;display:block!important;visibility:visible!important;opacity:1!important}.form-label{display:block!important;font-size:14px;font-weight:500;color:#0f172a!important;margin-bottom:8px;visibility:visible!important;opacity:1!important}[data-theme=dark] .form-label{color:#f0f6fc!important}.form-input,.form-textarea,.form-select{width:100%;padding:10px 14px;font-size:14px;border:1px solid #CBD5E1!important;border-radius:var(--radius-md);background-color:#fff!important;color:#0f172a!important;transition:all var(--transition-fast);min-height:42px;box-sizing:border-box}[data-theme=dark] .form-input,[data-theme=dark] .form-textarea,[data-theme=dark] .form-select{border:1px solid #30363D!important;background-color:#161b22!important;color:#f0f6fc!important}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-light)}.form-textarea{min-height:100px;resize:vertical}.form-hint{font-size:12px;color:var(--text-tertiary);margin-top:6px}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border-primary)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 640px){.modal-sm,.modal-md,.modal-lg{width:100%}.form-row{grid-template-columns:1fr}}.projects-page{display:flex;flex-direction:column;gap:var(--space-6)}.page-title-row{display:flex;align-items:center;gap:var(--space-3)}.projects-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4)}.search-box{position:relative;flex:1;max-width:400px}.search-icon{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);color:var(--text-tertiary);pointer-events:none}.search-input{width:100%;height:40px;padding:0 var(--space-3) 0 var(--space-10);font-size:var(--text-sm);color:var(--text-primary);background-color:var(--bg-surface);border:1px solid var(--border-primary);border-radius:var(--radius-lg);transition:all var(--duration-fast) var(--ease-default)}.search-input:hover{border-color:var(--border-secondary)}.search-input:focus{outline:none;border-color:var(--color-brand);box-shadow:var(--glow-brand)}.search-input::placeholder{color:var(--text-tertiary)}.view-switcher{display:flex;background-color:var(--bg-surface-secondary);border-radius:var(--radius-lg);padding:var(--space-0-5)}.view-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;border-radius:var(--radius-md);cursor:pointer;color:var(--text-secondary);transition:all var(--duration-fast) var(--ease-default)}.view-btn:hover{color:var(--text-primary)}.view-btn.active{background-color:var(--bg-surface);color:var(--text-primary);box-shadow:var(--shadow-sm)}.error-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background-color:var(--color-danger-alpha-10);border:1px solid var(--color-danger);border-radius:var(--radius-lg)}.error-icon{font-size:20px}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-5)}.projects-list{display:flex;flex-direction:column;gap:var(--space-3)}.project-card{display:flex;flex-direction:column;text-decoration:none;padding:0;overflow:hidden}.project-card-header{display:flex;align-items:flex-start;gap:var(--space-4);padding:var(--space-5)}.project-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:var(--text-xl);font-weight:var(--font-bold);border-radius:var(--radius-lg);flex-shrink:0}.project-info{flex:1;min-width:0}.project-name{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0;line-height:var(--leading-tight)}.project-description{font-size:var(--text-sm);color:var(--text-secondary);margin:var(--space-1) 0 0 0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-progress-section{display:flex;align-items:center;gap:var(--space-3);padding:0 var(--space-5) var(--space-4)}.project-progress-bar{flex:1;height:8px;background-color:var(--bg-surface-secondary);border-radius:var(--radius-full);overflow:hidden}.project-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-brand),var(--color-success));border-radius:var(--radius-full);transition:width var(--duration-slow) var(--ease-out);min-width:0}.project-progress-text{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-secondary);min-width:40px;text-align:right}.project-stats{display:flex;gap:var(--space-5);padding:var(--space-4) var(--space-5);background-color:var(--bg-surface-secondary);border-top:1px solid var(--border-primary)}.project-stat{display:flex;align-items:center;gap:var(--space-1-5)}.project-stat .stat-icon{font-size:14px}.project-stat .stat-value{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary)}.project-stat .stat-label{font-size:var(--text-xs);color:var(--text-tertiary)}.projects-list .project-card{flex-direction:row;align-items:center}.projects-list .project-card-header{flex:1;padding:var(--space-4)}.projects-list .project-progress-section{flex:0;width:140px;padding:var(--space-4);border-left:1px solid var(--border-primary)}.projects-list .project-stats{min-width:180px;border-top:none;border-left:1px solid var(--border-primary)}@media (max-width: 1024px){.projects-list .project-card{flex-direction:column}.projects-list .project-card-header{width:100%;border-bottom:1px solid var(--border-primary)}.projects-list .project-card-body{width:100%;border-left:none;justify-content:space-between}}@media (max-width: 768px){.projects-toolbar{flex-direction:column;align-items:stretch}.search-box{max-width:none}.view-switcher{display:none}.projects-grid{grid-template-columns:1fr}}.task-list{display:flex;flex-direction:column;gap:var(--space-2)}.task-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-surface);border:1px solid var(--border-primary);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-fast) var(--ease-default)}.task-item:hover{border-color:var(--color-brand);box-shadow:var(--shadow-sm)}.task-priority-indicator{width:4px;height:32px;border-radius:2px;flex-shrink:0}.task-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-1)}.task-main-row{display:flex;align-items:center;gap:var(--space-2)}.task-title{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.subtask-count{font-size:var(--text-xs);color:var(--text-tertiary);background:var(--bg-surface-secondary);padding:2px 6px;border-radius:var(--radius-sm);flex-shrink:0}.task-meta{display:flex;align-items:center;gap:var(--space-2)}.task-status{font-size:var(--text-xs);padding:2px 8px;border-radius:var(--radius-full);font-weight:var(--font-medium)}.task-due{display:flex;align-items:center;gap:4px;font-size:var(--text-xs);color:var(--text-tertiary)}.task-due.overdue{color:var(--color-danger)}.task-due.today{color:var(--color-warning)}.task-due.soon{color:var(--color-info)}.task-assignee{flex-shrink:0}.assignee-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--color-brand),var(--color-brand-dark, #4f46e5));color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:var(--font-semibold)}.assignee-empty{width:28px;height:28px;border-radius:50%;background:var(--bg-surface-secondary);border:1px dashed var(--border-primary);display:flex;align-items:center;justify-content:center;color:var(--text-tertiary)}.task-arrow{color:var(--text-tertiary);flex-shrink:0;opacity:0;transition:opacity var(--duration-fast)}.task-item:hover .task-arrow{opacity:1}@media (max-width: 640px){.task-item{padding:var(--space-3)}.task-meta{flex-wrap:wrap}}.project-detail-page{display:flex;flex-direction:column;gap:var(--space-5)}.project-header{display:flex;flex-direction:column;gap:var(--space-4)}.project-header-content{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-4)}.project-title-section{display:flex;align-items:flex-start;gap:var(--space-4)}.project-icon-large{width:56px;height:56px;display:flex;align-items:center;justify-content:center;font-size:var(--text-2xl);font-weight:var(--font-bold);color:#fff;background:linear-gradient(135deg,var(--color-brand),#8B5CF6);border-radius:var(--radius-xl);flex-shrink:0}.project-title-info{display:flex;flex-direction:column;gap:var(--space-1)}.project-title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);margin:0}.project-description{font-size:var(--text-sm);color:var(--text-secondary);margin:0;max-width:600px}.project-actions{display:flex;gap:var(--space-2);flex-shrink:0}.stats-bar{display:flex;align-items:center;gap:var(--space-6);padding:var(--space-4) var(--space-5);background-color:var(--bg-surface);border:1px solid var(--border-primary);border-radius:var(--radius-xl)}.stat-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-1)}.stat-value{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary)}.stat-label{font-size:var(--text-xs);color:var(--text-secondary)}.stat-divider{width:1px;height:32px;background-color:var(--divider)}.toolbar{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4)}.toolbar-left{display:flex;align-items:center;gap:var(--space-4)}.view-switcher{display:flex;flex-shrink:0;gap:4px;background:linear-gradient(to bottom,var(--bg-surface),var(--bg-hover));border:1px solid var(--border-primary);border-radius:10px;padding:4px}.view-btn{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:6px;min-width:70px;height:32px;padding:0 12px;font-size:13px;font-weight:500;color:var(--text-secondary);background:transparent;border:none;border-radius:6px;cursor:pointer;transition:all .15s ease;white-space:nowrap}.view-btn:hover{color:var(--text-primary);background-color:#0000000a}.view-btn.active{background-color:var(--bg-surface);color:var(--color-brand);box-shadow:0 1px 3px #0000001f}[data-theme=dark] .view-btn:hover{background-color:#ffffff0f}.view-btn .view-icon{font-size:14px;line-height:1;display:inline-block}.view-btn .view-label{font-size:13px;display:inline-block}.filters{display:flex;gap:var(--space-2)}.filter-select{height:36px;padding:0 var(--space-3);font-size:var(--text-sm);color:var(--text-primary);background-color:var(--bg-surface);border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-default)}.filter-select:hover{border-color:var(--border-secondary)}.filter-select:focus{outline:none;border-color:var(--color-brand)}.content-area{min-height:400px}.task-table-container{background-color:var(--bg-surface);border:1px solid var(--border-primary);border-radius:var(--radius-xl);overflow:hidden}.task-table{width:100%;border-collapse:collapse}.task-table th{padding:var(--space-3) var(--space-4);font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;text-align:left;background-color:var(--bg-surface-secondary);border-bottom:1px solid var(--border-primary)}.th-priority{width:60px}.th-status,.th-due{width:120px}.task-row{cursor:pointer;transition:background-color var(--duration-fast) var(--ease-default)}.task-row:hover{background-color:var(--bg-hover)}.task-row td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-primary)}.task-row:last-child td{border-bottom:none}.td-priority{text-align:center}.priority-dot{display:inline-block;width:8px;height:8px;border-radius:50%}.td-title .task-title{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.td-status .status-badge{display:inline-block;padding:var(--space-0-5) var(--space-2);font-size:var(--text-xs);font-weight:var(--font-medium);border-radius:var(--radius-full);white-space:nowrap}.td-due{font-size:var(--text-sm);color:var(--text-secondary)}@media (max-width: 1024px){.stats-bar{flex-wrap:wrap;gap:var(--space-4)}.stat-divider{display:none}}@media (max-width: 768px){.project-header-content{flex-direction:column}.project-actions{width:100%}.project-actions .btn{flex:1}.toolbar{flex-direction:column;align-items:stretch;gap:var(--space-3)}.toolbar-left{flex-direction:column;align-items:stretch}.view-switcher{justify-content:center}.filters{flex-direction:column}.filter-select{width:100%}.task-table{font-size:var(--text-xs)}.th-status,.th-due,.td-status,.td-due{display:none}}.danger-zone{margin-top:var(--space-6);padding-top:var(--space-5);border-top:1px solid var(--border-color)}.danger-zone h4{color:var(--color-danger);font-size:var(--text-sm);font-weight:600;margin:0 0 var(--space-2) 0}.danger-zone p{color:var(--text-secondary);font-size:var(--text-sm);margin:0 0 var(--space-4) 0}.danger-zone .btn-danger{background-color:var(--color-danger);color:#fff;border:none}.danger-zone .btn-danger:hover{background-color:#dc2626}.ai-modal-content{padding:var(--space-4)}.ai-task-info{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:linear-gradient(135deg,var(--color-brand-alpha-10),rgba(139,92,246,.1));border-radius:var(--radius-lg);margin-bottom:var(--space-5)}.ai-icon{color:var(--color-brand)}.ai-options{margin-bottom:var(--space-5)}.granularity-options{display:flex;gap:var(--space-2);margin-top:var(--space-2)}.granularity-btn{flex:1;padding:var(--space-3);border:1px solid var(--border-primary);background:var(--bg-surface);border-radius:var(--radius-lg);font-size:var(--text-sm);cursor:pointer;transition:all .2s;color:var(--text-primary)}.granularity-btn:hover{border-color:var(--color-brand)}.granularity-btn.active{border-color:var(--color-brand);background:var(--color-brand-alpha-10);color:var(--color-brand)}.ai-generate-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-2)}.ai-error-container{display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.ai-error{padding:var(--space-4);background:#fee2e2;color:#dc2626;border-radius:var(--radius-lg);text-align:center;width:100%}.ai-result{margin-top:var(--space-4)}.ai-result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.ai-result-header h4{margin:0;font-size:var(--text-lg)}.ai-result-summary{font-size:var(--text-sm);color:var(--text-secondary)}.subtask-list{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-4);max-height:400px;overflow-y:auto}.subtask-item{padding:var(--space-4);background:var(--bg-hover);border-radius:var(--radius-lg);border-left:3px solid var(--color-brand)}.subtask-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2)}.subtask-index{width:24px;height:24px;background:var(--color-brand);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600}.subtask-title{flex:1;font-weight:500}.subtask-priority{padding:2px 8px;border-radius:12px;font-size:11px;color:#fff}.subtask-description{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--space-2) 0}.subtask-meta{display:flex;gap:var(--space-4);font-size:12px;color:var(--text-tertiary)}.subtask-meta span{display:flex;align-items:center;gap:4px}.ai-reasoning{padding:var(--space-4);background:var(--bg-hover);border-radius:var(--radius-lg);margin-bottom:var(--space-4)}.ai-reasoning strong{display:block;margin-bottom:var(--space-2)}.ai-reasoning p{margin:0;font-size:var(--text-sm);color:var(--text-secondary)}.ai-actions{display:flex;gap:var(--space-3);justify-content:flex-end}.risk-panel{padding:var(--space-4);background:var(--bg-surface);border:1px solid var(--border-primary);border-radius:var(--radius-xl)}.risk-panel.loading,.risk-panel.error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);min-height:200px;color:var(--text-secondary)}.risk-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.risk-header h4{display:flex;align-items:center;gap:var(--space-2);margin:0;font-size:var(--text-base)}.btn-icon{background:none;border:none;padding:var(--space-2);border-radius:var(--radius-md);color:var(--text-tertiary);cursor:pointer}.btn-icon:hover{background:var(--bg-hover);color:var(--text-primary)}.risk-score-container{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-4)}.risk-score-circle{width:80px;height:80px;border:4px solid;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0}.risk-score-value{font-size:24px;font-weight:700}.risk-score-label{font-size:11px;color:var(--text-tertiary)}.risk-summary{flex:1}.risk-level{display:inline-block;padding:4px 12px;border-radius:12px;color:#fff;font-size:var(--text-sm);font-weight:500;margin-bottom:var(--space-2)}.risk-summary p{margin:4px 0;font-size:var(--text-sm);color:var(--text-secondary)}.risk-factors{margin-bottom:var(--space-4)}.risk-factors h5{font-size:var(--text-sm);margin:0 0 var(--space-3) 0}.risk-factor{padding:var(--space-3);background:var(--bg-hover);border-radius:var(--radius-lg);margin-bottom:var(--space-2);border-left:3px solid}.risk-factor.risk-high{border-left-color:#ef4444}.risk-factor.risk-medium{border-left-color:#f59e0b}.risk-factor.risk-low{border-left-color:#10b981}.risk-factor-header{display:flex;justify-content:space-between;margin-bottom:var(--space-2)}.risk-factor-type{font-size:11px;color:var(--text-tertiary);text-transform:uppercase}.risk-severity{font-size:11px;padding:2px 8px;border-radius:12px}.risk-severity-high{background:#fee2e2;color:#dc2626}.risk-severity-medium{background:#fef3c7;color:#d97706}.risk-severity-low{background:#d1fae5;color:#059669}.risk-factor-desc{font-size:var(--text-sm);margin:0 0 var(--space-2) 0}.risk-factor-mitigation{font-size:12px;color:var(--text-secondary);margin:0}.risk-recommendations{padding:var(--space-3);background:var(--color-brand-alpha-10);border-radius:var(--radius-lg)}.risk-recommendations h5{font-size:var(--text-sm);margin:0 0 var(--space-2) 0;color:var(--color-brand)}.risk-recommendations ul{margin:0;padding-left:var(--space-4)}.risk-recommendations li{font-size:var(--text-sm);margin-bottom:4px}.task-detail-page{display:flex;flex-direction:column;gap:var(--space-5)}.back-link{display:inline-flex;align-items:center;font-size:var(--text-sm);color:var(--text-secondary);text-decoration:none;transition:color var(--duration-fast) var(--ease-default)}.back-link:hover{color:var(--text-primary)}.task-detail-layout{display:grid;grid-template-columns:1fr 360px;gap:var(--space-6);align-items:start}.task-main{display:flex;flex-direction:column;gap:var(--space-5)}.task-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-4);padding:var(--space-5)}.task-title-row{display:flex;align-items:center;gap:var(--space-3);flex:1;min-width:0}.task-priority-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.task-title{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);margin:0;word-break:break-word}.task-actions{display:flex;gap:var(--space-2);flex-shrink:0;flex-wrap:wrap}.task-ai-actions{display:flex;gap:8px;padding:12px 16px;background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border-primary)}.ai-action-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;border:1px solid var(--border-primary);border-radius:var(--radius-md);font-size:13px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.ai-action-btn:hover{border-color:var(--color-brand);color:var(--color-brand)}.ai-action-btn.loading{opacity:.7;pointer-events:none}.task-attributes{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);padding:var(--space-5)}.attribute{display:flex;flex-direction:column;gap:var(--space-1)}.attribute-label{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.attribute-value{font-size:var(--text-sm);color:var(--text-primary);white-space:nowrap}.status-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-2);font-size:var(--text-xs);font-weight:var(--font-medium);border-radius:var(--radius-full);width:fit-content}.task-section{padding:var(--space-5)}.section-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-4) 0}.task-description{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);margin:0;white-space:pre-wrap}.blocked-reason{font-size:var(--text-sm);color:var(--color-danger);margin:0}.no-events{font-size:var(--text-sm);color:var(--text-tertiary);margin:0}.events-timeline{display:flex;flex-direction:column;gap:var(--space-4);position:relative;padding-left:var(--space-6)}.events-timeline:before{content:"";position:absolute;left:5px;top:8px;bottom:8px;width:2px;background-color:var(--border-primary)}.event-item{display:flex;gap:var(--space-3);position:relative}.event-dot{position:absolute;left:calc(-1 * var(--space-6) + 2px);top:4px;width:10px;height:10px;border-radius:50%;border:2px solid var(--bg-surface)}.event-content{display:flex;flex-direction:column;gap:var(--space-0-5)}.event-type{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.event-description{font-size:var(--text-sm);color:var(--text-secondary)}.event-time{font-size:var(--text-xs);color:var(--text-tertiary)}.task-sidebar{position:sticky;top:var(--space-4)}.ai-panel{padding:0;overflow:hidden}.ai-panel-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-primary)}.ai-panel-title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.ai-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-10);text-align:center}.ai-empty-icon{font-size:48px;opacity:.5;margin-bottom:var(--space-4)}.ai-empty-text{font-size:var(--text-sm);color:var(--text-primary);margin:0 0 var(--space-1) 0}.ai-empty-hint{font-size:var(--text-xs);color:var(--text-tertiary);margin:0}.ai-content{padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-6)}.progress-section{display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.progress-circle-wrapper{position:relative;width:100px;height:100px}.progress-circle{width:100%;height:100%;transform:rotate(-90deg)}.progress-bg{fill:none;stroke:var(--bg-surface-secondary);stroke-width:8}.progress-fill{fill:none;stroke:var(--color-brand);stroke-width:8;stroke-linecap:round;transition:stroke-dasharray var(--duration-slow) var(--ease-out)}.progress-value{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary)}.progress-summary{font-size:var(--text-sm);color:var(--text-secondary);text-align:center;margin:0}.ai-section{display:flex;flex-direction:column;gap:var(--space-3)}.ai-section-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.actions-list{display:flex;flex-direction:column;gap:var(--space-2)}.action-item{display:flex;flex-direction:column;gap:var(--space-0-5);padding:var(--space-3);border-radius:var(--radius-lg);border-left:3px solid transparent;background-color:var(--bg-surface-secondary)}.action-item.priority-high{border-left-color:var(--color-danger);background-color:var(--color-danger-alpha-10)}.action-item.priority-medium{border-left-color:var(--color-warning);background-color:var(--color-warning-alpha-10)}.action-item.priority-low{border-left-color:var(--color-success);background-color:var(--color-success-alpha-10)}.action-text{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.action-reason{font-size:var(--text-xs);color:var(--text-secondary)}.risks-list{display:flex;flex-direction:column;gap:var(--space-2)}.risk-item{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-3);border-radius:var(--radius-lg)}.risk-item.severity-high{background-color:var(--color-danger-alpha-10)}.risk-item.severity-medium{background-color:var(--color-warning-alpha-10)}.risk-item.severity-low{background-color:var(--bg-surface-secondary)}.risk-description{font-size:var(--text-sm);color:var(--text-primary)}.risk-mitigation{font-size:var(--text-xs);color:var(--text-secondary)}.current-status-info{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);background-color:var(--bg-surface-secondary);border-radius:var(--radius-lg);margin-bottom:var(--space-5)}.current-status-info .label{font-size:var(--text-sm);color:var(--text-secondary)}.status-options{display:flex;flex-wrap:wrap;gap:var(--space-2)}.status-option{display:flex;align-items:center;gap:var(--space-2);cursor:pointer}.status-option input{display:none}.status-option-badge{padding:var(--space-2) var(--space-3);font-size:var(--text-sm);font-weight:var(--font-medium);border-radius:var(--radius-lg);border:2px solid transparent;transition:all var(--duration-fast) var(--ease-default)}.status-option input:checked+.status-option-badge{border-color:var(--color-brand);box-shadow:var(--glow-brand)}.status-option:hover .status-option-badge{transform:scale(1.02)}.ai-analysis-modal{display:flex;flex-direction:column;gap:var(--space-4)}.ai-analysis-modal .modal-description{margin:0;color:var(--text-secondary);font-size:var(--text-sm);line-height:1.5}.ai-analysis-modal .help-text{margin:var(--space-2) 0 0;font-size:var(--text-xs);color:var(--text-tertiary)}.analysis-presets{display:flex;flex-direction:column;gap:var(--space-2)}.analysis-presets .presets-label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--text-tertiary)}.preset-tags{display:flex;flex-wrap:wrap;gap:var(--space-2)}.preset-tag{padding:var(--space-1) var(--space-3);border:1px solid var(--border-default);border-radius:16px;background:var(--bg-surface);font-size:var(--text-xs);color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-default)}.preset-tag:hover{background:var(--bg-hover);border-color:var(--color-primary);color:var(--color-primary)}@media (max-width: 1024px){.task-detail-layout{grid-template-columns:1fr}.task-sidebar{position:static}.task-attributes{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.task-header{flex-direction:column}.task-actions{width:100%}.task-actions .btn{flex:1}.task-attributes{grid-template-columns:1fr 1fr;gap:var(--space-3)}}.parent-task-hint{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-info-alpha-10);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-secondary)}.parent-link{color:var(--color-info);text-decoration:none;font-weight:var(--font-medium)}.parent-link:hover{text-decoration:underline}.assignee-select{padding:var(--space-1) var(--space-2);border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-surface);color:var(--text-primary);font-size:var(--text-sm);cursor:pointer;min-width:120px}.assignee-select:hover{border-color:var(--color-brand)}.assignee-select:focus{outline:none;border-color:var(--color-brand);box-shadow:0 0 0 2px var(--color-brand-alpha-20)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.section-header .section-title{margin:0}.no-subtasks{font-size:var(--text-sm);color:var(--text-tertiary);margin:0;padding:var(--space-4);text-align:center;background:var(--bg-surface-secondary);border-radius:var(--radius-md)}.subtasks-list{display:flex;flex-direction:column;gap:var(--space-2)}.subtask-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg-surface-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-default)}.subtask-item:hover{background:var(--bg-hover)}.subtask-priority{width:4px;height:24px;border-radius:2px;flex-shrink:0}.subtask-title{flex:1;font-size:var(--text-sm);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.subtask-status{font-size:var(--text-xs);padding:2px 8px;border-radius:var(--radius-full);font-weight:var(--font-medium);flex-shrink:0}.subtask-arrow{color:var(--text-tertiary);flex-shrink:0;opacity:0;transition:opacity var(--duration-fast)}.subtask-item:hover .subtask-arrow{opacity:1}.tree-node{--indent: calc(var(--level, 0) * 20px)}.tree-node-content{display:flex;align-items:center;gap:8px;padding:8px 12px;padding-left:calc(12px + var(--indent));border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.tree-node-content:hover{background-color:var(--bg-hover)}.tree-node-content.selected{background-color:var(--accent-light)}.tree-toggle{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text-tertiary);padding:0;flex-shrink:0;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.tree-toggle:hover{background-color:var(--bg-active);color:var(--text-primary)}.tree-toggle.invisible{visibility:hidden}.toggle-icon{font-size:10px;transition:transform var(--transition-fast)}.toggle-icon.expanded{transform:rotate(90deg)}.tree-node-icon{font-size:16px;flex-shrink:0}.tree-node-label{flex:1;font-size:14px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-node-badge{flex-shrink:0}.tree-node-children{margin-top:2px}.task-stats-badge{display:flex;align-items:center;gap:8px;font-size:12px}.task-stats-badge.compact{gap:6px}.stat-item{display:flex;align-items:center;gap:2px;padding:2px 6px;border-radius:var(--radius-sm);background-color:var(--bg-secondary);font-weight:500}.stat-total{font-weight:600;color:var(--text-secondary);padding:2px 8px;background-color:var(--bg-secondary);border-radius:var(--radius-sm)}.stat-blocked{color:var(--color-danger);font-weight:600}.member-detail-panel{background-color:var(--card-bg);border:1px solid var(--border-primary);border-radius:var(--radius-lg);height:100%;overflow-y:auto}.member-detail-panel.empty{display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.panel-header{display:flex;align-items:flex-start;gap:12px;padding:20px;border-bottom:1px solid var(--border-primary);position:relative}.member-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary),var(--accent-hover));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:18px;flex-shrink:0}.member-info{flex:1;min-width:0}.member-name{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 4px}.member-email{font-size:13px;color:var(--text-secondary);margin:0 0 8px}.member-role{display:inline-block;font-size:11px;font-weight:500;padding:2px 8px;border-radius:var(--radius-sm);background-color:var(--accent-light);color:var(--accent-primary)}.close-btn{position:absolute;top:12px;right:12px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.close-btn:hover{background-color:var(--bg-hover);color:var(--text-primary)}.panel-section{padding:16px 20px;border-bottom:1px solid var(--border-primary)}.panel-section:last-child{border-bottom:none}.panel-section h4{font-size:13px;font-weight:600;color:var(--text-secondary);margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.stat-card{background-color:var(--bg-secondary);border-radius:var(--radius-md);padding:12px;text-align:center}.stat-card .stat-value{display:block;font-size:24px;font-weight:700;color:var(--text-primary)}.stat-card .stat-label{display:block;font-size:12px;color:var(--text-secondary);margin-top:4px}.stat-card.done .stat-value{color:var(--color-success)}.stat-card.in-progress .stat-value{color:var(--color-info)}.stat-card.blocked .stat-value{color:var(--color-danger)}.subordinate-count{font-size:14px;color:var(--text-secondary);margin:0}.task-list{list-style:none;padding:0;margin:0}.task-item{margin-bottom:4px}.task-link{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-md);transition:all var(--transition-fast)}.task-link:hover{background-color:var(--bg-hover)}.task-status{width:8px;height:8px;border-radius:50%;flex-shrink:0}.task-title{flex:1;font-size:13px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-priority{font-size:11px;font-weight:500}.empty-text{font-size:13px;color:var(--text-tertiary);margin:0}.ai-analysis-panel{background-color:var(--card-bg);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:0;overflow:hidden;max-height:80vh;overflow-y:auto}.analysis-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:linear-gradient(135deg,var(--accent-light) 0%,transparent 100%);border-bottom:1px solid var(--border-primary);position:sticky;top:0;z-index:10}.analysis-header h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.close-btn{width:28px;height:28px;border-radius:var(--radius-sm);border:none;background-color:var(--bg-hover);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all var(--transition-fast)}.close-btn:hover{background-color:var(--bg-active);color:var(--text-primary)}.health-section{padding:20px;background-color:var(--bg-secondary);border-bottom:1px solid var(--border-primary)}.health-score{display:flex;align-items:center;gap:20px}.score-circle{width:80px;height:80px;border-radius:50%;border:4px solid;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:var(--card-bg);flex-shrink:0}.score-number{font-size:24px;font-weight:700;color:var(--text-primary);line-height:1}.score-label{font-size:10px;color:var(--text-tertiary);margin-top:2px}.health-info{flex:1}.health-status{font-size:14px;font-weight:600;display:inline-block;margin-bottom:4px}.health-summary{font-size:13px;color:var(--text-secondary);margin:0;line-height:1.5}.analysis-section{padding:16px 20px;border-bottom:1px solid var(--border-primary)}.analysis-section:last-child{border-bottom:none}.analysis-section h4{font-size:14px;font-weight:600;color:var(--text-primary);margin:0 0 12px}.analysis-section h5{font-size:12px;font-weight:500;color:var(--text-secondary);margin:12px 0 8px}.balance-score,.resource-score{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--text-secondary)}.progress-bar{flex:1;height:8px;background-color:var(--bg-tertiary);border-radius:4px;overflow:hidden}.progress-fill{height:100%;border-radius:4px;transition:width .5s ease}.balance-score .score-value,.resource-score .score-value{position:static!important;transform:none!important;font-size:13px!important;font-weight:600;color:var(--text-primary);min-width:40px;text-align:right}.member-list{margin-top:12px}.member-item{background-color:var(--bg-secondary);border-radius:var(--radius-md);padding:12px;margin-bottom:8px}.member-item.overloaded{border-left:3px solid var(--color-danger)}.member-item.idle{border-left:3px solid var(--color-warning)}.member-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.member-name{font-size:13px;font-weight:600;color:var(--text-primary)}.task-count{font-size:11px;color:var(--text-tertiary)}.member-suggestion{font-size:12px;color:var(--text-secondary);margin:0;line-height:1.4}.bottleneck-list{display:flex;flex-direction:column;gap:12px}.bottleneck-item{background-color:var(--bg-secondary);border-radius:var(--radius-md);padding:12px}.bottleneck-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.priority-badge{font-size:10px;font-weight:500;padding:2px 8px;border-radius:var(--radius-sm);color:#fff}.bottleneck-type{font-size:11px;color:var(--text-tertiary)}.bottleneck-desc{font-size:13px;color:var(--text-primary);margin:0 0 8px}.affected-members{font-size:11px;color:var(--text-tertiary);margin-bottom:8px}.bottleneck-suggestion{font-size:12px;color:var(--text-secondary);margin:0;padding:8px;background-color:var(--accent-light);border-radius:var(--radius-sm)}.recommendation-list{display:flex;flex-direction:column;gap:8px}.recommendation-item{background-color:var(--bg-secondary);border-radius:var(--radius-md);padding:12px}.recommendation-badges{display:flex;gap:8px;margin-bottom:8px}.impact-badge,.effort-badge{font-size:10px;font-weight:500;padding:2px 8px;border-radius:var(--radius-sm)}.impact-badge{color:#fff}.effort-badge{background-color:var(--bg-tertiary);color:var(--text-secondary)}.recommendation-action{font-size:13px;color:var(--text-primary);margin:0;line-height:1.4}.risk-heatmap{display:flex;flex-direction:column;gap:12px}.risk-group{display:flex;align-items:flex-start;gap:12px}.risk-label{font-size:12px;font-weight:500;min-width:80px}.risk-projects{display:flex;flex-wrap:wrap;gap:8px}.project-tag{font-size:11px;padding:4px 8px;border-radius:var(--radius-sm);background-color:var(--bg-tertiary);color:var(--text-primary)}.risk-group.high .project-tag{background-color:#ef44441a;color:var(--color-danger)}.risk-group.medium .project-tag{background-color:#f973161a;color:#f97316}.risk-group.low .project-tag{background-color:#10b9811a;color:var(--color-success)}.project-comparison{display:flex;flex-direction:column;gap:12px}.project-compare-item{background-color:var(--bg-secondary);border-radius:var(--radius-md);padding:12px}.project-compare-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.project-compare-header .project-name{font-size:14px;font-weight:600;color:var(--text-primary)}.health-score-mini{font-size:14px;font-weight:700}.project-issue{font-size:12px;color:var(--color-warning);margin:0 0 8px}.project-recommendation{font-size:12px;color:var(--text-secondary);margin:0}.imbalance-list{margin-top:12px;display:flex;flex-direction:column;gap:8px}.imbalance-item{background-color:var(--bg-secondary);border-radius:var(--radius-md);padding:12px}.imbalance-desc{font-size:13px;color:var(--text-primary);margin:0 0 8px}.affected-projects{font-size:11px;color:var(--text-tertiary);margin-bottom:8px}.imbalance-suggestion{font-size:12px;color:var(--text-secondary);margin:0;padding:8px;background-color:var(--accent-light);border-radius:var(--radius-sm)}.priority-list{display:flex;flex-direction:column;gap:8px}.priority-item{display:flex;align-items:center;gap:12px;padding:12px;background-color:var(--bg-secondary);border-radius:var(--radius-md)}.urgency-badge{font-size:10px;font-weight:500;padding:2px 8px;border-radius:var(--radius-sm);color:#fff;flex-shrink:0}.priority-project{font-size:12px;color:var(--text-tertiary);flex-shrink:0}.priority-action{font-size:13px;color:var(--text-primary);flex:1}.analysis-section.insights{background-color:var(--accent-light)}.analysis-section.insights p{font-size:13px;color:var(--text-primary);margin:0;line-height:1.6}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-full);color:#fff;font-weight:var(--font-semibold);flex-shrink:0;-webkit-user-select:none;user-select:none}.avatar-sm{width:28px;height:28px;font-size:10px}.avatar-md{width:36px;height:36px;font-size:var(--text-xs)}.avatar-lg{width:44px;height:44px;font-size:var(--text-sm)}.avatar-xl{width:56px;height:56px;font-size:var(--text-base)}.avatar-initials{line-height:1;letter-spacing:-.02em}img.avatar{object-fit:cover}.avatar-group{display:flex;flex-direction:row-reverse;justify-content:flex-end}.avatar-group .avatar{margin-left:-8px;border:2px solid var(--bg-surface);box-shadow:var(--shadow-sm)}.avatar-with-status{position:relative}.avatar-status{position:absolute;bottom:0;right:0;width:10px;height:10px;border-radius:var(--radius-full);border:2px solid var(--bg-surface)}.avatar-status.online{background-color:var(--color-success)}.avatar-status.offline{background-color:var(--text-tertiary)}.avatar-status.busy{background-color:var(--color-danger)}.member-edit-modal{background:var(--bg-surface);border-radius:12px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #0003}.member-edit-modal .modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-subtle)}.member-edit-modal .modal-header h2{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.member-edit-modal .close-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;border-radius:6px;color:var(--text-tertiary);cursor:pointer;transition:all .15s}.member-edit-modal .close-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.member-edit-modal form{padding:24px}.member-edit-modal .member-info{display:flex;align-items:center;gap:16px;padding:16px;background:var(--bg-surface-secondary);border-radius:10px;margin-bottom:24px}.member-edit-modal .member-details h3{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--text-primary)}.member-edit-modal .member-details p{margin:0;font-size:13px;color:var(--text-tertiary)}.member-edit-modal .error-alert{padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444;font-size:13px;margin-bottom:20px}.member-edit-modal .form-group{margin-bottom:24px}.member-edit-modal .form-group>label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:12px}.member-edit-modal .form-group>label svg{color:var(--text-tertiary)}.member-edit-modal .role-note{margin:0 0 16px;padding:10px 14px;background:#dbeafe;border:1px solid #93c5fd;border-radius:8px;font-size:12px;line-height:1.5;color:#1e40af}[data-theme=dark] .member-edit-modal .role-note{background:#3b82f626;border-color:#3b82f666;color:#93c5fd}.member-edit-modal .role-type-tabs{display:flex;gap:8px;margin-bottom:12px}.member-edit-modal .role-type-tabs .tab{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--border-default);border-radius:8px;background:var(--bg-surface);font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .15s}.member-edit-modal .role-type-tabs .tab:hover{background:var(--bg-hover);color:var(--text-primary)}.member-edit-modal .role-type-tabs .tab.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.member-edit-modal .role-selector{display:flex;flex-direction:column;gap:8px}.member-edit-modal .role-option{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-surface);border:2px solid var(--border-default);border-radius:10px;cursor:pointer;transition:all .15s}.member-edit-modal .role-option:hover{background:var(--bg-hover);border-color:var(--border-hover)}.member-edit-modal .role-option.selected{background:#3b82f61a;border-color:#3b82f6}.member-edit-modal .role-option input{display:none}.member-edit-modal .role-color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.member-edit-modal .role-content{display:flex;flex-direction:column;gap:4px}.member-edit-modal .role-label{font-size:14px;font-weight:600;color:var(--text-primary)}.member-edit-modal .role-desc{font-size:12px;color:var(--text-secondary)}.member-edit-modal .role-option.selected .role-label{color:#2563eb}.member-edit-modal .role-option.selected .role-desc{color:#3b82f6}[data-theme=dark] .member-edit-modal .role-option{background:var(--bg-surface-secondary)}[data-theme=dark] .member-edit-modal .role-option.selected{background:#3b82f633}[data-theme=dark] .member-edit-modal .role-option.selected .role-label{color:#60a5fa}[data-theme=dark] .member-edit-modal .role-option.selected .role-desc{color:#93c5fd}.member-edit-modal .custom-role-input{position:relative}.member-edit-modal .input-wrapper{position:relative;display:flex;align-items:center}.member-edit-modal .input-wrapper .input-icon{position:absolute;left:14px;color:var(--text-tertiary)}.member-edit-modal .custom-role-input input{width:100%;padding:12px 14px 12px 42px;border:1px solid var(--border-default);border-radius:8px;background:var(--bg-surface);font-size:14px;color:var(--text-primary);transition:border-color .15s}.member-edit-modal .custom-role-input input:focus{outline:none;border-color:var(--color-primary)}.member-edit-modal .custom-role-input input::placeholder{color:var(--text-quaternary)}.member-edit-modal .role-suggestions{margin-top:12px;padding:12px;background:var(--bg-surface-secondary);border-radius:8px}.member-edit-modal .suggestions-title{margin:0 0 8px;font-size:12px;font-weight:500;color:var(--text-secondary)}.member-edit-modal .suggestion-tags{display:flex;flex-wrap:wrap;gap:6px}.member-edit-modal .suggestion-tag{padding:4px 10px;border:1px solid var(--border-default);border-radius:16px;background:var(--bg-surface);font-size:12px;color:var(--text-primary);cursor:pointer;transition:all .15s}.member-edit-modal .suggestion-tag:hover{background:var(--bg-hover);border-color:var(--color-primary);color:var(--color-primary)}.member-edit-modal .suggestion-tag.active{background:#3b82f626;border-color:var(--color-primary);color:var(--color-primary)}.member-edit-modal .form-group textarea{width:100%;padding:12px 14px;border:1px solid var(--border-default);border-radius:8px;background:var(--bg-surface);font-size:14px;color:var(--text-primary);resize:vertical;min-height:100px;font-family:inherit;transition:border-color .15s}.member-edit-modal .form-group textarea:focus{outline:none;border-color:var(--color-primary)}.member-edit-modal .form-group textarea::placeholder{color:var(--text-quaternary)}.member-edit-modal .help-text{margin:8px 0 0;font-size:12px;color:var(--text-tertiary)}.member-edit-modal .modal-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:16px;border-top:1px solid var(--border-subtle);margin-top:8px}.members-tree-page{height:calc(100vh - 104px);display:flex;flex-direction:column}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;flex-wrap:wrap;gap:16px}.header-title-row{display:flex;align-items:center;gap:var(--space-3)}.page-icon{color:var(--color-brand)}.header-left h1{font-size:24px;font-weight:700;color:var(--text-primary);margin:0}.page-description{font-size:14px;color:var(--text-secondary);margin:var(--space-1) 0 0 0}.header-controls{display:flex;gap:12px}.select-control{padding:8px 12px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-surface);color:var(--text-primary);font-size:14px;min-width:160px;cursor:pointer;transition:border-color var(--duration-fast) var(--ease-default)}.select-control:focus{outline:none;border-color:var(--color-brand);box-shadow:var(--glow-brand)}.select-control:disabled{opacity:.5;cursor:not-allowed}.analyze-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:8px 20px;border:none;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--color-brand) 0%,var(--color-brand-light) 100%);color:#fff!important;font-size:14px;font-weight:600;cursor:pointer;transition:all var(--duration-fast) var(--ease-default);box-shadow:var(--shadow-sm);white-space:nowrap}.analyze-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md),0 0 20px #6366f14d}.analyze-btn:active:not(:disabled){transform:translateY(0)}.analyze-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.error-message{display:flex;align-items:center;gap:var(--space-2);background-color:var(--color-danger-alpha-10);border:1px solid var(--color-danger);color:var(--color-danger);padding:12px 16px;border-radius:var(--radius-md);margin-bottom:16px;font-size:14px}.tree-layout{flex:1;display:grid;grid-template-columns:1fr 380px;gap:20px;min-height:0}.tree-panel{background-color:var(--bg-surface);border:1px solid var(--border-primary);border-radius:var(--radius-lg);display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-sm)}.tree-panel-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-primary)}.tree-panel-header h3{font-size:15px;font-weight:600;color:var(--text-primary);margin:0}.member-count{font-size:12px;color:var(--text-secondary);background:var(--bg-hover);padding:4px 10px;border-radius:var(--radius-full)}.tree-panel-content{flex:1;overflow-y:auto;padding:12px}.tree-container{min-width:max-content}.member-label{display:inline-flex;align-items:center;gap:8px}.role-tag{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600}.edit-member-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border:none;background:transparent;border-radius:4px;color:var(--text-quaternary);cursor:pointer;opacity:0;transition:all .15s}.member-label:hover .edit-member-btn{opacity:1}.edit-member-btn:hover{background:var(--bg-hover);color:var(--color-primary)}.role-indicator{font-size:12px}.loading-state,.empty-state{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-secondary);font-size:14px}.detail-panel{min-height:0}@media (max-width: 1024px){.tree-layout{grid-template-columns:1fr}.detail-panel{height:400px}}.projects-tree-page{max-width:1400px;margin:0 auto}.projects-tree-page .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;flex-wrap:wrap;gap:16px}.projects-tree-page .header-left h1{font-size:24px;font-weight:700;color:var(--text-primary);margin:0 0 4px}.projects-tree-page .page-description{font-size:14px;color:var(--text-secondary);margin:0}.projects-tree-page .header-controls{display:flex;gap:12px}.projects-tree-page .select-control{padding:8px 12px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-surface);color:var(--text-primary);font-size:14px;min-width:160px;cursor:pointer;transition:border-color var(--duration-fast) var(--ease-default)}.projects-tree-page .select-control:focus{outline:none;border-color:var(--color-brand);box-shadow:var(--glow-brand)}.projects-tree-page .analyze-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:8px 20px;border:none;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--color-brand) 0%,var(--color-brand-light, #818cf8) 100%);color:#fff!important;font-size:14px;font-weight:600;cursor:pointer;transition:all var(--duration-fast) var(--ease-default);box-shadow:var(--shadow-sm);white-space:nowrap}.projects-tree-page .analyze-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md),0 0 20px #6366f14d}.projects-tree-page .analyze-btn:active:not(:disabled){transform:translateY(0)}.projects-tree-page .analyze-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.analysis-container{margin-bottom:24px}.projects-tree-page .error-message{background-color:#ef44441a;border:1px solid var(--color-danger);color:var(--color-danger);padding:12px 16px;border-radius:var(--radius-md);margin-bottom:16px}.projects-tree-page .loading-state,.projects-tree-page .empty-state{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-secondary);font-size:14px}.overall-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:24px}.stat-card.large{background-color:var(--bg-surface);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:20px;text-align:center}.stat-card.large .stat-value{display:block;font-size:32px;font-weight:700;color:var(--text-primary)}.stat-card.large .stat-label{display:block;font-size:13px;color:var(--text-secondary);margin-top:4px}.stat-card.large.done .stat-value{color:var(--color-success)}.stat-card.large.in-progress .stat-value{color:var(--color-info)}.stat-card.large.blocked .stat-value{color:var(--color-danger)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:20px}.projects-tree-page .project-card{background-color:var(--bg-surface);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:20px;transition:all var(--duration-fast) var(--ease-default)}.projects-tree-page .project-card:hover{border-color:var(--color-brand);box-shadow:var(--shadow-md)}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.projects-tree-page .project-name{font-size:18px;font-weight:600;color:var(--text-primary);text-decoration:none}.projects-tree-page .project-name:hover{color:var(--color-brand)}.health-badge{font-size:11px;font-weight:500;padding:4px 8px;border-radius:var(--radius-sm);color:#fff}.projects-tree-page .project-description{font-size:13px;color:var(--text-secondary);margin:0 0 16px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.progress-section{margin-bottom:16px}.progress-header{display:flex;justify-content:space-between;font-size:12px;color:var(--text-secondary);margin-bottom:6px}.progress-bar{height:6px;background-color:var(--bg-surface-secondary, var(--bg-hover));border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-brand),var(--color-success));border-radius:3px;transition:width .5s ease}.stats-row{padding:12px 0;border-top:1px solid var(--border-primary);border-bottom:1px solid var(--border-primary);margin-bottom:12px}.members-section h4{font-size:12px;font-weight:600;color:var(--text-tertiary);margin:0 0 8px;text-transform:uppercase}.members-list{display:flex;flex-direction:column;gap:6px}.member-item{display:flex;align-items:center;gap:8px}.member-avatar-sm{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--color-brand),var(--color-brand-light, #818cf8));color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600}.member-item .member-name{flex:1;font-size:13px;color:var(--text-primary)}.member-tasks{font-size:12px;color:var(--text-secondary)}.activity-info{font-size:11px;color:var(--text-tertiary);margin-top:12px}@media (max-width: 768px){.overall-stats{grid-template-columns:repeat(2,1fr)}.projects-grid{grid-template-columns:1fr}}.members-manage-page{max-width:1200px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.header-content{display:flex;align-items:center;gap:16px}.header-icon{width:56px;height:56px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-hover));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:var(--glow-primary)}.header-text h1{font-size:28px;font-weight:700;color:var(--text-primary);margin:0 0 4px}.header-text p{font-size:14px;color:var(--text-secondary);margin:0}.members-table-container{padding:0;overflow:hidden}.members-table{width:100%;border-collapse:collapse}.members-table th,.members-table td{padding:16px 20px;text-align:left;border-bottom:1px solid var(--border-primary)}.members-table th{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);background-color:var(--bg-secondary)}.members-table tbody tr:hover{background-color:var(--bg-hover)}.members-table tbody tr:last-child td{border-bottom:none}.member-cell{display:flex;align-items:center;gap:12px}.member-avatar{width:36px;height:36px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--accent-primary),var(--accent-hover));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0}.member-avatar.large{width:48px;height:48px;font-size:18px}.member-name{font-weight:500;color:var(--text-primary)}.email-cell{color:var(--text-secondary)}.date-cell{color:var(--text-tertiary);font-size:13px}.role-badge{display:inline-block;font-size:12px;font-weight:500;padding:4px 10px;border-radius:100px;white-space:nowrap}.action-buttons{display:flex;gap:8px;flex-wrap:nowrap}.action-buttons .btn-sm{white-space:nowrap}.btn-ghost.danger{color:var(--color-danger)}.btn-ghost.danger:hover{background-color:var(--color-danger-light)}.no-action{color:var(--text-tertiary)}.member-info-card{display:flex;align-items:center;gap:16px;padding:16px;background-color:var(--bg-secondary);border-radius:var(--radius-md);margin-bottom:24px}.member-info-card .member-name{font-size:16px;font-weight:600}.member-info-card .member-email{font-size:13px;color:var(--text-secondary)}.role-options{display:flex;flex-direction:column;gap:8px}.role-option{display:flex;align-items:flex-start;gap:12px;padding:12px;border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.role-option:hover{border-color:var(--accent-primary);background-color:var(--bg-hover)}.role-option input[type=radio]{margin-top:2px}.role-option input[type=radio]:checked+.role-option-content .role-option-label{color:var(--accent-primary)}.role-option-content{flex:1}.role-option-label{display:block;font-weight:500;color:var(--text-primary);margin-bottom:2px}.role-option-desc{font-size:12px;color:var(--text-tertiary)}.error-card{background-color:var(--color-danger-light);border:1px solid var(--color-danger);color:var(--color-danger);padding:16px 20px;margin-bottom:24px;border-radius:var(--radius-md)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 40px}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-primary);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@media (max-width: 768px){.page-header{flex-direction:column;align-items:flex-start;gap:16px}.members-table th:nth-child(4),.members-table td:nth-child(4){display:none}}.ai-insights-page{max-width:1400px;margin:0 auto}.ai-insights-page .page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-8);flex-wrap:wrap;gap:var(--space-5)}.header-content{display:flex;align-items:center;gap:var(--space-4)}.header-icon{width:56px;height:56px;background:linear-gradient(135deg,var(--color-brand),#8B5CF6);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:var(--glow-brand)}.header-text h1{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);margin:0 0 var(--space-1) 0}.header-text p{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.header-actions{display:flex;gap:var(--space-3)}.header-actions .select-control{min-width:180px;padding:var(--space-2) var(--space-3);border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-surface);color:var(--text-primary);font-size:var(--text-sm)}.ai-insights-page .empty-state{background-color:var(--bg-surface);border:2px dashed var(--border-primary);border-radius:var(--radius-xl);padding:var(--space-12) var(--space-8);text-align:center;overflow:hidden}.ai-insights-page .empty-state .empty-icon{width:80px;height:80px;margin:0 auto var(--space-5);background:linear-gradient(135deg,var(--color-brand-alpha-10),var(--color-brand-alpha-20));border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:40px;line-height:1}.ai-insights-page .empty-state h3{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-3) 0}.ai-insights-page .empty-state p{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--space-8) 0;max-width:400px;margin-left:auto;margin-right:auto;line-height:var(--leading-relaxed)}.empty-features{display:flex;justify-content:center;gap:var(--space-6);flex-wrap:wrap}.feature-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background-color:var(--bg-hover);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--text-secondary)}.feature-icon{font-size:var(--text-lg)}.ai-insights-page .loading-state{background-color:var(--bg-surface);border:1px solid var(--border-primary);border-radius:var(--radius-xl);padding:var(--space-16) var(--space-8);text-align:center}.ai-insights-page .loading-spinner{width:48px;height:48px;border:3px solid var(--border-primary);border-top-color:var(--color-brand);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto var(--space-5)}@keyframes spin{to{transform:rotate(360deg)}}.ai-insights-page .loading-state p{color:var(--text-secondary);font-size:var(--text-sm);margin:0}.error-card{background-color:var(--color-danger-alpha-10);border:1px solid var(--color-danger);color:var(--color-danger);padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);margin-bottom:var(--space-6)}.insights-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-6)}.insight-card{background-color:var(--bg-surface);border:1px solid var(--border-primary);border-radius:var(--radius-xl);padding:var(--space-6)}.insight-card .card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-5)}.insight-card .card-header h3{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-2);font-size:var(--text-xs);font-weight:var(--font-medium);border-radius:var(--radius-full)}.health-card{grid-column:1}.health-score{display:flex;justify-content:center;margin-bottom:var(--space-5)}.score-circle{position:relative;width:140px;height:140px}.score-circle svg{transform:rotate(-90deg);width:100%;height:100%}.score-bg{stroke:var(--bg-hover)}.score-fill{stroke:var(--color-brand);transition:stroke-dasharray 1s ease}.score-value{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--text-primary)}.health-summary{text-align:center;color:var(--text-secondary);font-size:var(--text-sm);line-height:var(--leading-relaxed);margin:0}.risk-card{grid-column:2}.risk-grid{display:flex;flex-direction:column;gap:var(--space-4)}.risk-level{padding:var(--space-4);border-radius:var(--radius-lg);display:flex;align-items:flex-start;gap:var(--space-3)}.risk-level.high{background-color:var(--color-danger-alpha-10)}.risk-level.medium{background-color:var(--color-warning-alpha-10)}.risk-level.low{background-color:var(--color-success-alpha-10)}.risk-label{font-size:var(--text-sm);font-weight:var(--font-semibold);min-width:60px}.risk-level.high .risk-label{color:var(--color-danger)}.risk-level.medium .risk-label{color:var(--color-warning)}.risk-level.low .risk-label{color:var(--color-success)}.risk-count{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);min-width:40px}.risk-projects{flex:1;display:flex;flex-wrap:wrap;gap:var(--space-1)}.risk-project{font-size:var(--text-xs);padding:var(--space-1) var(--space-2);background-color:var(--bg-surface);border-radius:var(--radius-sm);color:var(--text-secondary)}.comparison-card{grid-column:span 2}.comparison-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4)}.comparison-item{padding:var(--space-4);background-color:var(--bg-hover);border-radius:var(--radius-lg)}.comparison-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3)}.comparison-header .project-name{font-weight:var(--font-semibold);color:var(--text-primary)}.comparison-score{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}.score-bar{flex:1;height:6px;background-color:var(--bg-surface-secondary);border-radius:3px;overflow:hidden}.score-bar .score-fill{height:100%;background:linear-gradient(90deg,var(--color-brand),var(--color-success));border-radius:3px}.score-text{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-secondary);min-width:40px}.project-issue{font-size:var(--text-sm);color:var(--color-warning);margin:0 0 var(--space-2) 0}.project-recommendation{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.priorities-card{grid-column:1}.priorities-list{display:flex;flex-direction:column;gap:var(--space-3)}.priority-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3);background-color:var(--bg-hover);border-radius:var(--radius-lg);border-left:3px solid transparent}.priority-item.urgency-high{border-left-color:var(--color-danger)}.priority-item.urgency-medium{border-left-color:var(--color-warning)}.priority-item.urgency-low{border-left-color:var(--color-success)}.priority-urgency{font-size:var(--text-base)}.priority-content{flex:1}.priority-action{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);margin-bottom:var(--space-1)}.priority-project{font-size:var(--text-xs);color:var(--text-tertiary)}.resource-card{grid-column:2}.utilization-score{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-brand);background-color:var(--color-brand-alpha-10);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}.imbalances-list{display:flex;flex-direction:column;gap:var(--space-4)}.imbalance-item{padding:var(--space-3);background-color:var(--bg-hover);border-radius:var(--radius-lg)}.imbalance-desc{font-size:var(--text-sm);color:var(--text-primary);margin:0 0 var(--space-2) 0}.imbalance-suggestion{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.no-imbalances{font-size:var(--text-sm);color:var(--color-success);text-align:center;padding:var(--space-5);margin:0}.insights-card{grid-column:span 2}.insights-text{font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--text-secondary);margin:0;padding:var(--space-4);background-color:var(--bg-hover);border-radius:var(--radius-lg);border-left:3px solid var(--color-brand)}.spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;display:inline-block;margin-right:var(--space-2)}@media (max-width: 1024px){.insights-grid{grid-template-columns:1fr}.health-card,.risk-card,.comparison-card,.priorities-card,.resource-card,.insights-card{grid-column:1}}@media (max-width: 640px){.ai-insights-page .page-header{flex-direction:column;align-items:flex-start}.header-actions{width:100%;flex-direction:column}.header-actions .select-control,.header-actions .btn{width:100%}.ai-insights-page .empty-state{padding:var(--space-10) var(--space-5)}.empty-features{flex-direction:column;align-items:center}}.settings-page{max-width:1000px;margin:0 auto}.settings-page .page-header h1{font-size:28px;font-weight:700;color:var(--text-primary);margin:0 0 32px}.settings-layout{display:grid;grid-template-columns:220px 1fr;gap:24px}.settings-sidebar{padding:8px;height:fit-content;position:sticky;top:92px}.settings-tab{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;background:none;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:500;color:var(--text-secondary);cursor:pointer;text-align:left;transition:all var(--transition-fast)}.settings-tab:hover{background-color:var(--bg-hover);color:var(--text-primary)}.settings-tab.active{background-color:var(--accent-light);color:var(--accent-primary)}.settings-section{padding:24px}.settings-section h2{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 24px;padding-bottom:16px;border-bottom:1px solid var(--border-primary)}.profile-card{display:flex;align-items:center;gap:16px;padding:20px;background-color:var(--bg-secondary);border-radius:var(--radius-lg);margin-bottom:24px}.profile-avatar{width:64px;height:64px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--accent-primary),var(--accent-hover));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:24px}.profile-name{font-size:18px;font-weight:600;color:var(--text-primary)}.profile-email{font-size:14px;color:var(--text-secondary);margin-top:4px}.theme-options{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.theme-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px;background-color:var(--bg-secondary);border:2px solid var(--border-primary);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.theme-option:hover{border-color:var(--accent-primary)}.theme-option.active{border-color:var(--accent-primary);background-color:var(--accent-light)}.theme-icon{font-size:28px}.theme-name{font-size:14px;font-weight:500;color:var(--text-primary)}.settings-section .workspaces-list{display:flex;flex-direction:column;gap:8px}.settings-section .workspace-item{display:flex;align-items:center;gap:12px;padding:16px;background-color:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid transparent}.settings-section .workspace-item.current{border-color:var(--accent-primary);background-color:var(--accent-light)}.settings-section .workspace-icon{font-size:24px}.settings-section .workspace-name{font-weight:500;color:var(--text-primary);display:flex;align-items:center;gap:8px}.current-badge{font-size:11px;font-weight:500;padding:2px 8px;background-color:var(--accent-primary);color:#fff;border-radius:100px}.settings-section .workspace-meta{margin-top:4px}.settings-section .role-badge{font-size:11px;font-weight:500;padding:3px 8px;border-radius:100px}.settings-section .form-group{margin-bottom:20px}.settings-section .form-label{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:8px}.settings-section .form-input{width:100%;padding:10px 14px;font-size:14px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary)}.settings-section .form-input:disabled{background-color:var(--bg-secondary);color:var(--text-secondary);cursor:not-allowed}.settings-section .form-hint{font-size:12px;color:var(--text-tertiary);margin-top:6px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border-primary)}.section-header h2{margin:0;padding:0;border:none}.section-actions{display:flex;gap:8px}.settings-message{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:var(--radius-md);margin-bottom:16px;font-size:14px;font-weight:500}.settings-message.success{background-color:var(--color-success-alpha-10, rgba(16, 185, 129, .1));color:var(--color-success);border:1px solid var(--color-success)}.settings-message.error{background-color:var(--color-danger-alpha-10, rgba(239, 68, 68, .1));color:var(--color-danger);border:1px solid var(--color-danger)}.security-info{padding:20px;background-color:var(--bg-secondary);border-radius:var(--radius-lg)}.security-info p{margin:0;color:var(--text-secondary);font-size:14px;line-height:1.6}.security-info .security-hint{margin-top:8px;color:var(--text-tertiary);font-size:13px}.btn-sm{padding:6px 12px;font-size:13px}.settings-section .form-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-alpha-10, rgba(99, 102, 241, .1))}@media (max-width: 768px){.settings-layout{grid-template-columns:1fr}.settings-sidebar{position:static;display:flex;gap:8px;overflow-x:auto;padding:8px}.settings-tab{white-space:nowrap}.theme-options{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start;gap:12px}}.reports-page{max-width:1400px;margin:0 auto}.reports-page .page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px}.reports-page .header-content{display:flex;align-items:center;gap:16px}.reports-page .header-icon{width:56px;height:56px;background:linear-gradient(135deg,var(--color-info),#3b82f6);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:0 0 20px #3b82f64d}.reports-page .header-text h1{font-size:28px;font-weight:700;color:var(--text-primary);margin:0 0 4px}.reports-page .header-text p{font-size:14px;color:var(--text-secondary);margin:0}.reports-page .header-actions{display:flex;gap:12px}.reports-layout{display:grid;grid-template-columns:280px 1fr;gap:24px}.reports-list{padding:20px;height:fit-content;position:sticky;top:92px}.reports-list h3{font-size:14px;font-weight:600;color:var(--text-secondary);margin:0 0 16px}.report-items{display:flex;flex-direction:column;gap:4px}.report-item{display:flex;justify-content:space-between;align-items:center;padding:12px;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.report-item:hover{background-color:var(--bg-hover)}.report-item.active{background-color:var(--accent-light)}.report-type{font-size:14px;font-weight:500;color:var(--text-primary)}.report-date{font-size:12px;color:var(--text-tertiary)}.report-detail{padding:24px;min-height:400px}.report-detail-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border-primary);gap:16px;flex-wrap:wrap}.report-title-section h2{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.report-period{font-size:14px;color:var(--text-secondary)}.report-actions{display:flex;gap:8px;flex-wrap:wrap}.report-actions .btn{display:flex;align-items:center;gap:6px;white-space:nowrap}.report-summary{background-color:var(--accent-light);border-radius:var(--radius-md);padding:16px 20px;margin-bottom:24px}.report-summary h4{font-size:14px;font-weight:600;color:var(--accent-primary);margin:0 0 8px}.report-summary p{font-size:14px;color:var(--text-primary);line-height:1.6;margin:0}.report-insights{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.insight-section{padding:16px;border-radius:var(--radius-md)}.insight-section.highlights{background-color:var(--color-success-light)}.insight-section.concerns{background-color:var(--color-warning-light)}.insight-section h4{font-size:14px;font-weight:600;margin:0 0 12px}.highlights h4{color:var(--color-success)}.concerns h4{color:var(--color-warning)}.insight-section ul{margin:0;padding-left:20px}.insight-section li{font-size:13px;color:var(--text-primary);margin-bottom:6px}.report-stats{margin-bottom:24px}.report-stats h4,.report-projects h4{font-size:14px;font-weight:600;color:var(--text-secondary);margin:0 0 16px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.report-stats .stat-item{background-color:var(--bg-secondary);padding:16px;border-radius:var(--radius-md);text-align:center}.report-stats .stat-item .stat-value{display:block;font-size:28px;font-weight:700;color:var(--text-primary)}.report-stats .stat-item .stat-label{display:block;font-size:12px;color:var(--text-secondary);margin-top:4px}.project-stats-list{display:flex;flex-direction:column;gap:12px}.project-stat-item{background-color:var(--bg-secondary);padding:14px 16px;border-radius:var(--radius-md)}.project-info{display:flex;justify-content:space-between;margin-bottom:8px}.project-name{font-size:14px;font-weight:500;color:var(--text-primary)}.project-rate{font-size:13px;color:var(--accent-primary);font-weight:500}.project-bar{height:6px;background-color:var(--bg-tertiary);border-radius:3px;margin-bottom:8px;overflow:hidden}.project-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--color-success));border-radius:3px;transition:width .5s ease}.project-numbers{display:flex;justify-content:space-between;font-size:12px;color:var(--text-tertiary)}.no-report-selected,.empty-placeholder{padding:60px 20px;text-align:center;color:var(--text-secondary)}.empty-placeholder .hint{font-size:13px;color:var(--text-tertiary);margin-top:8px}.loading-placeholder{padding:40px 20px;text-align:center;color:var(--text-secondary)}.reports-page .error-card{background-color:var(--color-danger-light);border:1px solid var(--color-danger);color:var(--color-danger);padding:12px 16px;border-radius:var(--radius-md);margin-bottom:16px}.reports-page .success-toast{position:fixed;bottom:24px;right:24px;background-color:var(--color-success);color:#fff;padding:12px 20px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);font-size:14px;font-weight:500;z-index:1000;animation:slideUp .3s ease}.report-detail .form-group{margin-bottom:16px}.report-detail .form-label{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:8px}.report-detail .form-label .form-hint{font-weight:400;color:var(--text-tertiary)}.report-detail .form-input{width:100%;padding:10px 12px;font-size:14px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-surface);color:var(--text-primary);transition:all var(--transition-fast)}.report-detail .form-input:focus{outline:none;border-color:var(--color-brand);box-shadow:0 0 0 3px var(--color-brand-alpha-10)}.report-detail .form-hint{font-size:12px;color:var(--text-tertiary);margin-top:4px}.report-detail .form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:16px;border-top:1px solid var(--border-primary)}@media (max-width: 1024px){.reports-layout{grid-template-columns:1fr}.reports-list{position:static}.report-insights{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}}:root{--color-brand: #6366F1;--color-brand-light: #818CF8;--color-brand-dark: #4F46E5;--color-brand-alpha-10: rgba(99, 102, 241, .1);--color-brand-alpha-20: rgba(99, 102, 241, .2);--color-success: #10B981;--color-success-light: #34D399;--color-success-dark: #059669;--color-success-alpha-10: rgba(16, 185, 129, .1);--color-warning: #F59E0B;--color-warning-light: #FBBF24;--color-warning-dark: #D97706;--color-warning-alpha-10: rgba(245, 158, 11, .1);--color-danger: #EF4444;--color-danger-light: #F87171;--color-danger-dark: #DC2626;--color-danger-alpha-10: rgba(239, 68, 68, .1);--color-info: #3B82F6;--color-info-light: #60A5FA;--color-info-dark: #2563EB;--color-info-alpha-10: rgba(59, 130, 246, .1);--bg-base: #FFFFFF;--bg-surface: #FFFFFF;--bg-surface-secondary: #FAFAFA;--bg-surface-tertiary: #F5F5F5;--bg-hover: #F5F5F5;--bg-active: #EFEFEF;--bg-selected: #F0F0F0;--text-primary: #171717;--text-secondary: #525252;--text-tertiary: #A3A3A3;--text-disabled: #D4D4D4;--text-inverse: #FFFFFF;--border-primary: #E5E5E5;--border-secondary: #F0F0F0;--border-subtle: #F5F5F5;--border-focus: var(--color-brand);--divider: #E5E5E5;--accent-primary: #2563EB;--brand-primary: #171717;--brand-light: #F5F5F5;--shadow-xs: 0 1px 1px rgba(0, 0, 0, .02);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 2px 4px rgba(0, 0, 0, .06);--shadow-lg: 0 4px 8px rgba(0, 0, 0, .06);--shadow-xl: 0 8px 16px rgba(0, 0, 0, .06);--shadow-2xl: 0 16px 32px rgba(0, 0, 0, .08);--glow-brand: 0 0 0 3px rgba(99, 102, 241, .15);--glow-success: 0 0 0 3px rgba(16, 185, 129, .15);--glow-warning: 0 0 0 3px rgba(245, 158, 11, .15);--glow-danger: 0 0 0 3px rgba(239, 68, 68, .15);--space-0: 0;--space-px: 1px;--space-0-5: 2px;--space-1: 4px;--space-1-5: 6px;--space-2: 8px;--space-2-5: 10px;--space-3: 12px;--space-3-5: 14px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 28px;--space-8: 32px;--space-9: 36px;--space-10: 40px;--space-12: 48px;--space-14: 56px;--space-16: 64px;--space-20: 80px;--space-24: 96px;--radius-none: 0;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-2xl: 16px;--radius-3xl: 24px;--radius-full: 9999px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: "SF Mono", "Fira Code", "Fira Mono", "Roboto Mono", monospace;--text-xs: 11px;--text-sm: 12px;--text-base: 14px;--text-lg: 16px;--text-xl: 18px;--text-2xl: 20px;--text-3xl: 24px;--text-4xl: 30px;--text-5xl: 36px;--leading-none: 1;--leading-tight: 1.25;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--leading-loose: 2;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--tracking-tight: -.025em;--tracking-normal: 0;--tracking-wide: .025em;--duration-instant: 50ms;--duration-fast: .15s;--duration-normal: .2s;--duration-slow: .3s;--duration-slower: .4s;--duration-slowest: .5s;--ease-default: cubic-bezier(.4, 0, .2, 1);--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--ease-bounce: cubic-bezier(.34, 1.56, .64, 1);--ease-elastic: cubic-bezier(.68, -.55, .265, 1.55);--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-popover: 600;--z-tooltip: 700;--z-toast: 800;--sidebar-width: 260px;--sidebar-collapsed-width: 72px;--topbar-height: 56px;--container-max: 1280px}[data-theme=dark]{--bg-base: #09090B;--bg-surface: #18181B;--bg-surface-secondary: #27272A;--bg-surface-tertiary: #3F3F46;--bg-hover: rgba(255, 255, 255, .04);--bg-active: rgba(255, 255, 255, .08);--bg-selected: rgba(99, 102, 241, .16);--text-primary: #FAFAFA;--text-secondary: #A1A1AA;--text-tertiary: #71717A;--text-disabled: #52525B;--text-inverse: #09090B;--border-primary: #27272A;--border-secondary: #3F3F46;--divider: #27272A;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .3);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4), 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4), 0 4px 6px -2px rgba(0, 0, 0, .3);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .4), 0 10px 10px -5px rgba(0, 0, 0, .25);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .6);--glow-brand: 0 0 0 3px rgba(99, 102, 241, .25);--glow-success: 0 0 0 3px rgba(16, 185, 129, .25);--glow-warning: 0 0 0 3px rgba(245, 158, 11, .25);--glow-danger: 0 0 0 3px rgba(239, 68, 68, .25)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--text-primary);background-color:var(--bg-base);transition:background-color var(--duration-normal) var(--ease-default),color var(--duration-normal) var(--ease-default)}::selection{background-color:var(--color-brand);color:#fff}:focus{outline:none}:focus-visible{outline:2px solid var(--color-brand);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background-color:var(--text-tertiary);border-radius:var(--radius-full);border:2px solid transparent;background-clip:content-box}::-webkit-scrollbar-thumb:hover{background-color:var(--text-secondary)}*{scrollbar-width:thin;scrollbar-color:var(--text-tertiary) transparent}a{color:var(--color-brand);text-decoration:none;transition:color var(--duration-fast) var(--ease-default)}a:hover{color:var(--color-brand-dark)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);height:36px;padding:0 var(--space-4);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--font-medium);line-height:1;white-space:nowrap;text-decoration:none;border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);-webkit-user-select:none;user-select:none;position:relative;overflow:hidden}.btn:disabled,.btn.btn-disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn:active:not(:disabled){transform:scale(.98)}.btn-primary{background-color:var(--color-brand);color:#fff;border-color:var(--color-brand)}.btn-primary:hover:not(:disabled){background-color:var(--color-brand-dark);border-color:var(--color-brand-dark);box-shadow:0 0 0 3px var(--color-brand-alpha-20),0 2px 8px #6366f140}.btn-primary:active:not(:disabled){background-color:var(--color-brand-dark)}.btn-secondary{background-color:var(--bg-surface);color:var(--text-primary);border-color:var(--border-primary)}.btn-secondary:hover:not(:disabled){background-color:var(--bg-hover);border-color:var(--border-secondary)}.btn-secondary:active:not(:disabled){background-color:var(--bg-active)}.btn-ghost{background-color:transparent;color:var(--text-secondary);border-color:transparent}.btn-ghost:hover:not(:disabled){background-color:var(--bg-hover);color:var(--text-primary)}.btn-ghost:active:not(:disabled){background-color:var(--bg-active)}.btn-danger{background-color:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn-danger:hover:not(:disabled){background-color:var(--color-danger-dark);border-color:var(--color-danger-dark);box-shadow:0 0 0 3px var(--color-danger-alpha-10),0 2px 8px #ef444440}.btn-success{background-color:var(--color-success);color:#fff;border-color:var(--color-success)}.btn-success:hover:not(:disabled){background-color:var(--color-success-dark);border-color:var(--color-success-dark);box-shadow:0 0 0 3px var(--color-success-alpha-10),0 2px 8px #10b98140}.btn-warning{background-color:var(--color-warning);color:#fff;border-color:var(--color-warning)}.btn-warning:hover:not(:disabled){background-color:var(--color-warning-dark);border-color:var(--color-warning-dark);box-shadow:0 0 0 3px var(--color-warning-alpha-10),0 2px 8px #f59e0b40}.btn-text{background-color:transparent;color:var(--color-brand);border-color:transparent;padding:0 var(--space-2)}.btn-text:hover:not(:disabled){color:var(--color-brand-dark);background-color:var(--color-brand-alpha-10)}.btn-outline{background-color:transparent;color:var(--color-brand);border-color:var(--color-brand)}.btn-outline:hover:not(:disabled){background-color:var(--color-brand);color:#fff}.btn-xs{height:28px;padding:0 var(--space-2-5);font-size:var(--text-xs);border-radius:var(--radius-sm)}.btn-sm{height:32px;padding:0 var(--space-3);font-size:var(--text-sm)}.btn-lg{height:44px;padding:0 var(--space-6);font-size:var(--text-base);border-radius:var(--radius-lg)}.btn-xl{height:52px;padding:0 var(--space-8);font-size:var(--text-lg);border-radius:var(--radius-lg)}.btn-icon{width:36px;padding:0}.btn-icon.btn-xs{width:28px}.btn-icon.btn-sm{width:32px}.btn-icon.btn-lg{width:44px}.btn-icon.btn-xl{width:52px}.btn-loading{position:relative;color:transparent!important;pointer-events:none}.btn-loading:after{content:"";position:absolute;width:16px;height:16px;top:50%;left:50%;margin-top:-8px;margin-left:-8px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:btn-spin .6s linear infinite}.btn-primary.btn-loading:after,.btn-danger.btn-loading:after,.btn-success.btn-loading:after,.btn-warning.btn-loading:after{border-color:#fff;border-right-color:transparent}@keyframes btn-spin{to{transform:rotate(360deg)}}.btn-group{display:inline-flex}.btn-group .btn{border-radius:0;margin-left:-1px}.btn-group .btn:first-child{margin-left:0;border-top-left-radius:var(--radius-md);border-bottom-left-radius:var(--radius-md)}.btn-group .btn:last-child{border-top-right-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md)}.btn-group .btn:hover,.btn-group .btn:focus{z-index:1}.btn-block{display:flex;width:100%}@media (max-width: 768px){.btn{min-height:44px}.btn-xs{min-height:36px}.btn-sm{min-height:40px}}.form-group{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-5)}.form-group:last-child{margin-bottom:0}.form-label{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);line-height:var(--leading-tight)}.form-label-required:after{content:" *";color:var(--color-danger)}.form-input,.form-select,.form-textarea{width:100%;height:40px;padding:0 var(--space-3);font-family:var(--font-sans);font-size:var(--text-base);color:var(--text-primary);background-color:var(--bg-surface);border:1px solid var(--border-primary);border-radius:var(--radius-md);transition:all var(--duration-fast) var(--ease-default)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-tertiary)}.form-input:hover:not(:disabled):not(:focus),.form-select:hover:not(:disabled):not(:focus),.form-textarea:hover:not(:disabled):not(:focus){border-color:var(--border-secondary)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--color-brand);box-shadow:var(--glow-brand)}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background-color:var(--bg-surface-secondary);color:var(--text-disabled);cursor:not-allowed}.form-input-sm{height:32px;padding:0 var(--space-2-5);font-size:var(--text-sm)}.form-input-lg{height:48px;padding:0 var(--space-4);font-size:var(--text-lg)}.form-textarea{height:auto;min-height:100px;padding:var(--space-3);resize:vertical;line-height:var(--leading-relaxed)}.form-textarea-sm{min-height:80px;font-size:var(--text-sm)}.form-textarea-lg{min-height:160px;font-size:var(--text-base)}.form-select{padding-right:var(--space-10);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;background-size:16px;cursor:pointer}[data-theme=dark] .form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2371717A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E")}.form-checkbox,.form-radio{display:inline-flex;align-items:center;gap:var(--space-2);cursor:pointer;-webkit-user-select:none;user-select:none}.form-checkbox input,.form-radio input{width:18px;height:18px;margin:0;accent-color:var(--color-brand);cursor:pointer}.form-checkbox-label,.form-radio-label{font-size:var(--text-sm);color:var(--text-primary)}.form-switch{display:inline-flex;align-items:center;gap:var(--space-2);cursor:pointer}.form-switch-track{position:relative;width:40px;height:24px;background-color:var(--bg-surface-tertiary);border-radius:var(--radius-full);transition:background-color var(--duration-fast) var(--ease-default)}.form-switch-track:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background-color:#fff;border-radius:50%;box-shadow:var(--shadow-sm);transition:transform var(--duration-fast) var(--ease-bounce)}.form-switch input{position:absolute;opacity:0;pointer-events:none}.form-switch input:checked+.form-switch-track{background-color:var(--color-brand)}.form-switch input:checked+.form-switch-track:after{transform:translate(16px)}.form-switch input:focus-visible+.form-switch-track{box-shadow:var(--glow-brand)}.form-hint{font-size:var(--text-xs);color:var(--text-tertiary);line-height:var(--leading-normal)}.form-group.has-error .form-input,.form-group.has-error .form-select,.form-group.has-error .form-textarea,.form-input.is-error,.form-select.is-error,.form-textarea.is-error{border-color:var(--color-danger)}.form-group.has-error .form-input:focus,.form-group.has-error .form-select:focus,.form-group.has-error .form-textarea:focus,.form-input.is-error:focus,.form-select.is-error:focus,.form-textarea.is-error:focus{box-shadow:var(--glow-danger)}.form-error-message{font-size:var(--text-xs);color:var(--color-danger);display:flex;align-items:center;gap:var(--space-1)}.form-group.has-success .form-input,.form-group.has-success .form-select,.form-group.has-success .form-textarea,.form-input.is-success,.form-select.is-success,.form-textarea.is-success{border-color:var(--color-success)}.form-group.has-success .form-input:focus,.form-group.has-success .form-select:focus,.form-group.has-success .form-textarea:focus,.form-input.is-success:focus,.form-select.is-success:focus,.form-textarea.is-success:focus{box-shadow:var(--glow-success)}.form-input-group{position:relative;display:flex;align-items:center}.form-input-icon{position:absolute;left:var(--space-3);color:var(--text-tertiary);pointer-events:none;display:flex;align-items:center;justify-content:center;width:20px;height:20px}.form-input-group .form-input{padding-left:var(--space-10)}.form-input-icon-right{left:auto;right:var(--space-3)}.form-input-group.has-icon-right .form-input{padding-left:var(--space-3);padding-right:var(--space-10)}.form-actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-5);margin-top:var(--space-5);border-top:1px solid var(--divider)}.form-actions-left{justify-content:flex-start}.form-actions-between{justify-content:space-between}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}.form-row-3{grid-template-columns:repeat(3,1fr)}@media (max-width: 768px){.form-row,.form-row-3{grid-template-columns:1fr}.form-input,.form-select,.form-textarea{font-size:16px}}.form-search{position:relative}.form-search .form-input{padding-left:var(--space-10);padding-right:var(--space-10)}.form-search-icon{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);color:var(--text-tertiary);pointer-events:none}.form-search-clear{position:absolute;right:var(--space-2);top:50%;transform:translateY(-50%);width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;transition:all var(--duration-fast) var(--ease-default)}.form-search-clear:hover{background-color:var(--bg-hover);color:var(--text-primary)}.card{background-color:var(--bg-surface);border:1px solid var(--border-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;transition:all var(--duration-normal) var(--ease-default)}.card-interactive{cursor:pointer}.card-interactive:hover{border-color:var(--border-secondary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-interactive:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.card-static{cursor:default}.card-borderless{border:none;box-shadow:var(--shadow-md)}.card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--divider)}.card-title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);line-height:var(--leading-tight);margin:0}.card-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--space-1)}.card-actions{display:flex;align-items:center;gap:var(--space-2)}.card-body{padding:var(--space-5)}.card-body-sm{padding:var(--space-4)}.card-body-lg{padding:var(--space-6)}.card-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-top:1px solid var(--divider);background-color:var(--bg-surface-secondary)}.card-status{border-left-width:4px}.card-success{border-left-color:var(--color-success)}.card-warning{border-left-color:var(--color-warning)}.card-danger{border-left-color:var(--color-danger)}.card-info{border-left-color:var(--color-info)}.card-primary{border-left-color:var(--color-brand)}.card-grid{display:grid;gap:var(--space-5)}.card-grid-2{grid-template-columns:repeat(2,1fr)}.card-grid-3{grid-template-columns:repeat(3,1fr)}.card-grid-4{grid-template-columns:repeat(4,1fr)}.card-grid-auto{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}@media (max-width: 1024px){.card-grid-4,.card-grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.card-grid-2,.card-grid-3,.card-grid-4{grid-template-columns:1fr}.card-body{padding:var(--space-4)}}.card-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) var(--space-6);text-align:center}.card-empty-icon{font-size:48px;margin-bottom:var(--space-4);opacity:.5}.card-empty-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-2)}.card-empty-desc{font-size:var(--text-sm);color:var(--text-secondary);max-width:320px;margin-bottom:var(--space-6)}.card-stat{padding:var(--space-5)}.card-stat-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:24px;background-color:var(--color-brand-alpha-10);border-radius:var(--radius-lg);margin-bottom:var(--space-4)}.card-stat-value{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--text-primary);line-height:1;margin-bottom:var(--space-1)}.card-stat-label{font-size:var(--text-sm);color:var(--text-secondary)}.card-selectable{cursor:pointer;position:relative}.card-selectable.is-selected{border-color:var(--color-brand);box-shadow:var(--glow-brand)}.card-loading{position:relative;overflow:hidden}.card-loading:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,var(--bg-hover),transparent);animation:card-shimmer 1.5s infinite}@keyframes card-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.text-primary{color:var(--text-primary)!important}.text-secondary{color:var(--text-secondary)!important}.text-tertiary{color:var(--text-tertiary)!important}.text-disabled{color:var(--text-disabled)!important}.text-inverse{color:var(--text-inverse)!important}.text-brand{color:var(--color-brand)!important}.text-success{color:var(--color-success)!important}.text-warning{color:var(--color-warning)!important}.text-danger{color:var(--color-danger)!important}.text-info{color:var(--color-info)!important}.text-xs{font-size:var(--text-xs)!important}.text-sm{font-size:var(--text-sm)!important}.text-base{font-size:var(--text-base)!important}.text-lg{font-size:var(--text-lg)!important}.text-xl{font-size:var(--text-xl)!important}.text-2xl{font-size:var(--text-2xl)!important}.text-3xl{font-size:var(--text-3xl)!important}.text-4xl{font-size:var(--text-4xl)!important}.text-5xl{font-size:var(--text-5xl)!important}.font-normal{font-weight:var(--font-normal)!important}.font-medium{font-weight:var(--font-medium)!important}.font-semibold{font-weight:var(--font-semibold)!important}.font-bold{font-weight:var(--font-bold)!important}.text-left{text-align:left!important}.text-center{text-align:center!important}.text-right{text-align:right!important}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.line-clamp-1{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.whitespace-nowrap{white-space:nowrap!important}.whitespace-normal{white-space:normal!important}.flex{display:flex!important}.inline-flex{display:inline-flex!important}.flex-col{flex-direction:column!important}.flex-row{flex-direction:row!important}.flex-wrap{flex-wrap:wrap!important}.flex-nowrap{flex-wrap:nowrap!important}.flex-1{flex:1 1 0%!important}.flex-auto{flex:1 1 auto!important}.flex-none{flex:none!important}.flex-shrink-0{flex-shrink:0!important}.flex-grow{flex-grow:1!important}.items-start{align-items:flex-start!important}.items-center{align-items:center!important}.items-end{align-items:flex-end!important}.items-stretch{align-items:stretch!important}.items-baseline{align-items:baseline!important}.justify-start{justify-content:flex-start!important}.justify-center{justify-content:center!important}.justify-end{justify-content:flex-end!important}.justify-between{justify-content:space-between!important}.justify-around{justify-content:space-around!important}.justify-evenly{justify-content:space-evenly!important}.self-start{align-self:flex-start!important}.self-center{align-self:center!important}.self-end{align-self:flex-end!important}.self-stretch{align-self:stretch!important}.grid{display:grid!important}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))!important}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))!important}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))!important}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))!important}.col-span-2{grid-column:span 2 / span 2!important}.col-span-3{grid-column:span 3 / span 3!important}.col-span-full{grid-column:1 / -1!important}.gap-0{gap:0!important}.gap-1{gap:var(--space-1)!important}.gap-2{gap:var(--space-2)!important}.gap-3{gap:var(--space-3)!important}.gap-4{gap:var(--space-4)!important}.gap-5{gap:var(--space-5)!important}.gap-6{gap:var(--space-6)!important}.gap-8{gap:var(--space-8)!important}.gap-10{gap:var(--space-10)!important}.m-0{margin:0!important}.m-1{margin:var(--space-1)!important}.m-2{margin:var(--space-2)!important}.m-3{margin:var(--space-3)!important}.m-4{margin:var(--space-4)!important}.m-5{margin:var(--space-5)!important}.m-6{margin:var(--space-6)!important}.m-auto{margin:auto!important}.mt-0{margin-top:0!important}.mt-1{margin-top:var(--space-1)!important}.mt-2{margin-top:var(--space-2)!important}.mt-3{margin-top:var(--space-3)!important}.mt-4{margin-top:var(--space-4)!important}.mt-5{margin-top:var(--space-5)!important}.mt-6{margin-top:var(--space-6)!important}.mb-0{margin-bottom:0!important}.mb-1{margin-bottom:var(--space-1)!important}.mb-2{margin-bottom:var(--space-2)!important}.mb-3{margin-bottom:var(--space-3)!important}.mb-4{margin-bottom:var(--space-4)!important}.mb-5{margin-bottom:var(--space-5)!important}.mb-6{margin-bottom:var(--space-6)!important}.ml-0{margin-left:0!important}.ml-1{margin-left:var(--space-1)!important}.ml-2{margin-left:var(--space-2)!important}.ml-3{margin-left:var(--space-3)!important}.ml-4{margin-left:var(--space-4)!important}.ml-auto{margin-left:auto!important}.mr-0{margin-right:0!important}.mr-1{margin-right:var(--space-1)!important}.mr-2{margin-right:var(--space-2)!important}.mr-3{margin-right:var(--space-3)!important}.mr-4{margin-right:var(--space-4)!important}.mr-auto{margin-right:auto!important}.mx-auto{margin-left:auto!important;margin-right:auto!important}.my-0{margin-top:0!important;margin-bottom:0!important}.my-2{margin-top:var(--space-2)!important;margin-bottom:var(--space-2)!important}.my-4{margin-top:var(--space-4)!important;margin-bottom:var(--space-4)!important}.my-6{margin-top:var(--space-6)!important;margin-bottom:var(--space-6)!important}.p-0{padding:0!important}.p-1{padding:var(--space-1)!important}.p-2{padding:var(--space-2)!important}.p-3{padding:var(--space-3)!important}.p-4{padding:var(--space-4)!important}.p-5{padding:var(--space-5)!important}.p-6{padding:var(--space-6)!important}.pt-0{padding-top:0!important}.pt-2{padding-top:var(--space-2)!important}.pt-4{padding-top:var(--space-4)!important}.pt-6{padding-top:var(--space-6)!important}.pb-0{padding-bottom:0!important}.pb-2{padding-bottom:var(--space-2)!important}.pb-4{padding-bottom:var(--space-4)!important}.pb-6{padding-bottom:var(--space-6)!important}.px-0{padding-left:0!important;padding-right:0!important}.px-2{padding-left:var(--space-2)!important;padding-right:var(--space-2)!important}.px-4{padding-left:var(--space-4)!important;padding-right:var(--space-4)!important}.px-6{padding-left:var(--space-6)!important;padding-right:var(--space-6)!important}.py-0{padding-top:0!important;padding-bottom:0!important}.py-2{padding-top:var(--space-2)!important;padding-bottom:var(--space-2)!important}.py-4{padding-top:var(--space-4)!important;padding-bottom:var(--space-4)!important}.py-6{padding-top:var(--space-6)!important;padding-bottom:var(--space-6)!important}.w-full{width:100%!important}.w-auto{width:auto!important}.w-fit{width:fit-content!important}.min-w-0{min-width:0!important}.max-w-sm{max-width:384px!important}.max-w-md{max-width:448px!important}.max-w-lg{max-width:512px!important}.max-w-xl{max-width:576px!important}.max-w-2xl{max-width:672px!important}.max-w-full{max-width:100%!important}.h-full{height:100%!important}.h-auto{height:auto!important}.h-screen{height:100vh!important}.min-h-0{min-height:0!important}.min-h-screen{min-height:100vh!important}.hidden{display:none!important}.block{display:block!important}.inline{display:inline!important}.inline-block{display:inline-block!important}.visible{visibility:visible!important}.invisible{visibility:hidden!important}.opacity-0{opacity:0!important}.opacity-50{opacity:.5!important}.opacity-100{opacity:1!important}@media (max-width: 768px){.hide-mobile{display:none!important}}@media (min-width: 769px){.hide-desktop{display:none!important}}.relative{position:relative!important}.absolute{position:absolute!important}.fixed{position:fixed!important}.sticky{position:sticky!important}.inset-0{top:0!important;right:0!important;bottom:0!important;left:0!important}.top-0{top:0!important}.right-0{right:0!important}.bottom-0{bottom:0!important}.left-0{left:0!important}.border{border:1px solid var(--border-primary)!important}.border-0{border:none!important}.border-t{border-top:1px solid var(--border-primary)!important}.border-b{border-bottom:1px solid var(--border-primary)!important}.border-l{border-left:1px solid var(--border-primary)!important}.border-r{border-right:1px solid var(--border-primary)!important}.rounded-none{border-radius:0!important}.rounded-sm{border-radius:var(--radius-sm)!important}.rounded{border-radius:var(--radius-md)!important}.rounded-lg{border-radius:var(--radius-lg)!important}.rounded-xl{border-radius:var(--radius-xl)!important}.rounded-2xl{border-radius:var(--radius-2xl)!important}.rounded-full{border-radius:var(--radius-full)!important}.bg-base{background-color:var(--bg-base)!important}.bg-surface{background-color:var(--bg-surface)!important}.bg-hover{background-color:var(--bg-hover)!important}.bg-brand{background-color:var(--color-brand)!important}.bg-success{background-color:var(--color-success)!important}.bg-warning{background-color:var(--color-warning)!important}.bg-danger{background-color:var(--color-danger)!important}.bg-transparent{background-color:transparent!important}.shadow-none{box-shadow:none!important}.shadow-xs{box-shadow:var(--shadow-xs)!important}.shadow-sm{box-shadow:var(--shadow-sm)!important}.shadow{box-shadow:var(--shadow-md)!important}.shadow-lg{box-shadow:var(--shadow-lg)!important}.shadow-xl{box-shadow:var(--shadow-xl)!important}.overflow-hidden{overflow:hidden!important}.overflow-auto{overflow:auto!important}.overflow-scroll{overflow:scroll!important}.overflow-visible{overflow:visible!important}.overflow-x-auto{overflow-x:auto!important}.overflow-y-auto{overflow-y:auto!important}.cursor-pointer{cursor:pointer!important}.cursor-default{cursor:default!important}.cursor-not-allowed{cursor:not-allowed!important}.select-none{-webkit-user-select:none!important;user-select:none!important}.select-text{-webkit-user-select:text!important;user-select:text!important}.select-all{-webkit-user-select:all!important;user-select:all!important}.z-0{z-index:0!important}.z-10{z-index:10!important}.z-20{z-index:20!important}.z-30{z-index:30!important}.z-50{z-index:50!important}.z-auto{z-index:auto!important}.divider{height:1px;background-color:var(--divider);border:none;margin:var(--space-4) 0}.divider-vertical{width:1px;height:100%;background-color:var(--divider)}.fade-in{animation:fadeIn var(--duration-normal) var(--ease-out)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.slide-up{animation:slideUp var(--duration-normal) var(--ease-out)}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.slide-down{animation:slideDown var(--duration-normal) var(--ease-out)}@keyframes slideDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}.slide-right{animation:slideRight var(--duration-normal) var(--ease-out)}@keyframes slideRight{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}.slide-left{animation:slideLeft var(--duration-normal) var(--ease-out)}@keyframes slideLeft{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.scale-in{animation:scaleIn var(--duration-fast) var(--ease-bounce)}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.pop-in{animation:popIn var(--duration-normal) var(--ease-elastic)}@keyframes popIn{0%{opacity:0;transform:scale(.8)}70%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.pulse{animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.bounce{animation:bounce 1s infinite}@keyframes bounce{0%,to{transform:translateY(0);animation-timing-function:cubic-bezier(.8,0,1,1)}50%{transform:translateY(-25%);animation-timing-function:cubic-bezier(0,0,.2,1)}}.breathe{animation:breathe 3s ease-in-out infinite}@keyframes breathe{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.shake{animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}.blink{animation:blink 1s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hover-lift{transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.hover-lift:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.hover-scale{transition:transform var(--duration-fast) var(--ease-out)}.hover-scale:hover{transform:scale(1.02)}.hover-glow{transition:box-shadow var(--duration-fast) var(--ease-out)}.hover-glow:hover{box-shadow:var(--glow-brand)}.hover-bright{transition:filter var(--duration-fast) var(--ease-out)}.hover-bright:hover{filter:brightness(1.1)}.hover-dim{transition:opacity var(--duration-fast) var(--ease-out)}.hover-dim:hover{opacity:.8}.skeleton{background:linear-gradient(90deg,var(--bg-surface-secondary) 0%,var(--bg-surface-tertiary) 50%,var(--bg-surface-secondary) 100%);background-size:200% 100%;animation:skeleton 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}@keyframes skeleton{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:14px;margin-bottom:var(--space-2)}.skeleton-text:last-child{width:60%;margin-bottom:0}.skeleton-title{height:24px;width:50%;margin-bottom:var(--space-4)}.skeleton-avatar{width:40px;height:40px;border-radius:50%}.skeleton-button{height:36px;width:100px}.skeleton-card{height:120px}.progress-indeterminate{position:relative;overflow:hidden}.progress-indeterminate:after{content:"";position:absolute;top:0;left:0;height:100%;width:50%;background:linear-gradient(90deg,transparent,var(--color-brand-alpha-20),transparent);animation:indeterminate 1.5s ease-in-out infinite}@keyframes indeterminate{0%{transform:translate(-100%)}to{transform:translate(200%)}}.delay-0{animation-delay:0ms}.delay-75{animation-delay:75ms}.delay-100{animation-delay:.1s}.delay-150{animation-delay:.15s}.delay-200{animation-delay:.2s}.delay-300{animation-delay:.3s}.delay-400{animation-delay:.4s}.delay-500{animation-delay:.5s}.duration-fast{animation-duration:var(--duration-fast)}.duration-normal{animation-duration:var(--duration-normal)}.duration-slow{animation-duration:var(--duration-slow)}.duration-slower{animation-duration:var(--duration-slower)}.transition-none{transition:none!important}.transition-all{transition:all var(--duration-normal) var(--ease-default)}.transition-colors{transition:color var(--duration-fast) var(--ease-default),background-color var(--duration-fast) var(--ease-default),border-color var(--duration-fast) var(--ease-default)}.transition-opacity{transition:opacity var(--duration-normal) var(--ease-default)}.transition-transform{transition:transform var(--duration-normal) var(--ease-default)}.transition-shadow{transition:box-shadow var(--duration-normal) var(--ease-default)}.translate-y-0{transform:translateY(0)}.translate-y-1{transform:translateY(4px)}.translate-y-2{transform:translateY(8px)}.-translate-y-1{transform:translateY(-4px)}.-translate-y-2{transform:translateY(-8px)}.scale-95{transform:scale(.95)}.scale-100{transform:scale(1)}.scale-105{transform:scale(1.05)}.scale-110{transform:scale(1.1)}.rotate-0{transform:rotate(0)}.rotate-45{transform:rotate(45deg)}.rotate-90{transform:rotate(90deg)}.rotate-180{transform:rotate(180deg)}.-rotate-90{transform:rotate(-90deg)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}#root{min-height:100vh;display:flex;flex-direction:column}.page-enter{opacity:0;transform:translateY(8px)}.page-enter-active{opacity:1;transform:translateY(0);transition:opacity var(--duration-normal) var(--ease-out),transform var(--duration-normal) var(--ease-out)}.page-exit{opacity:1}.page-exit-active{opacity:0;transition:opacity var(--duration-fast) var(--ease-in)}.badge{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-1) var(--space-2);font-size:var(--text-xs);font-weight:var(--font-medium);line-height:1;border-radius:var(--radius-full);white-space:nowrap}.badge-sm{padding:2px var(--space-1-5);font-size:10px}.badge-lg{padding:var(--space-1-5) var(--space-3);font-size:var(--text-sm)}.badge-default{background-color:var(--bg-surface-secondary);color:var(--text-secondary)}.badge-primary{background-color:var(--color-brand-alpha-10);color:var(--color-brand)}.badge-success{background-color:var(--color-success-alpha-10);color:var(--color-success)}.badge-warning{background-color:var(--color-warning-alpha-10);color:var(--color-warning)}.badge-danger{background-color:var(--color-danger-alpha-10);color:var(--color-danger)}.badge-info{background-color:var(--color-info-alpha-10);color:var(--color-info)}.badge-solid-primary{background-color:var(--color-brand);color:#fff}.badge-solid-success{background-color:var(--color-success);color:#fff}.badge-solid-warning{background-color:var(--color-warning);color:#fff}.badge-solid-danger{background-color:var(--color-danger);color:#fff}.avatar{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background-color:var(--color-brand);color:#fff;font-size:var(--text-sm);font-weight:var(--font-semibold);flex-shrink:0;overflow:hidden}.avatar img{width:100%;height:100%;object-fit:cover}.avatar-xs{width:24px;height:24px;font-size:10px}.avatar-sm{width:32px;height:32px;font-size:var(--text-xs)}.avatar-lg{width:48px;height:48px;font-size:var(--text-base)}.avatar-xl{width:64px;height:64px;font-size:var(--text-xl)}.avatar-2xl{width:96px;height:96px;font-size:var(--text-3xl)}.avatar-square{border-radius:var(--radius-md)}.avatar-group{display:flex;flex-direction:row-reverse}.avatar-group .avatar{margin-left:-8px;border:2px solid var(--bg-surface)}.avatar-group .avatar:last-child{margin-left:0}.tooltip{position:relative}.tooltip:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-4px);padding:var(--space-1-5) var(--space-2-5);font-size:var(--text-xs);font-weight:var(--font-medium);color:#fff;background-color:var(--text-primary);border-radius:var(--radius-md);white-space:nowrap;opacity:0;visibility:hidden;transition:opacity var(--duration-fast) var(--ease-default),visibility var(--duration-fast) var(--ease-default),transform var(--duration-fast) var(--ease-default);z-index:var(--z-tooltip);pointer-events:none}.tooltip:hover:after{opacity:1;visibility:visible;transform:translate(-50%) translateY(-8px)}.dropdown{position:relative;display:inline-block}.dropdown-menu{position:absolute;top:100%;left:0;min-width:180px;margin-top:var(--space-1);padding:var(--space-1);background-color:var(--bg-surface);border:1px solid var(--border-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:var(--z-dropdown);opacity:0;visibility:hidden;transform:translateY(-4px);transition:opacity var(--duration-fast) var(--ease-default),visibility var(--duration-fast) var(--ease-default),transform var(--duration-fast) var(--ease-default)}.dropdown-menu.is-open{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--text-primary);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--duration-fast) var(--ease-default)}.dropdown-item:hover{background-color:var(--bg-hover)}.dropdown-item-danger{color:var(--color-danger)}.dropdown-item-danger:hover{background-color:var(--color-danger-alpha-10)}.dropdown-divider{height:1px;margin:var(--space-1) 0;background-color:var(--divider)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-6)}.page-header-content{flex:1;min-width:0}.page-title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);margin:0 0 var(--space-1) 0;line-height:var(--leading-tight)}.page-description{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.page-actions{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}@media (max-width: 768px){.page-header{flex-direction:column;align-items:stretch}.page-actions{width:100%}.page-actions .btn{flex:1}}.tabs{display:flex;gap:var(--space-1);border-bottom:1px solid var(--divider);margin-bottom:var(--space-5)}.tab{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary);background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;transition:all var(--duration-fast) var(--ease-default)}.tab:hover{color:var(--text-primary)}.tab.is-active{color:var(--color-brand);border-bottom-color:var(--color-brand)}.tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 var(--space-1-5);margin-left:var(--space-2);font-size:var(--text-xs);font-weight:var(--font-semibold);background-color:var(--bg-surface-secondary);border-radius:var(--radius-full)}.tab.is-active .tab-count{background-color:var(--color-brand-alpha-10);color:var(--color-brand)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-6);text-align:center}.empty-state-icon{font-size:64px;margin-bottom:var(--space-6);opacity:.4}.empty-state-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-2)}.empty-state-description{font-size:var(--text-sm);color:var(--text-secondary);max-width:360px;margin-bottom:var(--space-6)}.error-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);background-color:var(--color-danger-alpha-10);border:1px solid var(--color-danger);border-radius:var(--radius-lg)}.error-icon{font-size:24px;flex-shrink:0}.error-text{flex:1;font-size:var(--text-sm);color:var(--color-danger)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-6)}.loading-spinner{width:32px;height:32px;border:3px solid var(--border-primary);border-top-color:var(--color-brand);border-radius:50%;animation:spin .8s linear infinite}.loading-spinner-sm{width:16px;height:16px;border-width:2px}.loading-spinner-lg{width:48px;height:48px;border-width:4px}.loading-text{margin-top:var(--space-4);font-size:var(--text-sm);color:var(--text-secondary)}.progress{height:8px;background-color:var(--bg-surface-secondary);border-radius:var(--radius-full);overflow:hidden}.progress-bar{height:100%;background-color:var(--color-brand);border-radius:var(--radius-full);transition:width var(--duration-slow) var(--ease-out)}.progress-bar-success{background-color:var(--color-success)}.progress-bar-warning{background-color:var(--color-warning)}.progress-bar-danger{background-color:var(--color-danger)}.progress-sm{height:4px}.progress-lg{height:12px}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot-success{background-color:var(--color-success)}.status-dot-warning{background-color:var(--color-warning)}.status-dot-danger{background-color:var(--color-danger)}.status-dot-info{background-color:var(--color-info)}.status-dot-default{background-color:var(--text-tertiary)}.status-dot-pulse{position:relative}.status-dot-pulse:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:50%;background-color:inherit;opacity:.4;animation:statusPulse 2s ease-in-out infinite}@keyframes statusPulse{0%,to{transform:scale(1);opacity:.4}50%{transform:scale(1.5);opacity:0}}
