*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--background-color);color:var(--text-color);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{margin:0 auto;max-width:1200px;padding:0 1rem}.card{background:var(--card-background);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--card-shadow);padding:1.5rem}.card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.card-title{color:var(--text-color);font-size:1.125rem;font-weight:600}.metric-grid{grid-gap:1.5rem;gap:1.5rem;grid-template-columns:repeat(4,1fr);margin-bottom:2rem}@media (max-width:1200px){.metric-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.metric-grid{grid-template-columns:1fr}}.metric-grid .metric-card:nth-child(5){grid-column:4;grid-row:2}@media (max-width:1200px){.metric-grid .metric-card:nth-child(5){grid-column:2;grid-row:3}}@media (max-width:768px){.metric-grid .metric-card:nth-child(5){grid-column:1;grid-row:5}}.metric-card{border-radius:12px;padding:1.5rem;transition:transform .2s ease,box-shadow .2s ease}.metric-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;transform:translateY(-2px)}.metric-card.clickable{cursor:pointer;transition:all .2s ease}.metric-card.clickable:hover{border-color:#348aa7;box-shadow:0 8px 25px -5px #0000001a,0 4px 10px -2px #0000000d;transform:translateY(-2px)}.metric-value{font-size:2rem;font-weight:700;margin-bottom:.5rem}.metric-label{letter-spacing:.05em;text-transform:uppercase}.metric-change{align-items:center;display:flex;flex-wrap:wrap;font-size:.875rem;gap:.25rem;justify-content:flex-start;margin-top:.5rem}.metric-change.positive{color:#08d3a0}.metric-change.negative{color:#fd745e}.metric-change.neutral{color:#64748b}.status-badge{align-items:center;display:inline-flex;letter-spacing:.05em}.status-badge.on-track{background-color:#08d3a0;color:#fff}.status-badge.at-risk{background-color:#fd745e;color:#fff}.status-badge.overdue{background-color:#d85780;color:#fff}.status-badge.completed{background-color:#348aa7;color:#fff}.project-list{display:flex;flex-direction:column;gap:1rem}.project-item{background:#fff;border-radius:8px;padding:1rem;transition:all .2s ease}.project-item:hover{border-color:#3b82f6;box-shadow:0 1px 3px 0 #0000001a}.project-info{display:flex;flex-direction:column;gap:.25rem}.project-meta{color:#64748b;font-size:.875rem}.project-stats{align-items:center;display:flex;gap:1rem}.chart-container{height:300px;margin-top:1rem}.loading{color:#64748b}.error,.loading{height:200px;justify-content:center}.error{align-items:center;background:#fef2f2}.metric-header{align-items:center;display:flex;gap:.5rem;margin-bottom:.5rem}.metric-description{font-size:.75rem;opacity:.7}.progress-bar{margin-right:.5rem;width:100px}.progress-fill{background:linear-gradient(90deg,#08d3a0,#348aa7)}.progress-text{color:#1e293b;font-size:.875rem;font-weight:500}.project-status{gap:.5rem}.project-status,.project-team{align-items:center;display:flex}.project-team{color:#64748b;font-size:.875rem;gap:.25rem}.timeline{padding-left:2rem;position:relative}.timeline:before{background-color:#e2e8f0;bottom:0;content:"";left:.75rem;position:absolute;top:0;width:2px}.timeline-item{margin-bottom:1.5rem;padding-left:1rem;position:relative}.timeline-item.today{background-color:#fef3c7;border-radius:8px;margin-left:-.5rem;padding:.5rem}.timeline-marker{align-items:center;background-color:#fff;border:2px solid #e2e8f0;border-radius:50%;display:flex;height:1.5rem;justify-content:center;left:-1.5rem;position:absolute;top:.25rem;width:1.5rem}.timeline-content{background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:1rem}.timeline-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.5rem}.timeline-title{color:#1e293b;font-size:1rem;font-weight:600;margin:0}.timeline-meta{align-items:center;color:#64748b;display:flex;font-size:.875rem;gap:.5rem}.today-badge{background-color:#f59e0b;border-radius:9999px;color:#fff;font-size:.75rem;font-weight:500;padding:.125rem .5rem}.timeline-project{color:#348aa7;font-size:.875rem;font-weight:500;margin-bottom:.25rem}.timeline-description{color:#64748b;font-size:.875rem;margin-bottom:.5rem}.timeline-status{align-items:center;display:flex;gap:.5rem}.status-indicator{border-radius:50%;height:8px;width:8px}.status-text{font-size:.75rem;font-weight:500;text-transform:uppercase}.card-actions{align-items:flex-start;display:flex;flex-wrap:wrap;gap:1.5rem}.chart-controls{display:flex;flex-shrink:0;gap:.5rem}.chart-btn{align-items:center;background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;display:flex;font-size:.875rem;gap:.25rem;padding:.5rem 1rem;transition:all .2s ease;white-space:nowrap}.chart-btn:hover{background-color:#f8fafc;border-color:#3b82f6}.chart-btn.active{background-color:#348aa7;border-color:#348aa7;color:#fff}.filter-controls{align-items:center;display:flex;flex:1 1;flex-direction:row;gap:1.5rem;min-width:0}.filter-group{align-items:flex-start;gap:.25rem;min-width:0}.filter-group label{color:#374151;font-size:.875rem;font-weight:600;margin:0}.filter-select{background-color:#fff;border:1px solid #d1d5db;border-radius:4px;color:#374151;cursor:pointer;flex:0 1 auto;max-width:180px;min-width:130px;padding:.375rem .5rem}.filter-select.multi-select{height:auto;max-height:120px;max-width:220px;min-height:60px;min-width:150px;overflow-y:auto}.filter-select.multi-select option{cursor:pointer;padding:.25rem .5rem}.filter-select.multi-select option:hover{background-color:#f3f4f6}.filter-select.multi-select option:checked{background-color:#348aa7;color:#fff}.filter-count{color:#6b7280;font-size:.75rem;font-style:italic;margin-top:.25rem}.modal-overlay{padding:20px}.modal-content{display:flex;flex-direction:column;max-height:80vh;max-width:800px;overflow:hidden}.modal-header{border-bottom:1px solid #e5e7eb;padding:24px 24px 16px}.modal-title{color:#111827;font-size:1.5rem;font-weight:600;margin:0}.modal-close{border-radius:4px;color:#6b7280;padding:4px;transition:all .2s}.modal-close:hover{background-color:#f3f4f6;color:#374151}.modal-body{flex:1 1;overflow-y:auto;padding:24px}.no-projects{color:#6b7280;padding:40px 20px;text-align:center}.projects-list{gap:16px}.project-card{background-color:#fafafa;border:1px solid #e5e7eb;border-radius:8px;padding:16px;transition:all .2s}.project-card:hover{background-color:#f9fafb;border-color:#d1d5db;box-shadow:0 1px 3px 0 #0000001a}.project-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.project-name{color:#111827;flex:1 1;font-size:1.1rem;font-weight:600;margin:0 12px 0 0}.project-link{color:#348aa7;display:inline-block;position:relative;text-decoration:none;transition:all .2s ease}.project-link:hover{color:#2563eb;text-decoration:underline;transform:translateY(-1px)}.project-link:active{transform:translateY(0)}.user-name .project-link{color:inherit;text-decoration:none;transition:color .2s ease}.user-name .project-link:hover{color:#3b82f6;text-decoration:underline}.project-status{background-color:#f3f4f6;border-radius:4px;font-size:.875rem;font-weight:500;padding:4px 8px;white-space:nowrap}.project-details{display:flex;flex-direction:column;gap:8px}.detail-row{align-items:center;color:#6b7280;display:flex;font-size:.875rem;gap:8px}.detail-row svg{color:#9ca3af;flex-shrink:0}.health-status{font-weight:500}.login-screen{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.login-container{background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:400px;padding:48px;text-align:center;width:100%}.login-header{margin-bottom:32px}.login-icon{color:#348aa7;margin-bottom:16px}.login-header h1{color:#111827;font-size:1.875rem;font-weight:700;margin-bottom:8px}.login-header p{color:#6b7280;font-size:.875rem}.login-form{display:flex;flex-direction:column;gap:20px}.password-input-group{align-items:center;display:flex;position:relative}.password-input{border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;padding:12px 48px 12px 16px;transition:all .2s;width:100%}.password-input:focus{border-color:#348aa7;box-shadow:0 0 0 3px #348aa71a;outline:none}.password-toggle{background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;padding:4px;position:absolute;right:12px;transition:color .2s}.password-toggle:hover{color:#374151}.login-button{background:linear-gradient(135deg,#348aa7,#5b9bd5);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:all .2s}.login-button:hover:not(:disabled){box-shadow:0 4px 12px #348aa74d;transform:translateY(-1px)}.login-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.login-error{background-color:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#dc2626;font-size:.875rem;padding:12px;text-align:center}.login-footer{border-top:1px solid #e5e7eb;margin-top:24px;padding-top:16px}.login-footer p{color:#6b7280;font-size:.75rem;margin:0}.text-green-600{color:#059669}.text-orange-600{color:#ea580c}.text-blue-600{color:#2563eb}.text-gray-600{color:#4b5563}.text-yellow-600{color:#ca8a04}.text-red-600{color:#dc2626}.multi-select-container{max-width:280px;min-width:200px;position:relative}.multi-select-button{align-items:center;background-color:#fff;border:1px solid #d1d5db;border-radius:4px;color:#374151;cursor:pointer;display:flex;font-size:.875rem;justify-content:space-between;padding:.5rem .75rem;transition:all .2s ease;width:100%}.multi-select-button:hover{border-color:#9ca3af}.multi-select-button:focus{border-color:#348aa7;box-shadow:0 0 0 3px #348aa71a;outline:none}.multi-select-text{flex:1 1;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}.chevron{color:#6b7280;transition:transform .2s ease}.chevron.open{transform:rotate(180deg)}.multi-select-dropdown{background:#fff;border:1px solid #d1d5db;border-radius:4px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;left:0;max-height:300px;overflow:hidden;position:absolute;right:0;top:100%;z-index:1000}.multi-select-header{align-items:center;background-color:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:.5rem .75rem}.select-all-button{background:none;border:none;border-radius:3px;color:#348aa7;cursor:pointer;font-size:.75rem;font-weight:500;padding:.25rem .5rem;transition:background-color .2s ease}.select-all-button:hover{background-color:#e0f2fe}.clear-all-button{align-items:center;background:none;border:none;border-radius:3px;color:#6b7280;cursor:pointer;display:flex;padding:.25rem;transition:background-color .2s ease}.clear-all-button:hover{background-color:#f3f4f6;color:#ef4444}.multi-select-options{max-height:200px;overflow-y:auto}.multi-select-option{align-items:center;cursor:pointer;display:flex;font-size:.875rem;padding:.5rem .75rem;transition:background-color .2s ease}.multi-select-option:hover{background-color:#f3f4f6}.multi-select-option input[type=checkbox]{cursor:pointer;margin-right:.5rem}.option-text{cursor:pointer;flex:1 1}.time-filter{background-color:#fff;border:1px solid #d1d5db;border-radius:4px;color:#374151;cursor:pointer;flex:0 1 auto;font-size:.875rem;max-width:160px;min-width:120px;padding:.375rem .5rem}.time-filter:focus{border-color:#348aa7;box-shadow:0 0 0 3px #348aa71a;outline:none}.date-filter-controls{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;display:flex;flex-direction:column;gap:.75rem;padding:.75rem}@media (max-width:768px){.filter-controls{align-items:stretch;flex-direction:column;gap:1rem}.filter-group{width:100%}.filter-select,.time-filter{min-width:100%}}.date-filter-group{align-items:center;display:flex;gap:.5rem}.date-filter-select{background-color:#fff;border:1px solid #d1d5db;border-radius:4px;color:#374151;cursor:pointer;flex:1 1;font-size:.875rem;padding:.5rem}.date-filter-select:focus{border-color:#348aa7;box-shadow:0 0 0 3px #348aa71a;outline:none}.custom-date-inputs{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.date-input{background-color:#fff;border:1px solid #d1d5db;border-radius:4px;color:#374151;flex:1 1;font-size:.875rem;min-width:120px;padding:.5rem}.date-input:focus{border-color:#348aa7;box-shadow:0 0 0 3px #348aa71a;outline:none}.date-separator{color:#64748b;font-size:.875rem;font-weight:500}.date-filter-apply-btn{background-color:#348aa7;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease;white-space:nowrap}.date-filter-apply-btn:hover:not(:disabled){background-color:#274768}.date-filter-apply-btn:disabled{background-color:#e2e8f0;color:#64748b;cursor:not-allowed}.utilization-summary{grid-gap:1rem;background-color:#eff1f4;border-radius:8px;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:1.5rem;padding:1rem}.summary-item{align-items:center;display:flex;flex-direction:column;text-align:center}.summary-label{color:#64748b;font-size:.875rem;margin-bottom:.25rem}.summary-value{color:#1e293b;font-size:1.5rem;font-weight:700}.utilization-table{margin-top:1.5rem}.utilization-table h4{color:#1e293b;margin-bottom:1rem}.table-container{overflow-x:auto}table{border-collapse:collapse;font-size:.875rem;width:100%}td,th{border-bottom:1px solid #e2e8f0;padding:.75rem;text-align:left}th{background-color:#f8fafc;color:#374151;font-weight:600}.sortable-header:hover{background-color:#e2e8f0}.sortable-header svg{margin-left:.25rem;opacity:.6}.sortable-header:hover svg{opacity:1}.utilization-status{border-radius:9999px;font-size:.75rem;font-weight:500;padding:.25rem .75rem;text-transform:uppercase}.utilization-status.good{background-color:#08d3a0;color:#fff}.utilization-status.warning{background-color:#fd745e;color:#fff}.custom-tooltip{background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a;padding:.75rem}.tooltip-label{color:#1e293b;font-weight:600;margin-bottom:.25rem}.tooltip-value{color:#348aa7}.tooltip-role,.tooltip-value{font-weight:500;margin-bottom:.25rem}.tooltip-role{color:#fd745e;font-size:.875rem}.tooltip-hours{color:#08d3a0;font-size:.875rem;font-weight:500;margin-bottom:.25rem}.tooltip-projects{color:#64748b;font-size:.875rem}.btn-secondary{border:1px solid #e2e8f0;padding:.5rem 1rem}.btn-secondary:hover{background-color:#eff1f4;border-color:#348aa7}.retry-button{background-color:#348aa7;border:none;font-weight:500;margin-top:1rem;padding:.75rem 1.5rem}.retry-button:hover{background-color:#274768}.status-filter,.time-filter{background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#374151;font-size:.875rem;padding:.5rem}.main-nav{margin-right:1rem}.nav-btn{background-color:initial;border:1px solid #0000;color:#64748b;font-weight:500}.nav-btn:hover{background-color:#348aa71a;color:#348aa7}.nav-btn.active{background-color:#348aa7;border-color:#348aa7}.actions-container{display:flex;flex-direction:column;gap:1.5rem}.actions-tabs{border-bottom:1px solid #e2e8f0;display:flex;gap:.5rem;padding-bottom:1rem}.action-tab{align-items:center;background-color:initial;border:1px solid #0000;border-radius:6px;color:#64748b;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1rem;transition:all .2s ease}.action-tab:hover{background-color:rgba(var(--tab-color),.1);color:var(--tab-color)}.action-tab.active{background-color:var(--tab-color);border-color:var(--tab-color);color:#fff}.action-content{padding:1rem 0}.action-form{gap:1.5rem;max-width:600px}.action-form,.form-group{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.form-group label{color:#374151;font-size:.875rem;font-weight:600}.form-group input,.form-group select,.form-group textarea{background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#374151;font-size:.875rem;padding:.75rem;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#348aa7;box-shadow:0 0 0 3px #348aa71a;outline:none}.form-group textarea{min-height:80px;resize:vertical}.submit-btn{align-self:flex-start;background-color:#348aa7;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s ease}.submit-btn:hover:not(:disabled){background-color:#274768}.submit-btn:disabled{cursor:not-allowed;opacity:.6}.settings-container{padding:2rem 1rem}.settings-header h2{font-size:1.5rem;font-weight:600}.settings-layout{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr}.section-header h3{font-size:1.125rem}.environment-info{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.current-environment{align-items:center;color:#374151;display:flex;font-size:.875rem;gap:.5rem}.current-environment strong{color:#1e293b;font-weight:600}.api-keys-list{display:flex;flex-direction:column;gap:1rem}.api-key-item{background-color:#f8fafc;justify-content:space-between;transition:all .2s ease}.api-key-item.active{background-color:#eff6ff;border-color:#3b82f6}.api-key-info{margin-right:1rem}.api-key-header{align-items:center;display:flex;gap:.5rem;margin-bottom:.5rem}.active-badge{background-color:#10b981;border-radius:9999px;color:#fff;font-size:.75rem;font-weight:500;padding:.125rem .5rem;text-transform:uppercase}.api-key-input{border:1px solid #d1d5db}.api-key-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.api-key-actions{gap:.5rem}.activate-btn,.api-key-actions{align-items:center;display:flex}.activate-btn{background-color:#10b981;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;gap:.25rem;padding:.5rem .75rem;transition:all .2s ease}.activate-btn:hover{background-color:#059669}.delete-btn{background-color:#ef4444;height:32px;width:32px}.delete-btn:hover{background-color:#dc2626}.add-api-key{background-color:#f8fafc;border:2px dashed #d1d5db;border-radius:8px;display:flex;flex-direction:column;gap:1rem;padding:1rem}.add-api-key-inputs{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.api-key-name-input{background-color:#fff;border:1px solid #d1d5db;padding:.5rem}.api-key-name-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.add-btn{background-color:#3b82f6;justify-content:center}.add-btn:hover:not(:disabled){background-color:#2563eb}.add-btn:disabled{background-color:#9ca3af}.theme-colors-grid{grid-template-columns:1fr 1fr}.color-picker{width:40px}.color-input{background-color:#fff;border:1px solid #d1d5db}.color-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.theme-preview{margin-top:1.5rem}.theme-preview h4{color:#374151;margin-bottom:1rem}.preview-logo{border-radius:6px;height:32px;width:32px}.preview-title{font-size:1.125rem;font-weight:600}.preview-subtitle{opacity:.8}.capacity-item{display:flex;flex-direction:column;gap:.5rem}.capacity-item label{color:#374151;font-size:.875rem;font-weight:500}.capacity-input{background-color:#fff;border:1px solid #d1d5db}.capacity-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.capacity-unit{font-weight:500}.capacity-description{font-size:.75rem;line-height:1.4}.baseline-settings{gap:1.5rem}.baseline-item,.baseline-settings{display:flex;flex-direction:column}.baseline-item{gap:.5rem}.baseline-item label{color:#374151;font-weight:500}.baseline-input{border:1px solid #d1d5db}.baseline-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}@media (max-width:1024px){.settings-layout{grid-template-columns:1fr}}@media (max-width:768px){.settings-container{padding:1rem}.add-api-key-inputs,.theme-colors-grid{grid-template-columns:1fr}.api-key-item{align-items:stretch;flex-direction:column;gap:1rem}.api-key-info{margin-right:0}.api-key-actions{justify-content:flex-end}}.clickable-row{cursor:pointer;transition:background-color .2s ease}.clickable-row:hover{background-color:#f8fafc}.project-name-cell{font-weight:600}.progress-cell{align-items:center;display:flex;gap:.5rem;min-width:120px}.progress-bar{background-color:#e2e8f0;border-radius:4px;flex:1 1;height:8px;min-width:60px;overflow:hidden}.progress-fill{background-color:#348aa7;border-radius:4px;height:100%;transition:width .3s ease}.progress-text{color:#374151;font-size:.75rem;font-weight:600;min-width:35px;text-align:right}.empty-state{align-items:center;color:#64748b;display:flex;flex-direction:column;justify-content:center;padding:3rem 1rem}.empty-state svg{margin-bottom:1rem;opacity:.5}.empty-state p{margin:.5rem 0}.empty-state .text-gray-500{color:#6b7280}.risk-analysis-section{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fecaca;border-radius:12px;box-shadow:0 2px 8px #0000000d;margin:2rem 0;padding:1.5rem}.risk-analysis-section h5{align-items:center;color:#dc2626;display:flex;font-size:1.1rem;font-weight:600;gap:.5rem;margin:0 0 1.5rem}.task-overview-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr;margin-bottom:2rem}.task-overview-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:1rem}.task-overview-card h6{color:#374151;font-size:1rem;font-weight:600;margin:0 0 1rem}.task-stats{display:flex;justify-content:space-between;margin-bottom:1rem}.task-stat{align-items:center;display:flex;flex-direction:column;text-align:center}.stat-label{color:#6b7280;margin-bottom:.25rem}.stat-value{color:#1f2937;font-size:1.25rem}.stat-value.completed{color:#10b981}.stat-value.in-progress{color:#3b82f6}.mini-progress-chart{margin-top:1rem}.progress-bar-mini{background-color:#f3f4f6;border-radius:4px;height:8px;margin-bottom:.5rem;overflow:hidden;width:100%}.progress-fill-mini{float:left;height:100%;transition:width .3s ease}.progress-fill-mini.completed{background:linear-gradient(90deg,#10b981,#34d399)}.progress-fill-mini.in-progress{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.progress-labels{color:#6b7280;display:flex;font-size:.75rem;justify-content:space-between}.risk-indicators{margin-top:1.5rem}.risk-indicators h6{color:#374151;font-size:1rem;font-weight:600;margin:0 0 1rem}.risk-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.risk-item{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;gap:.75rem;padding:1rem;transition:transform .2s ease,box-shadow .2s ease}.risk-item:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.risk-icon{align-items:center;background:#0000000d;border-radius:8px;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.risk-info{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.risk-count{font-size:1.5rem;font-weight:700}.risk-label{font-size:.875rem;font-weight:500;opacity:.8}.loading-tasks{flex-direction:column;gap:1rem;padding:2rem}.loading-spinner{border:3px solid #e5e7eb;height:32px;width:32px}.no-tasks-message{align-items:center;color:#6b7280;display:flex;font-style:italic;justify-content:center;padding:2rem}.project-progress-section{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border:1px solid #e2e8f0;border-radius:12px;margin:2rem 0;padding:1.5rem}.project-progress-section h5{color:#1e293b;font-size:1.1rem;margin:0 0 1.5rem}.progress-chart{gap:2rem}.progress-circle-container{flex-shrink:0}.progress-circle{height:120px;width:120px}.progress-inner{background:#fff;border-radius:50%;box-shadow:0 2px 8px #0000001a;height:80px;width:80px}.progress-percentage{color:#1e293b;font-size:1.5rem;margin:0}.progress-label{color:#64748b;margin:0}.progress-details{gap:1rem}.progress-stat{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;color:#374151;font-weight:500;padding:.75rem}.hours-financial-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr;margin:2rem 0}.hours-breakdown-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:1.5rem}.hours-breakdown-section h5{align-items:center;color:#1e293b;display:flex;font-size:1.1rem;font-weight:600;gap:.5rem;margin:0 0 1.5rem}.hours-bars{gap:1rem}.hour-bar-item,.hours-bars{display:flex;flex-direction:column}.hour-bar-item{gap:.5rem}.hour-bar-label{align-items:center;color:#374151;display:flex;font-size:.875rem;font-weight:500;justify-content:space-between}.hour-value{color:#1e293b;font-weight:700}.hour-bar-container{background-color:#f1f5f9;border-radius:6px;height:12px;overflow:hidden;width:100%}.hour-bar{border-radius:6px;height:100%;transition:width .6s ease}.hour-bar.budgeted{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.hour-bar.tracked{background:linear-gradient(90deg,#10b981,#34d399)}.hour-bar.billable{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.hour-bar.remaining{background:linear-gradient(90deg,#ef4444,#f87171)}.financial-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:1.5rem}.financial-section h5{align-items:center;color:#1e293b;display:flex;font-size:1.1rem;font-weight:600;gap:.5rem;margin:0 0 1.5rem}.financial-cards{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.financial-card{align-items:center;border:1px solid #e2e8f0;border-radius:8px;display:flex;gap:1rem;padding:1rem;transition:transform .2s ease,box-shadow .2s ease}.financial-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.financial-card.budget{background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.financial-card.actual{background:linear-gradient(135deg,#d1fae5,#a7f3d0)}.financial-card.estimated{background:linear-gradient(135deg,#fef3c7,#fde68a)}.financial-icon{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;flex-shrink:0;padding:.75rem}.financial-card.budget .financial-icon{color:#3b82f6}.financial-card.actual .financial-icon{color:#10b981}.financial-card.estimated .financial-icon{color:#f59e0b}.financial-info{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.financial-label{color:#64748b;font-size:.875rem;font-weight:500}.financial-value{color:#1e293b;font-size:1.25rem;font-weight:700}.project-info-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:2rem 0}.info-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:1.5rem;transition:transform .2s ease,box-shadow .2s ease}.info-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.info-header{align-items:center;border-bottom:1px solid #e2e8f0;color:#1e293b;display:flex;font-size:1rem;font-weight:600;gap:.5rem;margin:0 0 1rem;padding-bottom:.5rem}.info-content{display:flex;flex-direction:column;gap:.75rem}.info-row,.info-row-icon{align-items:center;display:flex;gap:1rem;justify-content:space-between}.info-label{color:#64748b;font-size:.875rem;font-weight:500}.info-value{color:#1e293b;font-size:.875rem;font-weight:600;text-align:right}.info-icon-value{align-items:center;display:flex;gap:.5rem}.status-icon-yes{color:#10b981}.status-icon-no{color:#ef4444;opacity:.5}@media (max-width:768px){.progress-chart{flex-direction:column;gap:1rem}.hours-financial-grid,.task-overview-grid{gap:1rem;grid-template-columns:1fr}.financial-cards,.project-info-grid,.risk-grid{grid-template-columns:1fr}}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-height:90vh;max-width:900px;overflow-y:auto;width:100%}.modal-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;padding:1.5rem}.modal-header,.modal-title{align-items:center;display:flex}.modal-title{gap:.75rem}.modal-title h3{color:#1e293b;font-size:1.125rem;font-weight:600;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s ease;width:32px}.modal-close:hover{background-color:#f1f5f9;color:#1e293b}.modal-close-upper-right{align-items:center;background-color:#ef4444;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:32px;justify-content:center;position:absolute;right:1rem;top:1rem;transition:all .2s ease;width:32px;z-index:10}.modal-close-upper-right:hover{background-color:#dc2626;transform:scale(1.1)}.modal-body{padding:1.5rem}.modal-footer{border-top:1px solid #e2e8f0;gap:1rem;justify-content:flex-end}.modal-footer,.user-profile-section{align-items:center;display:flex;padding:1.5rem}.user-profile-section{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 4px #0000000d;gap:2rem;margin-bottom:2rem}.user-profile{align-items:center;display:flex;flex:1 1;gap:1rem;min-width:0}.project-progress-section{flex:0 0 auto;width:280px}.project-progress-section h5{align-items:center;color:#374151;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;margin:0 0 1rem}.progress-chart{align-items:center;display:flex;gap:1rem}.progress-circle-container{flex:0 0 auto}.progress-circle{border-radius:50%;height:80px;position:relative;width:80px}.progress-circle,.progress-inner{align-items:center;display:flex;justify-content:center}.progress-inner{flex-direction:column;text-align:center}.progress-percentage{color:#1f2937;font-size:1.25rem;font-weight:700;line-height:1}.progress-label{color:#6b7280;font-size:.75rem;margin-top:.125rem}.progress-details{display:flex;flex:1 1;flex-direction:column;gap:.5rem}.progress-stat{align-items:center;color:#6b7280;display:flex;font-size:.875rem;gap:.5rem}@media (max-width:768px){.user-profile-section{align-items:flex-start;flex-direction:column;gap:1.5rem}.project-progress-section{max-width:none;width:100%}.progress-chart{justify-content:flex-start}}.quality-audit-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.75rem;margin-top:2rem;padding:1.5rem}.quality-audit-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.quality-audit-section h5{align-items:center;color:#1e293b;display:flex;font-size:1rem;font-weight:600;gap:.5rem;margin:0}.save-quality-button{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:.375rem;box-shadow:0 2px 4px #0000001a;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;padding:.5rem 1rem;transition:all .2s ease}.save-quality-button:hover:not(:disabled){box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.save-quality-button:disabled{background:#9ca3af;cursor:not-allowed;opacity:.4;transform:none}.quality-audit-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.quality-field{display:flex;flex-direction:column;gap:.5rem}.quality-label{color:#374151;font-size:.875rem;font-weight:600;margin:0}.quality-input{align-items:center;display:flex;gap:.5rem}.quality-input input[type=checkbox]{accent-color:#3b82f6;height:1rem;width:1rem}.quality-input input[type=date],.quality-input input[type=text]{background:#fff;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;padding:.5rem;transition:border-color .2s ease;width:100%}.quality-input input[type=date]:focus,.quality-input input[type=text]:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.quality-select{background:#fff;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;padding:.5rem;transition:border-color .2s ease;width:100%}.quality-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.quality-textarea{background:#fff;border:1px solid #d1d5db;border-radius:.375rem;font-family:inherit;font-size:.875rem;min-height:60px;padding:.5rem;resize:vertical;transition:border-color .2s ease;width:100%}.quality-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.placeholder-suggestions{background:#fef3c7;border:1px solid #f59e0b;border-radius:.5rem;font-size:.875rem;margin-top:.75rem;padding:.75rem}.placeholder-label{color:#92400e;display:block;font-weight:600;margin-bottom:.5rem}.placeholder-list{display:flex;flex-direction:column;gap:.25rem}.placeholder-item{align-items:center;display:flex;gap:.5rem}.placeholder-count{background:#f59e0b;border-radius:.25rem;color:#fff;font-size:.75rem;font-weight:600;min-width:1.5rem;padding:.125rem .375rem;text-align:center}.placeholder-text{color:#92400e;font-size:.875rem}@media (max-width:768px){.quality-audit-grid{gap:1rem;grid-template-columns:1fr}.quality-audit-section{padding:1rem}.placeholder-suggestions{margin-top:.5rem;padding:.5rem}}.oneai-risk-predictions-section{background:linear-gradient(135deg,#667eea,#764ba2);border:1px solid #4c51bf;border-radius:.75rem;color:#fff;margin-top:2rem;padding:1.5rem}.oneai-risk-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.oneai-risk-header h5{align-items:center;color:#fff;display:flex;font-size:1rem;font-weight:600;gap:.5rem;margin:0}.ai-badge{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:1px solid #ffffff4d;border-radius:1rem;color:#fff;font-size:.75rem;font-weight:600;padding:.25rem .75rem}.risk-predictions-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.prediction-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:.75rem;padding:1.25rem;transition:transform .2s ease,box-shadow .2s ease}.prediction-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-2px)}.prediction-header{align-items:center;display:flex;gap:.75rem;margin-bottom:1rem}.prediction-header h6{color:#fff;font-size:1rem;font-weight:600;margin:0}.prediction-content{display:flex;flex-direction:column;gap:1rem}.risk-indicator{align-items:center;border-radius:.5rem;display:inline-flex;font-size:.875rem;font-weight:600;letter-spacing:.05em;padding:.5rem 1rem;text-transform:uppercase}.risk-indicator.high{background:#ef444433;border:1px solid #ef444466;color:#fecaca}.risk-indicator.medium{background:#f59e0b33;border:1px solid #f59e0b66;color:#fed7aa}.risk-indicator.low{background:#10b98133;border:1px solid #10b98166;color:#a7f3d0}.risk-factors-list{display:flex;flex-direction:column;gap:.5rem}.risk-factor{align-items:flex-start;display:flex;font-size:.875rem;gap:.5rem;line-height:1.4}.risk-factor svg{flex-shrink:0;margin-top:.125rem}.risk-factor.positive{color:#a7f3d0}.risk-factor:not(.positive){color:#fecaca}@media (max-width:768px){.risk-predictions-grid{gap:1rem;grid-template-columns:1fr}.oneai-risk-predictions-section{padding:1rem}.oneai-risk-header{align-items:flex-start;flex-direction:column;gap:.75rem}}.user-avatar{align-items:center;background-color:#e2e8f0;border:3px solid #348aa7;border-radius:50%;box-shadow:0 4px 8px #348aa733;color:#64748b;display:flex;height:64px;justify-content:center;position:relative;width:64px}.user-profile-image{border-radius:50%;height:100%;object-fit:cover;width:100%}.user-info{flex:1 1;min-width:0}.user-name{word-wrap:break-word;font-size:1.25rem;font-weight:600;line-height:1.3;margin:0 0 .25rem;overflow-wrap:break-word}.user-role{color:#64748b;font-size:.875rem;font-weight:500;margin:0}.user-billable-projects{margin-top:2rem}.user-billable-projects h5{align-items:center;color:#1e293b;display:flex;font-size:1rem;font-weight:600;gap:.5rem;margin:0 0 1rem}.projects-table-container{border:1px solid #e2e8f0;border-radius:8px;max-height:300px;overflow-y:auto}.projects-table{background-color:#fff;border-collapse:collapse;width:100%}.projects-table thead{background-color:#f8fafc;position:-webkit-sticky;position:sticky;top:0;z-index:1}.projects-table th{border-bottom:1px solid #e2e8f0;color:#374151;font-size:.875rem;font-weight:600;padding:.75rem;text-align:left}.projects-table td{border-bottom:1px solid #f1f5f9;font-size:.875rem;padding:.75rem}.projects-table tbody tr:hover{background-color:#f8fafc}.project-name-cell{color:#1e293b;font-weight:500;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.billable-hours-cell{color:#059669;font-weight:600;text-align:right}.no-projects-message{background-color:#f8fafc;border-radius:8px;color:#64748b;font-style:italic;padding:2rem;text-align:center}.user-details-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:2rem}.detail-item{display:flex;flex-direction:column;gap:.5rem}.detail-label{align-items:center;color:#374151;display:flex;font-size:.875rem;font-weight:500;gap:.5rem}.detail-value{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;color:#1e293b;font-size:.875rem;padding:.5rem}.user-stats{margin-bottom:2rem}.user-stats h5{color:#1e293b;font-size:1rem;font-weight:600;margin:0 0 1rem}.stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(5,1fr)}.stat-item{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1rem;text-align:center}.stat-value{color:#1e293b;font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.stat-label{color:#64748b;font-size:.75rem;font-weight:500;text-transform:uppercase}.user-projects{margin-bottom:1rem}.user-projects h5{color:#1e293b;font-size:1rem;font-weight:600;margin:0 0 1rem}.projects-list{display:flex;flex-direction:column;gap:.5rem}.project-item{align-items:center;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;display:flex;justify-content:space-between;padding:.75rem}.project-name{color:#1e293b;font-size:.875rem;font-weight:500}.project-role{background-color:#e2e8f0;color:#64748b;font-size:.75rem}.project-role,.status-badge{border-radius:9999px;padding:.25rem .5rem}.status-badge{text-transform:uppercase}.status-badge.active{background-color:#dcfce7;color:#166534}.status-badge.inactive{background-color:#fef2f2;color:#dc2626}.status-badge.pending{background-color:#fef3c7;color:#d97706}.btn-secondary{background-color:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:.875rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.btn-secondary:hover{background-color:#f9fafb;border-color:#9ca3af}.btn-danger{align-items:center;background-color:#ef4444;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s ease}.btn-danger:hover{background-color:#dc2626}@media (max-width:768px){.modal-content{margin:1rem;max-height:calc(100vh - 2rem)}.user-details-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.modal-footer{align-items:stretch;flex-direction:column}.modal-footer button{width:100%}}.error-banner{background-color:#fef3c7;border:1px solid #f59e0b;color:#92400e;font-weight:500;gap:1rem;justify-content:space-between;padding:.75rem 1rem}.error-banner,.error-banner .retry-button{align-items:center;display:flex;font-size:.875rem}.error-banner .retry-button{background-color:#f59e0b;border:none;border-radius:4px;color:#fff;cursor:pointer;gap:.5rem;padding:.5rem 1rem;transition:background-color .2s ease}.error-banner .retry-button:hover:not(:disabled){background-color:#d97706}.error-banner .retry-button:disabled{background-color:#d1d5db;cursor:not-allowed}.api-key-prompt-overlay{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:9999}.api-key-prompt-modal{background:#fff;border-radius:16px;box-shadow:0 25px 50px -12px #00000040;max-width:500px;padding:2rem;text-align:center;width:100%}.api-key-prompt-header{margin-bottom:2rem}.api-key-prompt-logo{align-items:center;color:#348aa7;display:flex;gap:.75rem;justify-content:center;margin-bottom:1rem}.api-key-prompt-logo h1{color:#1e293b;font-size:1.5rem;font-weight:700;margin:0}.api-key-prompt-subtitle{color:#64748b;font-size:.875rem;margin:0}.api-key-prompt-form{text-align:left}.api-key-input-wrapper{align-items:center;display:flex;position:relative}.api-key-input{background-color:#fff;border:2px solid #e2e8f0;border-radius:8px;font-family:monospace;padding:.75rem 2.5rem .75rem .75rem;transition:all .2s ease;width:100%}.api-key-input.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.api-key-input.valid{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.toggle-password-btn{align-items:center;background:none;border:none;border-radius:4px;color:#64748b;cursor:pointer;display:flex;height:2rem;justify-content:center;position:absolute;right:.5rem;transition:all .2s ease;width:2rem}.toggle-password-btn:hover{background-color:#f1f5f9;color:#1e293b}.validation-message{align-items:center;display:flex;font-size:.875rem;gap:.5rem;margin-top:.5rem}.validation-message.valid{color:#10b981}.validation-message.error{color:#ef4444}.api-key-help{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin:1.5rem 0;padding:1rem}.api-key-help h4{color:#1e293b;font-size:.875rem;font-weight:600;margin:0 0 .75rem}.api-key-help ol{color:#374151;font-size:.875rem;line-height:1.5;margin:0 0 1rem;padding-left:1.25rem}.api-key-help li{margin-bottom:.25rem}.api-key-note{color:#64748b;font-size:.75rem;font-style:italic;margin:0}.connect-btn{align-items:center;background-color:#348aa7;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem 1.5rem;transition:all .2s ease;width:100%}.connect-btn:hover:not(:disabled){background-color:#274768;transform:translateY(-1px)}.connect-btn:disabled{background-color:#e2e8f0;color:#64748b;cursor:not-allowed;transform:none}.spinner{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:currentcolor;height:16px;width:16px}:root{--primary-color:#348aa7;--secondary-color:#08d3a0;--accent-color:#fd745e;--background-color:#f8fafc;--header-gradient-1:#274768;--header-gradient-2:#348aa7;--text-color:#1e293b;--text-secondary:#6b7280;--border-color:#e2e8f0;--card-background:#fff;--card-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a}.dark-mode{--primary-color:#fd745e;--secondary-color:#348aa7;--accent-color:#08d3a0;--background-color:#0f172a;--header-gradient-1:#1e293b;--header-gradient-2:#334155;--text-color:#f1f5f9;--text-secondary:#94a3b8;--border-color:#334155;--card-background:#1e293b;--card-shadow:0 1px 3px 0 #0000004d,0 1px 2px -1px #0000004d}.App{background-color:#f8fafc;background-color:var(--background-color);color:#1e293b;color:var(--text-color);min-height:100vh;transition:background-color .3s ease,color .3s ease}.app-header{background:linear-gradient(135deg,#274768,#348aa7);background:linear-gradient(135deg,var(--header-gradient-1) 0,var(--header-gradient-2) 100%);box-shadow:0 4px 6px -1px #0000001a;color:#fff;margin-bottom:2rem;padding:2rem 0}.header-content{justify-content:space-between}.header-brand,.header-content{align-items:center;display:flex}.header-brand{gap:1rem}.header-logo{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.header-text h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#08d3a0,#348aa7);background:linear-gradient(135deg,var(--secondary-color),var(--primary-color));-webkit-background-clip:text;background-clip:text;font-size:2rem;font-weight:700;margin-bottom:.25rem}.header-text p{font-size:1rem;font-weight:500;opacity:.9}.header-right{text-align:right}.header-actions{align-items:center;display:flex;gap:1rem}.theme-toggle-button{align-items:center;background-color:#ffffff1a;border:1px solid #fff3;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.875rem;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.theme-toggle-button:hover{background-color:#fff3;border-color:#ffffff4d}.refresh-button{align-items:center;background-color:#ffffff1a;border:1px solid #fff3;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.875rem;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.refresh-button:hover{background-color:#fff3;border-color:#ffffff4d}.logout-button{align-items:center;background:none;border:1px solid #dc2626;border-radius:6px;color:#dc2626;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;margin-left:12px;padding:.5rem 1rem;transition:all .2s ease}.logout-button:hover{background-color:#dc2626;color:#fff}.main-nav,.nav-btn{display:flex;gap:.5rem}.nav-btn{align-items:center;background-color:#ffffff1a;border:1px solid #fff3;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:all .2s ease}.nav-btn:hover{background-color:#fff3;border-color:#ffffff4d}.nav-btn.active{background-color:#08d3a0;border-color:#08d3a0;color:#fff}.nav-btn.inactive{background-color:#ffffff0d;border-color:#ffffff1a;color:#ffffffb3}.nav-btn.inactive:hover{background-color:#ffffff26;border-color:#ffffff40;color:#fff}.environment-switcher{gap:.5rem;margin-right:1rem;position:relative}.switch-to-real-btn{align-items:center;background:linear-gradient(135deg,#059669,#10b981);border:1px solid #059669;border-radius:6px;box-shadow:0 2px 4px #05966933;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.switch-to-real-btn:hover{background:linear-gradient(135deg,#047857,#059669);border-color:#047857;box-shadow:0 4px 8px #0596694d;transform:translateY(-1px)}.environment-switcher-button{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.875rem;gap:.5rem;padding:.5rem .75rem;transition:all .2s ease}.environment-switcher-button:hover{background:#ffffff26;border-color:#ffffff4d}.dropdown-arrow{font-size:.75rem;transition:transform .2s ease}.dropdown-arrow.open{transform:rotate(180deg)}.environment-dropdown{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;left:0;margin-top:.25rem;min-width:280px;position:absolute;right:0;top:100%;z-index:1000}.environment-option{background:none;border:none;border-bottom:1px solid #f3f4f6;cursor:pointer;display:block;padding:.75rem;text-align:left;transition:background-color .2s ease;width:100%}.environment-option:last-child{border-bottom:none}.environment-option:hover{background-color:#f9fafb}.environment-option.active{background-color:#f0f9ff}.environment-option-header{align-items:center;display:flex;gap:.5rem;margin-bottom:.25rem}.environment-name{color:#111827;flex:1 1;font-weight:500}.active-indicator{color:#059669;font-weight:700}.environment-description{color:#6b7280;font-size:.75rem;margin:0;padding-left:1.5rem}.environment-switcher{align-items:center;background-color:#ffffff1a;border:1px solid #fff3;border-radius:6px;color:#fff;display:flex;font-size:.875rem;gap:1rem;padding:.5rem 1rem}.env-label{align-items:center;display:flex;font-weight:500;gap:.5rem}.env-buttons{display:flex;gap:.25rem}.env-btn{background-color:#ffffff1a;border:1px solid #ffffff4d;border-radius:4px;color:#fff;cursor:pointer;font-size:.75rem;font-weight:500;padding:.25rem .75rem;transition:all .2s ease}.env-btn:hover{background-color:#fff3}.env-btn.active{background-color:#08d3a0;background-color:var(--secondary-color);border-color:#08d3a0;border-color:var(--secondary-color);color:#fff}.env-indicator{align-items:center;display:flex;gap:.5rem}.env-dot{border-radius:50%;height:8px;width:8px}.env-dot.prod{background-color:#08d3a0;background-color:var(--secondary-color)}.env-dot.sandbox{background-color:#fd745e;background-color:var(--accent-color)}.env-text{font-size:.75rem;font-weight:500}.last-updated{font-size:.875rem;opacity:.8}.dashboard-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr}.dashboard-grid,.dashboard-section{margin-bottom:2rem}@media (max-width:768px){.header-content{flex-direction:column;gap:1rem;text-align:center}.dashboard-grid{grid-template-columns:1fr}.tabs-header{flex-direction:column;gap:.25rem}.tab-button{border-radius:8px;justify-content:center}.tab-button.active:after{display:none}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.animate-spin{animation:spin 1s linear infinite}.dashboard-tabs{margin-bottom:2rem;margin-top:3rem}.tabs-header{border-bottom:2px solid #e2e8f0;border-bottom:2px solid var(--border-color);display:flex;gap:.5rem;margin-bottom:1.5rem;padding-bottom:.5rem}.tab-button{align-items:center;background-color:#f8fafc;background-color:var(--background-color);border:none;border-radius:8px 8px 0 0;color:#6b7280;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;position:relative;transition:all .2s ease}.tab-button:hover{background-color:#e2e8f0;background-color:var(--border-color);color:#1e293b;color:var(--text-color)}.tab-button.active{color:#fff}.tab-button.active,.tab-button.active:after{background-color:#348aa7;background-color:var(--primary-color)}.tab-button.active:after{bottom:-.5rem;content:"";height:2px;left:0;position:absolute;right:0}.tab-button.disabled{cursor:not-allowed;opacity:.5}.tab-button.disabled,.tab-button.disabled:hover{background-color:#e2e8f0;background-color:var(--border-color);color:#6b7280;color:var(--text-secondary)}.tab-content{min-height:400px}.settings-container{margin:0 auto;max-width:1200px;padding:2rem 0}.settings-header{align-items:center;border-bottom:2px solid #e2e8f0;border-bottom:2px solid var(--border-color);display:flex;gap:1rem;margin-bottom:2rem;padding-bottom:1rem}.settings-header h2{color:#1e293b;color:var(--text-color);font-size:1.875rem;font-weight:700;margin:0}.settings-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr}.settings-section{background:#fff;background:var(--card-background);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;box-shadow:var(--card-shadow);padding:1.5rem;transition:background-color .3s ease,border-color .3s ease,box-shadow .3s ease}.section-header{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);display:flex;gap:.75rem;margin-bottom:1.5rem;padding-bottom:.75rem}.section-header h3{color:#1e293b;color:var(--text-color);font-size:1.25rem;font-weight:600;margin:0}.api-keys-list{margin-bottom:1.5rem}.api-key-item{align-items:center;background:#f8fafc;background:var(--background-color);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:8px;display:flex;gap:1rem;margin-bottom:.75rem;padding:1rem}.api-key-info{display:flex;flex:1 1;flex-direction:column;gap:.5rem}.api-key-name{font-weight:600}.api-key-input,.api-key-name{color:#1e293b;color:var(--text-color);font-size:.875rem}.api-key-input{background:#fff;background:var(--card-background);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:6px;padding:.5rem}.api-key-input:focus{border-color:#348aa7;box-shadow:0 0 0 3px #348aa71a;outline:none}.delete-btn{align-items:center;background:#ef4444;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:all .2s ease}.delete-btn:hover{background:#dc2626}.add-api-key{border-top:1px solid #e2e8f0;border-top:1px solid var(--border-color);padding-top:1.5rem}.add-api-key-inputs{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.api-key-name-input{background:#fff;background:var(--card-background);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:6px;color:#1e293b;color:var(--text-color);font-size:.875rem;padding:.75rem}.api-key-name-input:focus{border-color:#348aa7;box-shadow:0 0 0 3px #348aa71a;outline:none}.add-btn{align-items:center;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1rem;transition:all .2s ease}.add-btn,.add-btn:hover:not(:disabled){background:#348aa7;background:var(--primary-color)}.add-btn:hover:not(:disabled){opacity:.9}.add-btn:disabled{background:#9ca3af;cursor:not-allowed}.capacity-settings{margin-bottom:1.5rem}.capacity-item{margin-bottom:1rem}.capacity-item label{color:#1e293b;color:var(--text-color);display:block;font-weight:600;margin-bottom:.5rem}.capacity-input-wrapper{align-items:center;display:flex;gap:.5rem;margin-bottom:.5rem}.capacity-input{background:#fff;background:var(--card-background);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:6px;color:#1e293b;color:var(--text-color);font-size:.875rem;padding:.5rem;width:100px}.capacity-input:focus{border-color:#348aa7;box-shadow:0 0 0 3px #348aa71a;outline:none}.capacity-description,.capacity-unit{color:#6b7280;color:var(--text-secondary);font-size:.875rem}.capacity-description{margin:0}.user-capacities h4{color:#1e293b;color:var(--text-color);font-size:1rem;font-weight:600;margin:1rem 0 .5rem}.user-capacity-list{margin-top:1rem}.user-capacity-item{align-items:center;background-color:#f8fafc;background-color:var(--background-color);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:6px;display:flex;justify-content:space-between;margin-bottom:.5rem;padding:.75rem}.user-name{color:#1e293b;color:var(--text-color);font-weight:500}.baseline-item,.baseline-settings{margin-bottom:1.5rem}.baseline-item{background-color:#f8fafc;background-color:var(--background-color);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:8px;padding:1rem}.baseline-item label{color:#1e293b;color:var(--text-color);display:block;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.baseline-input-wrapper{align-items:center;display:flex;gap:.5rem;margin-bottom:.5rem}.baseline-input{background-color:#fff;background-color:var(--card-background);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:6px;color:#1e293b;color:var(--text-color);font-size:.875rem;padding:.5rem;width:100px}.baseline-input:focus{border-color:#348aa7;box-shadow:0 0 0 3px #348aa71a;outline:none}.baseline-unit{font-size:.875rem;font-weight:500;min-width:40px}.baseline-description,.baseline-unit{color:#6b7280;color:var(--text-secondary)}.baseline-description{font-size:.75rem;line-height:1.4;margin:0}.settings-section.full-width{grid-column:1/-1}.baseline-settings.two-column{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr}@media (max-width:768px){.baseline-settings.two-column{grid-template-columns:1fr}}.api-test-container{margin:0 auto;max-width:1200px;padding:2rem}.api-test-container h2{color:#1e293b;color:var(--text-color);font-size:1.5rem;font-weight:600;margin-bottom:1.5rem}.test-buttons{display:flex;gap:1rem;margin-bottom:2rem}.test-btn{background-color:#348aa7;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.test-btn:hover:not(:disabled){background-color:#2d7a94}.test-btn:disabled{cursor:not-allowed;opacity:.6}.loading{align-items:center;color:#6b7280;color:var(--text-secondary);font-size:.875rem;gap:.5rem}.error,.loading{display:flex;margin-bottom:1rem}.error{background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;flex-direction:column;gap:1rem;padding:1.5rem}.error-header{align-items:center;display:flex;gap:.75rem;margin-bottom:.5rem}.error-title{color:#dc2626;font-size:1.125rem;font-weight:600}.error-message{color:#991b1b;font-size:.875rem;line-height:1.5}.error-details{background-color:#fef2f2;margin-top:.75rem;padding:.75rem}.error-details p{color:#991b1b;font-size:.8rem;margin:.25rem 0}.error-actions{gap:.75rem;margin-top:.5rem}.error-actions,.retry-button{align-items:center;display:flex}.retry-button{background-color:#dc2626;border:1px solid #dc2626;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.retry-button:hover:not(:disabled){background-color:#b91c1c;border-color:#b91c1c}.retry-button:disabled{background-color:#9ca3af;border-color:#9ca3af;cursor:not-allowed;opacity:.6}.secondary-button{align-items:center;background-color:initial;border:1px solid #dc2626;border-radius:6px;color:#dc2626;cursor:pointer;display:flex;font-size:.875rem;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.secondary-button:hover{background-color:#dc2626;color:#fff}.test-results{background-color:#f8fafc;background-color:var(--background-color);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.test-results h3{color:#1e293b;color:var(--text-color);font-size:1.125rem;font-weight:600;margin-bottom:1rem}.test-results ul{list-style:none;margin:0 0 1rem;padding:0}.test-results li{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);color:#6b7280;color:var(--text-secondary);padding:.5rem 0}.test-results li:last-child{border-bottom:none}.sample-entry,.sample-members{margin-top:1rem}.sample-entry h4,.sample-members h4{color:#374151;font-size:1rem;font-weight:600;margin-bottom:.5rem}.sample-entry pre,.sample-members pre{background-color:#1f2937;border-radius:6px;color:#f9fafb;font-size:.75rem;line-height:1.4;overflow-x:auto;padding:1rem}.theme-colors-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr;margin-bottom:1.5rem}.color-picker-item{display:flex;flex-direction:column;gap:.5rem}.color-picker-item label{color:#374151;font-size:.875rem;font-weight:500}.color-picker-wrapper{align-items:center;display:flex;gap:.5rem}.color-picker{background:none;border:none;border-radius:6px;cursor:pointer;height:40px;width:50px}.color-picker::-webkit-color-swatch-wrapper{padding:0}.color-picker::-webkit-color-swatch{border:none;border-radius:6px}.color-input{background:#fff;background:var(--card-background);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:6px;color:#1e293b;color:var(--text-color);flex:1 1;font-family:monospace;font-size:.875rem;padding:.5rem}.color-input:focus{border-color:#348aa7;box-shadow:0 0 0 3px #348aa71a;outline:none}.theme-preview{border-top:1px solid #e2e8f0;border-top:1px solid var(--border-color);padding-top:1.5rem}.theme-preview h4{color:#1e293b;color:var(--text-color);font-size:1rem;font-weight:600;margin:0 0 1rem}.preview-header{border-radius:8px;color:#fff;padding:1rem}.preview-content{align-items:center;display:flex;gap:1rem}.preview-logo{border-radius:8px;height:40px;width:40px}.preview-text{display:flex;flex-direction:column;gap:.25rem}.preview-title{font-size:1.25rem;font-weight:700}.preview-subtitle{font-size:.875rem;opacity:.9}.loading-placeholder{padding:2rem}.empty-state,.loading-placeholder{color:#6b7280;color:var(--text-secondary);text-align:center}.empty-state{padding:3rem 2rem}.empty-state p{color:#1e293b;color:var(--text-color);font-size:1rem;margin:1rem 0 .5rem}.empty-state .text-sm{color:#9ca3af;font-size:.875rem}*{transition:background-color .3s ease,color .3s ease,border-color .3s ease,box-shadow .3s ease}.dark-mode .card,.dark-mode .settings-section{background:#fff;background:var(--card-background);border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode .card-title{color:#1e293b;color:var(--text-color)}.enhanced-metrics-section{margin-bottom:2rem}.enhanced-metrics-section h5{align-items:center;color:#1e293b;color:var(--text-color);display:flex;font-size:1.125rem;font-weight:600;gap:.5rem;margin-bottom:1rem}.enhanced-metrics-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.metric-card{background:#fff;background:var(--card-background);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;box-shadow:var(--card-shadow);padding:1.25rem}.metric-card h6{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);color:#1e293b;color:var(--text-color);font-size:1rem;font-weight:600;margin:0 0 1rem;padding-bottom:.5rem}.metric-content{display:flex;flex-direction:column;gap:.75rem}.metric-row{align-items:center;display:flex;justify-content:space-between;padding:.5rem 0}.metric-label{color:var(--text-secondary)}.metric-value{color:var(--text-color)}.metric-value.positive{color:#10b981}.metric-value.negative{color:#ef4444}.filter-section{background:#f8fafc;background:var(--background-color);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:8px;margin-bottom:1.5rem;padding:1rem}.filter-row{display:flex;gap:1rem;margin-bottom:1rem}.filter-group{display:flex;flex-direction:column;gap:.5rem;min-width:200px}.filter-label{font-weight:500}.filter-label,.filter-select{color:#1e293b;color:var(--text-color);font-size:.875rem}.filter-select{background:#fff;background:var(--card-background);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:6px;min-width:150px;padding:.5rem}.filter-select:focus{border-color:#348aa7;border-color:var(--primary-color);box-shadow:0 0 0 3px #348aa71a;outline:none}.filter-summary{align-items:center}.filter-summary,.filter-tags{display:flex;flex-wrap:wrap;gap:.5rem}.filter-tags{margin-top:.5rem}.filter-tag{align-items:center;background:#348aa7;background:var(--primary-color);border-radius:16px;color:#fff;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.25rem .75rem}.filter-tag-remove{align-items:center;background:none;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:700;height:16px;justify-content:center;padding:0;transition:background-color .2s;width:16px}.filter-tag-remove:hover{background:#fff3}.owner-requirement{background-color:#fef3c7;border:1px solid #f59e0b;border-radius:6px;margin-top:12px;padding:12px}.owner-requirement p{color:#92400e;font-size:.875rem;font-weight:500;margin:0}.no-owner-selected{background-color:#f9fafb;border-radius:8px;color:#6b7280;margin-top:20px;padding:40px 20px;text-align:center}.no-owner-selected p{font-size:1rem;margin:0}.summary-label{color:#6b7280;color:var(--text-secondary);font-size:.75rem}.summary-value{background:#f8fafc;background:var(--background-color);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:4px;color:#348aa7;color:var(--primary-color);font-size:.75rem;font-weight:600;padding:.25rem .5rem}.dark-mode .table-container,.dark-mode .utilization-summary{background:#fff;background:var(--card-background);border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode .sortable-header{background:#f8fafc;background:var(--background-color);color:#1e293b;color:var(--text-color)}.dark-mode .clickable-row:hover,.dark-mode .sortable-header:hover{background:#e2e8f0;background:var(--border-color)}.dark-mode .clickable-row:hover,.dark-mode .clickable-row:hover td{color:#1e293b;color:var(--text-color)}.dark-mode .hours-financial-grid,.dark-mode .project-info-grid,.dark-mode .project-progress-section,.dark-mode .risk-analysis-section,.dark-mode .user-billable-projects,.dark-mode .user-profile-section{background:#fff;background:var(--card-background);border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode .projects-table{background:#fff;background:var(--card-background)}.dark-mode .projects-table th{background:#f8fafc;background:var(--background-color)}.dark-mode .projects-table td,.dark-mode .projects-table th{border-color:#e2e8f0;border-color:var(--border-color);color:#1e293b;color:var(--text-color)}.dark-mode .enhanced-metrics-section,.dark-mode .metric-card,.dark-mode .projects-table-container{background:#fff;background:var(--card-background);border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode .metric-card h6{border-color:#e2e8f0;border-color:var(--border-color);color:#1e293b;color:var(--text-color)}.dark-mode .metric-label{color:#6b7280;color:var(--text-secondary)}.dark-mode .metric-value{color:#1e293b;color:var(--text-color)}.dark-mode .modal-overlay{background:#000000b3}.dark-mode .modal-content{background:#fff;background:var(--card-background);box-shadow:0 20px 25px -5px #00000080,0 10px 10px -5px #0000004d}.dark-mode .modal-content,.dark-mode .modal-header{border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode .modal-header{background:#f8fafc;background:var(--background-color)}.dark-mode .modal-close,.dark-mode .modal-title h3{color:#1e293b;color:var(--text-color)}.dark-mode .modal-close{background:#f8fafc;background:var(--background-color);border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode .modal-close:hover{background:#e2e8f0;background:var(--border-color)}.dark-mode .info-card{background:#fff;background:var(--card-background)}.dark-mode .info-card,.dark-mode .info-header{border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode .info-header{background:#f8fafc;background:var(--background-color);color:#1e293b;color:var(--text-color)}.dark-mode .info-row{border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode .info-label{color:#6b7280;color:var(--text-secondary)}.dark-mode .info-value{color:#1e293b;color:var(--text-color)}.dark-mode .task-overview-card{background:#fff;background:var(--card-background);border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode .task-overview-card h6{color:#1e293b;color:var(--text-color)}.dark-mode .task-stats{background:#f8fafc;background:var(--background-color);border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode .stat-label{color:#6b7280;color:var(--text-secondary)}.dark-mode .stat-value{color:#1e293b;color:var(--text-color)}.dark-mode .progress-bar-mini{background:#e2e8f0;background:var(--border-color)}.dark-mode .progress-fill-mini.completed{background:#08d3a0;background:var(--secondary-color)}.dark-mode .progress-fill-mini.in-progress{background:#348aa7;background:var(--primary-color)}.dark-mode .progress-labels span{color:#6b7280;color:var(--text-secondary)}.dark-mode .risk-grid{background:#f8fafc;background:var(--background-color)}.dark-mode .risk-grid,.dark-mode .risk-item{border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode .risk-item{background:#fff;background:var(--card-background)}.dark-mode .risk-count{color:#1e293b;color:var(--text-color)}.dark-mode .risk-label{color:#6b7280;color:var(--text-secondary)}.dark-mode .hours-breakdown-section{background:#fff;background:var(--card-background);border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode .hour-bar-label,.dark-mode .hours-breakdown-section h5{color:#1e293b;color:var(--text-color)}.dark-mode .hour-value{color:#6b7280;color:var(--text-secondary)}.dark-mode .hour-bar-container{background:#e2e8f0;background:var(--border-color)}.dark-mode .financial-section{background:#fff;background:var(--card-background);border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode .financial-section h5{color:#1e293b;color:var(--text-color)}.dark-mode .financial-card{background:#f8fafc;background:var(--background-color);border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode .financial-label{color:#6b7280;color:var(--text-secondary)}.dark-mode .financial-value{color:#1e293b;color:var(--text-color)}.dark-mode .progress-chart{background:#fff;background:var(--card-background)}.dark-mode .progress-chart,.dark-mode .progress-circle{border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode .progress-inner{background:#fff;background:var(--card-background)}.dark-mode .progress-percentage{color:#1e293b;color:var(--text-color)}.dark-mode .progress-label{color:#6b7280;color:var(--text-secondary)}.dark-mode .progress-details{background:#f8fafc;background:var(--background-color);border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode .progress-stat,.dark-mode .progress-stat span,.dark-mode .status-badge{color:#1e293b;color:var(--text-color)}.dark-mode .status-badge{background:#f8fafc;background:var(--background-color);border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode .status-badge.completed{background:#08d3a0;background:var(--secondary-color);color:#fff}.dark-mode .status-badge.active{background:#348aa7;background:var(--primary-color);color:#fff}.dark-mode .status-badge.in-progress{background:#fd745e;background:var(--accent-color);color:#fff}@media (max-width:768px){.filter-row{flex-direction:column;gap:1rem}.filter-group{min-width:auto}.settings-grid{grid-template-columns:1fr}.color-picker-wrapper{align-items:stretch;flex-direction:column}.color-picker{height:50px;width:100%}}.sortable-header{cursor:pointer;padding-right:1.5rem;position:relative;transition:background-color .2s ease;-webkit-user-select:none;user-select:none}.sortable-header:hover{background-color:#f3f4f6}.sortable-header svg{color:#6b7280;position:absolute;right:.5rem;top:50%;transform:translateY(-50%);transition:color .2s ease}.sortable-header:hover svg{color:#348aa7}.status-field-info{display:flex;flex-direction:column;gap:1.5rem}.field-details{background-color:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;padding:1rem}.field-details p{color:#374151;font-size:.875rem;margin:.5rem 0}.field-details strong{color:#1e293b;font-weight:600}.status-categories{display:flex;flex-direction:column;gap:1rem}.status-categories h4{border-bottom:1px solid #e5e7eb;color:#1e293b;font-size:1rem;font-weight:600;margin:0 0 .75rem;padding-bottom:.5rem}.status-category{background-color:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;padding:1rem}.category-header{align-items:center;color:#374151;display:flex;font-weight:500;gap:.5rem;margin-bottom:.75rem}.category-label{font-size:.875rem;font-weight:600}.status-options{display:flex;flex-wrap:wrap;gap:.5rem}.status-badge{border:1px solid;border-radius:20px;font-size:.75rem;font-weight:500;padding:.25rem .75rem}.status-badge.completed{background-color:#dcfce7;border-color:#bbf7d0;color:#166534}.status-badge.active{background-color:#dbeafe;border-color:#bfdbfe;color:#1e40af}.status-badge.archived{background-color:#f3f4f6;border-color:#d1d5db;color:#374151}.metrics-breakdown{background-color:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;padding:1rem}.metrics-breakdown h4{border-bottom:1px solid #e5e7eb;color:#1e293b;font-size:1rem;font-weight:600;margin:0 0 .75rem;padding-bottom:.5rem}.metrics-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.metric-item{align-items:center;background-color:#fff;border:1px solid #e5e7eb;border-radius:6px;display:flex;justify-content:space-between;padding:.75rem}.metric-label{color:#6b7280;font-size:.875rem;font-weight:500}.metric-value{color:#1e293b;font-size:.875rem;font-weight:600}@media (max-width:768px){.metrics-grid{grid-template-columns:1fr}.status-options{flex-direction:column}.status-badge{text-align:center}}.test-controls{margin-bottom:1.5rem}.test-summary{display:flex;flex-direction:column;gap:1rem}.test-item{background-color:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;padding:1rem}.test-header{align-items:center;display:flex;gap:.75rem;margin-bottom:.5rem}.test-name{color:#374151;flex:1 1;font-size:.875rem;font-weight:600}.test-status{border-radius:4px;font-size:.75rem;font-weight:600;padding:.25rem .5rem;text-transform:uppercase}.test-status.success{background-color:#dcfce7;color:#166534}.test-status.warning{background-color:#fef3c7;color:#92400e}.test-status.error{background-color:#fee2e2;color:#991b1b}.test-status.pending{background-color:#f3f4f6;color:#6b7280}.test-details{padding-left:2rem}.test-details p{color:#6b7280;font-size:.875rem;margin:.25rem 0}.test-details ul{margin:.5rem 0;padding-left:1rem}.test-details li{color:#6b7280;font-size:.875rem;margin:.25rem 0}.test-timestamp{border-top:1px solid #e5e7eb;color:#9ca3af;font-size:.75rem;margin-top:1rem;padding-top:1rem;text-align:center}.error-banner{background:linear-gradient(135deg,#ef4444,#dc2626);border-bottom:1px solid #b91c1c;box-shadow:0 2px 4px #ef444433;color:#fff;padding:12px 0;position:relative;z-index:1000}.error-banner-content{align-items:center;display:flex;gap:16px;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 24px}.error-icon{color:#fecaca;flex-shrink:0}.error-details{flex:1 1;gap:12px;min-width:0}.error-status{background:#fff3;border-radius:4px;flex-shrink:0;font-size:12px;font-weight:600;padding:4px 8px}.error-message{font-size:14px;font-weight:500;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.error-dismiss{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:4px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:6px;transition:all .2s ease}.error-dismiss:hover{background:#fff3;border-color:#ffffff4d}.error-dismiss:focus{outline:2px solid #ffffff80;outline-offset:2px}@media (max-width:768px){.error-banner-content{gap:12px;padding:0 16px}.error-details{align-items:flex-start;flex-direction:column;gap:8px}.error-message{line-height:1.3;white-space:normal}}.debug-content{padding:20px}.debug-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:24px;padding:16px}.debug-section h3{color:#1e293b;font-size:16px;font-weight:600;margin:0 0 12px}.status-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.status-item{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;display:flex;justify-content:space-between;padding:8px 12px}.status-label{color:#64748b;font-weight:500}.status-value{border-radius:4px;font-size:14px;font-weight:600;padding:4px 8px}.status-value.loading{background:#fef3c7;color:#92400e}.status-value.idle{background:#d1fae5;color:#065f46}.status-value.error{background:#fee2e2;color:#991b1b}.status-value.success{background:#d1fae5;color:#065f46}.error-details{background:#fee2e2;border:1px solid #fecaca;color:#991b1b}.error-details,.test-result{align-items:center;border-radius:6px;display:flex;gap:8px;padding:12px}.test-result{font-weight:500}.test-result.success{background:#d1fae5;border:1px solid #a7f3d0;color:#065f46}.test-result.error{background:#fee2e2;border:1px solid #fecaca;color:#991b1b}.data-preview{background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:16px}.data-preview h4{color:#374151;font-size:14px;font-weight:600;margin:0 0 8px}.data-preview pre{background:#f8fafc;border:1px solid #e2e8f0;border-radius:4px;font-size:12px;margin:8px 0;overflow-x:auto;padding:12px}.raw-data{background:#fff;border:1px solid #e2e8f0;border-radius:6px;max-height:400px;overflow-y:auto;padding:16px}.raw-data pre{background:#f8fafc;border:1px solid #e2e8f0;border-radius:4px;font-size:11px;margin:0;overflow-x:auto;padding:12px}.btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;padding:8px 16px;transition:all .2s ease}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-secondary{background:#6b7280;color:#fff}.btn-secondary:hover:not(:disabled){background:#4b5563}@media (max-width:768px){.debug-content{padding:16px}.status-grid{grid-template-columns:1fr}.data-preview pre,.raw-data pre{font-size:10px}}.metric-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:24px}.metric-grid-3x2{grid-gap:18px;display:grid;display:flex;flex-direction:column;gap:18px;gap:24px;grid-template-columns:repeat(6,1fr);margin-top:24px}.metric-row{grid-gap:18px;display:grid;gap:18px}.metric-row-1{grid-template-columns:repeat(6,1fr)}.metric-row-2,.metric-row-3{grid-template-columns:repeat(4,1fr)}@media (max-width:1700px){.metric-row-1{grid-template-columns:repeat(5,1fr)}}@media (max-width:1600px){.metric-row-1{grid-template-columns:repeat(4,1fr)}.metric-row-2,.metric-row-3{grid-template-columns:repeat(3,1fr)}}@media (max-width:1400px){.metric-row-1{grid-template-columns:repeat(3,1fr)}.metric-row-2,.metric-row-3{grid-template-columns:repeat(2,1fr)}}@media (max-width:1200px){.metric-row-1,.metric-row-2,.metric-row-3{grid-template-columns:repeat(2,1fr)}}@media (max-width:900px){.metric-row-1,.metric-row-2,.metric-row-3{grid-template-columns:repeat(1,1fr)}}@media (max-width:768px){.metric-grid,.metric-row-1,.metric-row-2,.metric-row-3{gap:16px;grid-template-columns:1fr}}.enhanced-risk-score{background:#fff;background:var(--card-background);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:8px;margin-bottom:1.5rem;padding:1.25rem}.enhanced-risk-score h6{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);color:#1e293b;color:var(--text-color);font-size:1rem;font-weight:600;margin:0 0 1rem;padding-bottom:.5rem}.risk-score-content,.risk-score-display{display:flex;flex-direction:column;gap:1rem}.risk-score-main{align-items:center;background:#f8fafc;background:var(--background-color);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:8px;display:flex;gap:1rem;padding:1rem}.risk-score-value{font-size:2rem;font-weight:700;min-width:80px;text-align:center}.risk-score-level{font-size:1.25rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.risk-factors{background:#f8fafc;background:var(--background-color);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:8px;display:flex;flex-direction:column;gap:.5rem;padding:1rem}.risk-factors-label{color:#1e293b;color:var(--text-color);font-size:.875rem;font-weight:600}.risk-factors-list{color:#6b7280;color:var(--text-secondary);font-size:.875rem;font-style:italic}.risk-breakdown{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.risk-breakdown-item{align-items:center;background:#f8fafc;background:var(--background-color);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:6px;display:flex;justify-content:space-between;padding:.75rem}.risk-breakdown-label{color:#1e293b;color:var(--text-color);font-size:.875rem;font-weight:500}.risk-breakdown-value{font-size:.875rem;font-weight:600}.risk-breakdown-value.positive{color:#10b981}.risk-breakdown-value.negative{color:#ef4444}.role-cell{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);color:#1e293b;color:var(--text-color);padding:.75rem;text-align:left}.modal-tabs{border-bottom:2px solid #e2e8f0;border-bottom:2px solid var(--border-color);display:flex;gap:.5rem;margin-bottom:2rem;padding:0 1rem}.modal-tab{align-items:center;background:#f8fafc;background:var(--background-color);border:1px solid #0000;border-bottom:none;border-radius:8px 8px 0 0;color:#6b7280;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;position:relative;transition:all .2s ease}.modal-tab:hover{background:#e2e8f0;background:var(--border-color)}.modal-tab.active,.modal-tab:hover{color:#1e293b;color:var(--text-color)}.modal-tab.active{background:#fff;background:var(--card-background);border-color:#e2e8f0;border-color:var(--border-color);border-bottom:2px solid #348aa7;border-bottom:2px solid var(--tab-active-color,var(--primary-color))}.modal-tab.active:after{background-color:#348aa7;background-color:var(--tab-active-color,var(--primary-color));bottom:-2px;content:"";height:2px;left:0;position:absolute;right:0}.modal-tab svg{color:#348aa7;color:var(--tab-color,var(--primary-color));transition:color .2s ease}.modal-tab.active svg{color:#348aa7;color:var(--tab-active-color,var(--primary-color))}.tab-content{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.dark-mode .modal-tabs{border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode .modal-tab{background:#f8fafc;background:var(--background-color);border-color:#0000;color:#6b7280;color:var(--text-secondary)}.dark-mode .modal-tab:hover{background:#e2e8f0;background:var(--border-color);color:#1e293b;color:var(--text-color)}.dark-mode .modal-tab.active{background:#fff;background:var(--card-background);border-color:#e2e8f0;border-color:var(--border-color);color:#1e293b;color:var(--text-color)}.dark-mode .modal-tab.active:after{background-color:#348aa7;background-color:var(--tab-active-color,var(--primary-color))}@media (max-width:768px){.modal-tabs{flex-direction:column;gap:.25rem;padding:0 .5rem}.modal-tab{border:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:8px;justify-content:center;text-align:center}.modal-tab.active{border-bottom-color:#348aa7;border-bottom-color:var(--tab-active-color,var(--primary-color))}.modal-tab.active:after{display:none}.modal-tab.active{border-bottom:2px solid #348aa7;border-bottom:2px solid var(--tab-active-color,var(--primary-color))}}.dark-mode .enhanced-risk-score{background:#fff;background:var(--card-background);border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode .enhanced-risk-score h6{border-color:#e2e8f0;border-color:var(--border-color);color:#1e293b;color:var(--text-color)}.dark-mode .risk-score-main{background:#f8fafc;background:var(--background-color);border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode .risk-score-level,.dark-mode .risk-score-value{color:#1e293b;color:var(--text-color)}.dark-mode .risk-factors{background:#f8fafc;background:var(--background-color);border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode .risk-factors-label{color:#1e293b;color:var(--text-color)}.dark-mode .risk-factors-list{color:#6b7280;color:var(--text-secondary)}.dark-mode .risk-breakdown-item{background:#f8fafc;background:var(--background-color);border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode .risk-breakdown-label,.dark-mode .role-cell{color:#1e293b;color:var(--text-color)}.dark-mode .role-cell{border-color:#e2e8f0;border-color:var(--border-color)}@media (max-width:768px){.risk-score-main{flex-direction:column;gap:.5rem;text-align:center}.risk-score-value{font-size:1.5rem;min-width:auto}.risk-score-level{font-size:1rem}.risk-breakdown{gap:.75rem;grid-template-columns:1fr}.risk-breakdown-item{flex-direction:column;gap:.5rem;text-align:center}.enhanced-metrics-grid{gap:1rem;grid-template-columns:1fr}.metric-card{padding:1rem}.metric-row{flex-direction:column;gap:.25rem;text-align:center}}.loading-tasks-row{padding:20px;text-align:center}.loading-tasks{align-items:center;color:#6b7280;display:flex;gap:12px;justify-content:center}.loading-spinner{animation:spin 1s linear infinite;border:2px solid #e5e7eb;border-radius:50%;border-top-color:#3b82f6;height:20px;width:20px}.tasks-cell{align-items:center;display:flex;flex-direction:column;gap:4px}.total-tasks{color:#1f2937;font-size:16px;font-weight:600}.completed-tasks{color:#6b7280;font-size:12px}.risk-cell{justify-content:center}.risk-badge,.risk-cell{align-items:center;display:flex}.risk-badge{border-radius:12px;font-size:12px;font-weight:600;gap:4px;padding:4px 8px}.risk-badge,.risk-badge.high{background-color:#ef44441a}.risk-badge.medium{background-color:#f59e0b1a}.risk-badge.low{background-color:#10b9811a}.risk-score-cell{align-items:center;display:flex;justify-content:center}.risk-score{background-color:#0000000d;border-radius:6px;font-size:14px;font-weight:600;padding:4px 8px}.load-more-container{display:flex;justify-content:center;margin-top:1rem;padding:1rem 0}.load-more-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:.5rem;box-shadow:0 2px 4px #0000001a;color:#fff;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .2s ease}.load-more-button:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.loading-more{align-items:center;color:#6b7280;display:flex;font-size:.875rem;gap:.5rem;justify-content:center;margin-top:1rem;padding:1rem}
/*# sourceMappingURL=main.9abd920d.css.map*/