@import url("https://fonts.googleapis.com/css2?family=Archivo+Black&family=Arimo:wght@400;500;600;700&display=swap");:root{--pp-green:#89BF4A;--pp-green-dark:#3D7A1A;--pp-green-light:#A8D65A;--pp-near-black:#1A1A1A;--pp-asphalt:#3A3A3A;--pp-off-white:#FAF9F5;--pp-white:#FFFFFF;--pp-gray-50:#F5F5F3;--pp-gray-100:#E8E8E5;--pp-gray-200:#D1D1CD;--pp-gray-300:#B5B5B0;--pp-gray-400:#8A8A85;--pp-gray-500:#5F5F5B;--pp-gray-700:#2A2A2A;--pp-gray-900:#0A0A0A;--bg-primary:#1A1A1A;--bg-secondary:#111111;--bg-card:#242424;--bg-card-hover:#2A2A2A;--bg-elevated:#2F2F2F;--text-primary:#FAF9F5;--text-secondary:#D1D1CD;--text-muted:#8A8A85;--glass-border:#3A3A3A;--glass-border-subtle:#2A2A2A;--border-strong:#FAF9F5;--severity-low:#89BF4A;--severity-medium:#E0B23A;--severity-high:#D97B3A;--severity-critical:#C0392B;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--radius-sm:4px;--radius-md:8px;--radius-lg:14px;--radius-xl:20px;--radius-full:9999px;--radius-label:22px;--shadow-sm:0 2px 6px rgba(0,0,0,0.40);--shadow-md:0 6px 16px rgba(0,0,0,0.50);--shadow-lg:0 14px 32px rgba(0,0,0,0.55);--shadow-green:0 6px 18px rgba(137,191,74,0.35);--transition-fast:120ms cubic-bezier(0.2,0.7,0.2,1);--transition-normal:200ms cubic-bezier(0.2,0.7,0.2,1);--transition-smooth:360ms cubic-bezier(0.2,0.7,0.2,1);--font-display:"Arial Black","Archivo Black","Arimo",system-ui,sans-serif;--font-body:"Arial","Arimo","Liberation Sans",system-ui,-apple-system,sans-serif;--font-mono:ui-monospace,"SF Mono","Menlo",monospace}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-body);background:radial-gradient(circle at 1px 1px,rgba(250,249,245,.025) 1px,transparent 0) 0 0 /32px 32px,var(--bg-primary);color:var(--text-primary);line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}a{color:var(--pp-green);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--pp-green-light)}ol{list-style-position:outside}.page-container{max-width:1400px;margin:0 auto;padding:var(--space-lg)}.page-header{margin-bottom:var(--space-2xl);padding-bottom:var(--space-md);border-bottom:1px solid var(--glass-border);display:grid;grid-template-columns:1fr auto;align-items:end;grid-gap:var(--space-md);gap:var(--space-md)}.page-header>div:first-child{min-width:0}.page-header .eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--pp-green-light);margin-bottom:6px}.page-header .eyebrow:before{content:"";width:24px;height:2px;background:var(--pp-green)}.page-header h1{font-family:var(--font-display);font-weight:900;font-size:clamp(28px,3.5vw,44px);line-height:1.02;letter-spacing:-.015em;text-transform:uppercase;color:var(--text-primary);margin:0}.page-header p{color:var(--text-secondary);margin-top:var(--space-sm);font-size:.92rem;max-width:60ch;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.page-header-meta{display:flex;flex-direction:column;align-items:flex-end;gap:6px;text-align:right}.page-header-meta .meta-label{font-family:var(--font-body);font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted)}.page-header-meta .meta-value{font-family:var(--font-mono);font-size:12px;color:var(--text-secondary);letter-spacing:.02em}@media (max-width:640px){.page-header{grid-template-columns:1fr}.page-header-meta{align-items:flex-start;text-align:left}}.navbar{position:-webkit-sticky;position:sticky;top:0;z-index:1000;background:var(--bg-primary);border-bottom:1px solid var(--glass-border-subtle);padding:0 var(--space-lg)}.navbar-inner{max-width:1400px;margin:0 auto;height:64px;gap:var(--space-xl)}.navbar-inner,.navbar-logo{display:flex;align-items:center}.navbar-logo{gap:var(--space-sm);color:var(--text-primary);text-decoration:none}.navbar-badge{font-family:var(--font-body);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;background:var(--pp-green);color:var(--pp-near-black);padding:3px 8px;border-radius:var(--radius-sm)}.navbar-links{display:flex;gap:var(--space-xs);list-style:none}.navbar-links a{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);color:var(--text-secondary);font-family:var(--font-body);font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;border-radius:var(--radius-sm);transition:color var(--transition-fast),background var(--transition-fast);text-decoration:none}.navbar-links a:hover{color:var(--text-primary);background:var(--bg-card)}.navbar-links a.active{color:var(--pp-green-light);background:transparent;border-bottom:2px solid var(--pp-green);border-radius:0}.nav-mobile-toggle{display:none;background:none;border:none;color:var(--text-primary);font-size:1.4rem;cursor:pointer;padding:var(--space-sm)}.navbar-user{display:flex;align-items:center;gap:var(--space-md);margin-left:auto}.navbar-user-email{font-size:.8rem;color:var(--text-muted);max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.navbar-signout{padding:6px 14px!important;font-size:12px!important}.card{background:var(--bg-card);border:1px solid var(--glass-border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);transition:border-color var(--transition-normal)}.card:hover{border-color:var(--glass-border)}.card-glass{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-lg)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));grid-gap:var(--space-md);gap:var(--space-md);margin-bottom:var(--space-2xl)}.kpi-card{background:var(--bg-card);border:1px solid var(--glass-border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-sm);transition:border-color var(--transition-normal);position:relative;overflow:hidden}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background-image:repeating-linear-gradient(-45deg,var(--pp-near-black) 0 8px,var(--pp-green) 8px 16px)}.kpi-card:not(:first-child):before{background:var(--pp-green);background-image:none;height:2px}.kpi-card:nth-child(2):before{background:var(--severity-critical)}.kpi-card:nth-child(3):before{background:var(--severity-medium)}.kpi-card:nth-child(4):before{background:var(--severity-low)}.kpi-card:hover{border-color:var(--glass-border);transform:translateY(-1px);transition:transform var(--transition-normal),border-color var(--transition-normal)}.kpi-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:rgba(137,191,74,.1);color:var(--pp-green);border:1px solid rgba(137,191,74,.2)}.kpi-label{font-family:var(--font-body);font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.14em}.kpi-value{font-family:var(--font-display);font-weight:900;font-size:clamp(2rem,3vw,2.6rem);letter-spacing:-.02em;color:var(--text-primary);line-height:.98;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;animation:fadeInUp .48s cubic-bezier(.2,.7,.2,1) both}.kpi-subtitle{font-size:.85rem;color:var(--text-secondary)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(460px,1fr));grid-gap:var(--space-lg);gap:var(--space-lg);margin-bottom:var(--space-2xl)}.chart-card{background:var(--bg-card);border:1px solid var(--glass-border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg)}.chart-card h3{font-family:var(--font-body);font-size:1rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-md);display:flex;align-items:center;gap:var(--space-sm);letter-spacing:.02em}.map-container{width:100%;height:600px;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--glass-border-subtle);position:relative}.map-container .leaflet-container{height:100%;width:100%;background:var(--bg-secondary)}.leaflet-tile-pane{filter:brightness(.65) contrast(1.08) saturate(.85)}.leaflet-popup-content-wrapper{color:var(--text-primary)!important;border-radius:var(--radius-md)!important;box-shadow:var(--shadow-lg)!important;border:1px solid var(--glass-border)!important}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:var(--bg-card)!important}.leaflet-popup-content{margin:var(--space-md)!important;font-family:var(--font-body)!important;color:var(--text-primary)!important}.leaflet-popup-close-button{color:var(--text-secondary)!important}.leaflet-control-zoom a{background:var(--bg-card)!important;color:var(--text-primary)!important;border-color:var(--glass-border-subtle)!important}.leaflet-control-zoom a:hover{background:var(--bg-card-hover)!important}.leaflet-control-attribution{background:rgba(26,26,26,.85)!important;color:var(--text-muted)!important;font-size:11px!important}.leaflet-control-attribution a{color:var(--text-secondary)!important}.pothole-popup{min-width:200px}.pothole-popup h4{font-family:var(--font-body);font-size:.9rem;font-weight:700;margin-bottom:var(--space-sm);color:var(--text-primary)}.pothole-popup .popup-row{display:flex;justify-content:space-between;padding:3px 0;font-size:.8rem;border-bottom:1px solid var(--glass-border-subtle)}.pothole-popup .popup-row:last-child{border-bottom:none}.pothole-popup .popup-label{color:var(--text-muted)}.pothole-popup .popup-value{color:var(--text-primary);font-weight:500}.severity-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-family:var(--font-body);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em}.severity-badge.low{background:rgba(137,191,74,.16);color:var(--severity-low);border:1px solid rgba(137,191,74,.35)}.severity-badge.medium{background:rgba(224,178,58,.16);color:var(--severity-medium);border:1px solid rgba(224,178,58,.35)}.severity-badge.high{background:rgba(217,123,58,.16);color:var(--severity-high);border:1px solid rgba(217,123,58,.35)}.severity-badge.critical{background:rgba(192,57,43,.16);color:var(--severity-critical);border:1px solid rgba(192,57,43,.35)}.type-badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:var(--radius-full);font-family:var(--font-body);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em}.type-badge.bookmark{background:rgba(137,191,74,.12);color:var(--pp-green-light);border:1px solid rgba(137,191,74,.3)}.type-badge.report{background:rgba(192,57,43,.14);color:#E58575;border:1px solid rgba(192,57,43,.35)}.consent-pill{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-full);font-family:var(--font-body);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em}.consent-pill.yes{background:rgba(137,191,74,.16);color:var(--severity-low);border:1px solid rgba(137,191,74,.35)}.consent-pill.no{background:rgba(192,57,43,.16);color:var(--severity-critical);border:1px solid rgba(192,57,43,.35)}.data-table{width:100%;border-collapse:separate;border-spacing:0;font-size:.85rem}.data-table thead th{background:var(--bg-elevated);color:var(--text-muted);font-family:var(--font-body);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.1em;padding:var(--space-md);text-align:left;border-bottom:1px solid var(--glass-border-subtle);position:-webkit-sticky;position:sticky;top:0;z-index:1}.data-table thead th:first-child{border-radius:var(--radius-md) 0 0 0}.data-table thead th:last-child{border-radius:0 var(--radius-md) 0 0}.data-table tbody tr{transition:background var(--transition-fast);position:relative}.data-table tbody tr td:first-child{border-left:2px solid transparent;transition:border-color var(--transition-fast)}.data-table tbody tr:hover{background:var(--bg-card-hover)}.data-table tbody tr:hover td:first-child{border-left-color:var(--pp-green)}.data-table tbody td{padding:var(--space-md);border-bottom:1px solid rgba(255,255,255,.04);color:var(--text-secondary);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.sort-icon{display:inline-flex;align-items:center;margin-left:4px;color:var(--text-muted);vertical-align:middle}.sort-icon.active{color:var(--pp-green)}.device-handle{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);letter-spacing:.01em}.device-handle button{background:none;border:none;color:var(--pp-green);cursor:pointer;font-size:10px;margin-left:4px;padding:0}.device-handle button:hover{color:var(--pp-green-light)}.filters-bar{display:flex;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap;align-items:center}.filter-input,.filter-select{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--glass-border-subtle);border-radius:var(--radius-sm);padding:var(--space-sm) var(--space-md);font-family:var(--font-body);font-size:14px;transition:border-color var(--transition-fast)}.filter-select{cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238A8A85' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 8px center;background-size:16px;padding-right:30px}.filter-input::placeholder{color:var(--text-muted)}.filter-input:focus,.filter-select:focus{outline:none;border-color:var(--pp-green)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:10px 18px;font-family:var(--font-display);font-size:13px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-normal),color var(--transition-normal),border-color var(--transition-normal),box-shadow var(--transition-normal),transform var(--transition-fast)}.btn-primary{background:var(--pp-green);color:var(--pp-near-black);border-color:var(--pp-green)}.btn-primary:hover{background:var(--pp-green-dark);color:var(--pp-off-white);border-color:var(--pp-green-dark);box-shadow:var(--shadow-green)}.btn-primary:active{transform:scale(.98)}.btn-outline{background:transparent;color:var(--text-secondary);border-color:var(--glass-border)}.btn-outline:hover{border-color:var(--text-primary);color:var(--text-primary)}.btn-sm{padding:5px 12px!important;font-size:11px!important;letter-spacing:.1em!important;border-radius:var(--radius-sm)!important;background:var(--bg-elevated)!important;border:1px solid var(--glass-border-subtle)!important;color:var(--text-secondary)!important}.btn-sm:hover{background:var(--bg-card-hover)!important;border-color:var(--glass-border)!important;color:var(--text-primary)!important}.btn-clear{color:var(--severity-critical)!important;border-color:rgba(192,57,43,.35)!important}.btn-clear:hover{background:rgba(192,57,43,.1)!important;border-color:rgba(192,57,43,.55)!important}.btn-clear:disabled,.btn-sm:disabled,.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-3xl);gap:var(--space-md)}.loading-spinner{width:40px;height:40px;border:3px solid var(--glass-border-subtle);border-top-color:var(--pp-green);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.loading-text{color:var(--text-muted);font-size:.9rem}.empty-state{text-align:center;padding:var(--space-3xl);color:var(--text-muted)}.empty-state-icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;margin:0 auto var(--space-md);color:var(--text-muted);opacity:.7}.hero{position:relative;padding:var(--space-3xl) 0 var(--space-xl);text-align:center}.hero h1{font-family:var(--font-display);font-size:clamp(40px,5vw,64px);font-weight:900;letter-spacing:-.01em;line-height:1.05;text-transform:uppercase;margin-bottom:var(--space-md);color:var(--text-primary)}.hero h1 .gradient-text{color:var(--pp-green);background:none;-webkit-text-fill-color:currentColor}.hero p{color:var(--text-secondary);font-size:1.05rem;max-width:600px;margin:0 auto var(--space-xl)}.bg-glow,.bg-glow-1,.bg-glow-2{display:none!important}.about-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:var(--space-lg);gap:var(--space-lg)}.about-card{background:var(--bg-card);border:1px solid var(--glass-border-subtle);border-radius:var(--radius-lg);padding:var(--space-xl);transition:border-color var(--transition-normal)}.about-card:hover{border-color:var(--glass-border)}.about-card-icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-md);background:rgba(137,191,74,.1);color:var(--pp-green);margin-bottom:var(--space-md)}.about-card h3{font-family:var(--font-body);font-size:1.1rem;font-weight:700;margin-bottom:var(--space-sm);color:var(--text-primary);letter-spacing:.02em}.about-card p{color:var(--text-secondary);font-size:.92rem;line-height:1.6}.footer{position:relative;padding:var(--space-xl) var(--space-lg);margin-top:var(--space-3xl);border-top:1px solid var(--glass-border-subtle)}.footer:before{content:"";position:absolute;top:-1px;left:0;right:0;height:4px;background-image:repeating-linear-gradient(-45deg,var(--pp-near-black) 0 8px,var(--pp-green) 8px 16px);opacity:.55;pointer-events:none}.footer-inner{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;grid-gap:var(--space-md);gap:var(--space-md)}.footer-confidential{font-family:var(--font-body);font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);display:inline-flex;align-items:center;gap:8px}.footer-confidential:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--severity-critical);box-shadow:0 0 0 2px rgba(192,57,43,.18)}.footer-stamp{font-family:var(--font-display);font-weight:900;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--text-secondary);padding:6px 14px;border:1.5px solid var(--glass-border);border-radius:var(--radius-sm);white-space:nowrap}.footer-stamp .pp-mark{color:var(--pp-green-light)}.footer-stamp .synqa{color:var(--text-primary)}.footer-meta{justify-self:end;font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;color:var(--text-muted);text-transform:uppercase}@media (max-width:768px){.footer-inner{grid-template-columns:1fr;text-align:center;justify-items:center}.footer-meta{justify-self:center}}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-lg)}.login-card{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-2xl) var(--space-xl);width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:var(--space-xl)}.login-logo{margin-bottom:var(--space-md)}.login-header h1{font-family:var(--font-display);font-size:1.4rem;font-weight:900;letter-spacing:.02em;text-transform:uppercase;color:var(--text-primary)}.login-brand{color:var(--pp-green)}.login-header p{color:var(--text-muted);font-size:.85rem;margin-top:var(--space-sm);letter-spacing:.04em}.login-form{gap:var(--space-md)}.login-field,.login-form{display:flex;flex-direction:column}.login-field{gap:var(--space-xs)}.login-field label{font-family:var(--font-body);font-size:12px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em}.login-field .filter-input{width:100%;padding:var(--space-md);font-size:.95rem}.login-btn{width:100%;padding:14px!important;font-size:14px!important;justify-content:center;margin-top:var(--space-sm)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-error{background:rgba(192,57,43,.1);border:1px solid rgba(192,57,43,.35);color:var(--severity-critical);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-size:.85rem;display:flex;align-items:center;gap:var(--space-sm)}.login-footer{margin-top:var(--space-xl);text-align:center}.login-footer p{color:var(--text-muted);font-size:.78rem;line-height:1.7;gap:6px}.auth-loading-screen,.login-footer p{display:flex;align-items:center;justify-content:center}.auth-loading-screen{min-height:100vh}.auth-loading-inner{display:flex;flex-direction:column;align-items:center;gap:var(--space-md)}code{font-family:var(--font-mono);font-size:.88em;background:rgba(137,191,74,.1);color:var(--pp-green-light);padding:1px 6px;border-radius:var(--radius-sm)}.photo-thumbnail-btn{display:inline-block;background:none;border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:2px;cursor:pointer;transition:border-color var(--transition-fast);line-height:0}.photo-thumbnail-btn:hover{border-color:var(--pp-green)}.photo-thumbnail{width:48px;height:48px;object-fit:cover;border-radius:3px;display:block}.lightbox-overlay{position:fixed;inset:0;background:rgba(26,26,26,.92);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.lightbox-content{position:relative;max-width:90vw;max-height:90vh}.lightbox-image{max-width:90vw;max-height:85vh;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);object-fit:contain}.lightbox-close{position:absolute;top:-44px;right:0;background:var(--bg-card);border:1px solid var(--glass-border);color:var(--text-primary);width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast)}.lightbox-close:hover{background:var(--pp-green);color:var(--pp-near-black)}.date-range-filter{display:flex;flex-direction:column;gap:8px;width:100%}.date-range-inputs{display:flex;align-items:center;gap:8px}.date-input{flex:1 1;min-width:130px;max-width:180px;color-scheme:dark}.date-separator{color:var(--text-muted);font-size:.85rem;flex-shrink:0}.date-range-presets{display:flex;gap:6px;flex-wrap:wrap}.map-toggle{position:absolute;top:14px;right:14px;z-index:1000;display:flex;gap:0;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--glass-border);box-shadow:var(--shadow-md)}.map-toggle-btn{padding:8px 14px;font-family:var(--font-body);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;border:none;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);background:var(--bg-card);color:var(--text-muted);display:inline-flex;align-items:center;gap:6px}.map-toggle-btn:hover{background:var(--bg-card-hover);color:var(--text-secondary)}.map-toggle-btn.active{background:var(--pp-green);color:var(--pp-near-black)}.realtime-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--pp-green);margin-right:6px;animation:realtime-pulse 2s infinite}@keyframes realtime-pulse{0%,to{opacity:1;box-shadow:0 0 0 0 rgba(137,191,74,.5)}50%{opacity:.7;box-shadow:0 0 0 6px rgba(137,191,74,0)}}.refresh-indicator{display:inline-flex;gap:6px;font-size:11px;letter-spacing:.1em;color:var(--text-muted)}.refresh-indicator,.session-warning{align-items:center;font-family:var(--font-body);font-weight:700;text-transform:uppercase}.session-warning{background:var(--severity-critical);color:var(--pp-off-white);text-align:center;padding:8px 16px;font-size:12px;letter-spacing:.06em;display:flex;justify-content:center;gap:8px;position:-webkit-sticky;position:sticky;top:64px;z-index:999}.pp-hazard-thin{background-image:repeating-linear-gradient(-45deg,var(--pp-near-black) 0 8px,var(--pp-green) 8px 16px);height:4px}@media (max-width:768px){.page-container{padding:var(--space-md)}.hero h1{font-size:2rem}.kpi-grid{grid-template-columns:repeat(2,1fr)}.charts-grid{grid-template-columns:1fr}.map-container{height:400px}.navbar-links{display:none}.nav-mobile-toggle{display:block;margin-left:auto}.navbar-links.open{display:flex;position:absolute;top:64px;left:0;right:0;background:var(--bg-primary);border-bottom:1px solid var(--glass-border-subtle);padding:var(--space-md)}.filters-bar,.navbar-links.open{flex-direction:column}.filter-input,.filter-select{width:100%}}@media (max-width:480px){.kpi-grid{grid-template-columns:1fr}.kpi-value{font-size:1.5rem}}.status-filter{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin:var(--space-md) 0}.status-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;font-family:var(--font-body);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:var(--bg-card);color:var(--text-muted);border:1px solid var(--glass-border-subtle);border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast);position:relative}.status-chip:hover{background:var(--bg-card-hover);color:var(--text-secondary);border-color:var(--glass-border)}.status-chip .status-chip-icon{display:inline-flex;opacity:.85}.status-chip .status-chip-count{color:var(--text-muted);font-weight:600}.status-chip-all.active{background:rgba(137,191,74,.12);color:var(--text-primary);border-color:rgba(137,191,74,.35)}.status-chip-unfixed.active{background:rgba(137,191,74,.18);color:var(--severity-low);border-color:rgba(137,191,74,.45)}.status-chip-fixed.active{background:rgba(61,122,26,.2);color:var(--pp-green-light);border-color:rgba(61,122,26,.55)}.status-chip-flagged.active{background:rgba(217,123,58,.16);color:var(--severity-high);border-color:rgba(217,123,58,.45)}.status-chip.active .status-chip-count{color:inherit;opacity:.85}.status-chip.active:after{content:"";position:absolute;left:14px;right:14px;bottom:-5px;height:2px;background:var(--pp-green);border-radius:2px}.map-area-tools{position:absolute;top:14px;left:14px;z-index:1000;display:flex;gap:6px}.map-area-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;font-family:var(--font-body);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-md);cursor:pointer;box-shadow:var(--shadow-md);transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.map-area-btn:hover{background:var(--bg-card-hover);color:var(--text-primary);border-color:var(--pp-green)}.map-area-btn-clear{color:var(--severity-critical);border-color:rgba(192,57,43,.4)}.map-area-btn-clear:hover{background:rgba(192,57,43,.1);border-color:rgba(192,57,43,.6);color:var(--severity-critical)}.map-area-btn-cancel{color:var(--severity-high);border-color:rgba(217,123,58,.4)}.map-draw-hint{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);z-index:1000;padding:6px 14px;font-weight:700;letter-spacing:.1em;background:var(--pp-near-black);color:var(--pp-green-light);border:1px solid var(--pp-green);border-radius:var(--radius-full);box-shadow:var(--shadow-md);pointer-events:none}.map-draw-hint,.recent-meta{font-family:var(--font-body);font-size:11px;text-transform:uppercase}.recent-meta{display:inline-block;margin-left:var(--space-sm);font-weight:600;letter-spacing:.08em;color:var(--text-muted)}.recent-table{margin-top:var(--space-sm)}.recent-cell-date{color:var(--text-secondary);white-space:nowrap}.recent-cell-date,.recent-cell-road{font-family:var(--font-body);font-weight:600}.recent-cell-road{color:var(--text-primary)}.recent-cell-area{font-family:var(--font-body);color:var(--text-secondary);white-space:nowrap}.recent-view-btn:disabled{opacity:.4;cursor:not-allowed}.export-menu{position:relative;display:inline-flex}.export-menu-dropdown{position:absolute;top:calc(100% + 6px);right:0;z-index:40;min-width:220px;background:var(--bg-secondary,#1f1f1f);border:1px solid var(--border-strong,#2a2a2a);border-radius:6px;box-shadow:0 12px 28px rgba(0,0,0,.45);padding:6px;display:flex;flex-direction:column;gap:2px}.export-menu-toggle{display:flex;align-items:center;gap:8px;padding:10px;border-bottom:1px solid var(--border-strong,#2a2a2a);margin-bottom:4px;font-family:Arial,sans-serif;font-size:.82rem;letter-spacing:.02em;color:var(--text-primary,#f5f5f0);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.export-menu-toggle input[type=checkbox]{accent-color:#89BF4A;width:14px;height:14px;cursor:pointer}.export-menu-toggle-hint{margin-left:auto;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted,#888)}.export-menu-item{display:flex;align-items:center;gap:10px;padding:9px 10px;background:transparent;border:0;color:var(--text-primary,#f5f5f0);font-family:Arial,sans-serif;font-size:.85rem;cursor:pointer;border-radius:4px;text-align:left}.export-menu-item:focus-visible,.export-menu-item:hover{background:rgba(137,191,74,.12);color:#89BF4A;outline:none}.export-modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.68);z-index:100;display:flex;align-items:center;justify-content:center;padding:24px}.export-modal{width:100%;max-width:480px;background:var(--bg-primary,#1A1A1A);border:1px solid var(--border-strong,#2a2a2a);border-radius:8px;box-shadow:0 24px 60px rgba(0,0,0,.6);padding:22px 22px 18px}.export-modal-header{display:flex;align-items:center;gap:10px;font-family:Arial Black,Arial,sans-serif;font-size:.95rem;letter-spacing:.02em;text-transform:uppercase;color:#89BF4A;margin-bottom:12px}.export-modal-body{font-family:Arial,sans-serif;font-size:.88rem;line-height:1.55;color:var(--text-primary,#f5f5f0);margin:0 0 18px}.export-modal-actions{display:flex;justify-content:flex-end;gap:8px}.btn.btn-ghost{background:transparent;color:var(--text-primary,#f5f5f0);border:1px solid var(--border-strong,#2a2a2a)}.btn.btn-ghost:hover{border-color:#89BF4A;color:#89BF4A}