:root{--bg-primary: #1a1a2e;--bg-secondary: #16213e;--bg-tertiary: #0f0f23;--text-primary: #eaeaea;--text-secondary: #a0a0a0;--text-muted: #666;--accent: #4a90d9;--accent-hover: #5fa8f5;--gap-strong-positive: #22c55e;--gap-positive: #84cc16;--gap-neutral: #fbbf24;--gap-negative: #f97316;--gap-strong-negative: #ef4444;--ownership-particulier: #3b82f6;--ownership-corporatie: #22c55e;--ownership-belegger: #f97316;--ownership-overheid: #a855f7;--sidebar-width: 280px;--topbar-height: 48px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:var(--bg-primary);color:var(--text-primary);overflow:hidden;display:flex;flex-direction:column;height:100vh}#root{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}#app{display:flex;flex:1;min-height:0;width:100vw}#topbar{display:flex;align-items:center;height:var(--topbar-height);min-height:var(--topbar-height);background:var(--bg-tertiary);border-bottom:1px solid rgba(255,255,255,.1);padding:0 20px;z-index:50}.topbar-brand{font-size:1.1rem;font-weight:700;letter-spacing:2px;color:var(--accent);text-decoration:none;margin-right:32px}.topbar-nav{display:flex;align-items:center;gap:4px;height:100%}.topbar-nav a{display:flex;align-items:center;height:100%;padding:0 16px;color:var(--text-secondary);text-decoration:none;font-size:.85rem;font-weight:500;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.topbar-nav a:hover{color:var(--text-primary)}.topbar-nav a.active{color:var(--accent);border-bottom-color:var(--accent)}.databronnen-page{flex:1;overflow-y:auto;padding:32px}.databronnen-header{max-width:800px;margin:0 auto 32px}.databronnen-header h1{font-size:1.6rem;font-weight:700;margin-bottom:8px}.databronnen-header p{color:var(--text-secondary);font-size:.9rem;line-height:1.5}.databronnen-grid{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:20px}.source-card{background:var(--bg-secondary);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:24px}.source-card-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.source-card-header h2{font-size:1.05rem;font-weight:600}.source-card-header .source-tag{font-size:.65rem;font-weight:600;padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.3px;background:#4a90d926;color:var(--accent)}.source-card-header .source-tag.placeholder{background:#ef444426;color:#ef4444}.source-card-desc{font-size:.82rem;color:var(--text-secondary);line-height:1.5;margin-bottom:16px}.source-field{margin-bottom:12px}.source-field:last-child{margin-bottom:0}.source-field-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px}.source-field-name{font-size:.82rem;font-weight:500}.source-field-pct{font-size:.82rem;font-weight:600;font-variant-numeric:tabular-nums}.source-progress{height:6px;background:#ffffff14;border-radius:3px;overflow:hidden}.source-progress-bar{height:100%;border-radius:3px;transition:width .6s ease}.source-progress-bar.green{background:#22c55e}.source-progress-bar.yellow{background:#eab308}.source-progress-bar.orange{background:#f97316}.source-progress-bar.red{background:#ef4444}.source-progress-bar.placeholder{background:repeating-linear-gradient(-45deg,#a0a0a040,#a0a0a040 4px,#a0a0a01a 4px 8px)}.source-field-note{font-size:.72rem;color:var(--text-muted);margin-top:3px}.source-card.summary-card{background:var(--bg-tertiary);border-color:#4a90d933}.source-card.warning-card{border-color:#ef444440}.databronnen-tabs{max-width:800px;margin:0 auto 24px;border-radius:6px;overflow:hidden}.datalayer-legend{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0}.datalayer-legend-item{display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--text-secondary)}.datalayer-legend-item .swatch{width:12px;height:12px;border-radius:2px;flex-shrink:0}.datalayer-formula{background:var(--bg-tertiary);border-radius:6px;padding:12px 16px;font-size:.78rem;margin:8px 0;line-height:1.6;color:var(--text-secondary)}.datalayer-formula code{color:var(--accent);font-family:monospace;font-size:.76rem}#sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;overflow-y:auto}.sidebar-header{padding:20px;border-bottom:1px solid rgba(255,255,255,.1);background:var(--bg-tertiary);position:relative}#user-menu{position:absolute;top:14px;right:14px}#user-menu-btn{width:32px;height:32px;border-radius:50%;border:none;background:var(--accent);color:#fff;font-size:.85rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}#user-menu-btn:hover{background:var(--accent-hover)}#user-dropdown{position:absolute;top:calc(100% + 6px);right:0;width:220px;background:var(--bg-tertiary);border:1px solid rgba(255,255,255,.12);border-radius:8px;box-shadow:0 8px 32px #00000080;z-index:200;padding:4px 0}#user-dropdown hr{border:none;border-top:1px solid rgba(255,255,255,.08);margin:4px 0}#user-info{padding:10px 14px;display:flex;align-items:center;gap:8px}#user-name{font-size:.85rem}.role-badge{font-size:.65rem;font-weight:600;padding:1px 7px;border-radius:9px;text-transform:uppercase;letter-spacing:.3px}.role-badge.role-admin{background:#4a90d933;color:var(--accent)}.role-badge.role-user{background:#ffffff14;color:var(--text-secondary)}#user-dropdown button,#user-dropdown a{display:block;width:100%;padding:8px 14px;background:none;border:none;color:var(--text-primary);font-size:.82rem;font-family:inherit;text-align:left;text-decoration:none;cursor:pointer;transition:background .1s}#user-dropdown button:hover,#user-dropdown a:hover{background:#ffffff0d}#pw-form{padding:6px 14px 10px;display:flex;flex-direction:column;gap:6px}#pw-form input{width:100%;padding:6px 8px;background:var(--bg-secondary);border:1px solid rgba(255,255,255,.12);border-radius:4px;color:var(--text-primary);font-size:.8rem;font-family:inherit;outline:none}#pw-form input:focus{border-color:var(--accent)}.pw-buttons{display:flex;gap:6px}.btn-sm{padding:4px 10px;border-radius:4px;border:1px solid rgba(255,255,255,.12);background:transparent;color:var(--text-primary);font-size:.75rem;font-family:inherit;cursor:pointer;transition:background .1s}.btn-sm:hover{background:#ffffff0d}.btn-sm.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-sm.btn-primary:hover{background:var(--accent-hover)}#pw-msg{font-size:.72rem;min-height:1em}.pw-msg-ok{color:#22c55e}.pw-msg-error{color:#ef4444}.sidebar-header h1{font-size:1.5rem;font-weight:700;letter-spacing:2px;color:var(--accent)}.sidebar-header .subtitle{font-size:.75rem;color:var(--text-secondary);display:block;margin-top:4px}.sidebar-section{padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.05)}.sidebar-section h2{display:flex;align-items:center;gap:8px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);margin-bottom:12px}.dv-selector{position:relative}.dv-active-header{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-tertiary);border-radius:8px;cursor:pointer;border:1px solid transparent;transition:all .2s ease}.dv-active-header:hover{border-color:#4a90d94d}.dv-color-preview{width:32px;height:14px;border-radius:3px;flex-shrink:0}.dv-active-info{flex:1;min-width:0}.dv-active-name{display:block;font-size:.9rem;font-weight:500}.dv-active-desc{display:block;font-size:.7rem;color:var(--text-secondary);margin-top:1px}.dv-chevron{color:var(--text-muted);font-size:.8rem;flex-shrink:0}.dv-popover{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:100;background:var(--bg-secondary);border:1px solid rgba(255,255,255,.15);border-radius:8px;box-shadow:0 8px 32px #00000080;max-height:320px;display:flex;flex-direction:column}.dv-search{width:100%;padding:10px 12px;border:none;border-bottom:1px solid rgba(255,255,255,.1);background:transparent;color:var(--text-primary);font-size:.85rem;font-family:inherit;outline:none}.dv-search::placeholder{color:var(--text-muted)}.dv-options{overflow-y:auto;padding:4px 0}.dv-category-label{padding:8px 12px 4px;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted)}.dv-option{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;transition:background .1s ease}.dv-option:hover{background:#ffffff0d}.dv-option.active{background:#4a90d91a}.dv-option-swatch{width:20px;height:10px;border-radius:2px;flex-shrink:0}.dv-option-name{font-size:.85rem}.dv-no-results{padding:16px 12px;color:var(--text-muted);font-size:.8rem;text-align:center}.dv-subdimensions{padding:0 20px}.dv-subdim-pills{display:flex;flex-wrap:wrap;gap:4px}.dv-subdim-pill{padding:4px 10px;border-radius:12px;border:1px solid rgba(255,255,255,.15);background:transparent;color:var(--text-secondary);font-size:.72rem;font-family:inherit;cursor:pointer;transition:all .15s ease;white-space:nowrap}.dv-subdim-pill:hover{border-color:var(--accent);color:var(--text-primary)}.dv-subdim-pill.active{border-color:var(--accent);background:#4a90d933;color:var(--text-primary);font-weight:500}.dv-subdim-slider{margin-top:8px}.dv-inline-filter{padding:4px 20px 0}.legend{display:flex;flex-direction:column;gap:6px}.legend-item{display:flex;align-items:center;gap:10px;font-size:.8rem}.legend-color{width:20px;height:14px;border-radius:3px;flex-shrink:0}.legend-gradient{width:100%;height:14px;border-radius:3px;margin-bottom:4px}.legend-labels{display:flex;justify-content:space-between;font-size:.7rem;color:var(--text-secondary)}.info-box{background:var(--bg-tertiary);border-radius:8px;padding:12px}.info-box .placeholder{font-size:.8rem;color:var(--text-muted);font-style:italic}.legend-item-interactive{cursor:pointer;padding:4px 6px;border-radius:4px;margin:-4px -6px;transition:all .15s ease;position:relative}.legend-item-interactive:hover{background:#ffffff0d}.legend-filtered-in{background:#4a90d91a}.legend-filtered-out{opacity:.35}.legend-distribution-bar{height:3px;background:#fff3;border-radius:2px;margin-left:auto;min-width:0;max-width:60px;transition:width .3s ease}#selection-info .feature-name{font-size:.95rem;font-weight:600;margin-bottom:8px}#selection-info .feature-details{display:flex;flex-direction:column;gap:4px}#selection-info .detail-row{display:flex;justify-content:space-between;font-size:.8rem}#selection-info .detail-label{color:var(--text-secondary)}#selection-info .detail-value{font-weight:500}.filter-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--accent);color:#fff;font-size:.65rem;font-weight:700;text-transform:none;letter-spacing:0}.filter-clear-link{margin-left:auto;font-size:.65rem;color:var(--text-secondary);text-decoration:none;text-transform:none;letter-spacing:0;font-weight:400}.filter-clear-link:hover{color:var(--accent-hover)}.filter-group{margin-bottom:8px;background:var(--bg-tertiary);border-radius:6px;border:1px solid transparent}.filter-group-active{border-color:#4a90d94d}.filter-group-header{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;cursor:pointer;font-size:.8rem;font-weight:500;-webkit-user-select:none;user-select:none}.filter-group-header:hover{color:var(--accent-hover)}.filter-chevron{font-size:.6rem;color:var(--text-muted)}.filter-group-body{padding:0 10px 10px}.filter-chips{display:flex;flex-wrap:wrap;gap:4px}.filter-chip{padding:3px 8px;border-radius:12px;border:1px solid rgba(255,255,255,.15);background:transparent;color:var(--text-secondary);font-size:.7rem;cursor:pointer;transition:all .15s ease;font-family:inherit}.filter-chip:hover{border-color:var(--accent);color:var(--text-primary)}.filter-chip.active{border-color:var(--accent);background:#4a90d933;color:var(--text-primary)}.filter-chip.null-chip{border-style:dashed}.filter-section-header{cursor:pointer}.filter-section-chevron{margin-left:auto;font-size:.6rem;color:var(--text-muted);transition:transform .2s ease}.filter-section-chevron.expanded{transform:rotate(90deg)}.filter-section-body{margin-top:4px}.filter-result-count{font-size:.75rem;color:var(--text-secondary);padding:0 0 8px}.filter-result-count .count-highlight{color:var(--accent);font-weight:600}.filter-range-slider{padding:4px 0}.filter-range-labels{display:flex;justify-content:space-between;font-size:.7rem;color:var(--text-secondary);margin-bottom:8px}.filter-slider-track{position:relative;height:24px;display:flex;align-items:center}.filter-slider-fill{position:absolute;height:4px;background:var(--accent);border-radius:2px;pointer-events:none;top:50%;transform:translateY(-50%)}.filter-slider-handle{position:absolute;width:100%;height:4px;-webkit-appearance:none;appearance:none;background:transparent;pointer-events:none;outline:none}.filter-slider-handle::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);border:2px solid var(--bg-secondary);cursor:pointer;pointer-events:auto;box-shadow:0 1px 4px #0000004d}.filter-slider-handle::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent);border:2px solid var(--bg-secondary);cursor:pointer;pointer-events:auto;box-shadow:0 1px 4px #0000004d}.filter-slider-handle::-webkit-slider-runnable-track{height:4px;background:#ffffff1a;border-radius:2px}.filter-slider-handle::-moz-range-track{height:4px;background:#ffffff1a;border-radius:2px}.hidden{display:none!important}#map-container{flex:1;position:relative;overflow:hidden;min-height:0}#map{width:100%;height:100%}.zoom-overlay{position:absolute;bottom:32px;left:12px;z-index:5;background:#16213ed9;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:6px 10px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.zoom-hierarchy{display:flex;align-items:center;gap:4px;font-size:.7rem}.zoom-step{padding:3px 8px;border-radius:4px;color:var(--text-muted);cursor:pointer;transition:all .15s ease;white-space:nowrap}.zoom-step:hover{color:var(--text-primary);background:#ffffff0d}.zoom-step.active{color:var(--accent);background:#4a90d926;font-weight:600}.zoom-step-separator{color:var(--text-muted);font-size:.55rem;-webkit-user-select:none;user-select:none}.zoom-level{text-align:center;font-size:.6rem;color:var(--text-muted);margin-top:2px;font-variant-numeric:tabular-nums}#geocoder-container{position:absolute;top:12px;left:50%;transform:translate(-50%);z-index:10;width:380px}#geocoder-container .maplibregl-ctrl-geocoder{background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid rgba(255,255,255,.1);border-radius:8px;box-shadow:0 2px 8px #0006;font-family:inherit}#geocoder-container .maplibregl-ctrl-geocoder input{color:var(--text-primary)}#geocoder-container .maplibregl-ctrl-geocoder input::placeholder{color:var(--text-muted)}#geocoder-container .maplibregl-ctrl-geocoder .suggestions{background-color:var(--bg-secondary);border:1px solid rgba(255,255,255,.1);border-radius:0 0 8px 8px}#geocoder-container .maplibregl-ctrl-geocoder .suggestions>li>a{color:var(--text-primary)}#geocoder-container .maplibregl-ctrl-geocoder .suggestions>.active>a{background-color:var(--accent);color:#fff}#geocoder-container .maplibregl-ctrl-geocoder--icon-search,#geocoder-container .maplibregl-ctrl-geocoder--icon-close{fill:var(--text-secondary)}.tooltip{position:absolute;pointer-events:none;background:var(--bg-secondary);border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:10px 14px;box-shadow:0 4px 20px #0006;z-index:1000;max-width:200px}.tooltip.hidden{display:none}.tooltip-title{font-size:.9rem;font-weight:600;margin-bottom:4px}.tooltip-value{font-size:.8rem;color:var(--text-secondary)}.tooltip-value .value{color:var(--accent);font-weight:500}.units-clickable{cursor:pointer;border-radius:4px;padding:2px 4px;margin:-2px -4px;transition:background .15s}.units-clickable:hover{background:#4a90d933}.units-clickable .detail-value{color:var(--accent)}.selection-popup .maplibregl-popup-content{background:var(--bg-secondary);border:1px solid rgba(255,255,255,.15);border-radius:10px;padding:14px 16px;box-shadow:0 6px 28px #00000080;color:var(--text-primary);font-family:inherit}.selection-popup .maplibregl-popup-close-button{color:var(--text-secondary);font-size:1.2rem;right:6px;top:4px}.selection-popup .maplibregl-popup-close-button:hover{color:var(--text-primary);background:none}.selection-popup .maplibregl-popup-tip,.selection-popup.maplibregl-popup-anchor-bottom .maplibregl-popup-tip{border-top-color:var(--bg-secondary)}.selection-popup.maplibregl-popup-anchor-top .maplibregl-popup-tip{border-bottom-color:var(--bg-secondary)}.selection-popup.maplibregl-popup-anchor-left .maplibregl-popup-tip{border-right-color:var(--bg-secondary)}.selection-popup.maplibregl-popup-anchor-right .maplibregl-popup-tip{border-left-color:var(--bg-secondary)}.selection-popup-content .feature-name{font-size:.9rem;font-weight:600;margin-bottom:8px;padding-right:16px}.selection-popup-content .feature-details{display:flex;flex-direction:column;gap:3px}.selection-popup-content .detail-row{display:flex;justify-content:space-between;font-size:.75rem;gap:12px}.selection-popup-content .detail-label{color:var(--text-secondary);white-space:nowrap}.selection-popup-content .detail-value{font-weight:500;text-align:right}.selection-popup-content .units-clickable{cursor:pointer;border-radius:3px;padding:1px 3px;margin:-1px -3px}.selection-popup-content .units-clickable:hover{background:#4a90d933}.selection-popup-content .units-clickable .detail-value{color:var(--accent)}.modal-overlay{position:absolute;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000}.modal-overlay.hidden{display:none}.modal{background:var(--bg-secondary);border:1px solid rgba(255,255,255,.15);border-radius:12px;max-width:600px;max-height:80vh;width:90%;box-shadow:0 8px 40px #00000080;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.1)}.modal-header h3{font-size:1rem;font-weight:600}.modal-close{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:0 4px;line-height:1}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:16px 20px;overflow-y:auto}.units-table{width:100%;border-collapse:collapse;font-size:.8rem}.units-table th{text-align:left;padding:6px 8px;color:var(--text-secondary);font-weight:600;font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid rgba(255,255,255,.15)}.units-table td{padding:5px 8px;border-bottom:1px solid rgba(255,255,255,.05)}.units-table .num{text-align:right;font-variant-numeric:tabular-nums}.units-table tbody tr:hover{background:#ffffff08}.units-table tfoot td{border-top:1px solid rgba(255,255,255,.15);border-bottom:none;padding-top:8px}#units-modal{z-index:2100}.detail-modal{max-width:520px}.detail-title-row{display:flex;align-items:center;gap:6px}.detail-copy-btn{background:none;border:1px solid rgba(255,255,255,.15);color:var(--text-muted);font-size:.75rem;padding:2px 5px;border-radius:3px;cursor:pointer;line-height:1;transition:all .15s;flex-shrink:0}.detail-copy-btn:hover{color:var(--accent);border-color:var(--accent)}.detail-copy-btn.copied{color:#22c55e;border-color:#22c55e}.detail-subtitle{font-size:.75rem;color:var(--text-secondary);margin-top:2px}.detail-subtitle-link{color:var(--accent);cursor:pointer;text-decoration:none;transition:color .15s}.detail-subtitle-link:hover{color:var(--accent-hover);text-decoration:underline}.detail-section{margin-bottom:2px}.detail-section-header{display:flex;align-items:center;justify-content:space-between;padding:10px 0 6px;cursor:pointer;-webkit-user-select:none;user-select:none;border-bottom:1px solid rgba(255,255,255,.06)}.detail-section-header:hover .detail-section-title{color:var(--text-primary)}.detail-section-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);transition:color .15s}.detail-section-chevron{font-size:.55rem;color:var(--text-muted);transition:transform .2s}.detail-section-chevron.collapsed{transform:rotate(-90deg)}.detail-section-body{padding:6px 0 4px;display:flex;flex-direction:column;gap:3px}.detail-section-body.collapsed{display:none}.detail-modal .detail-row{display:flex;justify-content:space-between;gap:12px;font-size:.8rem;padding:2px 0}.detail-modal .detail-label{color:var(--text-secondary);white-space:nowrap}.detail-modal .detail-value{font-weight:500;text-align:right}.detail-gmaps-link{display:inline-flex;align-items:center;gap:4px;color:var(--accent);font-size:.78rem;text-decoration:none;padding:4px 0 8px;transition:color .15s}.detail-gmaps-link:hover{color:var(--accent-hover)}.energie-badge{display:inline-block;padding:1px 7px;border-radius:3px;font-weight:700;font-size:.75rem;line-height:1.4;letter-spacing:.5px}.energie-badge-A{background:#22c55e;color:#000}.energie-badge-B{background:#84cc16;color:#000}.energie-badge-C{background:#eab308;color:#000}.energie-badge-D{background:#f59e0b;color:#000}.energie-badge-E{background:#f97316;color:#fff}.energie-badge-F{background:#ef4444;color:#fff}.energie-badge-G{background:#dc2626;color:#fff}.yield-value{color:#22c55e}.lbm-score-bar{display:inline-flex;align-items:center;gap:6px}.lbm-score-track{display:inline-block;width:60px;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden;vertical-align:middle}.lbm-score-fill{display:block;height:100%;border-radius:3px}.dev-bar-row{display:flex;align-items:center;gap:8px;font-size:.8rem;padding:3px 0}.dev-bar-label{color:var(--text-secondary);width:110px;flex-shrink:0;text-align:right;font-size:.75rem}.dev-bar-track{flex:1;height:10px;background:#ffffff0f;border-radius:2px;position:relative;min-width:120px}.dev-bar-center{position:absolute;left:50%;top:0;bottom:0;width:1px;background:#ffffff40}.dev-bar-fill{position:absolute;top:1px;bottom:1px;border-radius:1px}.dev-bar-fill.positive{left:50%;background:#22c55e}.dev-bar-fill.negative{right:50%;background:#ef4444}.dev-bar-val{width:42px;flex-shrink:0;font-size:.72rem;color:var(--text-muted)}.cmp-table{width:100%;font-size:.75rem;border-collapse:collapse;margin:4px 0}.cmp-table th{color:var(--text-muted);font-weight:400;text-align:right;padding:2px 6px;white-space:nowrap}.cmp-table th:first-child{text-align:left}.cmp-table td{text-align:right;padding:3px 6px;white-space:nowrap}.cmp-table td:first-child{text-align:left;color:var(--text-secondary)}.cmp-table .cmp-highlight{font-weight:600;color:var(--text-primary)}.cmp-delta{font-size:.65rem;font-weight:400}.cmp-delta-pos{color:#22c55e}.cmp-delta-neg{color:#ef4444}.detail-modal .units-clickable{cursor:pointer;border-radius:4px;padding:2px 4px;margin:-2px -4px;transition:background .15s}.detail-modal .units-clickable:hover{background:#4a90d933}.detail-modal .units-clickable .detail-value{color:var(--accent)}.maplibregl-ctrl-group{background:var(--bg-secondary)!important;border:1px solid rgba(255,255,255,.1)!important}.maplibregl-ctrl-group button{background-color:transparent!important;border-bottom:1px solid rgba(255,255,255,.1)!important}.maplibregl-ctrl-group button:last-child{border-bottom:none!important}.maplibregl-ctrl-group button span{filter:invert(1)}.maplibregl-ctrl-attrib{background:#1a1a2ecc!important;color:var(--text-muted)!important}.maplibregl-ctrl-attrib a{color:var(--text-secondary)!important}.sidebar-tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.1);background:var(--bg-tertiary)}.sidebar-tab{flex:1;padding:10px 16px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;font-family:inherit;transition:all .2s ease}.sidebar-tab:hover{color:var(--text-primary);background:#ffffff08}.signal-overlay-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;padding:8px 12px;background:var(--bg-tertiary);border-radius:8px}.signal-overlay-toggle input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.signal-toggle-label{font-size:.85rem;font-weight:500;flex:1}.signal-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:#4a90d933;color:var(--accent);font-size:.7rem;font-weight:700}#sidebar-data-content,#sidebar-signals-content{flex:1;overflow-y:auto}.signal-feed{padding:12px 16px}.signal-feed-empty{text-align:center;padding:32px 16px;color:var(--text-muted);font-size:.85rem;line-height:1.5}.signal-feed-count{font-size:.7rem;color:var(--text-muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.signal-refresh-indicator{font-size:.7rem;color:var(--text-muted);margin-bottom:8px;padding:4px 8px;background:#ffffff08;border-radius:4px}.signal-refresh-warn{color:#f59e0b;background:#f59e0b1a}.signal-feed-list{display:flex;flex-direction:column;gap:6px}.signal-feed-item{padding:10px 12px;background:var(--bg-tertiary);border-radius:8px;cursor:pointer;border:1px solid transparent;transition:all .15s ease}.signal-feed-item:hover{border-color:#4a90d94d;background:#4a90d90d}.signal-feed-item-selected{border-color:var(--accent);background:#4a90d91a}.signal-feed-item-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.signal-phase-badge{display:inline-block;padding:2px 8px;border-radius:10px;color:#fff;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.signal-feed-municipality{font-size:.7rem;color:var(--text-muted);margin-left:auto}.signal-feed-item-title{font-size:.82rem;font-weight:500;line-height:1.3;margin-bottom:4px}.signal-feed-item-meta{display:flex;gap:12px;font-size:.7rem;color:var(--text-muted)}.signal-detail{display:flex;flex-direction:column;gap:12px}.signal-detail-back{background:none;border:none;color:var(--accent);font-size:.8rem;cursor:pointer;padding:0;font-family:inherit;text-align:left}.signal-detail-back:hover{color:var(--accent-hover)}.signal-detail-header{display:flex;flex-direction:column;gap:8px}.signal-detail-title{font-size:1rem;font-weight:600;line-height:1.3;margin:0}.signal-detail-summary{font-size:.82rem;line-height:1.5;color:var(--text-secondary);margin:0}.signal-detail-meta{display:flex;flex-direction:column;gap:6px;padding:10px 12px;background:var(--bg-tertiary);border-radius:8px}.signal-meta-row{display:flex;justify-content:space-between;font-size:.8rem}.signal-meta-label{color:var(--text-secondary)}.signal-meta-value{font-weight:500;text-align:right}.signal-phase-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:4px;vertical-align:middle}.signal-detail-source-link{display:inline-block;padding:8px 12px;background:#4a90d91a;border:1px solid rgba(74,144,217,.3);border-radius:6px;color:var(--accent);font-size:.82rem;text-decoration:none;text-align:center;transition:all .15s ease}.signal-detail-source-link:hover{background:#4a90d933;border-color:var(--accent)}.signal-ai-disclaimer{font-size:.7rem;color:var(--text-muted);font-style:italic;padding:8px;background:#f59e0b0d;border:1px dashed rgba(245,158,11,.2);border-radius:4px}.signal-modal-backdrop{position:fixed;inset:0;z-index:1000;background:#00000080;display:flex;align-items:center;justify-content:center;padding:20px}.signal-modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;width:100%;max-width:520px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0006}.signal-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}.signal-modal-header h3{margin:0;font-size:.95rem;font-weight:600;color:var(--text)}.signal-modal-close{background:none;border:none;color:var(--text-muted);font-size:1.4rem;cursor:pointer;padding:0 4px;line-height:1}.signal-modal-close:hover{color:var(--text)}.signal-modal-list{overflow-y:auto;padding:8px;flex:1}.signal-modal-item{padding:10px 12px;border-left:3px solid var(--accent);border-radius:4px;background:#ffffff08;margin-bottom:8px}.signal-modal-item:last-child{margin-bottom:0}.signal-modal-item-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.signal-modal-phase{font-size:.65rem;font-weight:600;padding:2px 8px;border-radius:10px;color:#fff;text-transform:capitalize;white-space:nowrap}.signal-modal-municipality{font-size:.7rem;color:var(--text-muted)}.signal-modal-title{font-size:.8rem;font-weight:600;color:var(--text);margin-bottom:4px;line-height:1.3}.signal-modal-summary{font-size:.72rem;color:var(--text-muted);line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:6px}.signal-modal-footer{display:flex;align-items:center;justify-content:space-between;gap:8px}.signal-modal-date{font-size:.65rem;color:var(--text-muted)}.signal-modal-flyto{font-size:.7rem;padding:3px 10px;border-radius:4px;border:1px solid var(--accent);background:transparent;color:var(--accent);cursor:pointer;white-space:nowrap}.signal-modal-flyto:hover{background:#4a90d926}.signal-modal-more{text-align:center;font-size:.72rem;color:var(--text-muted);padding:8px;font-style:italic}.signal-phase-filters{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}.signal-phase-chip{padding:3px 8px;border-radius:12px;border:1px solid var(--phase-color, rgba(255, 255, 255, .15));background:transparent;color:var(--text-secondary);font-size:.65rem;cursor:pointer;transition:all .15s ease;font-family:inherit;white-space:nowrap}.signal-phase-chip:hover:not(:disabled){background:color-mix(in srgb,var(--phase-color) 20%,transparent);color:var(--text-primary)}.signal-phase-chip.active{background:color-mix(in srgb,var(--phase-color) 25%,transparent);border-color:var(--phase-color);color:var(--text-primary)}.signal-phase-chip.disabled{opacity:.3;cursor:default}.signal-phase-chip-count{font-weight:700;margin-left:2px}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-primary)}.login-card{background:var(--bg-secondary);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:40px 36px;width:360px;box-shadow:0 8px 40px #0006}.login-card .brand h1{font-size:1.8rem;font-weight:700;letter-spacing:2px;color:var(--accent)}.login-card .brand p{font-size:.8rem;color:var(--text-secondary);margin-top:4px;margin-bottom:32px}.login-card label{display:block;font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.login-card input[type=text],.login-card input[type=password]{width:100%;padding:10px 12px;background:var(--bg-tertiary);border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--text-primary);font-size:.95rem;font-family:inherit;outline:none;margin-bottom:18px;transition:border-color .2s}.login-card input:focus{border-color:var(--accent)}.login-card button[type=submit]{width:100%;padding:12px;background:var(--accent);border:none;border-radius:6px;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;font-family:inherit;transition:background .2s}.login-card button[type=submit]:hover{background:var(--accent-hover)}.login-card button[type=submit]:disabled{background:#3a6a9a;cursor:wait}.login-card .error{margin-top:16px;padding:10px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:6px;color:#ef4444;font-size:.85rem;text-align:center}.sidebar-tab{flex:1;padding:8px 12px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:color .2s,border-color .2s}.sidebar-tab:hover{color:var(--text-primary)}.sidebar-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.admin-content{flex:1;overflow-y:auto;padding:24px;background:var(--bg-primary);min-height:calc(100vh - var(--topbar-height))}.admin-inner{max-width:800px;margin:0 auto}.admin-title{font-size:1.3rem;color:var(--accent);letter-spacing:1px;margin-bottom:8px}.admin-subtitle{color:var(--text-secondary);font-size:.85rem;margin-bottom:32px}.btn{padding:8px 16px;border:1px solid rgba(255,255,255,.15);border-radius:6px;background:transparent;color:var(--text-primary);font-size:.85rem;cursor:pointer;font-family:inherit;transition:all .2s;text-decoration:none}.btn:hover{border-color:var(--accent);color:var(--accent)}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-danger{color:#ef4444;border-color:#ef44444d}.btn-danger:hover{border-color:#ef4444;background:#ef44441a}.btn-sm{padding:4px 10px;font-size:.75rem}.card{background:var(--bg-secondary);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:24px;margin-bottom:24px}.card h2{font-size:.75rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);margin-bottom:16px}.form-row{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}.form-group{flex:1;min-width:140px}.form-group label{display:block;font-size:.7rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.form-group input,.form-group select{width:100%;padding:8px 10px;background:var(--bg-tertiary);border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--text-primary);font-size:.85rem;font-family:inherit;outline:none}.form-group input:focus,.form-group select:focus{border-color:var(--accent)}.form-group select{cursor:pointer}.admin-content table{width:100%;border-collapse:collapse;font-size:.85rem}.admin-content th{text-align:left;padding:8px;font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);border-bottom:1px solid rgba(255,255,255,.15)}.admin-content td{padding:10px 8px;border-bottom:1px solid rgba(255,255,255,.05)}.admin-content tr:hover td{background:#ffffff05}.role-admin{background:#4a90d933;color:var(--accent)}.role-user{background:#a0a0a026;color:var(--text-secondary)}.actions{display:flex;gap:6px}.msg{padding:10px;border-radius:6px;font-size:.85rem;margin-bottom:16px}.msg-ok{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#22c55e}.msg-err{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444}.modal-bg{display:none;position:fixed;inset:0;background:#0009;align-items:center;justify-content:center;z-index:100}.modal-bg.open{display:flex}.modal-box{background:var(--bg-secondary);border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:28px;width:380px;box-shadow:0 8px 40px #00000080}.modal-box h3{font-size:1rem;margin-bottom:20px}.hamburger-btn,.drawer-overlay{display:none}@media(max-width:768px){#sidebar{position:fixed;top:var(--topbar-height);left:0;bottom:0;width:280px;z-index:501;transform:translate(0);transition:transform .25s ease;box-shadow:4px 0 20px #00000080}.drawer-overlay{display:block;position:fixed;inset:0;top:var(--topbar-height);background:#00000080;z-index:500;pointer-events:auto}.hamburger-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:none;border:none;cursor:pointer;margin-right:8px;padding:8px}.hamburger-icon{display:block;width:20px;height:2px;background:var(--text-primary);position:relative}.hamburger-icon:before,.hamburger-icon:after{content:"";position:absolute;width:20px;height:2px;background:var(--text-primary);left:0}.hamburger-icon:before{top:-6px}.hamburger-icon:after{top:6px}.topbar-brand{margin-right:12px}.topbar-nav a{padding:0 10px;font-size:.8rem}#geocoder-container{width:calc(100vw - 100px);max-width:380px;left:50%;transform:translate(-50%)}.modal-overlay{position:fixed;inset:0;align-items:flex-end}.detail-modal{max-width:100%;width:100%;max-height:80vh;max-height:80dvh;border-radius:12px 12px 0 0;margin:0;align-self:flex-end}.units-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.filter-chip{min-width:44px;min-height:44px;padding:8px 12px}.signal-phase-filters{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;padding-bottom:4px}.signal-phase-filters .signal-phase-btn{flex-shrink:0}.sidebar-header{padding:12px 16px}.sidebar-header h1{font-size:1.1rem}.zoom-overlay{bottom:28px;left:8px;font-size:.7rem}.zoom-level{display:none}}@media(max-width:1024px)and (min-width:769px){:root{--sidebar-width: 240px}#sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width)}#geocoder-container{width:320px}}
