.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.login-card{background:#fff;border-radius:12px;padding:3rem;box-shadow:0 20px 60px #0000004d;width:100%;max-width:400px}.login-card h1{margin:0 0 .5rem;font-size:1.75rem;color:#333;text-align:center}.login-card h2{margin:0 0 2rem;font-size:1.25rem;color:#666;text-align:center;font-weight:400}.login-error{background-color:#fee;color:#c33;padding:1rem;border-radius:4px;margin-bottom:1.5rem;border-left:4px solid #e74c3c;font-size:.9rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333;font-size:.9rem}.form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.login-button{width:100%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-bottom:1rem}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.login-button:disabled{opacity:.6;cursor:not-allowed}.toggle-button{width:100%;background:none;border:none;color:#667eea;padding:.5rem;cursor:pointer;font-size:.9rem;text-decoration:underline}.toggle-button:hover:not(:disabled){color:#764ba2}.toggle-button:disabled{opacity:.6;cursor:not-allowed}.portfolio-page{padding:2rem}.portfolio-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.portfolio-header h2{margin:0;font-size:1.75rem;color:#333}.refresh-button:hover:not(:disabled){background-color:#2980b9}.refresh-button:disabled{background-color:#95a5a6;cursor:not-allowed}.portfolio-filters{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.filter-input{flex:1;min-width:150px;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.filter-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.loading{text-align:center;padding:2rem;color:#666}.portfolio-table-container{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.portfolio-table{width:100%;border-collapse:collapse}.portfolio-table thead{background-color:#f8f9fa}.portfolio-table th{padding:1rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #dee2e6}.portfolio-table td{padding:1rem;border-bottom:1px solid #dee2e6;color:#555}.portfolio-table tbody tr:hover{background-color:#f8f9fa}.description-cell{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.command-centre{padding:2rem}.command-centre-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.digest-widget{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 4px 12px #00000026}.digest-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.digest-header h3{margin:0;font-size:1.25rem}.digest-timestamp{font-size:.85rem;opacity:.9}.digest-content{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.digest-summary{display:flex;flex-direction:column;gap:.75rem}.digest-item{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.2)}.digest-label{opacity:.9}.digest-value{font-weight:600;font-size:1.1rem}.digest-section{background:#ffffff1a;border-radius:4px;padding:1rem}.digest-section h4{margin:0 0 .5rem;font-size:1rem}.digest-section ul{margin:0;padding-left:1.25rem;list-style-type:disc}.digest-section li{margin-bottom:.25rem;font-size:.9rem}.command-centre-header h2{margin:0;font-size:1.75rem;color:#333}.command-centre-loading{text-align:center;padding:3rem;color:#666}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.kpi-card{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;border-left:4px solid #3498db}.kpi-card.kpi-warning{border-left-color:#f39c12}.kpi-card.kpi-danger{border-left-color:#e74c3c}.kpi-card.kpi-critical{border-left-color:#c0392b}.kpi-label{font-size:.9rem;color:#666;margin-bottom:.5rem;font-weight:500}.kpi-value{font-size:2rem;font-weight:700;color:#333}.top-tables-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem}.top-table-card{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.top-table-card h3{margin:0 0 1rem;font-size:1.1rem;color:#333}.top-table{width:100%;border-collapse:collapse;font-size:.9rem}.top-table thead{background-color:#f8f9fa}.top-table th{padding:.75rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #dee2e6}.top-table td{padding:.75rem;border-bottom:1px solid #dee2e6;color:#555}.top-table tbody tr:hover{background-color:#f8f9fa}.capacity-page{padding:2rem}.capacity-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.capacity-header h2{margin:0;font-size:1.75rem;color:#333}.capacity-loading{text-align:center;padding:3rem;color:#666}.capacity-section{background:#fff;border-radius:8px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a}.capacity-section h3{margin:0 0 1rem;font-size:1.25rem;color:#333}.capacity-table{width:100%;border-collapse:collapse}.capacity-table thead{background-color:#f8f9fa}.capacity-table th{padding:1rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #dee2e6}.capacity-table td{padding:1rem;border-bottom:1px solid #dee2e6;color:#555}.capacity-table tbody tr:hover{background-color:#f8f9fa}.util-normal{color:#27ae60;font-weight:600}.util-warning{color:#f39c12;font-weight:600}.util-overload{color:#e74c3c;font-weight:600}.util-critical{color:#c0392b;font-weight:700}.badge-normal{background-color:#27ae60;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.badge-overload{background-color:#e74c3c;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.empty-state{text-align:center;padding:2rem;color:#999;font-style:italic}.dependencies-page{padding:2rem}.dependencies-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.dependencies-header h2{margin:0;font-size:1.75rem;color:#333}.dependencies-loading{text-align:center;padding:3rem;color:#666}.dependencies-filters{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.filter-select{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;min-width:150px}.filter-select:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.filter-button{background-color:#2ecc71;color:#fff;border:none;padding:.5rem 1.5rem;border-radius:4px;cursor:pointer;font-size:.9rem}.filter-button:hover{background-color:#27ae60}.empty-state{text-align:center;padding:3rem;color:#999;font-style:italic}.dependencies-table-container{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.dependencies-table{width:100%;border-collapse:collapse}.dependencies-table thead{background-color:#f8f9fa}.dependencies-table th{padding:1rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #dee2e6}.dependencies-table td{padding:1rem;border-bottom:1px solid #dee2e6;color:#555}.dependencies-table tbody tr:hover{background-color:#f8f9fa}.dependencies-table tbody tr.row-critical{background-color:#fff5f5;border-left:4px solid #c0392b}.initiative-meta{font-size:.85rem;color:#999;margin-top:.25rem}.dependency-type{text-transform:capitalize;color:#666}.criticality-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.criticality-high{background-color:#ffebee;color:#d32f2f}.criticality-medium{background-color:#fff3e0;color:#f57c00}.criticality-low{background-color:#e8f5e9;color:#388e3c}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.status-resolved{background-color:#e8f5e9;color:#388e3c}.status-in-progress{background-color:#e3f2fd;color:#1976d2}.status-pending{background-color:#f5f5f5;color:#616161}.badge-critical{background-color:#c0392b;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.timeline-page{padding:2rem}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.timeline-header h2{margin:0;font-size:1.75rem;color:#333}.timeline-loading{text-align:center;padding:3rem;color:#666}.error-message{background-color:#fee;color:#c33;padding:1rem;border-radius:4px;margin-bottom:1.5rem;border-left:4px solid #e74c3c}.timeline-filters{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap;background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-size:.85rem;font-weight:500;color:#666}.filter-input,.filter-select{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;min-width:150px}.filter-input:focus,.filter-select:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.missing-dates-section{margin-bottom:2rem;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.missing-dates-toggle{width:100%;padding:1rem;background:#fff3cd;border:none;border-radius:8px 8px 0 0;text-align:left;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem}.missing-dates-toggle:hover{background:#ffe69c}.missing-dates-list{padding:1rem}.missing-dates-table{width:100%;border-collapse:collapse}.missing-dates-table th{padding:.75rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #dee2e6}.missing-dates-table td{padding:.75rem;border-bottom:1px solid #dee2e6}.reason-badge{background-color:#f8d7da;color:#721c24;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.timeline-board-container{overflow-x:auto;background:#f5f5f5;border-radius:8px;padding:1rem}.timeline-board{display:flex;gap:1rem;min-width:fit-content}.timeline-month-column{min-width:280px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column}.month-header{padding:1rem;background:#f8f9fa;border-bottom:2px solid #dee2e6;border-radius:8px 8px 0 0;display:flex;justify-content:space-between;align-items:center}.month-label{font-weight:600;font-size:1rem;color:#333}.month-count{background:#3498db;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.month-items{padding:1rem;display:flex;flex-direction:column;gap:1rem;min-height:200px}.timeline-card{background:#fff;border:1px solid #dee2e6;border-radius:6px;padding:1rem;cursor:pointer;transition:all .2s}.timeline-card:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px);border-color:#3498db}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;gap:.5rem}.card-name{font-weight:600;color:#333;font-size:.95rem;flex:1;line-height:1.3}.card-body{display:flex;flex-direction:column;gap:.5rem}.card-meta{font-size:.85rem;color:#666}.meta-label{font-weight:500}.card-date{font-size:.9rem;color:#2c3e50;font-weight:500}.card-risks{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.risk-badge{background-color:#fff3cd;color:#856404;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500;white-space:nowrap}.status-planned{background-color:#e3f2fd;color:#1976d2}.status-in_progress{background-color:#fff3e0;color:#f57c00}.status-at_risk{background-color:#ffebee;color:#d32f2f}.status-blocked{background-color:#f3e5f5;color:#7b1fa2}.status-done{background-color:#e8f5e9;color:#388e3c}.status-tbd{background-color:#f5f5f5;color:#616161}.empty-state{text-align:center;padding:3rem;color:#999;font-style:italic;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.import-page{padding:2rem}.import-header{margin-bottom:2rem}.import-header h2{margin:0;font-size:1.75rem;color:#333}.import-tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid #dee2e6}.tab-button{background:none;border:none;padding:1rem 1.5rem;cursor:pointer;font-size:1rem;color:#666;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s}.tab-button:hover{color:#333}.tab-button.active{color:#3498db;border-bottom-color:#3498db;font-weight:600}.import-section{background:#fff;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 2px 8px #0000001a}.import-section h3{margin:0 0 1rem;font-size:1.1rem;color:#333}.upload-area{display:flex;gap:1rem;align-items:center}.file-input{padding:.5rem;border:1px solid #ddd;border-radius:4px}.template-button{background-color:#2ecc71;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem}.template-button:hover{background-color:#27ae60}.mapping-table{overflow-x:auto}.mapping-table table{width:100%;border-collapse:collapse}.mapping-table th,.mapping-table td{padding:.75rem;text-align:left;border-bottom:1px solid #dee2e6}.mapping-table th{background-color:#f8f9fa;font-weight:600}.mapping-table select{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:4px}.preview-table{overflow-x:auto;max-height:400px;overflow-y:auto}.preview-table table{width:100%;border-collapse:collapse;font-size:.9rem}.preview-table th,.preview-table td{padding:.75rem;text-align:left;border-bottom:1px solid #dee2e6}.preview-table th{background-color:#f8f9fa;font-weight:600;position:sticky;top:0}.preview-table tbody tr:hover{background-color:#f8f9fa}.upload-button{background-color:#3498db;color:#fff;border:none;padding:1rem 2rem;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.upload-button:hover:not(:disabled){background-color:#2980b9}.upload-button:disabled{background-color:#95a5a6;cursor:not-allowed}.error-message{background-color:#fee;color:#c33;padding:1rem;border-radius:4px;margin-top:1rem;border-left:4px solid #e74c3c}.success-message{background-color:#efe;color:#3c3;padding:1rem;border-radius:4px;margin-top:1rem;border-left:4px solid #2ecc71}.exceptions-page{padding:2rem}.exceptions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.exceptions-header h2{margin:0;font-size:1.75rem;color:#333}.exceptions-controls{display:flex;gap:1rem;align-items:center}.stale-input{width:80px;padding:.5rem;border:1px solid #ddd;border-radius:4px;margin-left:.5rem}.refresh-button{background-color:#3498db;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem}.refresh-button:hover{background-color:#2980b9}.exceptions-filters{display:flex;gap:1rem;margin-bottom:1.5rem}.filter-select{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.exceptions-loading{padding:2rem;text-align:center;color:#666}.error-message{background-color:#fee;color:#c33;padding:1rem;border-radius:4px;margin-bottom:1rem;border-left:4px solid #e74c3c}.exceptions-list{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.exceptions-table{width:100%;border-collapse:collapse}.exceptions-table th{background-color:#f8f9fa;padding:1rem;text-align:left;font-weight:600;border-bottom:2px solid #dee2e6}.exceptions-table td{padding:1rem;border-bottom:1px solid #dee2e6}.exceptions-table tbody tr:hover{background-color:#f8f9fa}.type-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;color:#fff;font-size:.85rem;font-weight:600}.no-exceptions{padding:3rem;text-align:center;color:#666;font-style:italic}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background-color:#2c3e50;color:#fff;padding:1.5rem 2rem;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;gap:1rem}.app-header>div:first-child{display:flex;justify-content:space-between;align-items:center}.app-header h1{font-size:1.75rem;font-weight:600;margin:0}.app-nav{display:flex;gap:.5rem;flex-wrap:wrap}.nav-button{background-color:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s}.nav-button:hover{background-color:#fff3}.nav-button.active{background-color:#3498db;border-color:#3498db}.coming-soon{padding:3rem;text-align:center;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.coming-soon h2{color:#333;margin-bottom:1rem}.coming-soon p{color:#666;font-style:italic}.app-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:1.2rem;color:#666}.user-info{display:flex;align-items:center;gap:1rem;color:#fff;font-size:.9rem}.user-email{opacity:.9}.logout-button{background-color:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:.4rem .8rem;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background-color .2s}.logout-button:hover{background-color:#ffffff4d}.app-main{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:2rem}.form-section{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;background-color:#fff;cursor:pointer}.form-group select:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.form-group textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;font-family:Courier New,monospace;resize:vertical}.form-group textarea:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.submit-button{background-color:#3498db;color:#fff;border:none;padding:.75rem 2rem;font-size:1rem;font-weight:500;border-radius:4px;cursor:pointer;transition:background-color .2s}.submit-button:hover:not(:disabled){background-color:#2980b9}.submit-button:disabled{background-color:#95a5a6;cursor:not-allowed}.response-section{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.response-section.error{border-left:4px solid #e74c3c}.response-section h2{margin-bottom:1rem;color:#333;font-size:1.25rem}.response-section pre{background-color:#f8f9fa;padding:1rem;border-radius:4px;overflow-x:auto;font-size:.9rem;line-height:1.5;border:1px solid #e9ecef}.response-section.error pre{color:#e74c3c}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;color:#333}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}
