.app-layout{display:flex;flex-direction:column;min-height:100vh}.app-header{align-items:center;background:#1a3c6e;color:#fff;display:flex;gap:16px;height:56px;padding:0 24px;position:sticky;top:0;z-index:100}.sidebar-toggle{background:none;border:1px solid #ffffff4d;border-radius:4px;color:#fff;font-size:18px;padding:4px 8px}.header-title{align-items:center;display:flex;flex:1 1;gap:12px}.header-emblem{background:#fff;border-radius:3px;color:#1a3c6e;font-size:13px;font-weight:700;letter-spacing:1px;padding:4px 8px}.header-title h1{font-size:17px;font-weight:600;letter-spacing:.5px;margin:0}.header-subtitle{font-size:11px;opacity:.8}.header-right{align-items:center;display:flex;gap:12px}.header-status{background:#2f855a;border-radius:3px;font-size:12px;padding:3px 10px}.app-body{display:flex;flex:1 1}.sidebar{background:#fff;border-right:1px solid #d9dde3;display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;transition:width .2s;width:220px}.sidebar.collapsed{border:none;width:0}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;padding:8px 0}.nav-link{border-left:3px solid #0000;color:#2d3748;display:block;font-size:13px;padding:10px 20px;transition:background .15s}.nav-link:hover{background:#edf2f7}.nav-link.active{background:#ebf4ff;border-left-color:#1a3c6e;color:#1a3c6e;font-weight:600}.sidebar-controls{background:#f7fafc;border-top:1px solid #e2e8f0;padding:16px}.control-label{color:#4a5568;display:flex;flex-direction:column;font-size:12px;font-weight:600;gap:6px}.control-label input[type=range]{accent-color:#1a3c6e;width:100%}.control-value{color:#1a3c6e;font-size:14px;font-weight:700;text-align:center}.sidebar-stats{display:flex;flex-direction:column;font-size:12px;gap:4px;margin-top:12px}.main-content{flex:1 1;max-height:calc(100vh - 56px);overflow-y:auto;padding:24px}.page-title{color:#1a3c6e;font-size:20px;font-weight:700;margin-bottom:4px}.page-subtitle{color:#718096;font-size:13px;margin-bottom:20px}.section-title{border-bottom:2px solid #e2e8f0;color:#2d3748;font-size:15px;font-weight:600;margin:24px 0 12px;padding-bottom:6px}.metrics-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:20px}.metric-card{background:#fff;border:1px solid #e2e8f0;border-radius:6px;display:flex;flex-direction:column;gap:4px;padding:16px}.metric-card .metric-label{color:#718096;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.metric-card .metric-value{color:#1a3c6e;font-size:24px;font-weight:700}.metric-card .metric-delta{color:#718096;font-size:12px}.card{background:#fff;border:1px solid #e2e8f0;border-radius:6px;margin-bottom:12px;overflow:hidden}.card-header{align-items:center;background:#f7fafc;border-bottom:1px solid #e2e8f0;cursor:pointer;display:flex;justify-content:space-between;padding:12px 16px;-webkit-user-select:none;user-select:none}.card-header:hover{background:#edf2f7}.card-header h3{font-size:14px;font-weight:600;margin:0}.card-body{padding:16px}.card-toggle{color:#a0aec0;font-size:12px}.data-table{font-size:13px;width:100%}.data-table thead th{background:#f7fafc;border-bottom:2px solid #e2e8f0;color:#4a5568;font-weight:600;padding:8px 12px;text-align:left;white-space:nowrap}.data-table tbody td{border-bottom:1px solid #edf2f7;padding:8px 12px}.data-table tbody tr:hover{background:#f7fafc}.badge{border-radius:3px;display:inline-block;font-size:11px;font-weight:600;letter-spacing:.3px;padding:2px 8px;text-transform:uppercase}.badge-critical{background:#fed7d7;color:#c53030}.badge-moderate{background:#fefcbf;color:#b7791f}.badge-safe{background:#c6f6d5;color:#276749}.badge-warning{background:#feebc8;color:#c05621}.badge-clear{background:#c6f6d5;color:#276749}.badge-silted{background:#fefcbf;color:#b7791f}.badge-blocked{background:#fed7d7;color:#c53030}.btn{align-items:center;background:#fff;border:1px solid #d9dde3;border-radius:4px;color:#2d3748;display:inline-flex;font-size:13px;font-weight:500;gap:6px;padding:7px 14px;transition:background .15s}.btn:hover{background:#edf2f7}.btn-primary{background:#1a3c6e;border-color:#1a3c6e;color:#fff}.btn-primary:hover{background:#153259}.btn-danger{background:#c53030;border-color:#c53030;color:#fff}.btn-danger:hover{background:#9b2c2c}.btn-success{background:#2f855a;border-color:#2f855a;color:#fff}.btn-success:hover{background:#276749}.btn-sm{font-size:12px;padding:4px 10px}.detail-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.detail-item{font-size:13px}.detail-item .detail-label{color:#4a5568;font-weight:600}.detail-item .detail-value{color:#2d3748}.action-bar{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.toast{border-radius:4px;font-size:13px;margin-top:8px;padding:10px 16px}.toast-success{background:#c6f6d5;border:1px solid #9ae6b4;color:#276749}.toast-info{background:#bee3f8;border:1px solid #90cdf4;color:#2b6cb0}.toast-warning{background:#fefcbf;border:1px solid #f6e05e;color:#975a16}.toast-error{background:#fed7d7;border:1px solid #feb2b2;color:#c53030}.quick-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:20px}.quick-card{background:#fff;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;padding:20px;transition:border-color .15s,box-shadow .15s}.quick-card:hover{border-color:#1a3c6e;box-shadow:0 1px 4px #1a3c6e1f}.quick-card h3{color:#1a3c6e;font-size:14px;margin-bottom:6px}.quick-card p{color:#718096;font-size:12px;margin:0}.planning-page,.scenario-page{display:flex;flex-direction:column}.planning-actions{align-items:center;justify-content:space-between;margin-bottom:16px}.planning-actions,.planning-meta{display:flex;flex-wrap:wrap;gap:16px}.planning-meta{color:#4a5568;font-size:12px}.planning-toast,.scenario-toast{margin-bottom:16px}.allocation-summary-card{background:#fff;border:1px solid #e2e8f0;border-radius:6px;display:flex;flex-direction:column;gap:4px;padding:16px}.allocation-summary-label{color:#718096;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.allocation-summary-value{color:#1a3c6e;font-size:24px;font-weight:700}.allocation-summary-note{color:#718096;font-size:12px}.allocation-summary-critical .allocation-summary-value{color:#c53030}.allocation-summary-warning .allocation-summary-value{color:#b7791f}.allocation-summary-success .allocation-summary-value{color:#2f855a}.impact-grid,.inventory-grid,.priority-zone-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.impact-grid>div,.inventory-card,.priority-zone-grid>div{background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;display:flex;flex-direction:column;gap:4px;padding:12px}.inventory-label{color:#718096;font-size:11px;font-weight:600;letter-spacing:.4px;text-transform:uppercase}.priority-zone-list{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.priority-zone-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:12px}.priority-zone-header h4{font-size:14px;margin-bottom:4px}.allocation-confidence,.allocation-impact-list span,.allocation-reasoning li,.allocation-target-cell span,.planning-method,.priority-zone-header p,.reasoning-block p{color:#718096;font-size:12px}.priority-zone-header p{margin:0}.allocation-table-wrap{overflow-x:auto}.allocation-table td,.allocation-table th{vertical-align:top}.allocation-target-cell{display:flex;flex-direction:column;gap:2px}.allocation-resource-badge{white-space:nowrap}.allocation-reasoning{display:flex;flex-direction:column;gap:6px}.allocation-reasoning p{color:#2d3748;margin:0}.allocation-reasoning ul{margin-left:16px}.allocation-impact-list{display:flex;flex-direction:column;gap:4px}.empty-state{background:#fff;border:1px dashed #cbd5e0;border-radius:6px;color:#718096;font-size:13px;padding:18px}.reasoning-block{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;margin-top:8px}.reasoning-block p{margin:0}.scenario-chart-wrap,.scenario-controls-card,.scenario-hotspots-card{margin-bottom:16px}.scenario-controls-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:16px}.scenario-chart-wrap h3,.scenario-controls-header h3,.scenario-hotspots-card h3,.scenario-impact-grid h3{font-size:15px;margin-bottom:4px}.scenario-controls-header p{color:#718096;font-size:12px;margin:0}.scenario-preset-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}.scenario-preset-card{background:#fff;border:1px solid #e2e8f0;border-radius:6px;display:flex;flex-direction:column;gap:6px;padding:14px;text-align:left;transition:border-color .15s,box-shadow .15s,transform .15s}.scenario-preset-card:hover{border-color:#1a3c6e;box-shadow:0 1px 4px #1a3c6e1f}.scenario-preset-card.active{border-color:#1a3c6e;box-shadow:inset 0 0 0 1px #1a3c6e}.scenario-preset-name{color:#1a3c6e;font-size:14px;font-weight:700}.scenario-preset-rainfall{color:#2d3748;font-size:12px;font-weight:600}.scenario-preset-desc{color:#718096;font-size:12px}.scenario-metrics-row{margin-top:6px}.scenario-impact-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1.15fr;margin:16px 0}.scenario-impact-list{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.scenario-impact-list>div{background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;display:flex;flex-direction:column;gap:4px;padding:12px}.scenario-action-zone,.scenario-impact-list span{color:#718096;font-size:12px}.scenario-actions-table td,.scenario-actions-table th{vertical-align:top}.reports-page{display:flex;flex-direction:column}.reports-timestamp{margin-bottom:16px}.reports-detail-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.reports-selector-card{margin-bottom:16px}.reports-selector-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between}.reports-selector-header h3{font-size:15px;margin-bottom:4px}.reports-selector-header p{color:#718096;font-size:12px;margin:0}.reports-selector{display:flex;flex-direction:column;gap:6px;min-width:220px}.reports-selector label{color:#4a5568;font-size:12px;font-weight:600}.reports-selector select{background:#fff;border:1px solid #d9dde3;border-radius:4px;color:#2d3748;font-size:13px;padding:8px 10px}.reports-selector-note{color:#718096;font-size:12px;margin-top:12px}.reports-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));margin-bottom:16px}.report-download-card{height:100%}.report-download-head{align-items:flex-start;display:flex;gap:12px;margin-bottom:14px}.report-download-title-wrap h4{color:#1a3c6e;font-size:14px;margin:0 0 4px}.report-download-title-wrap p{color:#718096;font-size:12px;margin:0}.report-format-badge{align-items:center;background:#ebf4ff;border-radius:999px;color:#1a3c6e;display:inline-flex;font-size:11px;font-weight:700;justify-content:center;letter-spacing:.4px;min-width:44px;padding:4px 8px}.report-format-export{background:#edf7f2;color:#2f855a}@media (max-width:900px){.scenario-impact-grid{grid-template-columns:1fr}}.score-circle{align-items:center;border:4px solid #e2e8f0;border-radius:50%;display:flex;flex-direction:column;height:120px;justify-content:center;margin:0 auto 12px;width:120px}.score-circle .score-value{font-size:32px;font-weight:700;line-height:1}.score-circle .score-grade{font-size:14px;font-weight:600;margin-top:2px}.score-a{border-color:#276749}.score-a .score-grade,.score-a .score-value{color:#276749}.score-b{border-color:#2b6cb0}.score-b .score-grade,.score-b .score-value{color:#2b6cb0}.score-c{border-color:#b7791f}.score-c .score-grade,.score-c .score-value{color:#b7791f}.score-d{border-color:#c05621}.score-d .score-grade,.score-d .score-value{color:#c05621}.score-f{border-color:#c53030}.score-f .score-grade,.score-f .score-value{color:#c53030}.chart-container{background:#fff;border:1px solid #e2e8f0;border-radius:6px;margin-bottom:16px;padding:16px}.chart-container h3{color:#2d3748;font-size:14px;font-weight:600;margin-bottom:12px}.two-col{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}@media (max-width:768px){.two-col{grid-template-columns:1fr}.sidebar{height:calc(100vh - 56px);position:fixed;top:56px;z-index:50}.sidebar.collapsed{width:0}}.loading{color:#a0aec0;font-size:14px;padding:40px;text-align:center}.emergency-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.emergency-grid .btn{font-size:14px;justify-content:center;padding:14px}.map-container{border:1px solid #e2e8f0;border-radius:6px;height:400px;margin-bottom:16px;overflow:hidden}.leaflet-popup-content{font-family:inherit;font-size:13px;line-height:1.5;margin:10px 14px}.leaflet-popup-content strong{color:#1a3c6e}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{background:#f0f2f5;color:#2d3748;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px;line-height:1.5}a{color:#1a5276;text-decoration:none}button{cursor:pointer;font-family:inherit}table{border-collapse:collapse;width:100%}
/*# sourceMappingURL=main.51dfa0b0.css.map*/