*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;color:#000;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}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#e5e7eb}::-webkit-scrollbar-thumb{background:#9ca3af;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#6b7280}.change-password-modal{max-width:450px;width:90%}.change-password-form{display:flex;flex-direction:column;gap:20px;padding:20px}.password-input-wrapper{align-items:center;display:flex;position:relative}.password-input-wrapper input{background-color:#fff;border:1px solid #d1d5db;border-radius:6px;color:#1f2937;flex:1 1;font-size:14px;padding:10px 40px 10px 12px;transition:border-color .2s ease;width:100%}.password-input-wrapper input:focus{border-color:#3b82f6;outline:none}.toggle-password{color:#6b7280;right:10px}.toggle-password:hover{color:#374151}.error-message{font-size:14px}.success-message{background-color:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;color:#16a34a;font-size:14px;padding:12px}.modal-actions{margin-top:10px}.cancel-btn{color:#374151}.cancel-btn,.save-btn{border:none;cursor:pointer;transition:background-color .2s}.save-btn{background-color:#3b82f6}.save-btn:hover{background-color:#2563eb}.save-btn:disabled{background-color:#93c5fd;cursor:not-allowed}.header{background-color:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;padding:0 20px}.header-content{height:60px;justify-content:space-between;margin:0 auto;max-width:1600px}.header-content,.header-left{align-items:center;display:flex}.header-left{gap:40px}.logo{align-items:center;display:flex;font-size:18px;font-weight:600;gap:8px}.logo-icon{font-size:24px}.logo-text{color:#000;font-weight:700}.nav{display:flex;gap:24px}.nav-link{background:none;border:none;color:#374151;cursor:pointer;font-size:14px;font-weight:500;padding:8px 0;text-decoration:none;transition:all .2s ease}.nav-link:hover{color:#000}.nav-link.active{border-bottom-color:#3b82f6;color:#000}.header-right,.user-section{align-items:center;display:flex;gap:12px}.user-name{color:#111827;font-size:14px;font-weight:600}.user-role{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:20px;color:#fff;font-size:11px;font-weight:600;padding:4px 10px;text-transform:uppercase}.logout-btn{align-items:center;background:#ef44441a;border:none;border-radius:8px;color:#ef4444;cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .2s}.logout-btn:hover{background:#ef444433}.change-password-btn{align-items:center;background:#3b82f61a;border:none;border-radius:8px;color:#3b82f6;cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .2s}.change-password-btn:hover{background:#3b82f633}.login-link{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:8px;color:#fff;font-size:14px;font-weight:500;padding:8px 16px;text-decoration:none;transition:all .2s}.login-link:hover{box-shadow:0 4px 12px #6366f166;transform:translateY(-1px)}.nav-dropdown{position:relative}.nav-dropdown .nav-link{align-items:center;cursor:pointer;display:flex;gap:6px}.dropdown-menu{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 40px #00000026;display:none;left:0;min-width:160px;padding:8px 0;position:absolute;top:100%;z-index:100}.nav-dropdown:hover .dropdown-menu{display:block}.dropdown-menu a{align-items:center;color:#374151;display:flex;font-size:14px;gap:8px;padding:10px 16px;text-decoration:none;transition:all .2s}.dropdown-menu a.active,.dropdown-menu a:hover{background:#f3f4f6;color:#000}.import-btn{align-items:center;background-color:#3b82f6;border-radius:6px;color:#fff;display:flex;font-size:14px;font-weight:500;gap:6px;padding:8px 16px}.import-btn:hover{background-color:#2563eb}.dashboard-metrics-cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr);margin-bottom:24px}.dashboard-metric-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;gap:8px;padding:20px 24px;transition:all .2s ease}.dashboard-metric-card:hover{border-color:#d1d5db;box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.dashboard-metric-title{color:#374151;font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.dashboard-metric-value{font-size:20px;font-weight:700;line-height:1}.projects-section{background-color:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.projects-header{background-color:#f9fafb;border-bottom:1px solid #e5e7eb;padding:20px}.filters{display:flex;gap:8px;margin-bottom:16px}.filter-btn{align-items:center;background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#374151;display:flex;font-size:13px;font-weight:600;gap:6px;padding:8px 16px}.filter-btn:hover{background-color:#e5e7eb;color:#000}.filter-btn.active{background-color:#3b82f6;border-color:#3b82f6;color:#fff}.filter-btn .count{background-color:#fff3;border-radius:4px;font-size:11px;padding:2px 6px}.filter-dropdowns{align-items:center;display:flex;gap:12px}.filter-select{color:#1f2937;cursor:pointer;font-size:13px;max-width:160px;min-width:120px;width:auto}.filter-select:hover{border-color:#9ca3af}.new-project-btn{align-items:center;background-color:#10b981;border-radius:6px;color:#fff;display:flex;font-size:13px;font-weight:500;gap:6px;margin-left:auto;padding:8px 16px}.new-project-btn:hover{background-color:#059669}.projects-table{border-collapse:collapse;width:100%}.projects-table thead{background-color:#f9fafb}.projects-table th{border-bottom:1px solid #e5e7eb;color:#374151;font-size:11px;font-weight:700;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.projects-table th:last-child{text-align:center}.projects-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background-color .2s ease}.projects-table tbody tr:hover{background-color:#f9fafb}.projects-table td{color:#000;font-size:13px;font-weight:500;padding:16px;vertical-align:top}.projects-table td:last-child{text-align:center}.project-name strong{color:#000;display:block;font-weight:600;margin-bottom:4px}.project-name-link{transition:color .2s ease}.project-name-link:hover{color:#3b82f6}.project-clients{color:#6b7280;font-size:12px}.project-last-updated,.project-owner{color:#374151;font-size:13px;white-space:nowrap}.badge{display:inline-block;padding:4px 10px}.inline-select{border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;min-width:90px;outline:none;padding:4px 8px;transition:all .2s ease}.inline-select:hover{box-shadow:0 2px 4px #0003;filter:brightness(1.1)}.inline-select:focus{box-shadow:0 0 0 2px #3b82f64d}.priority-select,.stage-select,.status-select{background-color:inherit;color:inherit}.summary{color:#6b7280;line-height:1.5;max-width:400px}.summary-clients{color:#9ca3af;font-size:11px;font-style:italic;margin-top:6px}.link-icon{border-radius:4px;color:#3b82f6;display:inline-flex;padding:4px;transition:all .2s ease}.link-icon:hover{background-color:#3b82f61a;color:#60a5fa}.action-buttons{gap:8px}.action-btn{height:32px;width:32px}.action-btn svg{height:16px;width:16px}.edit-btn{border-color:#3b82f6}.delete-btn{border-color:#ef4444;color:#ef4444}.delete-btn:hover{background-color:#ef4444;color:#fff}.export-btn{align-items:center;background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;gap:6px;margin-right:8px;padding:6px 12px;transition:all .2s ease}.export-btn:hover{background-color:#e5e7eb;color:#2563eb}.tooltip-cell{position:relative}.ellipsis-text{display:block;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tooltip-cell:hover:after{word-wrap:break-word;background-color:#1f2937;border-radius:6px;box-shadow:0 4px 6px -1px #0000001a;color:#fff;content:attr(data-tooltip);font-size:12px;left:0;margin-top:4px;max-width:300px;padding:8px 12px;position:absolute;top:100%;white-space:normal;z-index:1000}.tooltip-cell:hover:before{border:6px solid;border-color:#0000 #0000 #1f2937;content:"";left:10px;margin-top:-8px;position:absolute;top:100%;z-index:1001}.empty-state,.loading{color:#6b7280;padding:60px 20px;text-align:center}.priority-badge,.stage-badge,.status-badge{align-items:center;border-radius:6px;display:inline-flex;font-size:13px;font-weight:600;letter-spacing:.5px;padding:6px 12px;text-transform:uppercase}.latest-update{color:#4b5563;font-size:13px;line-height:1.4;max-width:300px}.latest-update .update-text{margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.latest-update .update-author{color:#9ca3af;font-size:11px;font-style:italic}.modal-body{display:flex;flex-direction:column;gap:20px}.dropzone{background-color:#f9fafb;border:2px dashed #d1d5db;border-radius:8px;cursor:pointer;padding:40px;text-align:center;transition:all .3s ease}.dropzone.dragging,.dropzone:hover{background-color:#3b82f60d;border-color:#3b82f6}.dropzone svg{color:#6b7280;margin-bottom:16px}.dropzone-text{color:#1f2937;font-size:14px;margin-bottom:8px}.dropzone-subtext{color:#6b7280;font-size:12px;margin-bottom:16px}.file-input-label{background-color:#3b82f6;color:#fff;display:inline-block;font-weight:500;padding:10px 20px;transition:background-color .2s ease}.file-input-label:hover{background-color:#2563eb}.file-input{display:none}.format-info{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px}.format-info h4{color:#1f2937;font-size:14px;margin-bottom:12px}.format-info ul{list-style:none;margin:0;padding:0}.format-info li{border-bottom:1px solid #e5e7eb;color:#4b5563;font-size:13px;padding:6px 0}.format-info li:last-child{border-bottom:none}.format-info strong{color:#3b82f6;font-family:monospace}.modal-actions{margin-top:8px}.cancel-btn{background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#1f2937;font-size:14px;font-weight:500;padding:10px 20px}.cancel-btn:hover{background-color:#e5e7eb}.import-btn-modal{background-color:#3b82f6;border-radius:6px;color:#fff;font-size:14px;font-weight:500;padding:10px 20px}.import-btn-modal:hover:not(:disabled){background-color:#2563eb}.import-btn-modal:disabled{cursor:not-allowed;opacity:.5}.project-modal{max-width:700px}.project-form{display:flex;flex-direction:column;gap:20px}.form-group{gap:8px}.form-group label{color:#1f2937}.form-group input,.form-group select,.form-group textarea{background-color:#fff;color:#1f2937;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3b82f6}.form-group textarea{font-family:inherit}.save-btn{background-color:#10b981;border-radius:6px;color:#fff;font-size:14px;font-weight:500;padding:10px 20px}.save-btn:hover{background-color:#059669}.client-select-container{display:flex;flex-direction:column;gap:8px}.selected-clients{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;display:flex;flex-wrap:wrap;gap:8px;min-height:36px;padding:4px}.client-tag{background-color:#dbeafe;border-radius:16px;display:inline-flex;font-size:13px;font-weight:500;gap:6px;padding:6px 12px}.client-tag,.remove-client{align-items:center;color:#1e40af}.remove-client{background:none;border:none;border-radius:50%;cursor:pointer;display:flex;justify-content:center;padding:2px;transition:background-color .2s}.remove-client:hover{background-color:#bfdbfe}.client-dropdown-wrapper{position:relative}.client-input-wrapper{align-items:center;background-color:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;display:flex;gap:8px;padding:10px 12px;transition:border-color .2s ease}.client-input-wrapper:focus-within,.client-input-wrapper:hover{border-color:#3b82f6}.search-icon{color:#9ca3af;flex-shrink:0}.client-search-input{background:none;border:none;color:#1f2937;flex:1 1;font-size:14px;outline:none;padding:0}.client-search-input::placeholder{color:#9ca3af}.dropdown-arrow{color:#6b7280;flex-shrink:0;transition:transform .2s ease}.dropdown-arrow.open{transform:rotate(180deg)}.client-dropdown{background-color:#fff;border:1px solid #e5e7eb;border-radius:6px;box-shadow:0 10px 15px -3px #0000001a;left:0;margin-top:4px;max-height:200px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:100}.client-option{color:#374151;cursor:pointer;font-size:14px;padding:10px 12px;transition:background-color .15s ease}.client-option:hover{background-color:#f3f4f6}.client-option.no-results{color:#9ca3af;cursor:default}.client-option.no-results:hover{background-color:initial}.client-option.add-new{align-items:center;border-top:1px solid #e5e7eb;color:#2563eb;display:flex;font-weight:500;gap:8px}.client-option.add-new:hover{background-color:#eff6ff}.clients-readonly{background-color:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;display:flex;flex-wrap:wrap;gap:8px;min-height:36px;padding:8px 12px}.client-tag.readonly{background-color:#e5e7eb;color:#4b5563;cursor:default;padding:6px 12px}.no-clients{color:#9ca3af;font-size:14px;font-style:italic}.details-modal{max-width:500px}.details-form{display:flex;flex-direction:column;gap:16px}.details-form .form-group{display:flex;flex-direction:column;gap:6px}.details-form .form-group label{color:#6b7280;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.details-form .form-group input,.details-form .form-group select{background-color:#fff;border:1px solid #d4d4d8;border-radius:4px;color:#18181b;font-size:14px;padding:10px 12px;transition:border-color .2s ease}.details-form .form-group input:focus,.details-form .form-group select:focus{border-color:#3b82f6;outline:none}.details-form .form-group input::placeholder{color:#9ca3af}.save-changes-btn{background-color:#3b82f6;border-radius:6px;color:#fff;font-size:14px;font-weight:500;padding:10px 20px}.save-changes-btn:hover{background-color:#2563eb}.excel-upload-modal{max-width:90vw;width:500px}.excel-upload-modal .modal-body{padding:24px}.form-select{background-color:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:14px;padding:10px 12px;transition:border-color .2s;width:100%}.form-select:hover{border-color:#9ca3af}.form-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-select:disabled{background-color:#f3f4f6;cursor:not-allowed}.file-name-hint{background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;color:#1e40af;font-size:13px;margin-bottom:20px;padding:12px}.file-input-wrapper{position:relative}.file-input{height:0;opacity:0;position:absolute;width:0}.file-input-label{align-items:center;background-color:#f9fafb;border:2px dashed #d1d5db;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;font-size:14px;gap:10px;padding:10px 16px;transition:all .2s}.file-input-label:hover{background-color:#eff6ff;border-color:#3b82f6;color:#3b82f6}.error-message{background-color:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#dc2626;font-size:13px;padding:12px}.upload-info{background-color:#f9fafb;border-radius:6px;margin-top:20px;padding:16px}.upload-info p{color:#6b7280;font-size:13px;margin:0 0 8px}.upload-info p:last-child{margin-bottom:0}.upload-info strong{color:#374151}.modal-footer{border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.btn-secondary{background-color:#fff;padding:10px 20px}.btn-secondary:hover:not(:disabled){background-color:#f3f4f6;border-color:#9ca3af}.btn-secondary:disabled{cursor:not-allowed;opacity:.5}.btn-primary{padding:10px 20px}.btn-primary:hover:not(:disabled){background-color:#2563eb}:root{--color-primary-50:#eff6ff;--color-primary-100:#dbeafe;--color-primary-200:#bfdbfe;--color-primary-500:#3b82f6;--color-primary-600:#2563eb;--color-primary-700:#1d4ed8;--color-success:#10b981;--color-success-light:#dcfce7;--color-warning:#f59e0b;--color-warning-light:#fef3c7;--color-danger:#ef4444;--color-danger-light:#fee2e2;--color-info:#3b82f6;--color-info-light:#dbeafe;--color-gray-50:#f9fafb;--color-gray-100:#f3f4f6;--color-gray-200:#e5e7eb;--color-gray-300:#d1d5db;--color-gray-400:#9ca3af;--color-gray-500:#6b7280;--color-gray-600:#4b5563;--color-gray-700:#374151;--color-gray-800:#1f2937;--color-gray-900:#111827;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 1px 3px #0000001a;--shadow-lg:0 4px 6px #0000001a;--shadow-xl:0 10px 15px #0000001a;--font-size-xs:11px;--font-size-sm:12px;--font-size-md:13px;--font-size-lg:14px;--font-size-xl:16px;--font-size-2xl:20px;--font-size-3xl:24px;--font-normal:400;--font-medium:500;--font-semibold:600;--font-bold:700}.card{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--color-gray-200);border-radius:16px;border-radius:var(--radius-xl);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-md);padding:20px;padding:var(--space-5)}.card-hover{cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.card-hover:hover{box-shadow:0 16px 32px #0f172a26;transform:translateY(-2px)}.card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px;margin-bottom:var(--space-4)}.card-title{color:#1f2937;color:var(--color-gray-800);font-size:14px;font-size:var(--font-size-lg);font-weight:600;font-weight:var(--font-semibold);margin:0}.card-primary{background:linear-gradient(135deg,#dbeafe,#bfdbfe);background:linear-gradient(135deg,var(--color-primary-100) 0,var(--color-primary-200) 100%);border-color:#bfdbfe;border-color:var(--color-primary-200)}.card-success{background:linear-gradient(135deg,#dcfce7,#bbf7d0);background:linear-gradient(135deg,var(--color-success-light) 0,#bbf7d0 100%);border-color:#86efac}.card-warning{background:linear-gradient(135deg,#fef3c7,#fde68a);background:linear-gradient(135deg,var(--color-warning-light) 0,#fde68a 100%);border-color:#fcd34d}.card-danger{background:linear-gradient(135deg,#fee2e2,#fecaca);background:linear-gradient(135deg,var(--color-danger-light) 0,#fecaca 100%);border-color:#fca5a5}.card-default{background:#f9fafb;background:var(--color-gray-50);border-color:#e5e7eb;border-color:var(--color-gray-200)}.data-table{border-collapse:collapse;font-size:13px;font-size:var(--font-size-md);width:100%}.data-table thead{background-color:#1f2937;background-color:var(--color-gray-800)}.data-table th{color:#fff;font-size:11px;font-size:var(--font-size-xs);font-weight:600;font-weight:var(--font-semibold);letter-spacing:.5px;text-align:left;text-transform:uppercase}.data-table td,.data-table th{padding:12px;padding:var(--space-3)}.data-table td{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--color-gray-200);color:#1f2937;color:var(--color-gray-800)}.data-table tbody tr:hover{background-color:#f9fafb;background-color:var(--color-gray-50)}.badge{align-items:center;border-radius:6px;border-radius:var(--radius-sm);display:inline-flex;font-size:var(--font-size-xs);font-weight:500;font-weight:var(--font-medium);letter-spacing:.05em;padding:4px 8px;padding:var(--space-1) var(--space-2);text-transform:uppercase}.badge-success{background-color:#10b98133;color:#10b981;color:var(--color-success)}.badge-warning{background-color:#f59e0b33;color:#f59e0b;color:var(--color-warning)}.badge-danger{background-color:#ef444433;color:#ef4444;color:var(--color-danger)}.badge-info{background-color:#3b82f633;color:#3b82f6;color:var(--color-info)}.badge-gray{background-color:#e5e7eb;background-color:var(--color-gray-200);color:#4b5563;color:var(--color-gray-600)}.status-dot{height:10px;width:10px}.status-dot-success{background-color:#10b981;background-color:var(--color-success)}.status-dot-warning{background-color:#f59e0b;background-color:var(--color-warning)}.status-dot-danger{background-color:#ef4444;background-color:var(--color-danger)}.status-dot-info{background-color:#3b82f6;background-color:var(--color-info)}.modal-content{box-shadow:0 10px 15px #0000001a}.modal-header{padding:20px}.modal-title{color:#1f2937;color:var(--color-gray-800);font-size:20px;font-weight:600}.modal-body{padding:20px}.input{border:1px solid #e5e7eb;border:1px solid var(--color-gray-200);border-radius:8px;border-radius:var(--radius-md);font-size:13px;font-size:var(--font-size-md);outline:none;padding:8px 12px;padding:var(--space-2) var(--space-3);transition:border-color .2s ease;width:100%}.input:focus{border-color:#3b82f6;border-color:var(--color-primary-500)}.input-search{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E");background-position:12px;background-repeat:no-repeat;padding-left:40px}.btn{align-items:center;border:1px solid #0000;border-radius:8px;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-size:13px;font-size:var(--font-size-md);font-weight:500;font-weight:var(--font-medium);gap:8px;gap:var(--space-2);justify-content:center;padding:8px 16px;padding:var(--space-2) var(--space-4);transition:all .2s ease}.btn-primary{background-color:#3b82f6;background-color:var(--color-primary-500);border-color:#3b82f6;border-color:var(--color-primary-500)}.btn-primary:hover{background-color:#2563eb;background-color:var(--color-primary-600)}.btn-secondary{background-color:var(--color-gray-100);border-color:#d1d5db;border-color:var(--color-gray-300);color:var(--color-gray-700)}.btn-secondary:hover{background-color:var(--color-gray-200)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px;gap:var(--space-2)}.gap-3{gap:12px;gap:var(--space-3)}.gap-4{gap:16px;gap:var(--space-4)}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-sm{font-size:12px;font-size:var(--font-size-sm)}.text-md{font-size:13px;font-size:var(--font-size-md)}.text-lg{font-size:14px;font-size:var(--font-size-lg)}.font-medium{font-weight:500;font-weight:var(--font-medium)}.font-semibold{font-weight:600;font-weight:var(--font-semibold)}.font-bold{font-weight:700;font-weight:var(--font-bold)}.text-gray{color:#6b7280;color:var(--color-gray-500)}.text-dark{color:#1f2937;color:var(--color-gray-800)}.raid-log-container{display:flex;flex-direction:column;gap:var(--space-6)}.raid-summary{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.raid-stat{background-color:#fff;border:1px solid var(--color-gray-300);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:var(--space-5);text-align:center}.raid-stat.risk{border-left:3px solid var(--color-danger)}.raid-stat.assumption{border-left:3px solid var(--color-info)}.raid-stat.issue{border-left:3px solid var(--color-warning)}.raid-stat.dependency{border-left:3px solid #8b5cf6}.raid-table-container{overflow-x:auto}.raid-table{border-collapse:collapse;font-size:var(--font-size-md);width:100%}.raid-table thead{background-color:var(--color-gray-800)}.raid-table th{border-bottom:2px solid var(--color-gray-700);color:var(--color-gray-300);font-size:var(--font-size-xs);font-weight:var(--font-semibold);letter-spacing:.5px;padding:var(--space-3);text-align:left;text-transform:uppercase}.raid-table td{border-bottom:1px solid var(--color-gray-200);color:var(--color-gray-800);padding:var(--space-3)}.raid-table tbody tr:hover{background-color:var(--color-gray-50)}.raid-type{align-items:center;border-radius:var(--radius-sm);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-semibold);letter-spacing:.05em;padding:var(--space-1) 10px;text-transform:uppercase}.raid-type.risk{background-color:#ef444433;color:var(--color-danger)}.raid-type.assumption{background-color:#3b82f633;color:var(--color-info)}.raid-type.issue{background-color:#f59e0b33;color:var(--color-warning)}.raid-type.dependency{background-color:#8b5cf633;color:#8b5cf6}.raid-status-badge{align-items:center;border-radius:var(--radius-sm);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-medium);padding:var(--space-1) 10px}.raid-status-badge.notstarted{background-color:var(--color-gray-200);color:var(--color-gray-500)}.raid-status-badge.inprogress{background-color:#3b82f633;color:var(--color-info)}.raid-status-badge.behind{background-color:#ef444433;color:var(--color-danger)}.raid-status-badge.complete{background-color:#10b98133;color:var(--color-success)}.severity-badge{align-items:center;border-radius:var(--radius-sm);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-semibold);padding:var(--space-1) 10px}.severity-badge.critical{background-color:#ef444433;color:var(--color-danger)}.severity-badge.high{background-color:#f59e0b33;color:var(--color-warning)}.severity-badge.medium{background-color:#eab30833;color:#eab308}.severity-badge.low{background-color:#10b98133;color:var(--color-success)}.project-documents{margin-top:30px}.documents-tabs{border-bottom:2px solid #e5e7eb;display:flex;gap:8px;margin-bottom:24px;overflow-x:auto;padding-bottom:2px}.doc-tab{align-items:center;background:none;border:none;border-bottom:2px solid #0000;color:#374151;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;margin-bottom:-2px;padding:12px 16px;transition:all .2s ease;white-space:nowrap}.doc-tab:hover{background-color:#3b82f60d;color:#000}.doc-tab.active{border-bottom-color:#3b82f6;color:#000;font-weight:700}.documents-content{background-color:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000001a;min-height:400px;padding:24px}.document-content h3{color:#1f2937;font-size:20px;font-weight:600;margin-bottom:16px}.placeholder-text{background-color:#f9fafb;border-radius:6px;padding:20px}.empty-state,.loading-state,.placeholder-text{color:#6b7280;font-size:14px;text-align:center}.empty-state,.loading-state{padding:40px}.raid-insights-container{margin-bottom:var(--space-6)}.raid-insights-container h3{color:var(--color-gray-800);font-size:var(--font-size-xl);font-weight:var(--font-semibold);margin-bottom:var(--space-4)}.insights-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.insight-card{background-color:#fff;border:1px solid var(--color-gray-200);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:var(--space-5);text-align:center}.insight-value{color:var(--color-primary-500);font-size:28px;font-weight:var(--font-bold);margin-bottom:var(--space-2)}.insight-label{color:var(--color-gray-500);font-size:var(--font-size-sm);letter-spacing:.5px;text-transform:uppercase}.risk-matrix{border-top:1px solid var(--color-gray-200);margin-top:var(--space-6);padding-top:var(--space-6)}.risk-matrix h3{color:var(--color-gray-800);font-size:var(--font-size-xl);font-weight:var(--font-semibold);margin-bottom:var(--space-4)}.raid-header-controls{display:flex;flex-direction:column;gap:var(--space-5)}.view-toggle{gap:8px}.toggle-btn{background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#1f2937;font-size:13px;font-weight:500;padding:8px 20px}.toggle-btn:hover{background-color:#e5e7eb;color:#000}.toggle-btn.active{background-color:#3b82f6;border-color:#3b82f6}.toggle-btn.refresh-btn{background-color:#10b981;border-color:#10b981;color:#fff;margin-right:10px}.toggle-btn.refresh-btn:hover{background-color:#059669;border-color:#059669}.raid-visualization-container{margin-top:20px}.executive-summary{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:30px}.summary-card{align-items:center;background:#fff;border:2px solid #d1d5db;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;gap:16px;padding:20px;transition:all .3s ease}.summary-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.summary-card.critical{background:#fff;border-color:#ef4444}.summary-card.open{background:#fff;border-color:#3b82f6}.summary-card.overdue{background:#fff;border-color:#f59e0b}.summary-card.total{background:#fff;border-color:#10b981}.summary-icon{font-size:36px;line-height:1}.summary-content{flex:1 1}.summary-value{color:#1f2937;font-size:32px;font-weight:700;line-height:1;margin-bottom:6px}.summary-label{color:#6b7280;font-size:13px;font-weight:600;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.summary-sublabel{color:#6b7280;font-size:11px;font-style:italic}.dashboard-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(2,1fr)}.viz-card{background-color:#fff;border:1px solid #d1d5db;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:24px}.viz-card.full-width{grid-column:1/-1}.viz-card h4{color:#1f2937;font-size:16px;font-weight:600;margin-bottom:20px}.column-chart{flex-direction:column;height:250px}.chart-area,.column-chart{display:flex;position:relative}.chart-area{align-items:flex-end;background-image:linear-gradient(0deg,#0000 0,#0000 calc(25% - 1px),#e5e7eb 25%,#0000 calc(25% + 1px)),linear-gradient(0deg,#0000 0,#0000 calc(50% - 1px),#e5e7eb 50%,#0000 calc(50% + 1px)),linear-gradient(0deg,#0000 0,#0000 calc(75% - 1px),#e5e7eb 75%,#0000 calc(75% + 1px));border-bottom:2px solid #d1d5db;border-left:2px solid #d1d5db;flex:1 1;gap:20px;justify-content:space-around;padding:40px 30px 15px}.column-item{align-items:center;display:flex;flex:1 1;flex-direction:column;height:100%}.column-item.clickable{cursor:pointer;transition:transform .2s ease}.column-item.clickable:hover{transform:translateY(-3px)}.column-item.clickable:hover .column-bar{box-shadow:0 4px 8px #0000004d;filter:brightness(1.2)}.column-bar-container{align-items:center;display:flex;flex-direction:column;height:100%;justify-content:flex-end;position:relative;width:100%}.column-bar{background-color:#71717a;border-radius:6px 6px 0 0;max-height:100%;position:relative;transition:all .3s ease;width:70%}.column-value{align-items:center;background-color:initial;border-radius:6px;color:#1f2937;display:flex;font-size:16px;font-weight:700;gap:4px;padding:4px 8px;position:absolute;top:-32px;white-space:nowrap}.column-percentage-inline{color:#6b7280;font-size:13px;font-weight:500}.column-label{word-wrap:break-word;color:#4b5563;font-size:12px;font-weight:500;max-width:100%;text-align:center}.chart-axis{padding:10px;text-align:center}.axis-label{color:#6b7280;font-size:12px;font-weight:500}.donut-chart-container{align-items:center;display:flex;gap:40px;justify-content:center;min-height:280px;padding:30px 20px}.donut-chart{flex-shrink:0;height:220px;width:220px}.donut-legend{display:flex;flex-direction:column;gap:14px}.legend-item{align-items:center;display:flex;gap:12px}.legend-item.clickable-legend{cursor:pointer;transition:transform .2s ease}.legend-item.clickable-legend:hover{transform:translateX(4px)}.legend-color{border-radius:4px;box-shadow:0 2px 4px #0003;flex-shrink:0;height:20px;width:20px}.legend-text{display:flex;flex-direction:column;gap:2px}.legend-label{color:#1f2937;font-size:14px;font-weight:600}.legend-count{color:#6b7280;font-size:12px;font-weight:500}.donut-center-label{fill:#6b7280;font-size:12px;font-weight:500}.donut-center-value{fill:#1f2937;font-size:24px;font-weight:700}@media (max-width:1024px){.executive-summary{grid-template-columns:repeat(2,1fr)}.dashboard-grid{grid-template-columns:1fr}.viz-card.full-width{grid-column:1}.donut-chart-container{flex-direction:column}}@media (max-width:640px){.executive-summary{grid-template-columns:1fr}}.category-modal-overlay{align-items:center;background-color:#000000bf;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.category-modal{background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:85vh;max-width:900px;width:100%}.category-modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:24px}.category-modal-header h3{align-items:center;color:#1f2937;display:flex;font-size:20px;font-weight:600;gap:12px;margin:0}.category-color-indicator{border-radius:4px;height:24px;width:8px}.modal-close-btn{color:#6b7280;line-height:1;padding:4px 8px;transition:color .2s ease}.modal-close-btn:hover{color:#1f2937}.category-modal-content{flex:1 1;overflow-y:auto;padding:24px}.no-items{color:#6b7280;font-size:14px;padding:40px;text-align:center}.raid-items-list{grid-gap:16px;display:grid;gap:16px}.raid-item-card{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:20px;transition:all .2s ease}.raid-item-card:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f633}.raid-item-header{display:flex;gap:10px;margin-bottom:12px}.raid-item-title{color:#1f2937;font-size:16px;font-weight:600;margin:0 0 8px}.raid-item-description{color:#4b5563;font-size:14px;line-height:1.5;margin:0 0 16px}.raid-item-details{grid-gap:12px;border-top:1px solid #e5e7eb;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));padding-top:16px}.detail-row{align-items:center;gap:8px}.detail-row.full-width{align-items:flex-start;flex-direction:column;grid-column:1/-1}.detail-label{color:#6b7280;font-size:12px;letter-spacing:.5px;text-transform:uppercase}.detail-value{color:#1f2937;font-size:13px}.charter-content .cover-sheet{background:linear-gradient(135deg,#1f2937,#374151);border-radius:8px;color:#fff;margin-bottom:24px;padding:30px;text-align:center}.project-title{font-size:28px;font-weight:700;margin:0 0 8px}.project-subtitle{font-size:18px;font-weight:400;margin:0;opacity:.9}.charter-fields{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.charter-field{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:16px}.charter-field label{color:#6b7280;display:block;font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.charter-field .field-value{color:#1f2937;font-size:14px;word-break:break-word}.plan-table-container{max-height:500px;overflow-x:auto;overflow-y:auto}.plan-table{border-collapse:collapse;font-size:13px;width:100%}.plan-table thead{position:sticky;top:0;z-index:10}.plan-table th{background-color:#1f2937;color:#d1d5db;font-size:11px;font-weight:600;letter-spacing:.5px;padding:12px;text-align:left;text-transform:uppercase}.plan-table td{border-bottom:1px solid #e5e7eb;color:#1f2937;padding:10px 12px}.plan-table tbody tr:hover{background-color:#f9fafb}.rag-indicator{border-radius:4px;display:inline-block;font-size:11px;font-weight:600;padding:4px 10px;text-transform:uppercase}.rag-indicator.green{background-color:#22c55e33;color:#22c55e}.rag-indicator.amber,.rag-indicator.yellow{background-color:#f59e0b33;color:#f59e0b}.rag-indicator.red{background-color:#ef444433;color:#ef4444}.milestones-list{grid-gap:16px;display:grid}.milestone-card{background:#f9fafb;border:1px solid #e5e7eb;border-left:4px solid #6b7280;border-radius:8px;padding:20px}.milestone-card.completed{border-left-color:#22c55e}.milestone-card.in-progress{border-left-color:#3b82f6}.milestone-card.behind{border-left-color:#ef4444}.milestone-header{align-items:center;display:flex;gap:12px;margin-bottom:12px}.milestone-ref{background:#e5e7eb;border-radius:4px;font-weight:600;padding:4px 8px}.milestone-ref,.milestone-wbs{color:#6b7280;font-size:12px}.milestone-status{border-radius:4px;font-size:11px;font-weight:600;margin-left:auto;padding:4px 10px;text-transform:uppercase}.milestone-name{color:#1f2937;font-size:16px;font-weight:600;margin-bottom:12px}.milestone-details{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.milestone-detail{display:flex;flex-direction:column;gap:4px}.milestone-detail label{color:#6b7280;font-size:11px;font-weight:600;text-transform:uppercase}.milestone-detail span{color:#1f2937;font-size:13px}.milestone-detail.variance .behind{color:#ef4444;font-weight:600}.milestone-detail.variance .ahead{color:#22c55e;font-weight:600}.milestone-notes{border-top:1px solid #e5e7eb;margin-top:12px;padding-top:12px}.milestone-notes label{color:#6b7280;display:block;font-size:11px;font-weight:600;margin-bottom:6px;text-transform:uppercase}.milestone-notes p{color:#4b5563;font-size:13px;line-height:1.5;margin:0}.stakeholders-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-bottom:24px}.stakeholder-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px}.stakeholder-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.stakeholder-name{color:#1f2937;font-size:15px;font-weight:600}.stakeholder-id{background:#e5e7eb;border-radius:4px;color:#6b7280;font-size:11px;padding:2px 6px}.stakeholder-role{color:#4b5563;font-size:13px;margin-bottom:8px}.stakeholder-contact label{color:#6b7280;font-size:11px;font-weight:600}.raci-section{border-top:2px solid #e5e7eb;margin-top:24px;padding-top:24px}.raci-section h4{color:#1f2937;font-size:16px;font-weight:600;margin-bottom:16px}.raci-table-container{overflow-x:auto}.raci-table{border-collapse:collapse;font-size:13px;width:100%}.raci-table th{background-color:#f3f4f6;border-bottom:2px solid #e5e7eb;color:#6b7280;font-size:11px;font-weight:600;padding:10px 12px;text-align:left;text-transform:uppercase}.raci-table td{border-bottom:1px solid #e5e7eb;color:#1f2937;padding:10px 12px}.cadence-list{grid-gap:16px;display:grid;gap:16px}.meeting-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:20px}.meeting-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.meeting-name{color:#1f2937;font-size:16px;font-weight:600}.meeting-type{background:#e5e7eb;border-radius:4px;color:#6b7280;font-size:11px;font-weight:600;padding:4px 10px;text-transform:uppercase}.meeting-details{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));margin-bottom:12px}.meeting-detail{display:flex;flex-direction:column;gap:4px}.meeting-detail label{color:#6b7280;font-size:11px;font-weight:600;text-transform:uppercase}.meeting-detail span{color:#1f2937;font-size:13px}.meeting-agenda{border-top:1px solid #e5e7eb;padding-top:12px}.meeting-agenda label{color:#6b7280;display:block;font-size:11px;font-weight:600;margin-bottom:6px;text-transform:uppercase}.meeting-agenda p{color:#4b5563;font-size:13px;line-height:1.5;margin:0}.resource-management{margin-bottom:24px}.resource-summary{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.resource-field{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:16px}.resource-field label{color:#6b7280;display:block;font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.availability-section,.change-management-section{border-top:2px solid #e5e7eb;margin-top:24px;padding-top:24px}.availability-section h4,.change-management-section h4{color:#1f2937;font-size:16px;font-weight:600;margin-bottom:16px}.availability-list,.changes-list{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.availability-card,.change-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:12px}.availability-id,.change-id{color:#6b7280;font-size:12px;font-weight:600;margin-bottom:6px}.availability-details{display:flex;flex-wrap:wrap;gap:8px}.availability-details span{background:#e5e7eb;border-radius:4px;font-size:12px;padding:2px 8px}.unavailable-type{color:#ef4444!important}.change-status{color:#4b5563;font-size:12px}.closure-checklist{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-top:24px;padding:20px}.closure-checklist h4{color:#1f2937;font-size:16px;font-weight:600;margin-bottom:16px}.closure-checklist ul{list-style:none;margin:0;padding:0}.closure-checklist li{border-bottom:1px solid #e5e7eb;color:#4b5563;font-size:14px;padding:8px 0}.closure-checklist li:last-child{border-bottom:none}.charter-header-banner{background:linear-gradient(135deg,#1f2937,#374151);border-radius:8px;color:#fff;margin-bottom:24px;padding:24px 30px;text-align:center}.charter-title{color:#fff;font-size:24px;font-weight:700;margin:0}.charter-basic-info{background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:24px;overflow:hidden}.info-row{border-bottom:1px solid #e5e7eb;display:grid;grid-template-columns:repeat(3,1fr)}.info-row:last-child{border-bottom:none}.info-cell{border-right:1px solid #e5e7eb;display:flex;flex-direction:column;gap:6px;padding:16px 20px}.info-cell:last-child{border-right:none}.info-cell label{color:#6b7280;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.info-value{color:#1f2937;font-size:14px;font-weight:500}.info-value.budget{color:#10b981;font-weight:600}.info-value.complexity{border-radius:4px;display:inline-block;font-weight:600;padding:4px 10px;width:fit-content}.info-value.complexity.high{background-color:#ef44441a;color:#ef4444}.info-value.complexity.medium{background-color:#f59e0b1a;color:#f59e0b}.info-value.complexity.low{background-color:#22c55e1a;color:#22c55e}.charter-sections-two-col{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:24px}.charter-section{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px}.charter-section h4{color:#1f2937;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 16px;text-transform:uppercase}.section-content-box{background:#f9fafb;border-radius:6px;min-height:120px;padding:16px}.section-content-box p{color:#374151;font-size:13px;line-height:1.6;margin:0;white-space:pre-line}.deliverables-list{list-style:disc;margin:0;padding-left:20px}.deliverables-list li{color:#374151;font-size:13px;line-height:1.6;margin-bottom:6px}.no-data{color:#9ca3af;font-size:13px;font-style:italic}.more-details-btn{background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:13px;font-weight:600;margin-bottom:20px;padding:12px 20px;transition:all .2s ease;width:100%}.more-details-btn:hover{background:#e5e7eb;border-color:#9ca3af}.charter-expanded-details{animation:expandIn .3s ease-out}@keyframes expandIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.scope-section{margin-bottom:20px}.scope-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.scope-column{background:#f9fafb;border-radius:6px;padding:16px}.scope-column h5{color:#6b7280;font-size:12px;font-weight:600;margin:0 0 12px;text-transform:uppercase}.scope-column ul{list-style:disc;margin:0;padding-left:20px}.scope-column li{color:#374151;font-size:13px;line-height:1.5;margin-bottom:8px}.scope-column.included{border-left:3px solid #22c55e}.scope-column.excluded{border-left:3px solid #ef4444}.charter-milestones-table,.charter-risks-table{border-collapse:collapse;font-size:13px;width:100%}.charter-milestones-table th,.charter-risks-table th{background:#f3f4f6;border-bottom:2px solid #e5e7eb;color:#6b7280;font-size:11px;font-weight:600;padding:10px 12px;text-align:left;text-transform:uppercase}.charter-milestones-table td,.charter-risks-table td{border-bottom:1px solid #e5e7eb;color:#374151;padding:10px 12px}.charter-milestones-table tbody tr:hover,.charter-risks-table tbody tr:hover{background:#f9fafb}.risk-badge{border-radius:4px;display:inline-block;font-size:11px;font-weight:600;padding:4px 10px;text-transform:uppercase}.risk-badge.high{background-color:#ef444426;color:#ef4444}.risk-badge.medium{background-color:#f59e0b26;color:#f59e0b}.risk-badge.low{background-color:#22c55e26;color:#22c55e}.charter-risks-table tbody tr.risk-high{background-color:#ef44440d}.charter-risks-table tbody tr.risk-medium{background-color:#f59e0b0d}.charter-risks-table tbody tr.risk-low{background-color:#22c55e0d}@media (max-width:1024px){.charter-sections-two-col,.info-row,.scope-grid{grid-template-columns:1fr}.info-cell{border-bottom:1px solid #e5e7eb;border-right:none}.info-cell:last-child{border-bottom:none}}.project-dashboard{background:#f9fafb;border-radius:12px;margin-bottom:24px;padding:24px}.dashboard-header{grid-gap:24px;align-items:center;border-bottom:1px solid #e5e7eb;display:grid;gap:24px;grid-template-columns:200px 1fr auto;margin-bottom:24px;padding-bottom:16px}.dashboard-header-left{align-items:center;display:flex}.dashboard-header-center{flex:1 1}.dashboard-header-center h2{color:#111827;font-size:24px;font-weight:700;margin:0 0 8px}.dashboard-meta{color:#6b7280;font-size:13px;gap:16px}.dashboard-meta,.meta-item{align-items:center;display:flex}.meta-item{gap:4px}.refresh-btn{align-items:center;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;display:flex;font-size:12px;font-weight:500;gap:6px;padding:6px 12px;transition:all .2s}.refresh-btn:hover{background:#e5e7eb;border-color:#9ca3af}.dashboard-header-right{align-items:center;display:flex;justify-content:flex-end}.overall-status-badge{border-radius:8px;color:#fff;min-width:140px;padding:12px 24px;text-align:center}.status-label{font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:4px}.status-value{font-size:20px;font-weight:700;letter-spacing:1px}.metrics-grid{grid-gap:12px;gap:12px;margin-bottom:16px}.project-dashboard .dashboard-metrics-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(6,minmax(0,1fr));margin-bottom:20px}.project-dashboard .dashboard-metrics-row::-webkit-scrollbar{height:6px}.project-dashboard .dashboard-metrics-row::-webkit-scrollbar-thumb{background:#94a3b899;border-radius:999px}.project-dashboard .metric-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #00000014;display:flex;flex-direction:column;min-width:0;padding:14px 12px}.project-dashboard .metric-card.primary{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;color:#fff}.project-dashboard .metric-card.alert{border-left:4px solid #f59e0b}.project-dashboard .metric-label{color:#6b7280;font-size:11px;font-weight:600;letter-spacing:.4px;margin-bottom:6px;overflow:hidden;text-overflow:ellipsis;text-transform:uppercase;white-space:nowrap}.project-dashboard .metric-card.primary .metric-label{color:#ffffffe6}.project-dashboard .metric-value{color:#111827;font-size:26px;font-weight:700;line-height:1.2;margin-bottom:4px;word-break:break-word}.project-dashboard .metric-value-large{align-items:center;color:#fff;display:flex;font-size:30px;font-weight:700;gap:6px;line-height:1.2}.project-dashboard .metric-trend{align-items:center;display:flex;font-size:12px;gap:4px}.project-dashboard .metric-trend.success{color:#ffffffe6}.project-dashboard .metric-sublabel{color:#6b7280;font-size:12px;white-space:nowrap}.project-dashboard .highlight-blue{color:#3b82f6}.project-dashboard .highlight-red{color:#dc2626}.project-dashboard .highlight-orange{color:#f59e0b}.project-dashboard .metric-card.clickable:hover{box-shadow:0 4px 6px #0000001a;transform:translateY(-2px);transition:all .2s ease}.metrics-grid-secondary{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:24px}.metric-card-small{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #00000014;display:flex;gap:12px;padding:20px}.metric-icon{align-items:center;border-radius:8px;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.metric-icon.risk{background:#fee2e2;color:#dc2626}.metric-icon.issue{background:#fed7aa;color:#f59e0b}.metric-icon.aged{background:#ddd6fe;color:#7c3aed}.metric-icon.governance{background:#d1fae5;color:#10b981}.metric-content{flex:1 1}.metric-value-small{color:#111827;font-size:32px;font-weight:700;line-height:1.2;margin-bottom:6px}.metric-label-small{color:#6b7280;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.metric-trend-indicator{align-items:center;color:#9ca3af;display:flex;font-size:12px;gap:4px}.metric-sublabel-small{color:#6b7280;font-size:12px}.dashboard-footer{width:100%}.governance-card-compact{align-items:center;display:flex;gap:10px;padding:10px 12px;width:100%}.governance-card-compact,.raid-section{background:#fff;border-radius:8px;box-shadow:0 1px 3px #00000014}.raid-section{padding:20px}.raid-section h3{color:#111827;font-size:13px;font-weight:700;letter-spacing:.5px;margin:0 0 16px;text-transform:uppercase}.raid-content{align-items:stretch;display:flex;gap:20px}.raid-chart-compact{display:flex;flex:1 1;flex-direction:column;justify-content:space-between;min-width:0}.raid-item-compact{grid-gap:10px;align-items:center;display:grid;gap:10px;grid-template-columns:80px 1fr 40px}.raid-label{color:#374151;font-size:12px;font-weight:500}.raid-bar-container-compact{background:#f3f4f6;border-radius:4px;height:18px;overflow:hidden;position:relative}.raid-bar{border-radius:4px;height:100%;transition:width .3s ease}.raid-bar-assumption,.raid-bar-dependency,.raid-bar-issue,.raid-bar-risk{background:#3b82f6}.raid-count{color:#111827;font-size:13px;font-weight:600;text-align:right}.raid-summary-horizontal{grid-gap:16px;display:grid;flex:1.5 1;gap:16px;grid-template-columns:repeat(3,1fr)}.raid-summary-card{align-items:flex-start;background:#f9fafb;border:1px solid #f3f4f6;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;justify-content:space-between;min-height:120px;padding:16px;transition:all .2s ease}.raid-summary-card:hover{background:#f3f4f6;box-shadow:0 4px 6px -1px #0000000d;transform:translateY(-2px)}.raid-summary-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px;width:100%}.raid-summary-icon{align-items:center;border-radius:8px;display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.raid-summary-icon.risk{background:#fef3c7;color:#f59e0b}.raid-summary-icon.issue{background:#fee2e2;color:#dc2626}.raid-summary-icon.aged{background:#e0e7ff;color:#6366f1}.raid-summary-content{display:flex;flex-direction:column;width:100%}.raid-summary-value{color:#111827;font-size:24px;font-weight:700;line-height:1;margin-bottom:6px}.raid-summary-label{color:#6b7280;font-size:11px;font-weight:600;letter-spacing:.5px;line-height:1.2;margin-bottom:4px;text-transform:uppercase}.raid-summary-status{color:#9ca3af;font-size:11px}.status-badge{display:inline-block;font-size:11px;font-weight:600}.status-badge.complete,.status-badge.completed{background:#d1fae5;color:#065f46}.status-badge.in-progress,.status-badge.pending{background:#fef3c7;color:#92400e}.status-badge.overdue{background:#fee2e2;color:#991b1b}.last-update{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #00000014;flex-direction:column;padding:20px;text-align:center}.last-update,.update-icon{align-items:center;display:flex;justify-content:center}.update-icon{background:#f3f4f6;border-radius:50%;color:#6b7280;height:64px;margin-bottom:16px;width:64px}.update-label{color:#6b7280;font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.update-value{color:#111827;font-size:36px;font-weight:700;margin-bottom:4px}.update-sublabel{color:#9ca3af;font-size:11px}.dashboard-loading{color:#6b7280;font-size:14px;padding:40px;text-align:center}.modal-overlay{background:#00000080}.modal-content{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}@media (max-width:1024px){.dashboard-footer{grid-template-columns:1fr}.metrics-grid{grid-template-columns:repeat(3,1fr)}.metrics-grid-secondary{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.dashboard-header{flex-direction:column;gap:16px}.metrics-grid,.metrics-grid-secondary{grid-template-columns:1fr}}.project-detail-page{background-color:#fff;min-height:100vh}.project-detail-container{padding:20px 40px;width:100%}.project-sidebar{background-color:#fff;border:1px solid #d1d5db;border-radius:8px;box-shadow:0 1px 3px 0 #0000001a;height:fit-content;padding:20px;position:sticky;top:20px}.back-btn{color:#3b82f6;gap:8px;justify-content:flex-start;margin-bottom:24px;padding:8px 12px;width:100%}.back-btn:hover{background-color:#3b82f61a}.sidebar-section{border-bottom:1px solid #e5e7eb;margin-bottom:24px;padding-bottom:20px}.sidebar-section:last-child{border-bottom:none}.sidebar-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.sidebar-title{color:#6b7280;font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:0}.edit-details-btn{align-items:center;background:none;border-radius:4px;color:#3b82f6;display:flex;justify-content:center;padding:4px;transition:all .2s ease}.edit-details-btn:hover{background-color:#3b82f61a}.documents-section{background:#0000;padding:0}.sidebar-item{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.sidebar-label{color:#6b7280;font-size:12px}.sidebar-value{color:#1f2937;font-size:13px}.sidebar-empty{color:#9ca3af;font-size:13px}.sidebar-link{align-items:center;color:#3b82f6;display:flex;font-size:13px;gap:8px;padding:6px 0;text-decoration:none;transition:color .2s ease}.sidebar-link:hover{color:#60a5fa}.priority-badge{background-color:#3b82f633;border-radius:4px;color:#3b82f6;display:inline-block;font-size:11px;font-weight:600;padding:4px 10px}.project-main{background-color:#fff;border:1px solid #d1d5db;border-radius:8px;box-shadow:0 1px 3px 0 #0000001a;padding:32px}.back-btn-inline{align-items:center;background:none;border-radius:6px;color:#3b82f6;display:inline-flex;font-size:14px;font-weight:500;gap:8px;margin-bottom:20px;padding:8px 12px;transition:all .2s ease}.back-btn-inline:hover{background-color:#3b82f61a;color:#2563eb}.project-header{align-items:flex-start;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:32px;padding-bottom:24px}.project-header-left h1{color:#1f2937;font-size:28px;font-weight:700;margin-bottom:12px}.project-badges{display:flex;gap:8px}.badge{border-radius:4px;font-size:11px;font-weight:600;padding:4px 12px;text-transform:capitalize}.project-header-actions{display:flex;gap:12px}.project-detail-page .header-action-btn{align-items:center;border-radius:6px;cursor:pointer;display:inline-flex;flex-shrink:0;font-size:13px;font-weight:500;gap:6px;padding:8px 14px;transition:all .2s;white-space:nowrap}.project-detail-page .header-action-btn.upload-btn{background-color:#fff;border:1px solid #10b981;color:#10b981}.project-detail-page .header-action-btn.upload-btn:hover{background-color:#10b981;color:#fff}.project-detail-page .header-action-btn.edit-btn{background-color:#fff;border:1px solid #3b82f6;color:#3b82f6}.project-detail-page .header-action-btn.edit-btn:hover{background-color:#3b82f6;color:#fff}.content-section{margin-bottom:32px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.section-header h2{color:#6b7280;font-size:11px;font-weight:600;letter-spacing:.5px}.add-update-btn-inline,.edit-section-btn{background:none;border-radius:4px;color:#3b82f6;font-size:13px;padding:4px 8px}.add-update-btn-inline:hover,.edit-section-btn:hover{background-color:#3b82f61a}.section-content{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:20px}.section-content p{color:#1f2937;font-size:14px;line-height:1.6}.empty-message{color:#9ca3af!important;font-style:italic}.updates-timeline{display:flex;flex-direction:column;gap:24px}.timeline-item{display:flex;gap:16px;position:relative}.timeline-item:not(:last-child):before{background-color:#e5e7eb;bottom:-24px;content:"";left:7px;position:absolute;top:24px;width:2px}.timeline-marker{background-color:#3b82f6;border:3px solid #fff;border-radius:50%;flex-shrink:0;height:16px;margin-top:4px;width:16px}.timeline-content{flex:1 1}.timeline-header{align-items:center;display:flex;gap:12px;margin-bottom:8px}.timeline-date{color:#1f2937;font-size:13px;font-weight:600}.timeline-author{color:#6b7280;font-size:12px;font-style:italic}.timeline-body{display:flex;flex-direction:column;gap:12px}.timeline-section{color:#4b5563;font-size:13px;line-height:1.5}.timeline-section strong{color:#1f2937;display:block;margin-bottom:4px}.milestones-list{display:flex;flex-direction:column;gap:16px}.milestone-item{align-items:center;display:flex;gap:12px}.milestone-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:14px;height:24px;justify-content:center;width:24px}.milestone-item.completed .milestone-icon{background-color:#10b981;color:#fff}.milestone-item.in-progress .milestone-icon{background-color:#f59e0b;border:2px solid #f59e0b;color:#fff}.milestone-item.pending .milestone-icon{background-color:initial;border:2px solid #d1d5db;color:#6b7280}.milestone-title{color:#1f2937;font-size:14px}.milestone-item.completed .milestone-title{color:#10b981}.milestone-item.in-progress .milestone-title{color:#f59e0b}.milestone-item.pending .milestone-title{color:#6b7280}.error,.loading{color:#6b7280;font-size:14px;padding:60px 20px;text-align:center}.update-search-input{border:1px solid #d1d5db;border-radius:6px;font-size:14px;min-width:250px;padding:8px 12px;transition:all .2s ease}.update-search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.clickable-update{border-radius:8px;cursor:pointer;margin:-12px;padding:12px;transition:all .2s ease}.clickable-update:hover{background-color:#f9fafb;transform:translateX(4px)}.view-all-updates-btn{background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;display:block;font-size:14px;font-weight:500;margin-top:20px;padding:12px 20px;text-align:center;transition:all .2s ease;width:100%}.view-all-updates-btn:hover{background-color:#e5e7eb;border-color:#9ca3af;color:#1f2937}.update-detail-modal{max-height:90vh;max-width:700px;overflow-y:auto}.update-detail-content{padding:20px}.detail-row{border-bottom:1px solid #e5e7eb;display:flex;gap:12px;margin-bottom:16px;padding-bottom:12px}.detail-label{color:#374151;font-size:14px;font-weight:600;min-width:120px}.detail-value{color:#6b7280;font-size:14px}.detail-section{border-top:2px solid #e5e7eb;margin-top:24px}.detail-section h3{color:#1f2937;font-size:16px;font-weight:600;margin-bottom:12px}.detail-section p{color:#4b5563;line-height:1.6}.rag-badge{border-radius:4px;display:inline-block;font-size:12px;padding:4px 12px;text-transform:uppercase}.rag-badge.red{background-color:#fee2e2;color:#dc2626}.rag-badge.amber{background-color:#fef3c7;color:#d97706}.rag-badge.green{background-color:#d1fae5;color:#059669}@media (max-width:1024px){.project-detail-container{grid-template-columns:1fr}.project-sidebar{position:static}}.portfolio-metrics{background:#fff;border:1px solid #e2e8f0;border-radius:16px;margin-bottom:24px;padding:20px}.portfolio-header{margin-bottom:20px}.portfolio-title{color:#1f2937;font-size:24px;font-weight:600;margin:0 0 8px}.portfolio-last-updated{color:#6b7280;font-size:13px;margin:0}.metrics-grid{grid-gap:0;border:1px solid #e2e8f0;border-radius:12px;display:grid;gap:0;grid-template-columns:repeat(6,1fr);overflow:hidden}.metrics-grid>*{grid-column:span 1}.portfolio-metrics .metric-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;min-height:90px;padding:12px}.portfolio-metrics .metric-card-blue{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:#93c5fd}.portfolio-metrics .metric-card-green{background:linear-gradient(135deg,#dcfce7,#bbf7d0);border-color:#86efac}.portfolio-metrics .metric-card-warning{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#fcd34d}.portfolio-metrics .metric-card-red{background:linear-gradient(135deg,#fee2e2,#fecaca);border-color:#fca5a5}.portfolio-metrics .metric-card-default{background:#f9fafb;border-color:#e5e7eb}.portfolio-metrics .metric-value{color:#1f2937;font-size:24px;font-weight:700;line-height:1;margin-bottom:6px}.portfolio-metrics .metric-large{font-size:32px}.portfolio-metrics .metric-label{color:#374151;font-size:11px;font-weight:600;line-height:1.2;margin-bottom:2px}.portfolio-metrics .metric-sublabel{color:#6b7280;font-size:10px;line-height:1.2}.rag-green{color:#10b981}.rag-amber{color:#f59e0b}.rag-red{color:#ef4444}.rag-divider{color:#9ca3af;font-weight:400;margin:0 4px}.metrics-section-header{margin-bottom:16px}.metrics-section-title{color:#1e293b;font-size:16px;font-weight:600;margin:0}.metric-card-modern{align-items:flex-start;background:#fff;border:none;border-radius:0;border-right:1px solid #e2e8f0;box-shadow:none;display:flex;padding:16px;transition:all .15s ease}.metric-card-modern:last-child{border-right:none}.metric-card-modern:hover{background:#f8fafc}.metric-card-content{align-items:flex-start;display:flex;gap:12px;width:100%}.metric-icon-container{border-radius:50%;flex-shrink:0;height:40px;position:relative;width:40px}.metric-alert-badge,.metric-icon-container{align-items:center;display:flex;justify-content:center}.metric-alert-badge{border-radius:9px;color:#fff;font-size:11px;font-weight:600;height:18px;min-width:18px;padding:0 5px;position:absolute;right:-4px;top:-4px}.metric-text-content{display:flex;flex:1 1;flex-direction:column;gap:4px}.metric-label-modern{color:#1e293b;font-size:13px;font-weight:600;line-height:1.3}.metric-value-big{font-size:24px;font-weight:700;line-height:1.2;margin:2px 0}.metric-sublabel-modern{color:#64748b;font-size:11px;line-height:1.3}@media (max-width:1200px){.metrics-grid{gap:0;grid-template-columns:repeat(3,1fr)}.metric-card-modern{border-bottom:1px solid #e2e8f0;border-right:none}.metric-card-modern:nth-child(3n){border-right:none}.metric-card-modern:nth-child(n+4){border-bottom:none}.portfolio-metrics .metric-value{font-size:22px}.portfolio-metrics .metric-label{font-size:10px}}@media (max-width:900px){.metrics-grid{gap:0;grid-template-columns:repeat(2,1fr)}.metric-card-modern{border-bottom:1px solid #e2e8f0;border-right:1px solid #e2e8f0}.metric-card-modern:nth-child(2n){border-right:none}.metric-card-modern:nth-child(n+5){border-bottom:none}}@media (max-width:640px){.metrics-grid{gap:0;grid-template-columns:1fr}.metric-card-modern{border-bottom:1px solid #e2e8f0;border-right:none}.metric-card-modern:last-child{border-bottom:none}}.modal-content.wide{max-width:1000px}.modal-content.narrow{max-width:600px}.modal-title{color:var(--color-gray-900);font-size:var(--font-size-2xl);font-weight:var(--font-semibold);margin:0}.modal-subtitle{color:var(--color-gray-500);font-size:var(--font-size-md);margin:var(--space-1) 0 0 0}.modal-close-btn{align-items:center;background:none;border:none;border-radius:var(--radius-md);color:var(--color-gray-500);cursor:pointer;display:flex;font-size:24px;height:40px;justify-content:center;transition:all .2s ease;width:40px}.modal-close-btn:hover{background-color:var(--color-gray-100);color:var(--color-gray-800)}.modal-body.no-padding{padding:0}.critical-accordion{border:none;gap:var(--space-3)}.critical-project{border:1px solid var(--color-gray-200);border-radius:var(--radius-xl)}.critical-project-header{gap:var(--space-3);padding:var(--space-3) var(--space-4);transition:background-color .2s ease}.critical-project-header:hover{background-color:var(--color-gray-50)}.critical-project-info{gap:var(--space-1)}.critical-project-name{color:var(--color-gray-900);font-weight:var(--font-semibold);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.critical-meta{align-items:center;color:var(--color-gray-500);font-size:var(--font-size-sm);gap:var(--space-2)}.critical-project-right{gap:var(--space-3)}.critical-count{color:var(--color-danger);font-size:var(--font-size-md);font-weight:var(--font-semibold)}.critical-chevron{color:var(--color-gray-400)}.modal-search{flex:1 1;max-width:300px}.modal-search-icon{color:var(--color-gray-400);left:12px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.modal-search input{border:1px solid var(--color-gray-200);border-radius:var(--radius-md);font-size:var(--font-size-md);outline:none;padding:var(--space-2) var(--space-3);padding-left:40px;transition:border-color .2s ease;width:100%}.modal-search input:focus{border-color:var(--color-primary-500)}.view-toggle{display:flex;gap:var(--space-2);justify-content:flex-end}.toggle-btn{background-color:var(--color-gray-100);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);color:var(--color-gray-800);cursor:pointer;font-size:var(--font-size-md);font-weight:var(--font-medium);padding:var(--space-2) var(--space-4);transition:all .2s ease}.toggle-btn:hover{background-color:var(--color-gray-200);color:var(--color-gray-900)}.toggle-btn.active{background-color:var(--color-primary-500);border-color:var(--color-primary-500);color:#fff}.modal-empty{color:var(--color-gray-500);font-size:var(--font-size-md);padding:40px var(--space-5);text-align:center}.filter-badge{align-items:center;background-color:var(--color-gray-100);border-radius:var(--radius-sm);color:var(--color-gray-700);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-medium);padding:var(--space-1) var(--space-2)}.filter-badge.active{background-color:var(--color-primary-100);color:var(--color-primary-700)}.action-btn{background-color:#fff;border:1px solid;display:inline-flex;height:30px;transition:all .2s ease;width:30px}.view-btn{border-color:#d1d5db;color:#6b7280}.view-btn:hover{background-color:#eff6ff;border-color:#2563eb;color:#2563eb}.edit-btn{border-color:#bfdbfe;color:#3b82f6}.edit-btn:hover{background-color:#3b82f6;border-color:#3b82f6;color:#fff}.portfolio-page{background-color:#f3f4f6;min-height:calc(100vh - 64px);padding:24px}.portfolio-container{margin:0 auto;max-width:1600px}.error-container{align-items:center;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;justify-content:center;padding:60px}.error-message{color:#ef4444;font-size:16px;margin-bottom:16px}.retry-btn{background-color:#3b82f6;color:#fff;padding:10px 24px}.portfolio-exec-strip{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:24px}.exec-card{background:#fff;border:1px solid #e2e8f0e6;border-radius:var(--radius-xl);box-shadow:0 12px 30px #0f172a14;padding:18px 22px;position:relative}.exec-card,.exec-card-content{align-items:center;display:flex;flex-direction:row;gap:16px}.exec-card-content{width:100%}.exec-icon-container{align-items:center;border-radius:50%;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.exec-text-content{display:flex;flex:1 1;flex-direction:column;gap:4px}.exec-clickable{border:none;cursor:pointer;text-align:left;transition:transform .15s ease,box-shadow .15s ease}.exec-clickable:hover{box-shadow:0 8px 16px #0f172a1f;transform:translateY(-2px)}.exec-label{color:#6b7280;font-size:13px;font-weight:500;margin-bottom:2px}.exec-value{color:#111827;font-size:28px;font-weight:700;line-height:1.2;margin-bottom:2px}.exec-helper{color:#9ca3af;font-size:11px;font-weight:400}.exec-primary .exec-value{color:#2563eb}.exec-warning .exec-value{color:#d97706}.exec-danger .exec-value{color:#dc2626}.portfolio-rag-board{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));margin:32px 0}.rag-column{border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);min-height:280px;padding:var(--space-5)}.rag-column-header{justify-content:space-between;margin-bottom:16px}.rag-column-label{color:#0f172a;font-size:15px;font-weight:600}.rag-column-helper{color:#64748b;font-size:13px;margin:4px 0 0}.rag-column-count{color:#1f2937;font-size:24px}.rag-column-body{display:flex;flex:1 1;flex-direction:column;gap:12px}.rag-project-card{border:1px solid #e2e8f0;border-radius:12px}.rag-project-title{color:#0f172a;font-size:15px}.rag-project-meta{color:#64748b;display:flex;gap:8px;margin:4px 0 8px}.rag-project-stats{color:#475569;display:flex;flex-wrap:wrap;font-size:12px;gap:10px}.rag-empty{color:#94a3b8;font-size:13px;margin:auto 0;text-align:center}.portfolio-main-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:minmax(0,2fr) minmax(320px,1fr);margin-top:32px}.portfolio-main-left{grid-column:1/-1}.portfolio-main-left .portfolio-table-section{width:100%}.portfolio-main-right{display:flex;flex-direction:column;gap:24px}.critical-card,.freshness-card{background:#fff;border-radius:var(--radius-xl);box-shadow:0 12px 30px #0f172a14;padding:var(--space-5)}.critical-header,.freshness-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.critical-header h3,.freshness-header h3{font-size:16px;font-weight:600;margin:0}.freshness-groups{display:flex;flex-direction:column;gap:16px}.freshness-group h4{color:#475569;font-size:14px;margin:0 0 8px}.freshness-row{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;padding:10px 0}.freshness-row:last-child{border-bottom:none}.freshness-name{color:#0f172a;font-size:14px;font-weight:600}.freshness-meta{color:#94a3b8;font-size:12px}.freshness-bar{background:#e2e8f0;border-radius:999px;height:8px;position:relative;width:120px}.freshness-bar span{border-radius:999px;bottom:0;left:0;position:absolute;top:0}.freshness-bar.fill span{background:linear-gradient(90deg,#34d399,#10b981)}.freshness-bar.outline{background:#fca5a540}.freshness-bar.outline span{background:linear-gradient(90deg,#f87171,#dc2626)}.freshness-row.no-data{justify-content:space-between}.freshness-tag{background:#f973161a;border-radius:999px;color:#f97316;font-size:12px;letter-spacing:.08em;padding:4px 10px;text-transform:uppercase}.critical-empty,.freshness-empty{color:#94a3b8;font-size:13px;margin:0}.critical-list{list-style:none;margin:0;padding:0}.critical-accordion,.critical-list{display:flex;flex-direction:column;gap:12px}.critical-project{border:1px solid #e2e8f0;border-radius:16px;overflow:hidden}.critical-project-header{background:#0000;border:none;cursor:pointer;justify-content:space-between;padding:14px 16px;width:100%}.critical-project-header,.critical-project-left{align-items:center;display:flex;gap:12px}.critical-project-info{align-items:flex-start;display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:0}.critical-project-name{color:#0f172a;font-size:15px;font-weight:600}.critical-project-right{align-items:center;display:flex;gap:12px}.critical-status-dot{border-radius:50%;height:10px;width:10px}.status-dot-green{background-color:var(--color-success)}.status-dot-amber{background-color:var(--color-warning)}.status-dot-red{background-color:var(--color-danger)}.critical-status-dot{display:inline-block;flex-shrink:0}.critical-search{margin-bottom:16px}.critical-search input{border:1px solid #e2e8f0;border-radius:10px;font-size:14px;padding:10px 14px;width:100%}.critical-chevron{color:#94a3b8;font-size:18px;transition:transform .2s ease}.critical-chevron.open{transform:rotate(180deg)}.rag-summary-modal{grid-gap:16px;display:grid;gap:16px}.rag-summary-card{background-color:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:16px 20px}.rag-summary-card.rag-summary-green{border-color:#10b9814d}.rag-summary-card.rag-summary-amber{border-color:#f59e0b66}.rag-summary-card.rag-summary-red{border-color:#ef444466}.rag-summary-header{align-items:center;background:#0000;border:none;cursor:pointer;display:flex;justify-content:space-between;padding:0;text-align:left;width:100%}.rag-summary-header-left{display:flex;flex-direction:column;gap:2px}.rag-summary-header-right{align-items:center;display:flex}.rag-summary-label{color:#0f172a;font-size:15px;font-weight:600}.rag-summary-helper{color:#64748b;font-size:13px;margin:0}.rag-summary-count{color:#0f172a;font-size:20px;font-weight:600}.rag-summary-divider{background:#e2e8f0;height:1px;margin:12px 0}.rag-summary-list{display:flex;flex-direction:column;gap:10px;list-style:none;margin:0;padding:0}.rag-summary-item{align-items:center;background:#f8fafc;border-radius:10px;display:flex;justify-content:space-between;padding:10px 12px}.rag-summary-name{color:#0f172a;font-size:14px;font-weight:600}.rag-summary-meta{color:#64748b;display:flex;font-size:13px;gap:8px}.rag-summary-metrics{color:#475569;display:flex;font-size:12px;gap:12px}.rag-summary-empty{color:#94a3b8;font-size:13px;margin:0}.rag-summary-chevron{color:#94a3b8;font-size:18px;transition:transform .2s ease}.rag-summary-chevron.open{transform:rotate(180deg)}.rag-summary-projects{border-top:1px solid #e2e8f0;margin-top:12px;padding-top:12px}.rag-summary-project-item{border:1px solid #e2e8f0;border-radius:10px;margin-bottom:8px;overflow:hidden}.rag-summary-project-header{align-items:center;background:#f8fafc;border:none;cursor:pointer;display:flex;justify-content:space-between;padding:12px 14px;text-align:left;width:100%}.rag-summary-project-name{color:#0f172a;font-size:14px;font-weight:600}.rag-summary-project-metrics{background:#fff;color:#475569;display:flex;font-size:13px;gap:16px;padding:10px 14px}.critical-item{border:1px solid #e2e8f0;border-radius:14px;display:flex;flex-direction:column;gap:6px;padding:12px}.critical-type{color:#c026d3;font-size:12px;letter-spacing:.08em;text-transform:uppercase}.critical-item.critical-issue .critical-type{color:#dc2626}.critical-title{color:#0f172a;font-size:14px;font-weight:600}.critical-meta{color:#64748b;display:flex;font-size:12px;gap:8px}.portfolio-table-section{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.portfolio-table{border-collapse:collapse;font-size:14px;table-layout:fixed;width:100%}.portfolio-table th:first-child{width:160px}.portfolio-table th:nth-child(2){width:100px}.portfolio-table th:nth-child(3){width:90px}.portfolio-table th:nth-child(4){width:110px}.portfolio-table th:nth-child(5),.portfolio-table th:nth-child(6),.portfolio-table th:nth-child(7){width:auto}.portfolio-table th:nth-child(8){width:155px}.portfolio-table th:nth-child(9){width:90px}.portfolio-table thead{background-color:#1f2937;color:#fff}.portfolio-table th{font-size:13px;font-weight:600;letter-spacing:.5px;padding:14px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}.portfolio-table tbody tr{border-bottom:1px solid #e5e7eb}.portfolio-table tbody tr:hover{background-color:#f9fafb}.portfolio-table tbody tr:last-child{border-bottom:none}.portfolio-table td{max-width:0;overflow:hidden;padding:16px;text-overflow:ellipsis;vertical-align:middle;white-space:nowrap}.project-name-cell{color:#1f2937;font-weight:600}.project-name-link{color:#2563eb;cursor:pointer}.project-name-link:hover{text-decoration:underline}.percent-complete-cell{min-width:120px}.progress-bar-container{align-items:center;display:flex;gap:8px}.progress-bar{border-radius:4px;height:8px;min-width:60px;transition:width .3s ease}.progress-text{color:#6b7280;font-size:13px;font-weight:500;min-width:35px}.rag-cell{align-items:center;display:flex;gap:8px}.rag-indicator{border-radius:50%;flex-shrink:0;height:12px;width:12px}.rag-text{color:#374151;font-size:13px;font-weight:500}.date-cell{color:#6b7280;font-size:13px;white-space:nowrap}.number-cell{color:#374151;font-size:14px;font-weight:500;text-align:center}.milestone-cell{color:#6b7280;font-size:13px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width:1200px){.portfolio-table{font-size:13px}.portfolio-table td,.portfolio-table th{padding:12px}}@media (max-width:1024px){.portfolio-main-grid,.portfolio-rag-board{grid-template-columns:1fr}.portfolio-table-section{overflow-x:auto}.portfolio-table{min-width:900px}}.rag-project-card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:12px;padding:12px;transition:box-shadow .2s ease}.rag-project-card:hover{box-shadow:0 4px 12px #00000026}.rag-project-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:4px}.rag-project-title{color:#111827;flex:1 1;font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rag-health-badge{border-radius:12px;flex-shrink:0;font-size:11px;font-weight:600;margin-left:8px;padding:2px 8px;text-transform:uppercase}.rag-health-green{background-color:#d1fae5;color:#065f46}.rag-health-amber{background-color:#fef3c7;color:#92400e}.rag-health-red{background-color:#fee2e2;color:#991b1b}.rag-project-meta{color:#6b7280;font-size:12px;margin-bottom:12px}.rag-timeline-container{background:#f9fafb;border-radius:6px;margin-bottom:10px;padding:10px}.rag-timeline-labels{color:#9ca3af;display:flex;font-size:10px;justify-content:space-between;margin-bottom:4px}.rag-timeline-today{color:#6b7280;font-weight:600}.rag-timeline-track{background:#e5e7eb;border-radius:4px;display:flex;height:24px;margin-bottom:8px;overflow:hidden;position:relative}.rag-timeline-past{background:linear-gradient(90deg,#e5e7eb,#f3f4f6);height:100%}.rag-timeline-future{background:linear-gradient(90deg,#f3f4f6,#e5e7eb);height:100%}.rag-timeline-today-marker{background-color:#6b7280;bottom:0;position:absolute;top:0;transform:translateX(-50%);width:2px;z-index:2}.rag-timeline-today-marker:before{border-left:4px solid #0000;border-right:4px solid #0000;border-top:4px solid #6b7280;content:"";height:0;left:50%;position:absolute;top:-4px;transform:translateX(-50%);width:0}.rag-timeline-dot{border:2px solid #fff;border-radius:50%;box-shadow:0 1px 3px #0003;cursor:pointer;height:10px;position:absolute;top:50%;transform:translate(-50%,-50%);transition:transform .2s ease,box-shadow .2s ease;width:10px;z-index:3}.rag-timeline-dot:hover{box-shadow:0 2px 8px #0000004d;transform:translate(-50%,-50%) scale(1.3)}.rag-timeline-dot-completed{background-color:#10b981}.rag-timeline-dot-overdue{background-color:#ef4444}.rag-timeline-dot-upcoming{background-color:#f59e0b}.rag-timeline-dot-future{background-color:#9ca3af}.rag-timeline-summary{display:flex;flex-wrap:wrap;gap:12px}.rag-summary-item{color:#6b7280;font-size:11px}.rag-summary-overdue{color:#dc2626}.rag-summary-upcoming{color:#d97706}.rag-timeline-empty{background:#f9fafb;border-radius:6px;margin-bottom:10px;padding:12px;text-align:center}.rag-timeline-empty span{color:#9ca3af;font-size:12px;font-style:italic}.rag-project-quick-stats{display:flex;gap:8px;margin-top:8px}.rag-stat-badge{background:#f3f4f6;border-radius:4px;color:#374151;font-size:11px;padding:4px 8px}.rag-stat-risks{background:#fee2e2;color:#991b1b}.rag-stat-issues{background:#fef3c7;color:#92400e}.milestone-tooltip{animation:fadeIn .2s ease}.modal-content{background-color:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);max-height:80vh;overflow:auto;width:90%}.modal-header{border-bottom:1px solid var(--color-gray-200);padding:var(--space-5)}.modal-header h2{color:var(--color-gray-900);font-size:var(--font-size-2xl);font-weight:var(--font-semibold)}.modal-header button{align-items:center;background:none;border:none;border-radius:var(--radius-md);color:var(--color-gray-500);cursor:pointer;display:flex;font-size:24px;height:40px;justify-content:center;transition:background-color .2s;width:40px}.modal-header button:hover{background-color:var(--color-gray-100)}.modal-body{padding:var(--space-5)}.expanded-content{background:var(--color-gray-50);border-top:1px solid var(--color-gray-200);padding:var(--space-4)}.expanded-content h4{color:var(--color-gray-900);font-size:var(--font-size-lg);font-weight:var(--font-semibold);margin:0 0 var(--space-3) 0}.escalation-list{display:flex;flex-direction:column;gap:12px;list-style:none;margin:0;padding:0}.escalation-item{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:12px}.escalation-title{color:#0f172a;font-size:14px;font-weight:600;margin-bottom:4px}.escalation-meta{color:#64748b;display:flex;font-size:12px;gap:8px}.escalations-count{color:#dc2626;font-size:13px;font-weight:600;margin-right:12px}.rag-board{padding:0 24px 24px}.rag-board-search-container{margin:0 0 20px;padding:0 4px}.rag-search-wrapper{align-items:center;display:flex;max-width:500px;position:relative}.rag-search-icon{color:#9ca3af;left:14px;pointer-events:none;position:absolute}.rag-board-search-container input{background:#fff;border:2px solid #e5e7eb;border-radius:12px;font-size:14px;outline:none;padding:12px 16px 12px 44px;transition:all .2s ease;width:100%}.rag-board-search-container input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.rag-search-clear{align-items:center;background:#f3f4f6;border:none;border-radius:50%;color:#6b7280;cursor:pointer;display:flex;height:24px;justify-content:center;position:absolute;right:12px;transition:all .2s;width:24px}.rag-search-clear:hover{background:#e5e7eb;color:#374151}.rag-search-results{color:#6b7280;font-size:13px;margin-top:8px;padding-left:4px}.rag-board-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1.3fr 1.15fr .85fr}@media (max-width:1200px){.rag-board-grid{grid-template-columns:1fr 1fr 1fr}}@media (max-width:900px){.rag-board-grid{gap:20px;grid-template-columns:1fr}.rag-column.collapsed{max-height:60px}}.rag-column{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;display:flex;flex-direction:column;overflow:hidden;transition:all .3s ease}.rag-column.collapsed{max-height:56px}.rag-column-header{align-items:center;border-bottom:2px solid;cursor:pointer;display:flex;gap:10px;padding:14px 16px;transition:all .2s;-webkit-user-select:none;user-select:none}.rag-column-header:hover{filter:brightness(.98)}.rag-column-indicator{border-radius:50%;flex-shrink:0;height:12px;width:12px}.rag-column-title{flex:1 1;font-size:15px;font-weight:700}.rag-column-count{border-radius:20px;font-size:14px;font-weight:700;min-width:28px;padding:4px 12px;text-align:center}.rag-column-chevron{color:#6b7280;font-size:18px;margin-left:4px;transition:transform .3s ease}.rag-column-chevron.collapsed{transform:rotate(-90deg)}.rag-column-content{background:#f8fafc;max-height:65vh;overflow-y:auto;padding:12px;scrollbar-color:#cbd5e1 #f1f5f9;scrollbar-width:thin}.rag-column-content::-webkit-scrollbar{width:6px}.rag-column-content::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.rag-column-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.rag-column-content::-webkit-scrollbar-thumb:hover{background:#94a3b8}.rag-project-card-compact{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 1px 2px #0000000a;cursor:pointer;display:flex;gap:12px;margin-bottom:8px;padding:12px 14px;transition:all .2s ease}.rag-project-card-compact:hover{border-color:#cbd5e1;box-shadow:0 4px 12px #00000014;transform:translateY(-1px)}.rag-compact-main{flex:1 1;min-width:0}.rag-compact-name{color:#0f172a;font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rag-compact-owner{color:#64748b;font-size:12px;margin-top:2px}.rag-compact-badges{display:flex;flex-shrink:0;gap:6px}.rag-badge{border-radius:12px;font-size:11px;font-weight:600;min-width:22px;padding:3px 8px;text-align:center}.rag-badge-escalation{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.rag-badge-overdue{background:#fffbeb;border:1px solid #fcd34d;color:#d97706}.rag-badge-risk{background:#fef2f2;border:1px solid #fecaca;color:#ef4444}.rag-badge-issue{background:#fff7ed;border:1px solid #fed7aa;color:#f97316}.rag-compact-meta{align-items:center;display:flex;flex-shrink:0;gap:8px}.rag-compact-updated{color:#94a3b8;font-size:11px;white-space:nowrap}.rag-compact-expand-btn{align-items:center;background:#f1f5f9;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;height:28px;justify-content:center;padding:0;transition:all .2s;width:28px}.rag-compact-expand-btn:hover{background:#e2e8f0;color:#475569}.rag-compact-expand-btn svg{transition:transform .2s}.rag-empty-state{color:#9ca3af;font-size:14px;padding:40px 20px;text-align:center}.rag-project-wrapper{margin-bottom:8px}.rag-project-wrapper:last-child{margin-bottom:0}.portfolio-table-header{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-bottom:none;border-radius:12px 12px 0 0;cursor:pointer;display:flex;gap:12px;padding:16px 20px;transition:all .2s;-webkit-user-select:none;user-select:none}.portfolio-table-header:hover{background:#f1f5f9}.portfolio-table-header h3{color:#0f172a;font-size:16px;font-weight:600;margin:0}.project-count{background:#fff;border:1px solid #e2e8f0;border-radius:12px;color:#64748b;font-size:13px;padding:4px 10px}.collapse-btn{align-items:center;background:none;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;justify-content:center;margin-left:auto;padding:4px;transition:all .2s}.collapse-btn:hover{background:#e2e8f0;color:#475569}.collapse-btn svg{transition:transform .3s ease}.collapse-btn.collapsed svg{transform:rotate(-90deg)}.project-name-cell.clickable{align-items:center;color:#3b82f6;display:flex;font-weight:500;gap:8px;transition:color .2s}.project-name-cell.clickable:hover{color:#2563eb}.external-link-icon{color:#3b82f6;opacity:0;transition:opacity .2s}.project-name-cell.clickable:hover .external-link-icon{opacity:1}.expand-details-btn{align-items:center;background:#f1f5f9;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;height:28px;justify-content:center;padding:0;transition:all .2s;width:28px}.expand-details-btn:hover{background:#e2e8f0;color:#475569}.project-row{transition:background-color .15s}.project-row:hover{background-color:#f8fafc}.show-all-projects{background:#f8fafc;border:1px solid #e2e8f0;border-radius:0 0 12px 12px;border-top:none;padding:16px 20px;text-align:center}.show-all-projects button{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#475569;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s}.show-all-projects button:hover{background:#f1f5f9;border-color:#cbd5e1;color:#0f172a}.show-all-projects button svg{transition:transform .2s}.radial-modal-overlay{align-items:center;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172ad9;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.radial-modal-content{background:linear-gradient(145deg,#fff,#f8fafc);border-radius:24px;box-shadow:0 25px 50px -12px #0006,0 0 0 1px #ffffff1a;height:80vh;max-height:800px;max-width:900px;overflow:hidden;position:relative;width:90vw}.radial-close-btn{align-items:center;background:#f8fafc;border:none;border-radius:8px;color:#64748b;cursor:pointer;display:flex;font-size:20px;height:36px;justify-content:center;transition:all .2s;width:36px;z-index:10}.radial-close-btn:hover{background:#ef4444;color:#fff;transform:scale(1.05)}.radial-modal-topbar{align-items:center;display:flex;justify-content:space-between;left:0;padding:16px 24px;position:absolute;right:0;top:0;z-index:50}.radial-modal-logo{height:40px;object-fit:contain;width:auto}.radial-modal-actions{align-items:center;display:flex;gap:12px}.radial-modal-navigate-btn{align-items:center;background:#f8fafc;border:none;border-radius:8px;color:#3b82f6;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s;width:36px}.radial-modal-navigate-btn:hover{background:#3b82f6;color:#fff;transform:scale(1.05)}.radial-container{bottom:0;left:0;perspective:1200px;position:absolute;right:0;top:0;transform-style:preserve-3d}.radial-container-inner{height:600px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:600px}.radial-connections{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.radial-line{stroke-dasharray:300;stroke-dashoffset:300;animation:drawLine .6s ease forwards;filter:drop-shadow(0 0 2px currentColor);opacity:.6}@keyframes drawLine{to{stroke-dashoffset:0}}.radial-center-node{align-items:center;animation:centerPulse .5s ease forwards;display:flex;height:200px;justify-content:center;left:50%!important;position:absolute;top:50%!important;transform:translate(-50%,-50%);width:200px;z-index:5}@keyframes centerPulse{0%{opacity:0;transform:translate(-50%,-50%) scale(0)}70%{transform:translate(-50%,-50%) scale(1.1)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.center-glow{animation:glowPulse 3s ease-in-out infinite;border-radius:50%;filter:blur(20px);height:100%;opacity:.15;position:absolute;width:100%}@keyframes glowPulse{0%,to{opacity:.15;transform:scale(1)}50%{opacity:.25;transform:scale(1.1)}}.center-content{align-items:center;background:#fff;border-radius:50%;box-shadow:0 10px 40px #00000026,0 0 0 1px #0000000d;display:flex;flex-direction:column;height:160px;justify-content:center;padding:20px;position:relative;text-align:center;width:160px}.center-rag-indicator{border-radius:50%;box-shadow:0 0 0 4px #fffc,0 0 0 6px currentColor;height:16px;margin-bottom:12px;width:16px}.center-project-name{color:#0f172a;font-size:16px;font-weight:700;line-height:1.2;margin:0 0 4px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.center-project-owner{color:#64748b;font-size:13px;margin:0 0 8px}.center-client{background:#f1f5f9;border-radius:12px;color:#94a3b8;font-size:11px;padding:2px 10px}.radial-metric-node{animation:nodePop .5s ease forwards;background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014,0 0 0 1px #00000008;cursor:pointer;opacity:0;padding:12px;position:absolute;transform:translate(-50%,-50%) translateZ(20px);transition:all .3s cubic-bezier(.34,1.56,.64,1);width:140px;z-index:3}@keyframes nodePop{0%{opacity:0;transform:translate(-50%,-50%) translateZ(20px) scale(0)}70%{transform:translate(-50%,-50%) translateZ(30px) scale(1.05)}to{opacity:1;transform:translate(-50%,-50%) translateZ(20px) scale(1)}}.radial-metric-node:hover{box-shadow:0 12px 40px #00000026;transform:translate(-50%,-50%) translateZ(50px) scale(1.08);z-index:10}.metric-node-glow{border-radius:20px;bottom:-4px;filter:blur(8px);left:-4px;opacity:0;position:absolute;right:-4px;top:-4px;transition:opacity .3s;z-index:-1}.radial-metric-node:hover .metric-node-glow{opacity:.3}.metric-node-label{color:#94a3b8;font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-align:center;text-transform:uppercase}.metric-node-content{text-align:center}.radial-metric-content{align-items:center;display:flex;flex-direction:column}.metric-count{font-size:32px;font-weight:700;line-height:1;margin-bottom:4px}.metric-label-small{color:#64748b;font-size:11px}.metric-mini-list{color:#64748b;font-size:10px;list-style:none;margin:8px 0 0;max-width:100%;padding:0}.metric-mini-list li{margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.metric-mini-list li:before{color:#cbd5e1;content:"•";margin-right:4px}.rag-metric{align-items:center;flex-direction:row;gap:8px}.rag-large-dot{border-radius:50%;box-shadow:0 0 0 3px #fffc,0 0 0 5px currentColor;height:20px;width:20px}.rag-status-text{color:#0f172a;font-size:14px;font-weight:600}.metric-time{color:#0f172a;font-size:13px;font-weight:600}.metric-date{color:#94a3b8;font-size:10px;margin-top:2px}.metric-progress{align-items:center;display:flex;justify-content:center}.progress-ring{height:50px;position:relative;width:50px}.progress-ring svg{height:100%;transform:rotate(-90deg);width:100%}.progress-text{color:#3b82f6;font-size:12px;font-weight:700;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}@media (max-width:768px){.radial-modal-content{height:90vh;width:95vw}.radial-center-node{height:160px;width:160px}.center-content{height:130px;width:130px}.radial-metric-node{padding:8px;width:110px}.metric-count{font-size:24px}}.radial-metric-node.clickable{cursor:pointer}.radial-metric-node.clickable:hover{box-shadow:0 12px 40px #00000026;transform:translate(-50%,-50%) translateZ(50px) scale(1.08);z-index:10}.radial-detail-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffffa6;border-radius:inherit;bottom:0;display:flex;justify-content:center;left:0;padding:24px;position:absolute;right:0;top:0;z-index:200}.radial-detail-modal{animation:modalScaleUp .3s cubic-bezier(.34,1.56,.64,1) forwards;background:#fff;border-radius:16px;box-shadow:0 20px 50px #00000026,0 0 0 1px #0000000d;display:flex;flex-direction:column;height:100%;max-height:100%;max-width:100%;min-width:0;overflow:hidden;width:800px}@keyframes modalScaleUp{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.radial-detail-header{align-items:center;background:#f8fafc;border-bottom:3px solid;color:#0f172a;display:flex;font-size:15px;font-weight:600;justify-content:space-between;padding:16px 20px}.radial-detail-close{align-items:center;background:none;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;font-size:20px;height:28px;justify-content:center;transition:all .2s;width:28px}.radial-detail-close:hover{background:#e2e8f0;color:#0f172a}.radial-detail-content{flex:1 1;overflow-y:auto;padding:20px}.radial-detail-item{align-items:flex-start;border-bottom:1px solid #f1f5f9;display:flex;font-size:13px;justify-content:space-between;padding:12px 20px}.radial-detail-item:last-child{border-bottom:none}.radial-detail-label{color:#64748b;flex:1 1;line-height:1.4;padding-right:16px}.radial-detail-value{color:#0f172a;font-weight:500;line-height:1.4;max-width:50%;text-align:right}.radial-detail-table{border-collapse:collapse;font-size:13px;margin:-20px;table-layout:fixed;width:100%;width:calc(100% + 40px)}.radial-detail-table thead{background:#f8fafc;border-bottom:2px solid #e2e8f0;position:sticky;top:-20px;z-index:1}.radial-detail-table th{color:#64748b;font-size:11px;font-weight:600;letter-spacing:.5px;padding:14px 12px;text-align:left;text-transform:uppercase;white-space:nowrap}.radial-detail-table th:first-child{width:60px}.radial-detail-table th:nth-child(2){width:auto}.radial-detail-table th:nth-child(3){width:80px}.radial-detail-table th:nth-child(4){width:100px}.radial-detail-table th:nth-child(5){width:120px}.radial-detail-table th:nth-child(6){width:90px}.radial-detail-table tbody tr{border-bottom:1px solid #f1f5f9}.radial-detail-table tbody tr:last-child{border-bottom:none}.radial-detail-table td{color:#0f172a;line-height:1.4;padding:14px 12px;vertical-align:top}.radial-detail-table td:nth-child(2){word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.radial-detail-table td:first-child{color:#64748b;font-weight:500}.radial-line{stroke-linecap:round}.cl-page{display:flex;flex-direction:column;gap:16px;margin:0 auto;max-width:1400px;padding:24px}.cl-header{background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 1px 3px #0000000f;justify-content:space-between;padding:20px 24px}.cl-header,.cl-header-left{align-items:center;display:flex}.cl-header-left{gap:14px}.cl-icon-box{align-items:center;background:linear-gradient(135deg,#2563eb,#1d4ed8);border-radius:10px;display:flex;flex-shrink:0;height:44px;justify-content:center;width:44px}.cl-title{color:#0f172a;font-size:20px;font-weight:700;margin:0}.cl-subtitle{color:#64748b;font-size:13px;margin:2px 0 0}.cl-stats{gap:20px}.cl-stat,.cl-stats{align-items:center;display:flex}.cl-stat{flex-direction:column;gap:2px}.cl-stat-value{color:#2563eb;font-size:24px;font-weight:700;line-height:1}.cl-stat-label{color:#94a3b8;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.cl-stat-divider{background:#e5e7eb;height:32px;width:1px}.cl-tabs{background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 1px 3px #0000000f;display:flex;gap:6px;padding:5px}.cl-tab{align-items:center;background:#0000;border:none;border-radius:7px;color:#64748b;cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:600;gap:7px;justify-content:center;padding:9px 16px;transition:all .15s ease}.cl-tab:hover{background:#f8fafc;color:#2563eb}.cl-tab.active{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 2px 8px #2563eb4d;color:#fff}.cl-tab-badge{align-items:center;background:#fff3;border-radius:10px;display:inline-flex;font-size:11px;font-weight:700;height:20px;justify-content:center;min-width:20px;padding:0 6px}.cl-tab:not(.active) .cl-tab-badge{background:#f1f5f9;color:#64748b}.cl-form-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 1px 3px #0000000f;padding:16px 20px}.cl-form-row{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.cl-input{background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#0f172a;flex:1 1;font-family:inherit;font-size:14px;min-width:160px;padding:10px 14px;transition:border-color .15s}.cl-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb14;outline:none}.cl-input::placeholder{color:#94a3b8}.cl-select{appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg width='12' height='8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='m1 1.5 5 5 5-5' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;cursor:pointer;padding-right:36px}.cl-input-wide{flex:2 1}.cl-add-btn{align-items:center;background:linear-gradient(135deg,#2563eb,#1d4ed8);border:none;border-radius:8px;box-shadow:0 2px 8px #2563eb40;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:14px;font-weight:600;gap:6px;padding:10px 18px;transition:all .15s ease;white-space:nowrap}.cl-add-btn:hover:not(:disabled){background:linear-gradient(135deg,#1d4ed8,#1e40af);transform:translateY(-1px)}.cl-add-btn:disabled{background:#cbd5e1;box-shadow:none;cursor:not-allowed}.cl-error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#b91c1c;font-size:13px;gap:8px;margin-top:10px;padding:10px 14px}.cl-error,.cl-search-bar{align-items:center;display:flex}.cl-search-bar{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000000f;gap:10px;padding:9px 14px}.cl-search-input{background:#0000;border:none;color:#0f172a;flex:1 1;font-family:inherit;font-size:14px;outline:none}.cl-search-input::placeholder{color:#9ca3af}.cl-search-clear{align-items:center;background:none;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;display:flex;padding:2px;transition:color .15s}.cl-search-clear:hover{color:#374151}.cl-content{align-items:flex-start;display:flex;gap:16px}.cl-list-section{flex:1 1;min-width:0}.cl-grid{display:flex;flex-direction:column;gap:8px}.cl-card{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 1px 2px #0000000a;display:flex;justify-content:space-between;padding:14px 16px;transition:all .15s ease}.cl-card:hover{border-color:#bfdbfe;box-shadow:0 2px 8px #2563eb14}.cl-card-left{flex:1 1;gap:12px;min-width:0}.cl-avatar,.cl-card-left{align-items:center;display:flex}.cl-avatar{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-radius:10px;color:#2563eb;flex-shrink:0;font-size:16px;font-weight:700;height:40px;justify-content:center;width:40px}.cl-avatar-product{background:linear-gradient(135deg,#ccfbf1,#99f6e4);color:#0d9488}.cl-avatar-sm{border-radius:8px;font-size:13px;height:32px;width:32px}.cl-card-info{flex:1 1;min-width:0}.cl-card-name{color:#0f172a;display:block;font-size:15px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cl-card-meta{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.cl-meta-pill{align-items:center;background:#f1f5f9;border-radius:20px;color:#64748b;display:inline-flex;font-size:11px;font-weight:500;gap:4px;padding:2px 8px}.cl-pill-blue{background:#dbeafe;color:#1e40af}.cl-pill-teal{background:#ccfbf1;color:#0f766e}.cl-product-desc{color:#94a3b8;font-size:12px}.cl-card-actions{flex-shrink:0;gap:6px}.cl-arrow-btn,.cl-card-actions{align-items:center;display:flex}.cl-arrow-btn{background:none;border:1px solid #e5e7eb;border-radius:7px;color:#94a3b8;cursor:pointer;padding:5px 7px;transition:all .15s}.cl-arrow-btn:hover{background:#eff6ff;border-color:#2563eb;color:#2563eb}.cl-delete-btn{align-items:center;background:none;border:none;border-radius:6px;color:#cbd5e1;cursor:pointer;display:flex;padding:6px;transition:all .15s}.cl-delete-btn:hover{background:#fef2f2;color:#ef4444}.cl-empty{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:10px;color:#94a3b8;display:flex;flex-direction:column;font-size:14px;gap:12px;justify-content:center;padding:60px 20px}.cl-panel-section-title{align-items:center;color:#374151;display:flex;font-size:12px;font-weight:700;gap:6px;letter-spacing:.5px;text-transform:uppercase}.cl-panel-count{background:#f1f5f9;border-radius:10px;color:#64748b;font-size:11px;font-weight:700;margin-left:auto;padding:1px 7px}.cl-panel-empty{color:#94a3b8;font-size:13px;margin:0;padding:4px 0}.cl-panel-item-name{color:#1e293b;font-size:13px;font-weight:600;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cl-panel-item-sub{color:#94a3b8;font-size:12px;margin-top:2px}.cl-status-badge{border-radius:20px;display:inline-block;font-size:11px;font-weight:600;margin-top:3px;padding:2px 8px}.cl-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a73;display:flex;inset:0;justify-content:center;opacity:0;position:fixed;transition:opacity .2s ease;z-index:1000}.cl-modal-overlay.visible{opacity:1}.cl-modal{background:#fff;border-radius:14px;box-shadow:0 24px 48px #0000002e;display:flex;flex-direction:column;height:560px;max-width:860px;opacity:0;overflow:hidden;transform:translateY(24px) scale(.97);transition:transform .22s ease,opacity .22s ease;width:88vw}.cl-modal.visible{opacity:1;transform:translateY(0) scale(1)}.cl-modal-header{align-items:center;background:#f8fafc;border-bottom:1px solid #f1f5f9;display:flex;flex-shrink:0;justify-content:space-between;padding:18px 24px}.cl-modal-title{align-items:center;display:flex;gap:14px}.cl-panel-close{align-items:center;background:none;border:none;border-radius:6px;color:#94a3b8;cursor:pointer;display:flex;padding:6px;transition:all .15s}.cl-panel-close:hover{background:#f1f5f9;color:#374151}.cl-modal-body{min-height:0}.cl-modal-body,.cl-modal-col{display:flex;flex:1 1;overflow:hidden}.cl-modal-col{flex-direction:column;min-width:0}.cl-modal-col-header{border-bottom:1px solid #f1f5f9;display:flex;flex-direction:column;flex-shrink:0;gap:10px;padding:14px 20px 10px}.cl-modal-col-search{align-items:center;display:flex;position:relative}.cl-modal-search-icon{left:10px;pointer-events:none;position:absolute}.cl-modal-search-input{background:#fff;border:1px solid #e5e7eb;border-radius:7px;box-sizing:border-box;color:#0f172a;font-family:inherit;font-size:13px;outline:none;padding:7px 28px 7px 30px;transition:border-color .15s;width:100%}.cl-modal-search-input:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb14}.cl-modal-search-input::placeholder{color:#9ca3af}.cl-modal-search-clear{align-items:center;background:none;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;display:flex;padding:2px;position:absolute;right:8px;transition:color .15s}.cl-modal-search-clear:hover{color:#374151}.cl-modal-scroll{display:flex;flex:1 1;flex-direction:column;gap:8px;min-height:0;overflow-y:auto;padding:12px 16px}.cl-modal-scroll::-webkit-scrollbar{width:5px}.cl-modal-scroll::-webkit-scrollbar-track{background:#f8fafc}.cl-modal-scroll::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:3px}.cl-modal-scroll::-webkit-scrollbar-thumb:hover{background:#cbd5e1}.cl-modal-divider{background:#f1f5f9;flex-shrink:0;width:1px}.cl-modal-item{align-items:flex-start;background:#fafafa;border:1px solid #f1f5f9;border-radius:8px;display:flex;flex-shrink:0;gap:10px;padding:10px 12px;transition:background .12s,border-color .12s}.cl-modal-item.project:hover{background:#eff6ff;border-color:#bfdbfe}.cl-modal-item.product:hover{background:#f0fdfa;border-color:#99f6e4}.cl-modal-item-icon{align-items:center;border-radius:7px;display:flex;flex-shrink:0;height:28px;justify-content:center;margin-top:1px;width:28px}@media (max-width:640px){.cl-page{padding:16px}.cl-header{align-items:flex-start;gap:16px}.cl-form-row,.cl-header{flex-direction:column}.cl-add-btn{justify-content:center;width:100%}.cl-stats{justify-content:space-around;width:100%}.cl-modal{height:90vh;width:96vw}.cl-modal-body{flex-direction:column}.cl-modal-divider{height:1px;width:100%}}.login-page{background:#fff;display:flex;min-height:100vh}.login-image-panel{align-items:center;background:#fff;display:none;flex:0 0 60%;justify-content:center;overflow:hidden;position:relative}@media (min-width:900px){.login-image-panel{display:flex}}.login-panel-text{line-height:1.1;padding:48px}.login-panel-text p{color:#1e293b;font-size:clamp(52px,6.5vw,82px);font-weight:800;letter-spacing:-2px;margin:0 0 6px}.highlight-orange{color:#f97316}.highlight-blue{color:#2563eb}.highlight-dark{color:#1e293b}.login-image-overlay{display:none}.login-form-panel{background:#fff;border-left:1px solid #e2e8f0;box-shadow:-8px 0 32px #0000000f;display:flex;flex:0 0 40%;flex-direction:column;justify-content:center;padding:48px 44px}@media (max-width:899px){.login-form-panel{border-left:none;box-shadow:none;flex:1 1;padding:40px 24px}}.login-header{margin-bottom:36px}.login-logo-row{align-items:center;display:flex;gap:12px;margin-bottom:28px}.login-logo-img{height:40px;width:auto}.login-logo-text{color:#0f172a;font-size:18px;font-weight:700;letter-spacing:-.3px}.login-header h1{color:#0f172a;font-size:26px;font-weight:700;letter-spacing:-.5px;margin:0 0 6px}.login-header p{color:#64748b;font-size:14px;margin:0}.login-error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px;margin-bottom:20px;padding:12px 16px}.login-form{display:flex;flex-direction:column;gap:18px}.form-group label{align-items:center;display:flex;font-weight:600;gap:6px}.form-group input{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:8px;color:#0f172a;font-size:14px;outline:none;padding:11px 14px;transition:border-color .2s,box-shadow .2s}.form-group input:focus{background:#fff;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-group input::placeholder{color:#94a3b8}.password-input{position:relative}.password-input input{box-sizing:border-box;padding-right:44px;width:100%}.toggle-password{align-items:center;background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;justify-content:center;padding:4px;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:color .2s}.toggle-password:hover{color:#475569}.login-button{background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;letter-spacing:.1px;margin-top:4px;padding:13px;transition:background .2s,box-shadow .2s,transform .15s}.login-button:hover:not(:disabled){background:#1d4ed8;box-shadow:0 4px 14px #2563eb59;transform:translateY(-1px)}.login-button:disabled{cursor:not-allowed;opacity:.6}.login-help{margin-top:4px;text-align:center}.login-help p{color:#94a3b8;font-size:12px;line-height:1.5;margin:0}.forgot-password-link{margin-top:4px;text-align:center}.link-button{background:none;border:none;color:#2563eb;cursor:pointer;font-size:13px;font-weight:500;padding:0;text-decoration:none;transition:color .2s}.link-button:hover{color:#1d4ed8;text-decoration:underline}.link-button:disabled{cursor:not-allowed;opacity:.5}.login-divider{align-items:center;display:flex;gap:12px;margin:4px 0}.login-divider:after,.login-divider:before{background:#e2e8f0;content:"";flex:1 1;height:1px}.login-divider span{color:#94a3b8;font-size:12px}.loading-container{gap:16px;min-height:100vh}.loading-spinner{animation:spin .8s linear infinite;border:3px solid #e2e8f0;height:36px;width:36px}.access-denied{background:#fff;min-height:100vh;padding:20px}.access-denied h2{color:#0f172a;font-size:28px;margin:0 0 16px}.access-denied p{color:#64748b;font-size:16px}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a80}.forgot-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0003;max-height:90vh;max-width:420px;overflow-y:auto;width:100%}.forgot-modal-header{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;padding:20px 24px}.forgot-modal-header h2{align-items:center;color:#0f172a;display:flex;font-size:17px;font-weight:700;gap:10px;margin:0}.close-button{align-items:center;background:none;border:none;border-radius:6px;color:#94a3b8;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:color .2s}.close-button:hover{background:#f1f5f9;color:#0f172a}.close-button:disabled{cursor:not-allowed;opacity:.5}.forgot-modal-body{padding:24px}.forgot-instructions{color:#64748b;font-size:14px;line-height:1.6;margin:0 0 20px}.forgot-error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626}.forgot-error,.forgot-success{font-size:14px;margin-bottom:20px;padding:12px 16px}.forgot-success{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;color:#16a34a}.forgot-button{background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;margin-top:8px;padding:12px 24px;transition:background .2s,box-shadow .2s;width:100%}.forgot-button:hover:not(:disabled){background:#1d4ed8;box-shadow:0 4px 12px #2563eb4d}.forgot-button:disabled{cursor:not-allowed;opacity:.6}.forgot-actions{display:flex;gap:12px;margin-top:8px}.back-button{align-items:center;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:8px;color:#374151;cursor:pointer;display:flex;font-size:14px;gap:6px;padding:12px 16px;transition:all .2s;white-space:nowrap}.back-button:hover:not(:disabled){background:#f1f5f9;border-color:#cbd5e1}.back-button:disabled{cursor:not-allowed;opacity:.5}.resend-code{color:#64748b;font-size:13px;margin-bottom:0;margin-top:16px;text-align:center}@media (max-width:480px){.forgot-modal{border-radius:0;max-height:100vh;max-width:100%}.forgot-modal-body{padding:20px}}.admin-page{background:#f5f7fb;margin:0 auto;max-width:1400px;min-height:calc(100vh - 64px);padding:24px}.admin-header{justify-content:space-between;margin-bottom:24px}.admin-header,.admin-title{align-items:center;display:flex}.admin-title{color:#0f172a;gap:12px}.admin-title h1{font-size:24px;font-weight:600;margin:0}.btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;gap:8px;padding:10px 16px;transition:all .2s}.btn-primary:hover{box-shadow:0 4px 12px #6366f166;transform:translateY(-1px)}.btn-secondary{background:#e5e7eb;color:#1f2937;padding:10px 16px}.btn-secondary:hover{background:#dbeafe;border-color:#93c5fd}.btn-icon{background:#edf2f7;border:1px solid #e2e8f0;color:#475569;padding:8px}.btn-icon:hover{background:#dbeafe;border-color:#93c5fd;color:#1e3a8a}.btn-icon:disabled{cursor:not-allowed;opacity:.4}.btn-danger:hover{background:#ef44444d!important;color:#fca5a5!important}.admin-table-container{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 30px #0f172a14;overflow:hidden}.admin-table{border-collapse:collapse;width:100%}.admin-table th{background:#f9fafb;color:#4b5563;font-size:12px;font-weight:600;letter-spacing:.5px;padding:16px;text-align:left;text-transform:uppercase}.admin-table td{border-bottom:1px solid #f1f5f9;color:#0f172a;font-size:14px;padding:16px}.admin-table tr:hover td{background:#f8fafc}.admin-table tr.inactive td{color:#94a3b8}.admin-table .actions{display:flex;gap:8px}.role-badge{border-radius:20px;font-size:12px;padding:4px 10px}.role-admin{background:#ef444433;color:#fca5a5}.role-manager{background:#f59e0b33;color:#fcd34d}.role-viewer{background:#6366f133;color:#a5b4fc}.role-badge:not(.role-admin):not(.role-manager):not(.role-viewer){background:#94a3b833;color:#cbd5e1}.status-badge{border-radius:20px}.status-badge.active{background:#22c55e33;color:#86efac}.status-badge.inactive{background:#94a3b833;color:#94a3b8}.modal-overlay{background:#000c}.modal-content{border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 20px 25px -5px #0f172a26;max-width:480px;padding:32px}.modal-content.modal-large{max-width:720px}.modal-content h2{color:#0f172a;font-size:20px;margin:0 0 24px}.form-group{margin-bottom:20px}.form-group label{color:#475569;margin-bottom:8px}.form-group input,.form-group select{background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#0f172a;font-size:14px;padding:12px 16px;transition:all .2s;width:100%}.form-group select option{background:#fff;color:#0f172a}.form-group input:focus,.form-group select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f126;outline:none}.form-group.checkbox label{align-items:center;color:#0f172a;cursor:pointer;display:flex;gap:10px}.form-group.checkbox input{width:auto}.modal-actions{border-top:1px solid #e5e7eb;margin-top:24px;padding-top:24px}.admin-loading{align-items:center;color:#94a3b8;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:400px}.spin{animation:spin 1s linear infinite}.roles-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.role-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 25px #0f172a14;padding:20px;transition:all .2s}.role-card:hover{border-color:#93c5fd;transform:translateY(-2px)}.role-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:8px}.role-card-header h3{color:#0f172a;font-size:18px;margin:0}.role-actions{display:flex;gap:6px}.role-description{color:#475569;font-size:13px;margin:0 0 16px}.role-permissions h4{color:#64748b;font-size:12px;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.permission-tags{display:flex;flex-wrap:wrap;gap:6px}.permission-tag{background:#eef2ff;border-radius:6px;color:#4338ca;font-size:11px;font-weight:500;padding:4px 10px}.permission-tag.more{background:#e2e8f0;color:#475569}.permissions-section{margin:20px 0}.permissions-section>label{color:#94a3b8;display:block;font-size:14px;margin-bottom:16px}.permissions-by-resource{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.resource-group{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px}.resource-group h4{border-bottom:1px solid #e5e7eb;color:#0f172a;font-size:14px;font-weight:600;margin:0 0 12px;padding-bottom:8px;text-transform:capitalize}.permission-checkboxes{display:flex;flex-direction:column;gap:10px}.permission-checkbox{align-items:center;border-radius:6px;cursor:pointer;display:flex;gap:10px;padding:6px;transition:background .2s}.permission-checkbox:hover{background:#3b82f614}.permission-checkbox input{display:none}.checkmark{align-items:center;border:2px solid #ffffff4d;border-radius:4px;display:flex;flex-shrink:0;height:18px;justify-content:center;transition:all .2s;width:18px}.permission-checkbox input:checked+.checkmark{background:#6366f1;border-color:#6366f1}.perm-name{color:#0f172a;flex-shrink:0;font-size:13px;font-weight:500;min-width:80px}.perm-desc{color:#64748b;font-size:11px;margin-left:auto}.perm-text{color:#334155;flex:1 1;font-size:13px}.access-denied{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:400px;padding:40px;text-align:center}.access-denied h2{color:#fff;font-size:24px;margin:0 0 12px}.access-denied p{color:#94a3b8;font-size:14px;margin:0}.weekly-updates-page{margin:0 auto;max-width:1400px;padding:20px}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.page-header h1{color:#1f2937;font-size:24px;font-weight:600;margin:0}.header-actions{display:flex;gap:10px}.tabs-container{border-bottom:2px solid #e5e7eb;display:flex;gap:4px;margin-bottom:20px;padding-bottom:2px}.tab{background:none;border:none;border-bottom:2px solid #0000;color:#6b7280;cursor:pointer;font-size:14px;font-weight:500;margin-bottom:-2px;padding:10px 20px;transition:all .2s}.tab:hover{color:#374151}.tab.active{border-bottom-color:#2563eb;color:#2563eb}.filters-row{align-items:center;display:flex;gap:12px;margin-bottom:20px}.filter-select{background-color:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:14px;min-width:180px;padding:8px 12px}.filter-select:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.btn-primary{background-color:#2563eb;border-radius:6px;transition:background-color .2s}.btn-primary:hover{background-color:#1d4ed8}.btn-secondary{background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#374151;transition:all .2s}.btn-secondary:hover{background-color:#e5e7eb}.btn-icon{background:none;border-radius:4px;color:#6b7280;display:inline-flex;transition:all .2s}.btn-icon:hover{background-color:#f3f4f6;color:#374151}.btn-icon.edit:hover{background-color:#dbeafe;color:#1d4ed8}.btn-icon.delete:hover{background-color:#fee2e2;color:#dc2626}.form-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:20px;padding:24px}.form-card h3{color:#1f2937;font-size:18px;font-weight:600;margin:0 0 20px}.form-row{grid-template-columns:2fr 1fr;margin-bottom:16px}.form-group label{color:#374151;display:block;font-size:14px;margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{border:1px solid #d1d5db;border-radius:6px;padding:8px 12px;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-group textarea{min-height:80px;resize:vertical}.form-actions{display:flex;gap:12px;margin-top:20px}.updates-list{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.table-container{overflow-x:auto}.updates-table{border-collapse:collapse;width:100%}.updates-table th{background-color:#f9fafb;border-bottom:1px solid #e5e7eb;color:#6b7280;font-size:12px;font-weight:600;letter-spacing:.05em;padding:12px 16px;text-align:left;text-transform:uppercase}.updates-table td{border-bottom:1px solid #f3f4f6;padding:12px 16px}.update-row:hover{background-color:#f9fafb}.status-badge{align-items:center;border-radius:12px;display:inline-flex;font-size:12px;font-weight:500;padding:4px 10px;text-transform:capitalize}.status-badge.draft{background-color:#fef3c7;color:#92400e}.status-badge.submitted{background-color:#d1fae5;color:#065f46}.manager-cell,.resource-cell,.week-cell{align-items:center;color:#374151;display:flex;font-size:14px;gap:8px}.action-buttons{gap:4px}.details-row td{background-color:#f9fafb;padding:0}.update-details{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(3,1fr);padding:20px}.detail-section h4{color:#6b7280;font-size:13px;letter-spacing:.05em;margin:0 0 8px}.detail-section p{color:#374151;font-size:14px;line-height:1.5;margin:0;white-space:pre-wrap}.empty-state{padding:60px 20px}.empty-state p{color:#6b7280;font-size:16px;margin-bottom:20px}.loading-spinner{border:3px solid #f3f4f6;border-top-color:#2563eb}.text-muted{color:#9ca3af}.resource-row:hover{background-color:#f9fafb}.resource-cell.clickable{color:#2563eb;cursor:pointer;transition:color .2s}.resource-cell.clickable:hover{color:#1d4ed8;text-decoration:underline}.clients-header{margin-bottom:20px}.clients-header h3{color:#1f2937;font-size:18px;font-weight:600;margin:0 0 4px}.clients-header p{color:#6b7280;font-size:14px;margin:0}.clients-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.client-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:12px;padding:20px;transition:all .2s}.client-card:hover{border-color:#2563eb;box-shadow:0 4px 6px -1px #0000001a}.client-card-header{align-items:center;color:#2563eb;display:flex;gap:12px}.client-card-header h4{color:#1f2937;font-size:16px;font-weight:600;margin:0}.client-card-stats{display:flex;flex-direction:column;gap:8px}.client-card-stats .stat{align-items:center;color:#6b7280;display:flex;font-size:13px;gap:6px}.client-card-stats .stat.update-status{color:#374151}.client-card-stats .stat.no-update{color:#9ca3af;font-style:italic}.client-card-arrow{color:#9ca3af;display:flex;justify-content:center;margin-top:8px}.resources-header{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.resources-header h3{color:#1f2937;font-size:18px;font-weight:600;margin:0}.back-btn{align-self:flex-start}.role-badge{align-items:center;border-radius:12px;display:inline-flex;font-weight:500;letter-spacing:.02em;padding:2px 8px}.role-badge.manager{background-color:#dbeafe;color:#1d4ed8}.role-badge.resource{background-color:#f3f4f6;color:#4b5563}.role-badge.admin,.role-badge.csp{background-color:#d1fae5;color:#065f46}.client-cell{color:#6b7280}.client-cell,.last-update-cell{align-items:center;display:flex;gap:8px}.last-update-cell{flex-wrap:wrap}.last-update-cell .status-badge.small{font-size:10px;padding:2px 6px}.no-update{color:#9ca3af;font-style:italic}.btn-icon.view:hover{background-color:#dbeafe;color:#1d4ed8}.btn-icon.remind:hover{background-color:#fef3c7;color:#92400e}.modal-overlay{background-color:#00000080;padding:20px}.modal-content{border-radius:8px;box-shadow:0 20px 25px -5px #0000001a;max-width:800px}.modal-header{border-bottom:1px solid #e5e7eb}.modal-header h2{align-items:center;color:#1f2937;display:flex;gap:10px}.resource-info{background-color:#f9fafb;border-radius:6px;margin-bottom:20px;padding:16px}.resource-info p{color:#374151;font-size:14px;margin:4px 0}.email-link{color:#2563eb;text-decoration:none}.email-link:hover{text-decoration:underline}.modal-actions{align-items:center;gap:8px}.modal-filter{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;gap:12px;margin-bottom:20px;padding-bottom:16px}.modal-filter label{color:#374151;font-size:14px;font-weight:500}.pending-update{padding:40px 20px;text-align:center}.pending-icon{color:#9ca3af;margin-bottom:16px}.pending-update h3{color:#374151;font-size:18px;font-weight:600;margin:0 0 8px}.pending-update p{color:#6b7280;font-size:14px;margin:0 0 20px}.remind-btn{align-items:center;display:inline-flex;gap:8px}.update-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:16px;padding:16px}.update-card .update-header{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:12px}.update-card .update-week{color:#374151;font-weight:500}.update-card .update-content{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr)}.update-card .update-section h4{color:#6b7280;font-size:12px;font-weight:600;margin:0 0 8px;text-transform:uppercase}.update-card .update-section p{color:#374151;font-size:14px;line-height:1.5;margin:0}@media (max-width:1024px){.form-row,.update-card .update-content,.update-details{grid-template-columns:1fr}}@media (max-width:768px){.filters-row{flex-wrap:wrap}.filter-select{min-width:0;min-width:auto;width:100%}.weekly-updates-page{padding:12px}.updates-table td,.updates-table th{padding:8px 12px}.page-header{align-items:flex-start;flex-direction:column;gap:12px}.modal-content{margin:10px;max-height:95vh}}.performance-page{margin:0 auto;max-width:100%;padding:24px}.performance-header{align-items:center;display:flex;gap:8px;margin-bottom:24px}.performance-header h1{color:#0f172a;font-size:24px;font-weight:700;margin:0}.perf-page-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.perf-page-title h1{align-items:center;color:#0f172a;display:flex;font-size:22px;font-weight:700;gap:8px;margin:0 0 6px}.perf-page-title .info-icon{color:#94a3b8;cursor:help;transition:color .15s ease}.perf-page-title .info-icon:hover{color:#64748b}.perf-page-title p{color:#64748b;font-size:13px;margin:0}.upload-feedback-btn{align-items:center;background:#0f172a;border:none;border-radius:10px;box-shadow:0 4px 6px -1px #0f172a1a;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;padding:10px 18px;transition:all .15s ease;white-space:nowrap}.upload-feedback-btn:hover{background:#1e293b;box-shadow:0 8px 12px -2px #0f172a1f;transform:translateY(-1px)}.perf-controls-row{align-items:flex-end;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:20px}.last-updated{color:#64748b;font-size:13px;margin-left:auto;padding-bottom:8px}.perf-control-group select:disabled{background:#f8fafc;color:#94a3b8;cursor:not-allowed}.perf-control-group{display:flex;flex-direction:column;gap:4px}.perf-control-group label{color:#475569;font-size:12px;font-weight:600;letter-spacing:.3px;text-transform:uppercase}.perf-control-group select{background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#0f172a;cursor:pointer;font-size:14px;min-width:200px;padding:8px 12px}.perf-control-group select:focus{border-color:#0f172a;outline:none}.client-badge{align-items:center;background:#f1f5f9;border-radius:6px;color:#475569;display:inline-flex;font-size:13px;font-weight:500;margin-left:8px;padding:2px 10px}.metrics-cards-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:24px}.metrics-cards-row.two-col{grid-template-columns:1fr 1fr}.metrics-cards-row.three-col{grid-gap:20px;align-items:stretch;display:grid;gap:20px;grid-template-columns:1fr 1fr 1fr}@media (max-width:992px){.metrics-cards-row.three-col{grid-template-columns:1fr}}@media (max-width:768px){.metrics-cards-row.two-col{grid-template-columns:1fr}}.metric-card-large{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #00000005,0 2px 4px -2px #00000005;padding:20px 24px;transition:all .2s ease}.metric-card-large:hover{box-shadow:0 10px 15px -3px #0000000a,0 4px 6px -4px #00000005}.metric-card-large h5{color:#64748b;font-size:11px;font-weight:600;letter-spacing:.8px;margin:0 0 16px;text-transform:uppercase}.metric-large-value{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#0f172a,#334155);-webkit-background-clip:text;background-clip:text;color:#0f172a;font-size:42px;font-weight:800;line-height:1;margin-bottom:6px}.metric-large-sublabel{color:#64748b;font-size:13px}.metric-card-clickable{transition:all .15s ease}.metric-card-clickable:hover{border-color:#0f172a;box-shadow:0 4px 12px #0000000f}.highlight-missing{font-weight:600}.metric-card-compact{display:flex;flex-direction:column;gap:8px}.metric-card-compact .metric-card-body{flex-direction:row!important}.metric-card-compact .metric-text-right{flex:1 1;min-width:0}.metric-card-compact .metric-big-value{font-size:28px;font-weight:800;line-height:1.1;margin-bottom:4px}.metric-card-compact .metric-big-label{color:#475569;font-size:13px;font-weight:600;margin-bottom:4px}.metric-card-compact .metric-big-sublabel{color:#64748b;font-size:12px}.metric-card-compact .metric-card-body.total-resources-body{align-items:flex-start;flex-direction:row}.metric-card-compact .metric-text-block{flex:1 1}.metric-missing-breakdown{font-size:12px;margin-top:4px}.missing-detail{color:#64748b;display:flex;font-size:11px;gap:12px;margin-top:4px}.missing-dot{border-radius:50%;display:inline-block;height:8px;margin-right:4px;width:8px}.metric-all-good{align-items:center;color:#22c55e;display:flex;font-size:12px;gap:4px;margin-top:4px}.role-badge{border-radius:4px;display:inline-block;font-size:11px;font-weight:600;letter-spacing:.3px;padding:3px 8px;text-transform:uppercase}.role-badge.manager{background:#f3e8ff;border:1px solid #ddd6fe;color:#7c3aed}.role-badge.resource{background:#eff6ff;border:1px solid #dbeafe;color:#2563eb}.distribution-list{display:flex;flex-direction:column;gap:10px}.dist-row{align-items:center;display:flex;font-size:13px;gap:10px}.dist-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.dist-name{color:#475569;flex:1 1}.dist-count{color:#0f172a;font-weight:600;min-width:24px;text-align:right}.dist-pct{color:#64748b}.dist-empty{font-size:12px;padding:8px 0}.metrics-cards-row.three-col .metric-card-large{display:flex;flex-direction:column;min-height:180px}.metrics-cards-row.three-col .metric-card-large.sc-breakdown-card{align-self:start;min-height:0;min-height:auto}.metrics-cards-row.three-col .metric-card-large>.distribution-list,.metrics-cards-row.three-col .metric-card-large>.metric-card-body{display:flex;flex:1 1;flex-direction:column;justify-content:center}.dist-pct{color:#94a3b8;font-size:12px;min-width:36px;text-align:right}.dist-empty{color:#94a3b8;font-size:13px;font-style:italic}.table-section-header{align-items:baseline;display:flex;gap:16px;justify-content:space-between;margin-bottom:12px}.table-section-header h3{color:#0f172a;font-size:16px;font-weight:600;margin:0}.table-count{color:#64748b;font-size:13px}.feedback-summary{color:#475569;font-size:13px;line-height:1.4;max-width:280px}.data-table-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000a;overflow:hidden}.data-table-header{border-bottom:1px solid #f1f5f9;color:#64748b;font-size:13px;font-weight:500;padding:14px 20px}.perf-data-table{border-collapse:collapse;font-size:13px;width:100%}.perf-data-table thead th{background:#fafafa;border-bottom:1px solid #e2e8f0;color:#64748b;font-size:11px;letter-spacing:.5px;padding:10px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}.perf-data-table tbody td{border-bottom:1px solid #f1f5f9;color:#0f172a;padding:12px 16px;vertical-align:middle}.perf-data-table tbody tr:last-child td{border-bottom:none}.perf-data-table tbody tr:hover{background:#f8fafc}.resource-cell{align-items:center;display:flex;gap:10px}.resource-cell .resource-avatar{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:12px;font-weight:600;height:32px;justify-content:center;width:32px}.resource-name{color:#0f172a;font-weight:500}.status-cell{align-items:center;display:flex;gap:8px}.status-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.na-text{color:#94a3b8}.btn-icon-action{align-items:center;background:none;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:inline-flex;justify-content:center;padding:6px;transition:all .15s ease}.btn-icon-action:hover{background:#f1f5f9;color:#0f172a}.perf-data-table td:last-child{align-items:center;display:flex;gap:4px}.metrics-filter-row{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:20px}.metrics-title{color:#0f172a;font-size:18px;font-weight:700}.client-filter,.metrics-title{align-items:center;display:flex;gap:8px}.client-filter select{background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#0f172a;cursor:pointer;font-size:14px;min-width:160px;padding:8px 12px}.client-filter select:focus{border-color:#0f172a;outline:none}.metrics-cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.metric-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #0000000a;gap:14px;padding:18px 20px}.metric-card,.metric-card-icon{align-items:center;display:flex}.metric-card-icon{border-radius:10px;flex-shrink:0;height:44px;justify-content:center;width:44px}.metric-card-body{display:flex;flex-direction:column;gap:2px}.metric-value{color:#0f172a;font-size:22px;font-weight:700}.metric-label{color:#64748b;font-size:13px;font-weight:500}.charts-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:32px}.chart-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #0000000a;padding:20px}.chart-card h4{color:#475569;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 16px;text-transform:uppercase}.chart-wrapper{width:100%}.back-btn{align-items:center;background:none;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;font-size:14px;gap:6px;padding:4px 8px;transition:all .15s ease}.back-btn:hover{background:#f1f5f9;color:#0f172a}.breadcrumb{align-items:center;color:#64748b;display:flex;font-size:14px;gap:8px;margin-bottom:20px}.breadcrumb span.active{color:#0f172a;font-weight:600}.client-metrics-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-top:24px}.client-metric-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #00000005,0 2px 4px -2px #00000005;cursor:pointer;padding:20px;transition:all .2s ease}.client-metric-card:hover{border-color:#cbd5e1;box-shadow:0 10px 15px -3px #0000000a,0 4px 6px -4px #00000005;transform:translateY(-2px)}.client-metric-header{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:16px}.client-metric-header h3{color:#0f172a;font-size:16px;font-weight:600;margin:0}.client-status-badge{border-radius:6px;font-size:12px;font-weight:600;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase}.client-metrics-body{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.client-metric-item{display:flex;flex-direction:column;gap:4px}.client-metric-label{color:#64748b;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.client-metric-value{color:#0f172a;font-size:24px;font-weight:700;line-height:1}.client-metric-date{color:#64748b;font-size:13px;font-weight:500}.highlight-missing{color:#ef4444}.all-resources-section{width:100%}.resource-filters.compact{align-items:center;display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.resource-filters.compact .filter-input{background:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#1e293b;flex:2 1;font-size:13px;height:32px;max-width:200px;min-width:140px;outline:none;padding:6px 10px}.multi-select-wrapper{flex:1 1;height:32px;max-width:160px;min-width:110px;position:relative}.multi-select-wrapper select.multi-select{cursor:pointer;height:100%;left:0;opacity:0;position:absolute;top:0;width:100%;z-index:2}.multi-select-wrapper .multi-select-label{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#1e293b;display:flex;font-size:13px;height:100%;left:0;overflow:hidden;padding:6px 24px 6px 10px;pointer-events:none;position:absolute;text-overflow:ellipsis;top:0;white-space:nowrap;width:100%;z-index:1}.multi-select-wrapper .multi-select-label:after{color:#64748b;content:"▼";font-size:10px;position:absolute;right:8px;top:50%;transform:translateY(-50%)}.multi-select-wrapper:hover .multi-select-label{border-color:#cbd5e1}.multi-select-wrapper select.multi-select:focus+.multi-select-label{border-color:#6366f1;box-shadow:0 0 0 2px #6366f11a}.resource-filters.compact .filter-select{background:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#1e293b;cursor:pointer;flex:1 1;font-size:13px;height:32px;max-width:160px;min-width:110px;outline:none;padding:6px 10px}.resource-filters.compact .filter-input:focus,.resource-filters.compact .filter-select:focus{border-color:#6366f1;box-shadow:0 0 0 2px #6366f11a}.clear-filters-btn{background:#ef4444;border:none;border-radius:6px;color:#fff;cursor:pointer;flex-grow:0;flex-shrink:0;font-size:13px;font-weight:500;padding:6px 12px;transition:all .2s;white-space:nowrap}.clear-filters-btn:hover{background:#dc2626;transform:translateY(-1px)}.clear-filters-btn:active{transform:translateY(0)}.data-table-container{border:1px solid #e2e8f0;border-radius:8px;max-height:400px;overflow-y:auto}.data-table-container::-webkit-scrollbar{width:8px}.data-table-container::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.data-table-container::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.data-table-container::-webkit-scrollbar-thumb:hover{background:#94a3b8}.perf-data-table thead{background:#f8fafc;position:sticky;top:0;z-index:10}.perf-data-table thead th{background:#f8fafc;border-bottom:2px solid #e2e8f0;font-weight:600}.last-updated-row{display:flex;justify-content:flex-end;margin-bottom:16px}.last-updated-row span{color:#64748b;font-size:13px}.resource-filters{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:16px}.filter-group{flex:1 1;min-width:150px}.filter-input,.filter-select{background:#fff;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;padding:8px 12px;width:100%}.filter-input:focus,.filter-select:focus{border-color:#0f172a;outline:none}.resources-table td,.resources-table th{font-size:13px;padding:10px 12px}.resources-table td:last-child,.resources-table th:last-child{text-align:center;width:150px}.action-buttons{gap:6px}.action-btn,.action-buttons{align-items:center;display:flex;justify-content:center}.action-btn{border:none;border-radius:6px;cursor:pointer;flex-shrink:0;font-size:18px;height:40px;transition:all .15s ease;width:40px}.action-btn svg{height:20px;width:20px}.action-btn svg circle,.action-btn svg line,.action-btn svg path,.action-btn svg rect{stroke:#64748b!important;fill:none!important}.action-btn.view-btn{background:#0000;border:none;color:#64748b;padding:0}.action-btn.view-btn:hover{background:#0000;color:#2563eb}.action-btn.view-btn:hover svg circle,.action-btn.view-btn:hover svg line,.action-btn.view-btn:hover svg path,.action-btn.view-btn:hover svg rect{stroke:#2563eb!important}.stat-label{color:#94a3b8;font-size:12px}.role-team-text{color:#475569;font-size:13px;font-weight:500}.recommendation-badge{align-items:center;border-radius:12px;display:inline-flex;font-size:12px;font-weight:600;letter-spacing:.3px;padding:4px 10px;text-transform:uppercase}.recommendation-badge.continue_meets,.recommendation-badge.continue_strong{background:#dcfce7;color:#166534}.recommendation-badge.continue_improvement{background:#fef3c7;color:#92400e}.recommendation-badge.replacement,.recommendation-badge.replacement_backfill,.recommendation-badge.role_change{background:#fee2e2;color:#991b1b}.recommendation-badge.none{background:#f1f5f9;color:#64748b}.rating-display{align-items:center;display:flex;gap:6px}.rating-value{color:#0f172a;font-size:14px;font-weight:600;min-width:24px}.rating-stars{color:#f59e0b;font-size:12px;letter-spacing:1px}.rating-empty{color:#94a3b8;font-size:14px}.resource-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.resource-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #0000000a;cursor:pointer;padding:18px;transition:all .15s ease}.resource-card:hover{border-color:#cbd5e1;box-shadow:0 4px 12px #00000014}.resource-card-header{align-items:center;display:flex;gap:10px;margin-bottom:14px}.resource-avatar{align-items:center;background:#f0fdf4;border-radius:50%;color:#15803d;display:flex;font-size:13px;font-weight:600;height:36px;justify-content:center;width:36px}.resource-card h4{color:#0f172a;font-size:15px;font-weight:600;margin:0}.resource-card p{color:#94a3b8;font-size:12px;margin:2px 0 0}.resource-metrics-preview{border-top:1px solid #f1f5f9;display:flex;gap:12px;padding-top:12px}.metric-pill{align-items:center;color:#475569;display:flex;font-size:12px;gap:4px}.metric-pill strong{color:#0f172a;font-weight:600}.no-reports{border-top:1px solid #f1f5f9;color:#94a3b8;font-size:12px;padding-top:12px}.reports-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px}.reports-section h3{color:#0f172a;font-size:18px;font-weight:600;margin:0}.reports-header{gap:16px;justify-content:space-between;margin-bottom:20px}.reports-filters,.reports-header{align-items:center;display:flex;flex-wrap:wrap}.reports-filters{gap:12px}.reports-filters .filter-group{margin:0}.reports-table{cursor:pointer}.report-row:hover{background:#f8fafc}.report-quarter{color:#0f172a;font-weight:600}.scorecard-summary{color:#64748b;display:flex;font-size:12px;gap:12px}.scorecard-summary span{background:#f1f5f9;border-radius:4px;padding:2px 6px}.scorecard-inline{align-items:center;display:flex;gap:8px}.scorecard-metric{align-items:center;background:#fff;border:1px solid;border-radius:4px;display:flex;flex-direction:column;gap:2px;min-width:60px;padding:4px 6px}.metric-label{font-size:8px;letter-spacing:.3px;line-height:1;opacity:.65;text-transform:uppercase}.metric-label,.metric-value{font-weight:600;text-align:center}.metric-value{font-size:11px;line-height:1.2}.scorecard-metric.delivery-yes{border-color:#16a34a;color:#16a34a}.scorecard-metric.delivery-mostly{border-color:#f59e0b;color:#f59e0b}.scorecard-metric.delivery-not{border-color:#dc2626;color:#dc2626}.scorecard-metric.quality-good{border-color:#16a34a;color:#16a34a}.scorecard-metric.quality-mixed{border-color:#f59e0b;color:#f59e0b}.scorecard-metric.quality-poor{border-color:#dc2626;color:#dc2626}.scorecard-metric.rework-low{border-color:#16a34a;color:#16a34a}.scorecard-metric.rework-medium{border-color:#f59e0b;color:#f59e0b}.scorecard-metric.rework-high{border-color:#dc2626;color:#dc2626}.scorecard-metric.communication-effective{border-color:#16a34a;color:#16a34a}.scorecard-metric.communication-needs_improvement{border-color:#f59e0b;color:#f59e0b}.scorecard-metric.communication-none,.scorecard-metric.delivery-none,.scorecard-metric.quality-none,.scorecard-metric.rework-none{border-color:#cbd5e1;color:#94a3b8}.reports-table th{border-bottom:2px solid #e2e8f0;color:#64748b;font-size:12px;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.reports-table td{border-bottom:1px solid #f1f5f9;color:#334155;font-size:14px;padding:14px 16px}.reports-table tr:hover td{background:#f8fafc}.score-badge{align-items:center;border-radius:8px;display:inline-flex;font-size:13px;font-weight:700;height:36px;justify-content:center;width:36px}.score-high{background:#f0fdf4;color:#15803d}.score-mid{background:#fefce8;color:#a16207}.score-low{background:#fef2f2;color:#b91c1c}.notes-cell{color:#64748b;font-size:13px;max-width:300px}.empty-state{color:#94a3b8;padding:48px 24px;text-align:center}.empty-state h3{color:#475569;font-size:16px;font-weight:600;margin:0 0 8px}.empty-state p{font-size:14px;margin:0}.loading-container{align-items:center;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;color:#6b7280;display:flex;flex-direction:column;font-size:14px;justify-content:center;padding:60px}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#3b82f6;height:40px;margin-bottom:16px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.report-cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.report-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #0000000a;overflow:hidden;padding:0;transition:all .15s ease}.report-card:hover{border-color:#cbd5e1;box-shadow:0 4px 12px #00000014}.report-card-header{align-items:center;border-bottom:1px solid #f1f5f9;cursor:pointer;display:flex;gap:12px;justify-content:space-between;padding:14px 16px}.report-card-header:hover{background:#f8fafc}.report-info{align-items:center;display:flex;gap:10px;min-width:0}.report-info h4{color:#0f172a;font-size:15px;font-weight:600;margin:0;white-space:nowrap}.report-date{color:#94a3b8;font-size:12px;white-space:nowrap}.report-status-badge{border-radius:6px;flex-shrink:0;font-size:11px;font-weight:700;letter-spacing:.5px;padding:4px 10px}.report-status-badge-large{border-radius:8px;display:inline-block;font-size:14px;font-weight:700;letter-spacing:.5px;padding:8px 16px}.report-card-body{cursor:pointer;display:flex;flex-direction:column;gap:6px;padding:12px 16px}.report-card-body:hover{background:#f8fafc}.report-summary-row{color:#475569;display:flex;flex-wrap:wrap;font-size:13px;gap:16px}.report-summary-row strong{color:#0f172a;font-weight:500}.report-card-actions{background:#fafafa;border-top:1px solid #f1f5f9;display:flex;gap:6px;justify-content:flex-end;padding:10px 16px}.btn-primary{align-items:center;background:#0f172a;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:6px;padding:8px 16px;transition:all .15s ease}.btn-primary:hover{background:#1e293b}.btn-primary:disabled{cursor:not-allowed;opacity:.5}.btn-secondary{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#475569;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:6px;padding:8px 16px;transition:all .15s ease}.btn-secondary:hover{background:#f8fafc}.btn-icon{align-items:center;background:#0000;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .15s ease;width:32px}.btn-icon:hover{background:#f1f5f9}.btn-edit{color:#0369a1}.btn-edit:hover{background:#f0f9ff}.btn-danger{color:#ef4444}.btn-danger:hover{background:#fef2f2}.modal-overlay{background:#0006;inset:0;padding:24px;z-index:100}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 60px #00000026;max-height:90vh;overflow-y:auto;width:100%}.modal-header{border-bottom:1px solid #e2e8f0;padding:20px 24px}.modal-header h2{color:#0f172a;font-size:18px;margin:0}.modal-body{padding:24px}.modal-actions{border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.upload-modal{max-width:480px}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-group label{color:#334155;font-size:13px;font-weight:500}.form-group input,.form-group select,.form-group textarea{background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#0f172a;font-family:inherit;font-size:14px;padding:10px 12px;transition:border-color .15s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#0f172a;outline:none}.file-dropzone{border:2px dashed #cbd5e1;border-radius:10px;cursor:pointer;padding:32px;text-align:center;transition:all .15s ease}.file-dropzone:hover{background:#f8fafc;border-color:#0f172a}.file-dropzone p{color:#64748b;font-size:13px;margin:8px 0 0}.review-modal{max-width:960px}.review-modal-body{grid-gap:0;display:grid;gap:0;grid-template-columns:1fr 1fr;min-height:500px}.pdf-preview-panel{background:#f8fafc;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;padding:20px}.pdf-preview-panel h4{color:#0f172a;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.pdf-embed{background:#fff;border:1px solid #e2e8f0;width:100%}.pdf-embed,.pdf-placeholder{border-radius:8px;flex:1 1;min-height:400px}.pdf-placeholder{align-items:center;background:#f1f5f9;color:#64748b;display:flex;font-size:14px;justify-content:center}.metadata-form-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr;margin-bottom:20px}.metadata-form-grid .form-group{margin:0}.metadata-form-grid .form-group input{border:1px solid #e2e8f0;border-radius:6px;font-size:14px;padding:8px 12px;width:100%}.ocr-panel{background:#f8fafc;border-right:1px solid #e2e8f0;padding:20px 24px}.ocr-panel h4{color:#475569;font-size:14px;font-weight:600;margin:0 0 12px}.ocr-text{background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#334155;font-family:SF Mono,Consolas,monospace;font-size:12px;line-height:1.6;max-height:600px;overflow-y:auto;padding:12px;white-space:pre-wrap;word-break:break-word}.form-panel{max-height:70vh;overflow-y:auto;padding:20px 24px}.section-title{color:#0f172a;font-size:14px;font-weight:600;letter-spacing:.5px;margin:20px 0 12px;text-transform:uppercase}.extracted-metadata{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:20px;padding:16px}.metadata-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.metadata-item{display:flex;flex-direction:column;gap:2px}.metadata-label{color:#64748b;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.metadata-value{color:#0f172a;font-size:14px;font-weight:500}.scorecard-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.radio-group{display:flex;gap:10px}.radio-chip{align-items:center;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;display:flex;font-size:13px;gap:6px;padding:8px 12px;transition:all .15s ease}.radio-chip:hover{background:#f8fafc}.radio-chip input[type=radio]{accent-color:#0f172a}.detail-modal{max-height:85vh;max-width:960px;width:90vw}.detail-modal .modal-header{border-bottom:1px solid #e2e8f0;padding-bottom:12px}.detail-modal .detail-body{max-height:calc(85vh - 80px);overflow-y:auto;padding-top:0}.detail-body{padding:24px}.detail-section{margin-bottom:20px;padding-top:16px}.detail-section:first-of-type{padding-top:0}.detail-section h4{color:#475569;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 10px;text-transform:uppercase}.detail-text{word-wrap:break-word;background:#f8fafc;border-radius:8px;color:#334155;font-size:14px;line-height:1.6;margin-top:12px;padding:12px;white-space:pre-wrap}.detail-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.detail-item{background:#f8fafc;border-radius:8px;padding:12px}.detail-item label{color:#64748b;display:block;font-size:12px;margin-bottom:4px}.detail-item strong{color:#0f172a;font-size:14px;font-weight:500}.detail-item p{color:#94a3b8;font-size:12px;margin:4px 0 0}.feedback-item{background:#f8fafc;border-radius:8px;margin-bottom:16px;padding:12px}.feedback-item label{color:#64748b;display:block;font-size:12px;font-weight:600;letter-spacing:.3px;margin-bottom:6px;text-transform:uppercase}.feedback-item p{word-wrap:break-word;color:#334155;font-size:14px;line-height:1.6;margin:0;white-space:pre-wrap}.recommendation-box{display:inline-block;font-size:14px}.no-report-modal{display:flex;flex-direction:column;height:600px;max-height:80vh;max-width:95vw;width:600px}.no-report-modal .modal-header{border-bottom:1px solid var(--color-gray-200);flex-shrink:0;padding:var(--space-5)}.modal-header-left{align-items:center;display:flex;gap:12px}.modal-count{background:var(--color-gray-100);border-radius:20px;color:var(--color-gray-500);font-size:13px;font-weight:var(--font-medium);padding:4px 12px}.modal-filters{background:var(--color-gray-50);border-bottom:1px solid var(--color-gray-200);display:flex;flex-direction:column;flex-shrink:0;gap:16px;padding:var(--space-4) var(--space-5)}.modal-search{align-items:center;display:flex;position:relative}.modal-search .search-icon{color:var(--color-gray-400);left:12px;pointer-events:none;position:absolute}.modal-search-input{background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--radius-md);font-size:14px;padding:10px 36px 10px 40px;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.modal-search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a;outline:none}.clear-search{align-items:center;background:none;border:none;border-radius:4px;color:var(--color-gray-400);cursor:pointer;display:flex;justify-content:center;padding:4px;position:absolute;right:10px;transition:background .15s ease,color .15s ease}.clear-search:hover{background:var(--color-gray-100);color:var(--color-gray-600)}.modal-role-toggle{display:flex;gap:8px;justify-content:flex-end}.role-toggle-btn{align-items:center;background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--radius-md);color:var(--color-gray-500);cursor:pointer;display:flex;font-size:13px;font-weight:var(--font-medium);gap:6px;padding:8px 14px;transition:all .15s ease}.role-toggle-btn:hover{background:var(--color-gray-50);border-color:var(--color-gray-300)}.role-toggle-btn.active{background:var(--color-gray-900);border-color:var(--color-gray-900);color:#fff}.role-toggle-btn svg{color:currentColor}.no-report-list{flex:1 1;overflow-y:auto;padding:0}.no-report-summary{background:var(--color-gray-50);border-bottom:1px solid var(--color-gray-200);display:flex;flex-shrink:0;font-size:13px;font-weight:var(--font-medium);gap:16px;padding:12px var(--space-5)}.summary-item{align-items:center;display:flex;gap:6px}.summary-item.managers{color:#7c3aed}.summary-item.resources{color:#2563eb}.dot{border-radius:50%;height:8px;width:8px}.manager-dot{background:#8b5cf6}.resource-dot{background:#3b82f6}.no-report-items{display:flex;flex-direction:column}.no-report-item{align-items:center;border-bottom:1px solid var(--color-gray-200);cursor:pointer;display:flex;justify-content:space-between;padding:14px var(--space-5);transition:background .15s ease}.no-report-item:hover{background:var(--color-gray-50)}.no-report-item:last-child{border-bottom:none}.no-report-info{display:flex;flex-direction:column;gap:3px}.resource-client{color:var(--color-gray-400);font-size:12px}.empty-state.compact{padding:var(--space-8) var(--space-5);text-align:center}.empty-state.compact p{color:#64748b;font-size:14px;margin:8px 0 0}.sc-breakdown-card{min-height:0!important;min-height:auto!important}.sc-categories{display:flex;flex-direction:column;gap:4px}.sc-category{grid-gap:6px;align-items:center;background:#fafafa;border:1px solid #e2e8f0;border-radius:6px;display:grid;gap:6px;grid-template-columns:96px 1fr;padding:4px 6px}.sc-category-label{color:#374151;font-size:10px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;white-space:nowrap}.sc-pills{display:flex;flex-wrap:wrap}.sc-pill,.sc-pills{align-items:center;gap:4px}.sc-pill{border-radius:20px;display:inline-flex;line-height:1.3;padding:2px 6px;white-space:nowrap}.sc-pct-summary,.sc-pill,.sc-pill strong{font-size:10px;font-weight:700}.sc-pct-summary{align-items:center;border-left:1px solid #e2e8f0;display:inline-flex;gap:4px;margin-left:auto;padding-left:6px}.perf-total-resources-card{display:flex;flex-direction:column;gap:0}.perf-total-resources-body{align-items:flex-start;display:flex;gap:20px;margin-top:4px}.perf-total-number{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#0f172a,#334155);-webkit-background-clip:text;background-clip:text;color:#0f172a;flex-shrink:0;font-size:52px;font-weight:800;line-height:1}.perf-total-meta{flex:1 1;min-width:0;padding-top:4px}.perf-total-label{color:#475569;font-size:13px;font-weight:600;margin-bottom:10px}.perf-report-bar-wrap{display:flex;flex-direction:column;gap:5px;margin-bottom:10px}.perf-report-bar{background:#e2e8f0;border-radius:99px;height:6px;overflow:hidden;width:100%}.perf-report-bar-fill{background:linear-gradient(90deg,#16a34a,#22c55e);border-radius:99px;height:100%;transition:width .4s ease}.perf-report-bar-label{color:#64748b;font-size:11px;font-weight:500}.perf-missing-tag{align-items:center;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#dc2626;display:inline-flex;font-size:12px;font-weight:600;gap:6px;padding:3px 8px}.perf-missing-dot{background:#ef4444;border-radius:50%;flex-shrink:0;height:7px;width:7px}.perf-all-good-tag{align-items:center;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;color:#16a34a;display:inline-flex;font-size:12px;font-weight:600;gap:5px;padding:3px 8px}.perf-modal-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:1100}.perf-modal-box{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000002e;display:flex;flex-direction:column;height:560px;max-height:90vh;max-width:100%;overflow:hidden;width:560px}.perf-modal-box.wide{height:600px;width:720px}.perf-modal-header{align-items:flex-start;border-bottom:1px solid #e2e8f0;display:flex;flex-shrink:0;justify-content:space-between;padding:20px 24px 16px}.perf-modal-title{color:#0f172a;font-size:17px;font-weight:700;line-height:1.3;margin:0}.perf-modal-subtitle{color:#64748b;font-size:13px;margin:3px 0 0}.perf-modal-close{background:none;border:none;border-radius:6px;color:#94a3b8;cursor:pointer;flex-shrink:0;font-size:22px;line-height:1;padding:0 2px;transition:color .15s,background .15s}.perf-modal-close:hover{background:#f1f5f9;color:#0f172a}.perf-modal-filters{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;flex-shrink:0;flex-wrap:wrap;gap:10px;padding:12px 24px}.perf-modal-search-wrap{flex:1 1;min-width:160px;position:relative}.perf-modal-search-icon{color:#94a3b8;left:10px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.perf-modal-search-input{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;box-sizing:border-box;color:#0f172a;font-size:13px;outline:none;padding:7px 32px;transition:border-color .15s;width:100%}.perf-modal-search-input:focus{background:#fff;border-color:#94a3b8}.perf-modal-search-clear{align-items:center;background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;padding:2px;position:absolute;right:8px;top:50%;transform:translateY(-50%)}.perf-modal-toggle-group{background:#f1f5f9;border-radius:8px;display:flex;flex-shrink:0;gap:2px;padding:3px}.perf-modal-toggle-btn{background:#0000;border:none;border-radius:6px;color:#64748b;cursor:pointer;font-size:12px;font-weight:500;padding:5px 12px;transition:all .15s}.perf-modal-toggle-btn.active{background:#fff;box-shadow:0 1px 3px #00000014;color:#0f172a;font-weight:600}.perf-modal-body{flex:1 1;overflow-y:auto;padding:16px 24px}.perf-modal-table-body{padding:0}.perf-modal-list{display:flex;flex-direction:column;gap:2px}.perf-modal-list-item{align-items:center;border-radius:10px;cursor:pointer;display:flex;gap:12px;padding:10px 12px;transition:background .12s}.perf-modal-list-item:hover{background:#f8fafc}.perf-modal-avatar{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:13px;font-weight:700;height:36px;justify-content:center;width:36px}.perf-modal-item-info{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.perf-modal-item-name{color:#0f172a;font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.perf-modal-item-sub{color:#64748b;font-size:12px}.perf-modal-role-badge{border-radius:20px;flex-shrink:0;font-size:11px;font-weight:600;padding:2px 8px}.perf-modal-role-badge.manager{background:#ede9fe;color:#6d28d9}.perf-modal-role-badge.resource{background:#dbeafe;color:#1d4ed8}.perf-modal-empty{align-items:center;color:#64748b;display:flex;flex-direction:column;font-size:14px;gap:10px;height:100%;justify-content:center;min-height:160px;text-align:center}.perf-modal-table{font-size:13px;width:100%}.perf-modal-table thead th{background:#f8fafc;position:sticky;top:0;z-index:1}.app{background-color:#fff;min-height:100vh}.container{margin:0 auto;max-width:1600px;padding:20px}button{border:none;cursor:pointer;font-family:inherit;outline:none;transition:all .2s ease}button:disabled{cursor:not-allowed;opacity:.5}input,select,textarea{font-family:inherit;outline:none}.modal-overlay{align-items:center;animation:fadeIn .2s ease;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{animation:slideUp .3s ease;background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;padding:24px;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.modal-header h2{color:#000;font-size:20px;font-weight:600}.close-btn{align-items:center;background:none;border-radius:6px;color:#6b7280;display:flex;font-size:24px;height:32px;justify-content:center;padding:0;width:32px}.close-btn:hover{background-color:#f3f4f6;color:#000}
/*# sourceMappingURL=main.a97e82ef.css.map*/