:root{--primary: #1e3a5f;--primary-light: #2d4a6f;--primary-dark: #152a47;--accent: #00b4d8;--accent-light: #48cae4;--accent-dark: #0096c7;--bg-primary: #0f1419;--bg-secondary: #1a2332;--bg-tertiary: #243447;--bg-card: #1e2d3d;--bg-hover: #2a3f54;--text-primary: #f0f4f8;--text-secondary: #94a3b8;--text-muted: #64748b;--border-color: #2d4356;--border-light: #3d5369;--rag-green: #10b981;--rag-green-bg: rgba(16, 185, 129, .15);--rag-amber: #f59e0b;--rag-amber-bg: rgba(245, 158, 11, .15);--rag-red: #ef4444;--rag-red-bg: rgba(239, 68, 68, .15);--status-lead: #9ca3af;--status-evaluation: #3b82f6;--status-development: #8b5cf6;--status-construction: #f59e0b;--status-operational: #10b981;--status-hold: #ef4444;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .4);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .5);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--z-dropdown: 100;--z-modal: 200;--z-toast: 300}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:var(--text-primary)}h1{font-size:1.75rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.125rem}h5{font-size:1rem}h6{font-size:.875rem}p{color:var(--text-secondary)}a{color:var(--accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-light)}code,pre{font-family:JetBrains Mono,Fira Code,monospace;font-size:.875rem}code{background:var(--bg-tertiary);padding:.125rem .375rem;border-radius:var(--radius-sm)}.app-container{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{padding:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.sidebar-logo{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:700;font-size:1.25rem;color:var(--text-primary)}.sidebar-logo svg{color:var(--accent)}.sidebar-nav{flex:1;padding:var(--spacing-md);overflow-y:auto}.nav-link{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.875rem;font-weight:500;transition:all var(--transition-fast);margin-bottom:var(--spacing-xs)}.nav-link:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-link.active{background:var(--accent);color:#fff}.nav-link svg{width:18px;height:18px}.sidebar-footer{padding:var(--spacing-md);border-top:1px solid var(--border-color)}.user-info{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);border-radius:var(--radius-md);cursor:pointer}.user-info:hover{background:var(--bg-hover)}.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.875rem}.user-details{flex:1;min-width:0}.user-name{font-size:.875rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.75rem;color:var(--text-muted)}.main-content{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--bg-primary)}.page-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg) var(--spacing-xl);background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.page-title{font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.page-subtitle{font-size:.875rem;color:var(--text-muted)}.page-actions{display:flex;gap:var(--spacing-sm)}.page-content{flex:1;padding:var(--spacing-xl);overflow-y:auto}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:.625rem 1rem;font-size:.875rem;font-weight:500;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-dark)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-light)}.btn-accent{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);color:#fff;box-shadow:0 4px 12px #00b4d84d}.btn-accent:hover:not(:disabled){box-shadow:0 6px 16px #00b4d866;transform:translateY(-1px)}.btn-danger{background:var(--rag-red);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.btn-icon{padding:.5rem;min-width:auto}.btn-sm{padding:.375rem .75rem;font-size:.8125rem}.btn-lg{padding:.875rem 1.5rem;font-size:1rem}.btn-full{width:100%}.form-group{margin-bottom:var(--spacing-md)}.form-label{display:block;font-size:.8125rem;font-weight:500;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.form-input{width:100%;padding:.625rem .875rem;font-size:.875rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);transition:all var(--transition-fast)}.form-input::placeholder{color:var(--text-muted)}.form-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #00b4d826}.form-input:disabled{opacity:.6;cursor:not-allowed}select.form-input{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.5rem}textarea.form-input{min-height:100px;resize:vertical}.form-hint{font-size:.75rem;color:var(--text-muted);margin-top:var(--spacing-xs)}.form-error{font-size:.75rem;color:var(--rag-red);margin-top:var(--spacing-xs)}.search-input-wrapper{position:relative}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.search-input{padding-left:2.5rem;padding-right:2.5rem}.search-clear{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:var(--radius-sm)}.search-clear:hover{color:var(--text-primary);background:var(--bg-hover)}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.card-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color)}.card-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:1rem;font-weight:600}.card-title svg{color:var(--accent)}.card-body{padding:var(--spacing-lg)}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.stat-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-xs)}.stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary)}.stat-value span{font-size:.875rem;font-weight:400;color:var(--text-muted)}.table-container{overflow-x:auto}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;border-bottom:1px solid var(--border-color)}.table th{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;background:var(--bg-secondary)}.table td{font-size:.875rem}.table tbody tr:hover{background:var(--bg-hover)}.rag-badge{display:inline-flex;align-items:center;padding:.25rem .625rem;font-size:.75rem;font-weight:600;border-radius:9999px;text-transform:uppercase;letter-spacing:.025em}.rag-badge.green{background:var(--rag-green-bg);color:var(--rag-green)}.rag-badge.amber{background:var(--rag-amber-bg);color:var(--rag-amber)}.rag-badge.red{background:var(--rag-red-bg);color:var(--rag-red)}.gate-badge{display:inline-flex;padding:.25rem .5rem;font-size:.7rem;font-weight:600;background:var(--bg-tertiary);color:var(--accent);border-radius:var(--radius-sm);border:1px solid var(--accent)}.status-badge{display:inline-flex;padding:.25rem .625rem;font-size:.75rem;font-weight:500;border-radius:9999px}.status-badge.lead{background:#9ca3af33;color:#9ca3af}.status-badge.under_evaluation{background:#3b82f633;color:#3b82f6}.status-badge.active_development{background:#8b5cf633;color:#8b5cf6}.status-badge.under_construction{background:#f59e0b33;color:#f59e0b}.status-badge.operational{background:#10b98133;color:#10b981}.status-badge.on_hold{background:#ef444433;color:#ef4444}.status-badge.cancelled{background:#6b728033;color:#6b7280}.tabs{display:flex;gap:var(--spacing-xs);padding:var(--spacing-sm);background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.tab{padding:var(--spacing-sm) var(--spacing-md);font-size:.875rem;font-weight:500;color:var(--text-secondary);background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.tab:hover{color:var(--text-primary);background:var(--bg-hover)}.tab.active{color:var(--accent);background:var(--bg-card)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--spacing-xl)}.modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);max-width:560px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-xl)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.modal-title{font-size:1.25rem;font-weight:600}.modal-body{padding:var(--spacing-lg);overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-color)}.map-layout{flex:1;display:flex;overflow:hidden}.filter-panel{width:320px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.filter-panel-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color)}.filter-panel-title{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:600}.filter-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 .375rem;font-size:.7rem;font-weight:600;background:var(--accent);color:#fff;border-radius:9999px}.filter-panel-body{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color)}.filter-panel-sites{flex:1;display:flex;flex-direction:column;overflow:hidden}.filter-panel-sites-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-lg);font-size:.8125rem;font-weight:500;color:var(--text-muted);border-bottom:1px solid var(--border-color)}.sites-list{flex:1;overflow-y:auto;padding:var(--spacing-sm)}.rag-filter-group{display:flex;gap:var(--spacing-xs)}.rag-filter-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-size:.8rem;font-weight:500;color:var(--text-secondary)}.rag-filter-btn:hover{background:var(--bg-hover)}.rag-filter-btn.green.active{background:var(--rag-green-bg);border-color:var(--rag-green);color:var(--rag-green)}.rag-filter-btn.amber.active{background:var(--rag-amber-bg);border-color:var(--rag-amber);color:var(--rag-amber)}.rag-filter-btn.red.active{background:var(--rag-red-bg);border-color:var(--rag-red);color:var(--rag-red)}.site-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-sm);margin-bottom:var(--spacing-sm);cursor:pointer;transition:all var(--transition-fast)}.site-card:hover{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.site-card-header{display:flex;align-items:flex-start;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.site-card-rag{width:8px;height:8px;border-radius:50%;margin-top:.375rem;flex-shrink:0}.site-card-info{flex:1;min-width:0}.site-card-name{font-size:.875rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.site-card-location{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:var(--text-muted)}.site-card-stats{display:flex;gap:var(--spacing-md);margin:var(--spacing-sm) 0;padding-left:calc(8px + var(--spacing-sm))}.site-card-stat{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:var(--text-secondary)}.site-card-stat svg{color:var(--text-muted)}.site-card-footer{display:flex;justify-content:space-between;align-items:center;padding-left:calc(8px + var(--spacing-sm))}.site-card-pm{font-size:.7rem;color:var(--text-muted)}.map-container{flex:1;position:relative;overflow:hidden}.map-wrapper{position:absolute;top:0;right:0;bottom:0;left:0}.map-placeholder{width:100%;height:100%}.map-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(0,180,216,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(0,180,216,.05) 1px,transparent 1px);background-size:50px 50px}.map-controls{position:absolute;top:var(--spacing-md);right:var(--spacing-md);display:flex;flex-direction:column;gap:2px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.map-control-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-primary);font-size:1.25rem;cursor:pointer;transition:background var(--transition-fast)}.map-control-btn:hover{background:var(--bg-hover)}.map-control-btn:first-child{border-bottom:1px solid var(--border-color)}.map-legend{position:absolute;bottom:var(--spacing-md);right:var(--spacing-md);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md)}.map-legend-title{font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;margin-bottom:var(--spacing-xs)}.map-legend-items{display:flex;gap:var(--spacing-md)}.map-legend-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.75rem;color:var(--text-secondary)}.legend-dot{width:10px;height:10px;border-radius:50%}.sites-table-container{padding:var(--spacing-lg);height:100%;overflow-y:auto}.task-board{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md)}.task-column{background:var(--bg-secondary);border-radius:var(--radius-lg);overflow:hidden}.task-column-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary)}.task-column-title{font-size:.8125rem;font-weight:600}.task-column-count{font-size:.75rem;color:var(--text-muted);background:var(--bg-primary);padding:.125rem .5rem;border-radius:9999px}.task-list{padding:var(--spacing-sm);max-height:400px;overflow-y:auto}.task-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-sm);margin-bottom:var(--spacing-sm);cursor:pointer;transition:all var(--transition-fast)}.task-card:hover{border-color:var(--accent)}.task-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs)}.task-code{font-size:.7rem;font-family:JetBrains Mono,monospace;color:var(--text-muted)}.task-blocking{font-size:.65rem;font-weight:600;color:var(--rag-red);background:var(--rag-red-bg);padding:.125rem .375rem;border-radius:var(--radius-sm);text-transform:uppercase}.task-title{font-size:.8125rem;font-weight:500;margin-bottom:var(--spacing-xs);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.task-meta{display:flex;justify-content:space-between;align-items:center;font-size:.7rem;color:var(--text-muted)}.grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--spacing-md)}.dimension-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-md)}.dimension-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.dimension-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.8125rem;font-weight:600}.dimension-icon{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.dimension-metrics{display:flex;flex-direction:column;gap:var(--spacing-sm)}.dimension-metric{display:flex;justify-content:space-between;font-size:.75rem}.dimension-metric-label{color:var(--text-muted)}.dimension-metric-value{font-weight:500}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg)}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-lg)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl) * 2;text-align:center}.empty-state-icon{font-size:3rem;margin-bottom:var(--spacing-md);opacity:.5}.empty-state-title{font-size:1.25rem;font-weight:600;margin-bottom:var(--spacing-sm)}.empty-state-text{color:var(--text-muted);max-width:300px}.loading{display:flex;align-items:center;justify-content:center;min-height:200px}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.fade-in{animation:fadeIn var(--transition-normal)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--primary-dark) 100%);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 80%,rgba(0,180,216,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(30,58,95,.3) 0%,transparent 50%)}.login-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-xl);width:100%;max-width:400px;position:relative;z-index:1;box-shadow:var(--shadow-xl)}.login-logo{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-lg)}.login-logo svg{color:var(--accent)}.login-title{text-align:center;margin-bottom:var(--spacing-lg)}.login-title h1{font-size:1.5rem;margin-bottom:var(--spacing-xs)}.login-title p{font-size:.875rem}.login-error{background:var(--rag-red-bg);border:1px solid var(--rag-red);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);color:var(--rag-red);font-size:.875rem;margin-bottom:var(--spacing-md)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}@media (max-width: 1200px){.grid-5{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.sidebar{display:none}.map-layout{flex-direction:column}.filter-panel{width:100%;height:auto;max-height:300px}.grid-5,.grid-4,.grid-3,.grid-2,.task-board{grid-template-columns:1fr}.page-header{flex-direction:column;gap:var(--spacing-md);align-items:flex-start}}
