body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#0f0f0f;color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;transition:background-color .3s ease,color .3s ease}:root.light-mode body{background-color:#f8f9fa;color:#333}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{display:flex;flex-direction:column;min-height:100vh}.main-content{display:flex;flex:1 1;flex-direction:column}.app{text-align:center}.app-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.app-logo{animation:appLogoSpin 20s linear infinite}}.app-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.app-link{color:#61dafb}@keyframes appLogoSpin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}:root{--navbar-padding-y:0.75rem;--navbar-logo-height:70px;--navbar-total-height:calc(var(--navbar-padding-y)*2 + var(--navbar-logo-height));--page-content-offset:calc(var(--navbar-total-height) + 0.5rem)}@media (max-width:1366px){:root{--navbar-logo-height:70px}}@media (max-width:1024px){:root{--navbar-logo-height:50px;--navbar-padding-y:0.5rem}}@media (max-width:768px){:root{--navbar-logo-height:60px;--navbar-padding-y:1rem}}@media (max-width:480px){:root{--navbar-logo-height:50px;--navbar-padding-y:0.75rem}}.navbar{background:#1e1e1e;box-sizing:border-box;height:calc(1.5rem + 70px);height:var(--navbar-total-height);left:0;overflow:visible;padding:.75rem 2rem;padding:var(--navbar-padding-y) 2rem;position:fixed;top:0;width:100%;z-index:2000}:root.light-mode .navbar{background:#fff;border-bottom:1px solid #e5e5e5}.navbar .navbar-content{flex:1 1;height:100%;margin:0 auto;max-width:2000px}.navbar .navbar-content,.navbar .tg-nav-links{align-items:center;display:flex;justify-content:center}.navbar .tg-nav-links{flex-wrap:wrap;gap:2.5rem;list-style:none;margin:0;min-width:0;padding:0}.navbar .nav-item{cursor:pointer;font-family:Merge One,sans-serif;font-weight:500;min-width:0}.navbar .nav-item a{color:#fff;display:inline-block;position:relative;text-decoration:none;transition:color .15s ease;white-space:nowrap}:root.light-mode .navbar .nav-item a{color:#333}.navbar .nav-item.active a,.navbar .nav-item:hover a{color:#feac34}.navbar .nav-item a:after{background-color:#feac34;bottom:-4px;content:"";height:.5px;left:50%;position:absolute;transform:translateX(-50%);transition:width .2s ease;width:0}.navbar .nav-item.active a:after,.navbar .nav-item:hover a:after{width:100%}.navbar .logo-container{align-items:center;display:flex;height:100%;padding:0}.navbar .navbar-logo{display:block;height:70px;height:var(--navbar-logo-height);max-width:100%;object-fit:contain;width:auto}.navbar .icon-group{align-items:center;display:flex;flex-shrink:0;gap:1rem}.navbar .help-icon-container,.navbar .search-icon-container{align-items:center;display:flex;min-width:0}.navbar .help-icon,.navbar .search-icon{color:#fff;cursor:pointer;font-size:20px;transition:color .15s ease}:root.light-mode .navbar .help-icon,:root.light-mode .navbar .search-icon{color:#333}.navbar .help-icon:hover,.navbar .help-link.active .help-icon,.navbar .search-icon:hover{color:#feac34}@media (max-width:768px){.navbar .tg-nav-links{flex-direction:row;gap:1rem;justify-content:center;position:relative}.navbar .nav-item a{font-size:.9rem}.navbar .help-icon,.navbar .search-icon{font-size:18px}.navbar .icon-group{gap:.8rem}}@media screen and (max-width:1366px){.navbar{padding:.75rem 1rem;padding:var(--navbar-padding-y) 1rem}.navbar .tg-nav-links{gap:1.5rem}.navbar .nav-item a{font-size:.9rem}}@media screen and (max-width:1024px){.navbar{padding:.75rem .5rem;padding:var(--navbar-padding-y) .5rem}.navbar .tg-nav-links{gap:1rem}.navbar .logo-container{padding:.75rem}.navbar .nav-item a{font-size:.85rem}.navbar .help-icon{font-size:18px}}.global-alert-badge{align-items:flex-end;display:flex;flex-direction:column;gap:12px;pointer-events:none;position:fixed;right:20px;top:20px;z-index:9999}.global-alert-badge>*{pointer-events:all}.global-alerts-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#3b82f6,#1d4ed8);border:2px solid #fff3;border-radius:50%;box-shadow:0 4px 12px #3b82f666;color:#fff;cursor:pointer;display:flex;height:60px;justify-content:center;position:relative;transition:all .3s ease;width:60px}.global-alerts-btn:hover{background:linear-gradient(135deg,#2563eb,#1e40af);box-shadow:0 6px 20px #3b82f680;transform:scale(1.05)}.global-alerts-btn.has-alerts{animation:pulseAlerts 2s infinite;background:linear-gradient(135deg,#dc2626,#b91c1c)}.global-alerts-btn.has-alerts:hover{background:linear-gradient(135deg,#b91c1c,#991b1b)}.global-alerts-btn svg{height:26px;width:26px}.global-alert-count{animation:bounceIn .5s ease-out;background:linear-gradient(135deg,#ff8a5b,#feac34);border:2px solid #fff;border-radius:12px;box-shadow:0 2px 6px #0003;color:#1f2937;font-size:11px;font-weight:700;line-height:1;min-width:22px;padding:3px 7px;position:absolute;right:-8px;text-align:center;top:-8px}@keyframes pulseAlerts{0%,to{box-shadow:0 4px 12px #dc262666;transform:scale(1)}50%{box-shadow:0 6px 24px #dc262699;transform:scale(1.05)}}@keyframes bounceIn{0%{opacity:0;transform:scale(0)}50%{opacity:100%;transform:scale(1.2)}to{opacity:100%;transform:scale(1)}}.global-alert-panel-overlay{align-items:flex-start;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#0009;bottom:0;display:flex;justify-content:flex-end;left:0;padding:20px;position:fixed;right:0;top:0;z-index:9998}.global-alert-panel{animation:slideInRight .3s ease-out;background:#fff;border:1px solid #0000001a;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;max-height:80vh;max-width:450px;width:100%}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:100%;transform:translateX(0)}}.global-alert-panel-header{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e5e7eb;border-radius:16px 16px 0 0;display:flex;justify-content:space-between;padding:24px}.global-alert-panel-header h3{color:#1e293b;font-size:18px;font-weight:700;margin:0}.global-alert-panel-actions{align-items:center;display:flex;gap:12px}.btn-link-global{background:none;border:none;border-radius:4px;color:#3b82f6;cursor:pointer;font-size:12px;padding:4px 8px;text-decoration:underline;transition:all .2s ease}.btn-link-global:hover{background:#3b82f61a;color:#2563eb}.btn-close-global{align-items:center;background:none;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;justify-content:center;padding:6px;transition:all .2s ease}.btn-close-global:hover{background:#f1f5f9;color:#475569}.btn-close-global svg{height:18px;width:18px}.global-alert-panel-content{flex:1 1;overflow-y:auto;padding:0}.global-alerts-empty{align-items:center;color:#64748b;display:flex;flex-direction:column;justify-content:center;padding:60px 20px;text-align:center}.global-alerts-empty svg{height:64px;margin-bottom:16px;opacity:50%;width:64px}.global-alerts-empty p{color:#374151;font-size:16px;font-weight:600;margin:0 0 8px}.empty-subtitle{color:#6b7280!important;font-size:14px!important;margin-bottom:24px!important}.btn-view-all-incidents,.btn-view-incidents{background:linear-gradient(135deg,#3b82f6,#1d4ed8);border:none;border-radius:8px;box-shadow:0 2px 8px #3b82f64d;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s ease}.btn-view-all-incidents:hover,.btn-view-incidents:hover{background:linear-gradient(135deg,#2563eb,#1e40af);box-shadow:0 4px 12px #3b82f666;transform:translateY(-1px)}.global-alerts-list{padding:0}.global-alert-item{align-items:flex-start;border-bottom:1px solid #f1f5f9;display:flex;gap:16px;justify-content:space-between;padding:20px 24px;position:relative;transition:all .2s ease}.global-alert-item:last-child{border-bottom:none}.global-alert-item.unread{background:linear-gradient(135deg,#fefefe,#f8fafc);border-left:4px solid #3b82f6}.global-alert-item.unread:before{background:#3b82f6;border-radius:50%;box-shadow:0 0 0 3px #3b82f633;content:"";height:8px;left:12px;position:absolute;top:50%;transform:translateY(-50%);width:8px}.global-alert-item.acknowledged{background:#f8fafc;opacity:80%}.global-alert-item.severity-high{border-left-color:#dc2626}.global-alert-item.severity-high.unread:before{background:#dc2626;box-shadow:0 0 0 3px #dc262633}.global-alert-item.severity-medium{border-left-color:#ea580c}.global-alert-item.severity-medium.unread:before{background:#ea580c;box-shadow:0 0 0 3px #ea580c33}.global-alert-item.severity-low{border-left-color:#059669}.global-alert-item.severity-low.unread:before{background:#059669;box-shadow:0 0 0 3px #05966933}.global-alert-content{flex:1 1;min-width:0}.global-alert-header{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:12px}.global-alert-severity{border-radius:12px;font-size:12px;font-weight:700;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.global-alert-severity.high{background:#fee2e2;color:#dc2626}.global-alert-severity.medium{background:#fed7aa;color:#ea580c}.global-alert-severity.low{background:#d1fae5;color:#059669}.global-alert-time{color:#64748b;font-size:11px;font-weight:500;white-space:nowrap}.global-alert-id,.global-alert-location,.global-alert-reporter,.global-alert-status{color:#475569;font-size:13px;line-height:1.4}.global-alert-id{color:#1e293b;font-weight:600}.btn-acknowledge-global{align-items:center;background:#3b82f6;border:none;border-radius:8px;box-shadow:0 2px 4px #3b82f633;color:#fff;cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:8px;transition:all .2s ease}.btn-acknowledge-global:hover{background:#2563eb;box-shadow:0 4px 8px #3b82f64d;transform:scale(1.05)}.btn-acknowledge-global svg{height:16px;width:16px}.global-alert-panel-footer{background:#f8fafc;border-radius:0 0 16px 16px;border-top:1px solid #e5e7eb;padding:20px 24px}@media (max-width:768px){.global-alert-badge{gap:8px;right:15px;top:15px}.global-alerts-btn{height:50px;width:50px}.global-alerts-btn svg{height:22px;width:22px}.global-alert-panel-overlay{padding:10px}.global-alert-panel{max-height:90vh;max-width:100%}.global-alert-item,.global-alert-panel-header{padding:16px}}.alerts-panel-overlay~.global-alert-badge,.modal-overlay~.global-alert-badge,.video-modal-overlay~.global-alert-badge{display:none}@media (max-width:480px){.global-alert-badge{right:10px;top:10px;z-index:998}.global-alerts-btn{height:45px;width:45px}.global-alert-count{font-size:10px;min-width:18px;padding:2px 5px;right:-6px;top:-6px}}.data-attribution{background-color:var(--background-secondary);border-top:1px solid var(--border-color);color:var(--text-secondary);font-size:12px;margin-top:auto;opacity:80%;padding:8px 16px}.attribution-content{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:0 auto;max-width:1200px}.attribution-text{font-weight:500}.attribution-links{align-items:center;display:flex;gap:6px}.attribution-link{color:var(--primary-color);font-weight:500;text-decoration:none;transition:color .2s ease}.attribution-link:hover{color:var(--primary-hover-color);text-decoration:underline}.attribution-separator{color:var(--text-tertiary);font-weight:400}@media (max-width:768px){.data-attribution{font-size:11px;padding:6px 12px}.attribution-content{flex-direction:column;gap:4px;text-align:center}}.btn-primary{background:#feac34;border:2px solid #feac34;color:#000!important;font-weight:700;overflow:hidden;position:relative;transition:all .3s ease}.btn-primary:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .6s ease;width:100%}.btn-primary:hover:before{left:100%}.btn-primary:hover{background:#f79400;border-color:#f79400;box-shadow:0 12px 35px #feac3466;color:#000!important;transform:translateY(-3px)}.btn-secondary{background:#0000;border:2px solid #feac34;color:#feac34;overflow:hidden;position:relative;transition:all .3s ease}.btn-secondary:hover{background:#feac34;box-shadow:0 10px 30px #feac3466;color:#000!important;transform:translateY(-3px)}.landing-page{background-color:#121212!important;color:#fff!important;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh;width:100%}.landing-page *{box-sizing:border-box;margin:0;padding:0}.landing-page a,.landing-page div,.landing-page h1,.landing-page h2,.landing-page h3,.landing-page h4,.landing-page h5,.landing-page h6,.landing-page li,.landing-page p,.landing-page span,.landing-page ul{color:inherit}.landing-page .btn,.landing-page button{font-family:inherit}:root{--primary-dark:#121212;--secondary-dark:#1e1e1e;--accent-orange:#feac34;--accent-orange-dark:#f79400;--text-secondary:#ddd;--text-muted:#aaa;--card-dark:#1e1e1e;--gradient-orange:linear-gradient(135deg,#feac34,#f79400);--gradient-dark:linear-gradient(135deg,#121212,#1e1e1e)}.landing-page nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#121212fa;box-shadow:0 2px 10px #0000004d;padding:1rem 0;position:fixed;top:0;transition:all .3s ease;width:100%;z-index:1000}.landing-page nav.scrolled{background:#121212;box-shadow:0 5px 20px #00000080}.nav-container{justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 2rem}.logo,.nav-container{align-items:center;display:flex}.logo{gap:.5rem}.logo-img{height:50px;width:auto}.nav-links{align-items:center;display:flex;gap:2rem;list-style:none}.nav-links a{color:#ddd!important;font-weight:500;text-decoration:none;transition:color .3s}.nav-links a:hover{color:#feac34!important}.nav-btn{background:none;border:none;border-radius:25px;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:500;padding:.5rem 1.5rem;transition:all .3s}.nav-btn-login{border:2px solid #feac34;color:#feac34}.nav-btn-login:hover{background:#feac34;color:#000!important}.nav-btn-signup{background:linear-gradient(135deg,#feac34,#f79400);color:#000!important}.nav-btn-signup:hover{box-shadow:0 5px 15px #ff9d0066;transform:translateY(-2px)}.hamburger{background:none;border:none;cursor:pointer;display:none;flex-direction:column;padding:.5rem}.hamburger span{background:#feac34;height:3px;margin:3px 0;transition:.3s;width:25px}.hero{align-items:center;background:linear-gradient(#12121266,#12121299),url(/static/media/traffic_sunset.eef0bbc7fa77e220e700.jpg) 50%/cover no-repeat;display:flex;min-height:100vh;overflow:hidden;padding-top:80px;position:relative}.hero:before{background:#12121233;bottom:0;content:"";left:0;position:absolute;right:0;top:0;z-index:0}.hero-content{margin:0 auto;max-width:1200px;padding:0 2rem;position:relative;text-align:center;z-index:2}.hero h1{-webkit-text-fill-color:#0000;animation:fadeInUp 1s ease-out;background:linear-gradient(135deg,#feac34,#f79400);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(2px 2px 4px rgb(0 0 0/80%));font-size:clamp(2.5rem,5vw,4rem);margin-bottom:1.5rem}.hero-subtitle{animation:fadeInUp 1s ease-out .2s;animation-fill-mode:both;color:#f5f5f5;font-size:clamp(1.2rem,2vw,1.5rem);line-height:1.6;margin-bottom:2.5rem;margin-left:auto;margin-right:auto;max-width:800px;text-shadow:1px 1px 3px #000000b3}.cta-buttons{animation:fadeInUp 1s ease-out .4s;animation-fill-mode:both;display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center;margin-bottom:4rem}.auth-section{animation:fadeInUp 1s ease-out .6s;animation-fill-mode:both;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1e1e1ee6;border:1px solid #f7be014d;border-radius:15px;box-shadow:0 8px 32px #00000080;margin:3rem 0;overflow:hidden;padding:2.5rem;position:relative}.auth-section:before{background:linear-gradient(90deg,#feac34,#f79400);content:"";height:3px;left:0;position:absolute;top:0;width:100%}.auth-section:after{display:none}.auth-section h3{color:#fff!important;font-size:1.8rem;font-weight:600;margin-bottom:2rem;text-align:center}.auth-buttons{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center}.btn{border:2px solid #0000;border-radius:50px;cursor:pointer;display:inline-block;font-size:1.1rem;font-weight:600;overflow:hidden;padding:1rem 2.5rem;position:relative;text-decoration:none;transition:all .3s}.btn-login{background:#0000;border:2px solid #feac34;color:#feac34;font-size:1rem;font-weight:600;padding:.75rem 2rem;transition:all .3s ease}.btn-login:hover{box-shadow:0 8px 25px #ffb9004d;transform:translateY(-2px)}.btn-login:hover,.btn-signup{background:#feac34;color:#000!important}.btn-signup{border:2px solid #feac34;font-size:1rem;font-weight:600;padding:.75rem 2rem;transition:all .3s ease}.btn-signup:hover{background:#f79400;border-color:#f79400;box-shadow:0 8px 25px #feac3466;color:#000!important;transform:translateY(-2px)}.floating{animation:float 6s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.problem{background:#1e1e1e;padding:5rem 0;position:relative}.container{margin:0 auto;max-width:1200px;padding:0 2rem}.section-title{color:#fff!important;font-size:clamp(2rem,4vw,3rem);margin-bottom:1.5rem;text-align:center}.section-title span{color:#feac34!important}.problem .section-title,.solution .section-title{margin-bottom:2.5rem}.problem-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:1rem}.problem-card{background:#1e1e1e;border:1px solid #feac3433;border-radius:20px;opacity:0;padding:2rem;text-align:center;transform:translateY(30px);transition:all .3s}.problem-card.animate-in{animation:fadeInUp .6s ease-out forwards}.problem-card:hover{border-color:#feac34;box-shadow:0 20px 40px #feac3433;transform:translateY(-10px)}.problem-icon{align-items:center;background:linear-gradient(135deg,#feac34,#f79400);border-radius:50%;display:flex;font-size:2rem;height:80px;justify-content:center;margin:0 auto 1.5rem;width:80px}.problem-icon i{color:#000!important}.problem-card h3{color:#feac34!important;margin-bottom:1rem}.problem-card p{color:#aaa!important}.solution{background:#121212;padding:5rem 0}.solution-content{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr;margin-top:1rem}.solution-text h3{color:#feac34!important;font-size:2rem;margin-bottom:1rem}.solution-text p{color:#aaa!important;margin-bottom:2rem}.solution-text ul{list-style:none;padding:0}.solution-text li{color:#ddd!important;padding:.5rem 0}.solution-text li:before{color:#feac34!important;content:"✓ ";font-weight:700;margin-right:.5rem}.solution-visual{background:#1e1e1e;border:2px solid #feac34;border-radius:20px;display:inline-block;height:auto;overflow:hidden;position:relative;width:auto}.demo-video{border-radius:18px;display:block;height:auto;max-width:100%;width:auto}.solution-visual:after{background:linear-gradient(135deg,#feac34,#f79400);border-radius:20px;color:#000!important;content:"Live Detection Demo";font-weight:600;left:20px;padding:.5rem 1rem;position:absolute;top:20px}.demo-placeholder{color:#ddd;text-align:center}.features{background:#1e1e1e;padding:5rem 0}.features-grid{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:1rem}.feature-card{background:#1e1e1e;border:1px solid #0000;border-radius:20px;opacity:0;overflow:hidden;padding:2.5rem;position:relative;transform:translateY(30px);transition:all .3s}.feature-card.animate-in{animation:fadeInUp .6s ease-out forwards}.feature-card:before{background:linear-gradient(135deg,#feac34,#f79400);content:"";height:3px;left:0;position:absolute;top:0;width:100%}.feature-card:hover{border-color:#feac34;box-shadow:0 20px 50px #feac3433;transform:translateY(-5px)}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-icon i{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#feac34,#f79400);-webkit-background-clip:text;background-clip:text}.feature-title{color:#fff!important;font-size:1.5rem;margin-bottom:1rem}.feature-card p{color:#aaa!important}.tech-stack{background:#121212;padding:5rem 0;text-align:center}.tech-logos{align-items:center;display:flex;flex-wrap:wrap;gap:3rem;justify-content:center;margin-top:3rem}.tech-item{background:#1e1e1e;border:1px solid #feac344d;border-radius:15px;color:#ddd!important;font-weight:600;padding:1.5rem 2rem;transition:all .3s}.tech-item:hover{background:linear-gradient(135deg,#feac34,#f79400);border-color:#0000;color:#000!important;transform:translateY(-5px)}.team{background:#1e1e1e;padding:5rem 0}.team-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:3rem}.team-member-link{color:inherit;display:block;text-decoration:none}.team-member{background:#1e1e1e;border:1px solid #0000;border-radius:20px;cursor:pointer;opacity:0;padding:2rem;text-align:center;transform:translateY(30px);transition:all .3s}.team-member.animate-in{animation:fadeInUp .6s ease-out forwards}.team-member-link:hover .team-member{border-color:#feac34;box-shadow:0 20px 50px #feac3433;transform:translateY(-10px)}.member-avatar{align-items:center;background:linear-gradient(135deg,#feac34,#f79400);border-radius:50%;color:#000!important;display:flex;font-size:2rem;font-weight:700;height:100px;justify-content:center;margin:0 auto 1rem;width:100px}.team-member h4{color:#fff!important;margin-bottom:.5rem}.team-member p{color:#feac34!important;font-size:.9rem;margin-bottom:0}.final-cta{align-items:center;background:linear-gradient(135deg,#feac34,#f79400);color:#000!important;display:flex;flex-direction:column;justify-content:center;padding:5rem 0;text-align:center}.final-cta h2{font-size:clamp(2rem,4vw,3rem);margin-bottom:1.5rem}.final-cta .btn-primary{background:#121212;border:2px solid #121212;color:#fff!important;display:inline-block;font-size:.85rem;margin:0 auto;max-width:200px;padding:.5rem 1.2rem}.final-cta .btn-primary:hover{background:#1e1e1e;color:#fff!important}.landing-page footer{background:#121212;border-top:1px solid #feac3433;color:#ddd!important;padding:2rem 0;text-align:center}.landing-page footer a{color:#feac34!important;text-decoration:none}.aws-badge{background:#ffffff1a;border:1px solid #feac344d;border-radius:5px;color:#ddd!important;display:inline-block;font-weight:700;margin-top:1rem;padding:.5rem 1rem}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:100%;transform:translateY(0)}}@media (max-width:768px){.hamburger{display:flex!important}.nav-links{background:#1e1e1e;background:var(--secondary-dark);display:none;flex-direction:column;gap:1rem;left:0;padding:1rem 0;position:absolute;top:100%;width:100%}.nav-links.active{display:flex}.solution-content{grid-template-columns:1fr}.auth-buttons,.cta-buttons{align-items:center;flex-direction:column}.btn{max-width:300px;width:100%}.tech-logos{gap:1rem}.tech-item{font-size:.9rem;padding:1rem 1.5rem}.hero-stats{gap:2rem}.stat-number{font-size:2rem}.impact-grid,.process-timeline{grid-template-columns:1fr}.details-grid{grid-template-columns:repeat(2,1fr)}.contact-info{gap:1rem}.section-title{font-size:2rem}}.pems-analysis{background:var(--stat-card-bg);border:2px solid var(--stat-card-border);border-radius:12px;box-shadow:0 4px 12px #0000001a;margin-bottom:24px;padding:24px}.pems-analysis.loading{align-items:center;color:var(--subtitle-color);display:flex;flex-direction:column;justify-content:center;min-height:400px}.pems-analysis.loading .loading-spinner{animation:spin 1s linear infinite;border:3px solid var(--progress-bar-bg);border-radius:50%;border-top-color:var(--title-color);height:40px;margin-bottom:16px;width:40px}.pems-analysis.error{align-items:center;color:var(--severity-critical-text);display:flex;flex-direction:column;justify-content:center;min-height:400px;text-align:center}.pems-analysis.error svg{height:48px;margin-bottom:16px;width:48px}.pems-analysis.error .retry-btn{background:var(--button-primary-bg);border:none;border-radius:6px;color:var(--button-primary-text);cursor:pointer;font-weight:500;margin-top:16px;padding:12px 24px;transition:background-color .2s ease}.pems-analysis.error .retry-btn:hover{background:var(--button-primary-hover)}.pems-header{align-items:flex-start;border-bottom:2px solid var(--header-border);display:flex;justify-content:space-between;margin-bottom:32px;padding-bottom:20px}.pems-title-section h2{color:var(--title-color);font-size:1.8rem;font-weight:700;margin:0 0 8px}.pems-region{align-items:center;display:flex;gap:12px}.district-badge{background:var(--title-color);border-radius:20px;color:var(--button-primary-text);font-size:.85rem;font-weight:600;padding:4px 12px}.region-name{color:var(--subtitle-color);font-size:1rem;font-weight:500}.pems-status{align-items:flex-end;display:flex;flex-direction:column;gap:8px}.system-status{border-radius:20px;font-size:.9rem;font-weight:600;gap:8px;padding:6px 12px}.system-status .status-indicator{border-radius:50%;height:10px;width:10px}.system-status.health-good{background:var(--severity-low-bg);color:var(--severity-low-text)}.system-status.health-good .status-indicator{background:var(--severity-low-text)}.system-status.health-warning{background:var(--severity-medium-bg);color:var(--severity-medium-text)}.system-status.health-warning .status-indicator{background:var(--severity-medium-text)}.system-status.health-critical{background:var(--severity-critical-bg);color:var(--severity-critical-text)}.system-status.health-critical .status-indicator{background:var(--severity-critical-text)}.pems-metrics{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:32px}.metric-card{align-items:center;background:var(--user-card-bg);border:1px solid var(--user-card-border);border-radius:8px;display:flex;gap:16px;padding:20px;transition:all .2s ease}.metric-card:hover{box-shadow:0 6px 16px #0000001a;transform:translateY(-2px)}.metric-card.risk-critical{border-left:4px solid var(--severity-critical-text)}.metric-card.risk-high{border-left:4px solid #feac34}.metric-card.risk-medium{border-left:4px solid var(--severity-medium-text)}.metric-card.risk-low{border-left:4px solid var(--severity-low-text)}.metric-icon{background:var(--stat-card-icon-bg);border-radius:8px;padding:12px}.metric-icon svg{color:var(--title-color);height:24px;width:24px}.metric-value{color:var(--text-color);font-size:1.8rem;margin-bottom:4px}.metric-label{color:var(--text-color);font-size:.9rem;margin-bottom:2px}.metric-subtitle{color:var(--subtitle-color);font-size:.8rem}.pems-tabs{background:var(--content-bg);border-radius:8px;display:flex;gap:2px;margin-bottom:24px;padding:4px}.pems-tabs button{background:#0000;border:none;border-radius:6px;color:var(--subtitle-color);cursor:pointer;flex:1 1;font-weight:500;padding:12px 16px;transition:all .2s ease}.pems-tabs button:hover{background:var(--user-card-hover-shadow);color:var(--text-color)}.pems-tabs button.tab-active{background:var(--title-color);box-shadow:0 2px 8px #00000026;color:var(--button-primary-text)}.pems-content{min-height:400px}.overview-section{grid-gap:24px;display:grid;gap:24px;grid-template-columns:2fr 1fr}.critical-areas h3,.risk-distribution h3{color:var(--text-color);font-size:1.2rem;font-weight:600;margin-bottom:16px}.critical-areas-list{display:flex;flex-direction:column;gap:12px}.critical-area-card{background:var(--incident-item-bg);border:1px solid var(--incident-item-border);border-left:4px solid var(--severity-medium-text);border-radius:8px;padding:16px}.critical-area-card.risk-critical{border-left-color:var(--severity-critical-text)}.critical-area-card.risk-high{border-left-color:#feac34}.area-header{margin-bottom:12px}.freeway-name{color:var(--text-color);font-size:1.1rem;font-weight:700}.risk-badge{background:var(--severity-critical-bg);color:var(--severity-critical-text);padding:4px 8px}.area-metrics{grid-gap:8px;color:var(--subtitle-color);display:grid;font-size:.9rem;gap:8px;grid-template-columns:repeat(2,1fr)}.no-alerts,.no-critical-areas,.no-high-risk{color:var(--subtitle-color);font-size:1.1rem;padding:60px 20px;text-align:center}.risk-bars{flex-direction:column}.risk-bar,.risk-bars{display:flex;gap:12px}.risk-bar{align-items:center}.risk-label{display:flex;flex-direction:column;font-size:.9rem;min-width:120px}.risk-label span:first-child{color:var(--text-color);font-weight:600}.risk-label span:last-child{color:var(--subtitle-color);font-size:.8rem}.risk-progress{background:var(--progress-bar-bg);border-radius:4px;flex:1 1;height:8px;overflow:hidden}.risk-fill{height:100%;transition:width .3s ease}.risk-fill.risk-critical{background:var(--severity-critical-text)}.risk-fill.risk-high{background:#feac34}.risk-fill.risk-medium{background:var(--severity-medium-text)}.risk-fill.risk-low{background:var(--severity-low-text)}.risk-percentage{color:var(--text-color);font-size:.9rem;font-weight:600;min-width:50px;text-align:right}.alerts-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.alerts-header h3{color:var(--text-color);font-size:1.2rem;font-weight:600;margin:0}.alert-summary{display:flex;gap:16px}.priority-count{border-radius:12px;font-size:.85rem;font-weight:600;padding:4px 12px}.priority-count.high{background:var(--severity-critical-bg);color:var(--severity-critical-text)}.priority-count.medium{background:var(--severity-medium-bg);color:var(--severity-medium-text)}.priority-count.low{background:var(--severity-low-bg);color:var(--severity-low-text)}.alerts-list{display:flex;flex-direction:column;gap:16px;max-height:600px;overflow-y:auto}.alert-card{background:var(--incident-item-bg);border:1px solid var(--incident-item-border);border-radius:8px;cursor:pointer;padding:16px;transition:all .2s ease}.alert-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-1px)}.alert-card.priority-high{border-left:4px solid var(--severity-critical-text)}.alert-card.priority-medium{border-left:4px solid var(--severity-medium-text)}.alert-card.priority-low{border-left:4px solid var(--severity-low-text)}.alert-header{justify-content:space-between;margin-bottom:12px}.alert-header,.alert-info{align-items:center;display:flex}.alert-info{gap:12px}.freeway-direction{color:var(--text-color);font-weight:600}.alert-meta{align-items:center;display:flex;gap:12px}.priority-badge{background:var(--severity-critical-bg);border-radius:4px;color:var(--severity-critical-text);font-size:.75rem;font-weight:600;padding:2px 8px}.risk-score{color:var(--subtitle-color);font-size:.9rem;font-weight:500}.alert-message{color:var(--text-color);line-height:1.5;margin-bottom:12px}.alert-action{background:var(--timeline-item-bg);border-radius:6px;color:var(--text-color);font-size:.9rem;margin-bottom:8px;padding:10px}.alert-timestamp{color:var(--subtitle-color);font-size:.8rem;text-align:right}.detectors-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));max-height:600px;overflow-y:auto}.detector-card{background:var(--incident-item-bg);border:1px solid var(--incident-item-border);border-radius:8px;cursor:pointer;padding:16px;transition:all .2s ease}.detector-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.detector-card.risk-critical{border-left:4px solid var(--severity-critical-text)}.detector-card.risk-high{border-left:4px solid #feac34}.detector-card.risk-medium{border-left:4px solid var(--severity-medium-text)}.detector-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.detector-card .detector-id{color:var(--title-color);font-family:monospace;font-weight:700}.risk-level-badge{background:var(--severity-critical-bg);border-radius:4px;color:var(--severity-critical-text);font-size:.7rem;font-weight:600;padding:2px 6px}.detector-location{color:var(--subtitle-color);font-size:.9rem;margin-bottom:12px}.detector-metrics{display:flex;flex-direction:column;gap:4px}.metric-row{align-items:center;display:flex;font-size:.9rem;justify-content:space-between}.metric-row span:first-child{color:var(--subtitle-color)}.metric-row span:last-child{color:var(--text-color);font-weight:500}.metric-warning{color:var(--severity-critical-text)!important;font-weight:600!important}.risk-score-value{color:var(--title-color)!important;font-weight:700!important}.recommendations-list{display:flex;flex-direction:column;gap:16px}.recommendation-card{background:var(--incident-item-bg);border:1px solid var(--incident-item-border);border-radius:8px;padding:20px}.recommendation-card.priority-high{border-left:4px solid var(--severity-critical-text)}.recommendation-card.priority-medium{border-left:4px solid var(--severity-medium-text)}.recommendation-card.priority-low{border-left:4px solid var(--severity-low-text)}.recommendation-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.rec-type{color:var(--text-color);font-weight:700;text-transform:capitalize}.rec-priority{background:var(--severity-medium-bg);border-radius:4px;color:var(--severity-medium-text);font-size:.75rem;font-weight:600;padding:4px 8px}.recommendation-message{color:var(--text-color);line-height:1.5;margin-bottom:16px}.recommendation-actions{color:var(--text-color)}.recommendation-actions ul{margin-top:8px;padding-left:20px}.recommendation-actions li{color:var(--subtitle-color);margin-bottom:4px}.pems-footer{align-items:center;border-top:1px solid var(--header-border);display:flex;justify-content:space-between;margin-top:24px;padding-top:16px}.refresh-btn{background:var(--button-primary-bg);border:none;border-radius:6px;color:var(--button-primary-text);cursor:pointer;font-weight:500;padding:10px 20px;transition:background-color .2s ease}.refresh-btn:hover{background:var(--button-primary-hover)}.data-source{color:var(--subtitle-color);font-size:.85rem}@media (max-width:1024px){.pems-metrics{grid-template-columns:repeat(2,1fr)}.overview-section{gap:32px;grid-template-columns:1fr}.detectors-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (max-width:768px){.pems-analysis{padding:16px}.pems-header{align-items:flex-start;flex-direction:column;gap:16px}.pems-metrics{grid-template-columns:1fr}.pems-tabs{flex-direction:column}.detectors-grid{grid-template-columns:1fr}.alerts-header{align-items:flex-start;flex-direction:column;gap:12px}.alert-summary{justify-content:flex-start;width:100%}}@media (max-width:480px){.area-metrics{grid-template-columns:1fr}.alert-header{align-items:flex-start;flex-direction:column;gap:8px}.pems-footer{flex-direction:column;gap:12px;text-align:center}}.alerts-list::-webkit-scrollbar,.detectors-grid::-webkit-scrollbar{width:6px}.alerts-list::-webkit-scrollbar-track,.detectors-grid::-webkit-scrollbar-track{background:var(--scrollbar-track)}.alerts-list::-webkit-scrollbar-thumb,.detectors-grid::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:3px}.alerts-list::-webkit-scrollbar-thumb:hover,.detectors-grid::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}.loading-spinner-container{flex-direction:column;padding:20px}.loading-spinner{border:3px solid #f3f3f3;border-top-color:#d97700;border-top:3px solid var(--title-color,#d97700)}.loading-spinner.small{border-width:2px;height:20px;width:20px}.loading-spinner.medium{border-width:3px;height:40px;width:40px}.loading-spinner.large{border-width:4px;height:60px;width:60px}.loading-text{color:#666;color:var(--subtitle-color,#666);font-size:14px;font-weight:500;margin-top:12px}.loading-spinner-container.fullscreen{background:#fffc;bottom:0;left:0;min-height:100vh;position:fixed;right:0;top:0;z-index:9999}.loading-spinner-container.content{align-items:center;background:#0000;display:flex;flex-direction:column;justify-content:center;min-height:50vh;padding:60px 20px}.loading-spinner-container.inline{min-height:auto;padding:10px}.weekly-traffic-trends{background:var(--card-background);border-radius:12px;box-shadow:0 4px 6px #0000001a;margin-bottom:1.5rem;padding:1.5rem}.trends-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.trends-title h3{align-items:center;color:var(--text-primary);display:flex;font-size:1.4rem;font-weight:600;gap:.5rem;margin:0 0 .5rem}.public-badge{background:#feac34;border-radius:16px;color:#fff;font-size:.75rem;font-weight:500;padding:.2rem .6rem}.trends-subtitle{color:var(--text-secondary);font-size:.9rem;margin:0}.trends-controls{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.chart-type-selector,.metric-selector{align-items:center;display:flex;gap:.5rem}.chart-type-selector label,.metric-selector label{color:var(--text-secondary);font-size:.9rem;font-weight:500}.chart-type-selector select,.metric-selector select{background:var(--input-background);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:.9rem;padding:.5rem}.trends-error{background:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;margin-bottom:1rem;padding:1rem;text-align:center}.trends-error p{color:#856404;margin:0 0 .5rem}.retry-btn{background:#f79400;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:.5rem 1rem}.retry-btn:hover{background:#d04a1e}.trends-chart{margin:1.5rem 0;min-height:400px}.trends-insights{border-top:1px solid var(--border-color);margin-top:2rem;padding-top:1.5rem}.trends-insights h4{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin:0 0 1rem}.insights-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.day-insight{background:var(--secondary-background);border:1px solid var(--border-color);border-radius:8px;padding:1rem}.day-insight h5{color:var(--text-primary);font-size:1rem;font-weight:600;margin:0 0 .75rem;text-align:center}.insight-metrics{display:flex;flex-direction:column;gap:.5rem}.metric{align-items:center;display:flex;justify-content:space-between}.metric-label{color:var(--text-secondary);font-size:.85rem}.metric-value{color:var(--text-primary);font-size:.9rem;font-weight:600}.upgrade-notice{background:linear-gradient(135deg,#f79400,#feac34);border-radius:8px;color:#fff;margin-top:1.5rem;padding:1rem;text-align:center}.upgrade-notice p{font-size:.95rem;margin:0}.upgrade-notice a{color:#fff;font-weight:600;margin:0 .25rem;text-decoration:underline}.upgrade-notice a:hover{text-decoration:none}.dark-mode .weekly-traffic-trends{--card-background:#2d2d2d;--text-primary:#fff;--text-secondary:#b0b0b0;--border-color:#404040;--input-background:#3d3d3d;--secondary-background:#3d3d3d}.light-mode .weekly-traffic-trends{--card-background:#fff;--text-primary:#333;--text-secondary:#666;--border-color:#e0e0e0;--input-background:#fff;--secondary-background:#f8f9fa}@media (max-width:768px){.trends-header{align-items:stretch;flex-direction:column}.trends-controls{justify-content:space-between}.insights-grid{grid-template-columns:1fr}.weekly-traffic-trends{padding:1rem}}@media (max-width:480px){.trends-controls{align-items:stretch;flex-direction:column}.chart-type-selector,.metric-selector{justify-content:space-between}}.event-item-simple{background:var(--background-color);border-bottom:1px solid var(--header-border);font-family:Courier New,monospace;font-size:.9em;padding:12px 16px;transition:background-color .2s ease}.event-item-simple:hover{background:var(--camera-item-hover-bg)}.event-item-simple .event-timestamp{color:var(--subtitle-color);font-size:.8em;margin-bottom:4px}.event-item-simple .event-text{color:var(--text-color);word-break:break-word}.event-item-formatted{background:var(--background-color);border-bottom:1px solid var(--header-border);padding:16px;transition:background-color .2s ease}.event-item-formatted:hover{background:var(--camera-item-hover-bg)}.event-item-formatted:last-child{border-bottom:none}.event-header{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;margin-bottom:12px}.event-timestamp{background:var(--stat-card-icon-bg);border-radius:4px;color:var(--title-color);font-family:Courier New,monospace;font-size:.85em;font-weight:600;padding:4px 8px}.event-location{color:var(--text-color);font-size:.95em;font-weight:600}.location-label{color:var(--text-color);font-weight:500;margin-right:4px}.incidents-summary{margin-bottom:12px}.incidents-count{background:var(--severity-medium-bg);border-radius:16px;display:inline-block;font-size:.85em;font-weight:600;padding:6px 12px}.incidents-list{display:flex;flex-direction:column;gap:8px}.incident-card{background:var(--stat-card-bg);border:1px solid var(--incident-item-border);border-radius:8px;padding:12px;transition:all .2s ease}.incident-card:hover{border-color:var(--stat-card-border);box-shadow:0 2px 8px var(--stat-card-hover-shadow)}.incident-type{gap:8px;margin-bottom:8px}.incident-category{color:var(--text-color);font-size:.9em;font-weight:600}.incident-severity{align-items:center;display:flex;gap:6px;margin-bottom:8px}.severity-indicator{font-size:1.2em;font-weight:700;margin-right:4px}.severity-indicator.severity-low{color:#22c55e}.severity-indicator.severity-medium{color:#f59e0b}.severity-indicator.severity-critical{color:#dc2626}.severity-indicator.severity-unknown{color:#6b7280}.severity-text{color:var(--text-color);font-size:.85em;font-weight:500}.incident-icon{font-size:1.2em;font-weight:700;margin-right:6px}.incident-icon.icon-road-works{color:#f59e0b}.incident-icon.icon-slow-traffic{color:#eab308}.incident-icon.icon-heavy-traffic{color:#ef4444}.incident-icon.icon-accident{color:#dc2626}.incident-icon.icon-closure{color:#7c2d12}.incident-icon.icon-default{color:var(--title-color)}.incident-description{color:var(--text-color);font-size:.85em;font-style:italic;margin-bottom:6px}.incident-coordinates{color:var(--text-color);font-family:Courier New,monospace;font-size:.75em;font-weight:500}[data-theme=dark] .event-item-formatted,[data-theme=dark] .event-item-simple{border-bottom-color:var(--header-border)}[data-theme=dark] .incident-card{background:var(--content-bg);border-color:var(--incident-item-border)}@media (max-width:768px){.event-item-formatted{padding:12px}.event-header{align-items:flex-start;flex-direction:column;gap:6px}.incident-card{padding:10px}.incident-severity,.incident-type{flex-wrap:wrap;gap:6px}.event-timestamp{font-size:.8em;padding:3px 6px}.event-location{font-size:.9em}.incidents-count{font-size:.8em;padding:4px 10px}}.incident-card:focus-within{outline:2px solid var(--title-color);outline-offset:2px}.event-item-formatted:focus-within,.event-item-simple:focus-within{background:var(--camera-item-hover-bg)}@keyframes slideInEvent{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.event-item-formatted,.event-item-simple{animation:slideInEvent .3s ease-out}.camera-carousel-container{animation:fadeIn .5s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:var(--stat-card-bg);border:1px solid var(--stat-card-border);border-radius:16px;box-shadow:0 8px 32px #0000001f;display:flex;flex-direction:column;margin-bottom:2rem;min-height:400px;overflow:hidden;transition:all .3s ease}.camera-carousel-container:hover{box-shadow:0 12px 48px #00000026;transform:translateY(-2px)}.camera-carousel-header{align-items:center;background-color:var(--incidents-header-bg);color:var(--incidents-header-text);display:flex;justify-content:space-between;padding:1rem 1.5rem}.camera-carousel-header h3{align-items:center;display:flex;font-size:1.2rem;font-weight:600;gap:.5rem;margin:0}.camera-carousel-subtitle{color:#ffffffe6;font-size:.85rem;opacity:90%}.camera-carousel-error,.camera-carousel-loading{align-items:center;display:flex;justify-content:center;padding:4rem 2rem}.camera-carousel-error{flex-direction:column;text-align:center}.camera-carousel-error .error-icon{margin-bottom:1rem;opacity:50%}.error-icon svg{color:var(--subtitle-color);height:64px;width:64px}.camera-carousel-error .error-message{color:var(--subtitle-color);font-size:.9rem}.camera-carousel-wrapper{display:flex;flex:1 1;flex-direction:column;padding:1.5rem}.camera-carousel{background:var(--content-bg);border-radius:8px;flex:1 1;margin-bottom:1rem;overflow:hidden;position:relative}.camera-slide-container{aspect-ratio:4/3;display:flex;height:280px;transition:transform .5s cubic-bezier(.4,0,.2,1);width:100%}.camera-slide{min-width:100%;position:relative;transition:transform .5s ease-in-out}.camera-image-container{background:linear-gradient(135deg,#667eea,#764ba2);overflow:hidden;position:relative}.camera-image,.camera-image-container{border-radius:12px;height:100%;width:100%}.camera-image{object-fit:cover;object-position:center;transition:transform .4s cubic-bezier(.4,0,.2,1)}.camera-image:hover{transform:scale(1.03)}.camera-image-placeholder{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:linear-gradient(135deg,#667eea1a,#764ba21a);border:2px dashed #fff3;border-radius:12px;display:flex;flex-direction:column;height:100%;justify-content:center;width:100%}.placeholder-icon{margin-bottom:1rem;opacity:60%}.placeholder-icon svg{color:var(--subtitle-color);height:48px;width:48px}.placeholder-text{color:var(--subtitle-color);font-size:.9rem;text-align:center}.camera-overlay{align-items:flex-end;background:linear-gradient(#0000,#000000d9);bottom:0;color:#fff;display:flex;justify-content:space-between;left:0;padding:2rem 1.5rem 1.5rem;position:absolute;right:0}.camera-info{flex:1 1}.camera-location{font-size:1.1rem;font-weight:600;margin-bottom:.25rem;text-shadow:0 1px 2px #00000080}.camera-route{font-size:.85rem;margin-bottom:.5rem;opacity:90%}.traffic-count{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffff26;border:1px solid #ffffff1a;border-radius:8px;display:inline-flex;font-size:.9rem;font-weight:600;gap:.5rem;padding:.5rem .75rem;transition:all .2s ease}.traffic-count svg{height:16px;opacity:90%;width:16px}.traffic-count:hover{background:#ffffff40;transform:translateY(-1px)}.camera-status{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:4px;display:flex;font-size:.8rem;font-weight:500;gap:.5rem;padding:.25rem .75rem;text-transform:capitalize}.camera-status.online{background:#22c55e33;border:1px solid #22c55e4d;color:#22c55e}.camera-status.offline{background:#ef444433;border:1px solid #ef44444d;color:#ef4444}.status-dot{background:currentcolor;height:8px;width:8px}.carousel-nav{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border:1px solid #fff3;border-radius:50%;box-shadow:0 4px 16px #0000001a;color:#333;cursor:pointer;display:flex;height:48px;justify-content:center;position:absolute;top:50%;transform:translateY(-50%);transition:all .3s cubic-bezier(.4,0,.2,1);width:48px;z-index:10}.carousel-nav:hover{background:#fff;box-shadow:0 8px 24px #00000026;transform:translateY(-50%) scale(1.1)}.carousel-nav svg{height:18px;width:18px}.carousel-nav.prev{left:10px}.carousel-nav.next{right:10px}.camera-carousel-indicators{background:#0000;display:flex;gap:.5rem;justify-content:center;padding:2rem 1.5rem}.carousel-indicator{background:#ffffff80;border:none;border-radius:50%;cursor:pointer;height:4px!important;margin:0;max-height:4px!important;max-width:4px!important;min-height:4px!important;min-width:4px!important;padding:0;transition:all .2s ease;width:4px!important}.carousel-indicator:hover{background:#fffc}.carousel-indicator.active{background:var(--title-color)}@media (max-width:768px){.camera-carousel-container:hover{transform:none}.camera-carousel-header{flex-direction:column;gap:.5rem;padding:1rem;text-align:center}.camera-slide-container{height:280px}.camera-overlay{padding:1.5rem 1rem 1rem}.camera-location{font-size:1rem}.camera-route{font-size:.8rem}.carousel-nav{height:40px;width:40px}.carousel-nav svg{height:16px;width:16px}.camera-carousel-indicators{padding:1rem}}@media (max-width:480px){.camera-carousel-wrapper{padding:1rem}.camera-slide-container{height:200px}.camera-overlay{padding:.75rem .5rem .5rem}.camera-location{font-size:.9rem}.camera-status{font-size:.75rem;padding:.2rem .5rem}.traffic-count{font-size:.8rem}}[data-theme=dark] .camera-carousel-container{background-color:var(--stat-card-bg);border-color:var(--stat-card-border)}[data-theme=dark] .camera-image-placeholder{background:linear-gradient(135deg,var(--incident-item-bg),var(--camera-item-bg));border-color:var(--incident-item-border)}.camera-carousel-loading .loading-spinner{color:var(--title-color)}.camera-slide:hover .camera-image{transform:scale(1.02)}.camera-slide:hover .camera-overlay{background:linear-gradient(#0000,#000000e6)}.archive-summary-container{animation:fadeIn .5s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:var(--stat-card-bg);border:1px solid var(--stat-card-border);border-radius:16px;box-shadow:0 8px 32px #0000001f;display:flex;flex-direction:column;min-height:400px;overflow:hidden;transition:all .3s ease}.archive-summary-container:hover{box-shadow:0 12px 48px #00000026;transform:translateY(-2px)}.archive-summary-header{align-items:center;background-color:var(--incidents-header-bg);color:var(--incidents-header-text);display:flex;justify-content:space-between;padding:1rem 1.5rem}.archive-summary-header h3{align-items:center;display:flex;font-size:1.2rem;font-weight:600;gap:.5rem;margin:0}.archive-summary-subtitle{color:#ffffffe6;font-size:.85rem;opacity:90%}.archive-summary-error,.archive-summary-loading{align-items:center;display:flex;justify-content:center;padding:4rem 2rem}.archive-summary-error{flex-direction:column;text-align:center}.archive-summary-error .error-icon{margin-bottom:1rem;opacity:50%}.archive-summary-error .error-icon svg{color:var(--subtitle-color);height:64px;width:64px}.archive-summary-error .error-message{color:var(--subtitle-color);font-size:.9rem}.archive-summary-content{display:flex;flex:1 1;flex-direction:column;gap:2rem;overflow-y:auto;padding:1.5rem}.summary-metrics{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}.metric-item{align-items:center;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;display:flex;gap:1rem;padding:1rem;transition:all .2s ease}.metric-item:hover{background:#ffffff14;transform:translateY(-1px)}.metric-icon{align-items:center;border-radius:10px;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.metric-icon svg{height:20px;width:20px}.metric-icon.total{background:var(--stat-card-icon-bg);color:var(--title-color)}.metric-icon.recent{background:#6666661a;color:var(--subtitle-color)}.metric-icon.critical{background:var(--severity-critical-bg);color:var(--severity-critical-text)}.metric-icon.resolved{background:var(--status-monitoring-bg);color:var(--status-monitoring-text)}.metric-content{flex:1 1;min-width:0}.metric-value{color:var(--title-color);font-size:1.5rem;line-height:1}.metric-label{color:var(--subtitle-color);font-size:.8rem;font-weight:500}.summary-categories{display:flex;flex-direction:column;gap:1.5rem}.category-section h4{align-items:center;color:var(--title-color);display:flex;font-size:1rem;font-weight:600;gap:.5rem;margin:0 0 1rem}.category-list{display:flex;flex-direction:column;gap:.75rem}.category-item{align-items:center;background:#ffffff08;border:1px solid #ffffff0d;border-radius:8px;display:flex;gap:1rem;padding:.75rem 1rem;transition:all .2s ease}.category-item:hover{background:#ffffff0f;border-color:#ffffff1a}.category-rank{align-items:center;background:var(--title-color);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.8rem;font-weight:600;height:24px;justify-content:center;width:24px}.severity-indicator{border-radius:50%;flex-shrink:0;height:12px;width:12px}.severity-indicator.critical,.severity-indicator.high{background:var(--severity-critical-text);box-shadow:0 0 8px #f446}.severity-indicator.medium{background:var(--severity-medium-text);box-shadow:0 0 8px #d9770066}.severity-indicator.low{background:var(--severity-low-text);box-shadow:0 0 8px #19901966}.category-content{align-items:center;display:flex;flex:1 1;justify-content:space-between;min-width:0}.category-name{color:var(--title-color);font-size:.9rem;font-weight:500;text-transform:capitalize}.category-count{background:#ffffff1a;border-radius:4px;color:var(--subtitle-color);font-size:.85rem;font-weight:600;min-width:-webkit-fit-content;min-width:fit-content;padding:.25rem .5rem}@media (max-width:768px){.archive-summary-container:hover{transform:none}.archive-summary-header{flex-direction:column;gap:.5rem;padding:1rem;text-align:center}.archive-summary-content{gap:1.5rem;padding:1rem}.summary-metrics{gap:.75rem;grid-template-columns:1fr}.metric-item{padding:.75rem}.metric-value{font-size:1.25rem}}@media (max-width:480px){.summary-categories{gap:1rem}.category-item{padding:.5rem .75rem}.metric-icon{height:32px;width:32px}.metric-icon svg{height:16px;width:16px}}[data-theme=dark] .archive-summary-container{background-color:var(--stat-card-bg);border-color:var(--stat-card-border)}[data-theme=dark] .metric-item{background:#ffffff08;border-color:#ffffff0d}[data-theme=dark] .category-item{background:#ffffff05;border-color:#ffffff08}.archive-summary-loading .loading-spinner{color:var(--title-color)}.archive-signin-prompt{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:300px;padding:3rem 2rem;text-align:center}.archive-signin-prompt .signin-prompt-content{max-width:400px;width:100%}.archive-signin-prompt .signin-prompt-icon{align-items:center;background:var(--stat-card-icon-bg);border-radius:12px;color:var(--title-color);display:flex;height:56px;justify-content:center;margin-bottom:1.5rem;width:56px}.archive-signin-prompt .signin-prompt-icon svg{height:28px;width:28px}.archive-signin-prompt .signin-prompt-text{margin-bottom:2rem}.archive-signin-prompt .signin-prompt-text p{color:var(--text-color);line-height:1.5;margin:0 0 1rem}.archive-signin-prompt .signin-prompt-text p:first-child{font-size:1.1rem;margin-bottom:.5rem}.archive-signin-prompt .signin-prompt-text p:last-child{color:var(--subtitle-color);font-size:.9rem}.archive-signin-prompt .signin-prompt-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.archive-signin-prompt .signin-btn{align-items:center;border:2px solid #0000;border-radius:8px;display:inline-flex;font-size:.85rem;font-weight:600;gap:.5rem;justify-content:center;min-width:140px;padding:.625rem 1.25rem;text-decoration:none;transition:all .2s ease}.archive-signin-prompt .signin-btn.primary{background:var(--button-primary-bg);border-color:var(--button-primary-bg);color:var(--button-primary-text)}.archive-signin-prompt .signin-btn.primary:hover{background:var(--button-primary-hover);border-color:var(--button-primary-hover);box-shadow:0 3px 12px #d9770040;transform:translateY(-1px)}.archive-signin-prompt .signin-btn.secondary{background:var(--button-secondary-bg);border-color:var(--button-secondary-border);color:var(--button-secondary-text)}.archive-signin-prompt .signin-btn.secondary:hover{background:var(--button-secondary-hover-bg);border-color:var(--button-secondary-hover-border);color:var(--title-color);transform:translateY(-1px)}@media (max-width:768px){.archive-signin-prompt{padding:2rem 1.5rem}.archive-signin-prompt .signin-prompt-actions{align-items:center;flex-direction:column}.archive-signin-prompt .signin-btn{max-width:240px;width:100%}}@media (max-width:480px){.archive-signin-prompt{padding:1.5rem 1rem}.archive-signin-prompt .signin-prompt-icon{height:48px;width:48px}.archive-signin-prompt .signin-prompt-icon svg{height:24px;width:24px}}[data-theme=light]{--background-color:#fff;--text-color:#333;--header-bg:#f5f5f5;--header-border:#d1d1d1;--title-color:#d97700;--subtitle-color:#666;--button-primary-bg:#d97700;--button-primary-text:#fff;--button-primary-hover:#c06800;--button-secondary-bg:#0000;--button-secondary-text:#333;--button-secondary-border:#999;--button-secondary-hover-bg:#d977001a;--button-secondary-hover-border:#d97700;--incidents-header-bg:#d97700;--incidents-header-text:#fff;--content-bg:#f9f9f9;--stat-card-bg:#fff;--stat-card-border:#d97700;--stat-card-hover-shadow:#d9770033;--stat-card-icon-bg:#d9770033;--progress-bar-bg:#e5e5e5;--progress-fill-critical:#f44;--progress-fill-default:#4f4;--incident-item-bg:#f5f5f5;--incident-item-border:#ccc;--severity-critical-bg:#f443;--severity-critical-text:#f44;--severity-medium-bg:#d9770033;--severity-medium-text:#d97700;--severity-low-bg:#4f43;--severity-low-text:#199019;--status-active-bg:#fc03;--status-active-text:#e6b800;--status-responding-bg:#007bff33;--status-responding-text:#007bff;--status-monitoring-bg:#4f43;--status-monitoring-text:#199019;--camera-section-bg:#fff;--camera-header-bg:#e5e5e5;--camera-item-bg:#f5f5f5;--camera-item-hover-bg:#e5e5e5;--camera-status-online:#199019;--camera-status-offline:#f44;--quick-actions-bg:#fff;--action-button-bg:#f5f5f5;--action-button-border:#ccc;--action-button-hover-bg:#d977001a;--action-button-hover-border:#d97700;--modal-overlay-bg:#00000080;--modal-content-bg:#fff;--modal-header-bg:#d97700;--modal-header-text:#fff;--form-section-title:#d97700;--form-help-text:#666;--uploaded-file-bg:#0000000d;--notification-bg:#fff;--notification-border:#ccc;--notification-critical-bg:#f443;--notification-critical-text:#f44;--notification-success-bg:#4f43;--notification-success-text:#199019;--notification-warning-bg:#fc03;--notification-warning-text:#e6b800;--notification-info-bg:#007bff33;--notification-info-text:#007bff;--loading-spinner:#d97700;--scrollbar-track:#e5e5e5;--scrollbar-thumb:#999;--scrollbar-thumb-hover:#666;--status-dot-healthy:#199019;--status-dot-warning:#e6b800;--status-dot-error:#f44;--weather-section-bg:#fff;--weather-card-bg:#f8f9fa;--weather-card-border:#e9ecef;--weather-card-hover-shadow:#d9770026;--weather-temp-color:#d97700;--weather-detail-label:#666;--weather-detail-value:#333;--weather-icon-color:#d97700;--user-section-bg:#fff;--user-card-bg:#f8f9fa;--user-card-border:#e9ecef;--user-card-hover-shadow:#d9770026;--user-stat-title-color:#666;--user-main-stat-color:#d97700;--user-sub-stat-color:#333;--timeline-item-bg:#d977000d;--timeline-action-connect:#199019;--timeline-action-disconnect:#f44;--timeline-text-color:#333;--timeline-time-color:#666;--magnitude-badge-bg:#d977001a;--magnitude-badge-text:#d97700}[data-theme=dark]{--background-color:#1e1e1e;--text-color:#fff;--header-bg:#1a1a1a;--header-border:#404040;--title-color:#fa3;--subtitle-color:#ccc;--button-primary-bg:#fa3;--button-primary-text:#000;--button-primary-hover:#fa3;--button-secondary-bg:#0000;--button-secondary-text:#ccc;--button-secondary-border:#666;--button-secondary-hover-bg:#ff8c001a;--button-secondary-hover-border:#fa3;--content-bg:#1e1e1e;--stat-card-bg:#3a3a3a;--stat-card-border:#fa3;--incidents-header-bg:#fa3;--incidents-header-text:#000;--stat-card-hover-shadow:#ff8c0033;--stat-card-icon-bg:#ff8c0033;--progress-bar-bg:#404040;--progress-fill-critical:#f44;--progress-fill-default:#4f4;--incident-item-bg:#2a2a2a;--incident-item-border:#666;--severity-critical-bg:#f443;--severity-critical-text:#f44;--severity-medium-bg:#fa03;--severity-medium-text:#fa0;--severity-low-bg:#4f43;--severity-low-text:#4f4;--status-active-bg:#fc03;--status-active-text:#fc0;--status-responding-bg:#007bff33;--status-responding-text:#4da8ff;--status-monitoring-bg:#4f43;--status-monitoring-text:#4f4;--camera-section-bg:#3a3a3a;--camera-header-bg:#404040;--camera-item-bg:#2a2a2a;--camera-item-hover-bg:#333;--camera-status-online:#4f4;--camera-status-offline:#f44;--quick-actions-bg:#3a3a3a;--action-button-bg:#2a2a2a;--action-button-border:#666;--action-button-hover-bg:#ff8c001a;--action-button-hover-border:#fa3;--modal-overlay-bg:#000c;--modal-content-bg:#3a3a3a;--modal-header-bg:#fa3;--modal-header-text:#000;--form-section-title:#fa3;--form-help-text:#999;--uploaded-file-bg:#ffffff0d;--notification-bg:#3a3a3a;--notification-border:#666;--notification-critical-bg:#f443;--notification-critical-text:#f44;--notification-success-bg:#4f43;--notification-success-text:#4f4;--notification-warning-bg:#fc03;--notification-warning-text:#fc0;--notification-info-bg:#007bff33;--notification-info-text:#4da8ff;--loading-spinner:#fa3;--status-dot-healthy:#4f4;--status-dot-warning:#fc0;--status-dot-error:#f44;--weather-section-bg:#3a3a3a;--weather-card-bg:#2a2a2a;--weather-card-border:#404040;--weather-card-hover-shadow:#ff8c0026;--weather-temp-color:#fa3;--weather-detail-label:#999;--weather-detail-value:#ccc;--weather-icon-color:#fa3;--user-section-bg:#3a3a3a;--user-card-bg:#2a2a2a;--user-card-border:#404040;--user-card-hover-shadow:#ff8c0026;--user-stat-title-color:#999;--user-main-stat-color:#fa3;--user-sub-stat-color:#ccc;--timeline-item-bg:#ff8c000d;--timeline-action-connect:#4f4;--timeline-action-disconnect:#f44;--timeline-text-color:#ccc;--timeline-time-color:#999;--magnitude-badge-bg:#ff8c001a;--magnitude-badge-text:#fa3}body{background:var(--background-color);font-family:Segoe UI,Arial,sans-serif}.dashboard{background-color:#0f0f0f;color:#f1f1f1;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:100vh;padding-top:var(--page-content-offset)}:root.light-mode .dashboard{background-color:#f8f9fa;color:#333;padding-top:var(--page-content-offset)}@media (max-width:768px){.dashboard{padding-top:var(--page-content-offset)}}@media (max-width:480px){.dashboard{padding-top:var(--page-content-offset)}}.dashboard-header{align-items:center;background-color:var(--header-bg);border-bottom:1px solid var(--header-border);display:flex;justify-content:space-between;padding:1.5rem 2rem}.dashboard-title{align-items:center;display:flex;gap:1rem}.dashboard-title h2{color:var(--title-color);font-size:1.8rem;font-weight:600;margin:0}.dashboard-subtitle{color:var(--subtitle-color);font-size:.9rem;margin-top:.25rem}.dashboard-header-right{align-items:center;display:flex;gap:2rem}.dashboard-time{color:var(--text-color);text-align:right}.dashboard-time-label{color:var(--subtitle-color);font-size:.8rem;margin-bottom:.25rem}.dashboard-time-value{font-size:1.1rem;font-weight:500}.header-weather,.weather-loading{align-items:center;display:flex}.weather-loading{color:var(--subtitle-color);font-size:.9rem;gap:.5rem}.weather-loading .loading-spinner.small{border-width:2px;height:16px;width:16px}.weather-summary{align-items:center;background-color:var(--weather-card-bg);border:1px solid var(--weather-card-border);border-radius:6px;display:flex;gap:.75rem;padding:.5rem .75rem}.weather-icon svg{color:var(--weather-icon-color);height:20px;width:20px}.weather-info{align-items:flex-start;display:flex;flex-direction:column}.weather-temp{color:var(--weather-temp-color);font-size:1.1rem;font-weight:600;margin-bottom:.1rem}.weather-location{color:var(--subtitle-color);font-size:.8rem}.weather-error{color:var(--subtitle-color);font-size:.9rem}.status-indicator,.system-status{align-items:center;display:flex}.status-indicator{color:var(--subtitle-color);font-size:.9rem;gap:.5rem}.status-dot{border-radius:50%;height:10px;width:10px}.status-dot.healthy{background-color:var(--status-dot-healthy)}.status-dot.warning{background-color:var(--status-dot-warning)}.status-dot.error{background-color:var(--status-dot-error)}.dashboard-content{margin:0 auto;max-width:1400px;padding:2rem}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.stat-card{border-radius:8px;padding:1.5rem;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{box-shadow:0 4px 12px var(--stat-card-hover-shadow);transform:translateY(-2px)}.stat-card-icon{background-color:var(--stat-card-icon-bg);border-radius:6px;margin-bottom:1rem;padding:.75rem}.stat-card-icon svg{color:var(--title-color);height:24px;width:24px}.stat-card-title{color:var(--subtitle-color);font-size:.9rem;margin-bottom:.5rem}.stat-card-value{color:var(--text-color);font-size:2rem;font-weight:700;margin-bottom:.25rem}.stat-card-subtitle{color:var(--subtitle-color);font-size:.8rem}.progress-bar{background-color:var(--progress-bar-bg);border-radius:3px;height:6px;margin-top:.5rem;overflow:hidden}.progress-bar.small{height:4px;margin-top:.25rem}.progress-fill{background-color:var(--progress-fill-default);height:100%;transition:width .3s ease}.progress-fill.critical{background-color:var(--progress-fill-critical)}.user-section{background-color:var(--user-section-bg);border-radius:8px;margin-bottom:2rem;padding:1.5rem}.user-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.user-header h3{color:var(--text-color);font-size:1.2rem;font-weight:600;margin:0}.user-last-update{color:var(--subtitle-color);font-size:.8rem}.user-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.user-card{background-color:var(--user-card-bg);border:1px solid var(--user-card-border);border-radius:8px;padding:1.5rem;transition:transform .2s ease,box-shadow .2s ease}.user-card:hover{box-shadow:0 4px 12px var(--user-card-hover-shadow);transform:translateY(-2px)}.user-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.user-stat-title{color:var(--user-stat-title-color);font-size:.9rem;font-weight:500}.user-card-header svg{color:var(--title-color);height:20px;width:20px}.user-main-stat{color:var(--user-main-stat-color);font-size:1.8rem;font-weight:700;margin-bottom:.5rem}.user-sub-stat{color:var(--user-sub-stat-color);font-size:.9rem}.user-timeline{display:flex;flex-direction:column;gap:.75rem;max-height:200px;overflow-y:auto}.timeline-item{align-items:center;background-color:var(--timeline-item-bg);border-radius:4px;display:flex;gap:.75rem;padding:.5rem}.timeline-action{font-size:.8rem;text-align:center;width:20px}.timeline-action.connect{color:var(--timeline-action-connect)}.timeline-action.disconnect{color:var(--timeline-action-disconnect)}.timeline-text{color:var(--timeline-text-color);flex:1 1;font-size:.8rem}.timeline-time{color:var(--timeline-time-color);font-size:.7rem}.timeline-empty{color:var(--subtitle-color);font-size:.9rem;padding:1rem;text-align:center}.magnitude-badge{background-color:var(--magnitude-badge-bg);border-radius:4px;color:var(--magnitude-badge-text);font-size:.7rem;font-weight:500;margin-left:.5rem;padding:.25rem .5rem}.weather-section{background-color:var(--weather-section-bg);border-radius:8px;margin:1rem 0 2rem;padding:1.5rem}.weather-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.weather-header h3{color:var(--text-color);font-size:1.2rem;font-weight:600;margin:0}.weather-last-update{color:var(--subtitle-color);font-size:.8rem}.weather-loading-section{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:2rem}.weather-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.weather-card{background-color:var(--weather-card-bg);border:1px solid var(--weather-card-border);border-radius:8px;padding:1.5rem;transition:transform .2s ease,box-shadow .2s ease}.weather-card:hover{box-shadow:0 4px 12px var(--weather-card-hover-shadow);transform:translateY(-2px)}.weather-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.weather-location-name{color:var(--text-color);font-size:1.1rem;font-weight:600}.weather-icon-large svg{color:var(--weather-icon-color);height:32px;width:32px}.weather-main-temp{color:var(--weather-temp-color);font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.weather-condition{color:var(--text-color);font-size:1rem;font-weight:500;margin-bottom:1rem}.weather-details{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:1fr 1fr;margin-bottom:1rem}.weather-detail-item{align-items:center;display:flex;justify-content:space-between}.weather-detail-label{color:var(--weather-detail-label);font-size:.85rem;font-weight:500}.weather-detail-value{color:var(--weather-detail-value);font-size:.85rem;font-weight:600}.weather-update-time{border-top:1px solid var(--weather-card-border);color:var(--form-help-text);font-size:.75rem;padding-top:.75rem;text-align:center}.weather-error-section{align-items:center;display:flex;justify-content:center;padding:2rem}.weather-error-message{color:var(--subtitle-color);font-size:1rem;text-align:center}.dashboard-main-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:2fr 1fr;margin-bottom:2rem}.incidents-section{background-color:var(--stat-card-bg);border-radius:8px;overflow:hidden}.incidents-section.incidents-full-width{margin-bottom:2rem;width:100%}.incidents-header{background-color:var(--incidents-header-bg);color:var(--incidents-header-text);padding:1rem 1.5rem}.incidents-header h3{font-size:1.2rem;font-weight:600;margin:0}.incidents-badge{background-color:var(--severity-medium-bg);border-radius:12px;color:var(--severity-medium-text);font-size:.8rem;font-weight:500;padding:.25rem .75rem}.incidents-list{max-height:600px;overflow-y:auto;padding:1.5rem;scrollbar-width:thin}.incident-item{background-color:var(--incident-item-bg);border-radius:6px;margin-bottom:1rem;padding:1rem;transition:border-color .2s ease}.incident-item:last-child{margin-bottom:0}.public-user-notice{background:var(--stat-card-bg);border:2px dashed var(--stat-card-border);border-radius:16px;box-shadow:0 4px 16px #00000014;margin:1rem 0 2rem;overflow:hidden;padding:0}.notice-content{align-items:center;color:#fff;display:flex;gap:.75rem;justify-content:center;padding:2rem;text-align:center}.notice-content h3{font-size:1.5rem;font-weight:700;margin:0 0 1rem}.notice-content p{font-size:1.1rem;margin:0 0 1.5rem;opacity:95%}.notice-features{display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;margin:1.5rem 0}.feature{font-size:1rem;font-weight:600}.notice-cta{align-items:center;display:flex;flex-direction:column;gap:1rem;margin-top:2rem}.cta-button{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0003;color:#f79400;font-size:1.1rem;font-weight:700;padding:1rem 2rem;text-decoration:none;transition:all .2s ease}.cta-button:hover{box-shadow:0 4px 12px #0000004d;color:#e6840a;text-decoration:none;transform:translateY(-2px)}.cta-benefits{font-size:.95rem;font-style:italic;opacity:90%}@media (max-width:768px){.notice-features{flex-direction:column;gap:1rem}.notice-content{padding:1.5rem}.notice-content h3{font-size:1.3rem}.notice-content p{font-size:1rem}}.incident-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.75rem}.incident-type{color:var(--text-color);font-weight:600}.incident-type svg{color:var(--title-color)}.severity-badge{border-radius:4px;font-size:.7rem;padding:.25rem .5rem;text-transform:uppercase}.status-badge.responding{background-color:var(--status-responding-bg);color:var(--status-responding-text)}.status-badge.monitoring{background-color:var(--status-monitoring-bg);color:var(--status-monitoring-text)}.incident-details{grid-gap:.5rem;display:grid;gap:.5rem;margin-bottom:.75rem}.incident-detail{align-items:center;color:var(--subtitle-color);display:flex;font-size:.85rem;gap:.5rem}.incident-detail svg{color:var(--subtitle-color);height:14px;width:14px}.incident-metadata{grid-gap:.5rem;display:grid;gap:.5rem}.metadata-item{align-items:center;display:flex;justify-content:space-between}.metadata-label{color:var(--subtitle-color);font-size:.8rem;font-weight:500}.metadata-value{color:var(--text-color);font-size:.8rem}.incident-actions{gap:1rem;justify-content:flex-end}.incident-action{background:none;border:none;color:var(--title-color);cursor:pointer;font-size:.8rem;padding:.25rem 0;text-decoration:underline;transition:color .2s ease}.incident-action:hover{color:var(--button-primary-hover)}.regional-stats-section,.weekly-trends-section{background-color:var(--camera-section-bg);border-radius:8px;overflow:hidden}.weekly-trends-section{box-shadow:0 2px 8px #00000014;margin:1.5rem 0}.dashboard-weekly-trends{background:#0000;border:none;box-shadow:none}.dashboard-weekly-trends .trends-chart{height:300px}.dashboard-weekly-trends .weekly-traffic-trends h3{font-size:1.25rem;margin-bottom:.75rem}.dashboard-weekly-trends .trends-subtitle{font-size:.85rem;margin-bottom:1rem}.public-user-notice h3 i{color:var(--accent-orange);font-weight:900;margin-right:.5rem;text-shadow:0 1px 2px #0000004d}.public-user-notice .feature i{background:#22c55e1a;border-radius:3px;color:#22c55e;font-size:.9rem;font-weight:900;margin-right:.5rem;padding:2px;text-shadow:0 1px 2px #0006}.upgrade-notice p i{color:var(--accent-orange);font-weight:900;margin-right:.5rem;text-shadow:0 1px 2px #0000004d}.severity-badge.high{background-color:#ef444426;border:1px solid #ef44444d;color:#ef4444}.magnitude-badge.low{background-color:#22c55e1a;color:#22c55e}.magnitude-badge.medium{background-color:#feac341a;color:#feac34}.magnitude-badge.high{background-color:#ef44441a;color:#ef4444}.weather-grid.compact{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.weather-grid.compact .weather-card{min-height:auto;padding:1rem}.weather-grid.compact .weather-card-header{margin-bottom:.5rem}.weather-grid.compact .weather-location-name{font-size:.9rem;font-weight:600}.weather-grid.compact .weather-main-temp{font-size:1.5rem;margin:.5rem 0}.weather-grid.compact .weather-condition{font-size:.8rem;margin-bottom:.5rem}.weather-details.compact{display:flex;gap:1rem;justify-content:space-between}.weather-details.compact .weather-detail-item{font-size:.75rem;text-align:center}.weather-details.compact .weather-detail-value{color:var(--text-secondary)}.regional-header{background-color:var(--camera-header-bg);border-bottom:1px solid var(--incident-item-border);color:var(--text-color);padding:1rem 1.5rem}.regional-header h3{font-size:1.2rem;font-weight:600;margin:0}.regional-list{padding:1.5rem}.regional-item{align-items:center;background-color:var(--camera-item-bg);border-radius:6px;display:flex;justify-content:space-between;margin-bottom:.75rem;padding:.75rem;transition:background-color .2s ease}.regional-item:last-child{margin-bottom:0}.regional-item:hover{background-color:var(--camera-item-hover-bg)}.regional-info{align-items:center;display:flex;gap:.75rem}.regional-details h4{color:var(--text-color);font-size:.9rem;margin:0 0 .25rem}.regional-details p{color:var(--subtitle-color);font-size:.8rem;margin:0}.regional-stats{min-width:100px;text-align:right}.camera-section{background-color:var(--camera-section-bg);border-radius:8px;overflow:hidden}.camera-header{background-color:var(--camera-header-bg);border-bottom:1px solid var(--incident-item-border);color:var(--text-color);padding:1rem 1.5rem}.camera-header h3{font-size:1.2rem;font-weight:600;margin:0}.camera-list{padding:1.5rem}.camera-item{align-items:center;background-color:var(--camera-item-bg);border-radius:6px;display:flex;justify-content:space-between;margin-bottom:.75rem;padding:.75rem;transition:background-color .2s ease}.camera-item:last-child{margin-bottom:0}.camera-item:hover{background-color:var(--camera-item-hover-bg)}.camera-info{gap:.75rem}.camera-status-dot{border-radius:50%;height:10px;width:10px}.camera-status-dot.active{background-color:var(--camera-status-online)}.camera-status-dot.offline{background-color:var(--camera-status-offline)}.camera-details h4{color:var(--text-color);font-size:.9rem;margin:0 0 .25rem}.camera-details p{color:var(--subtitle-color);font-size:.8rem;margin:0}.camera-status{text-align:right}.camera-status-text{font-size:.8rem;font-weight:500;margin-bottom:.25rem}.camera-status-text.active{color:var(--camera-status-online)}.camera-status-text.offline{color:var(--camera-status-offline)}.camera-incidents{color:var(--title-color);font-size:.7rem}.quick-actions{background-color:var(--quick-actions-bg);border-radius:8px;padding:1.5rem}.quick-actions h3{color:var(--text-color);font-size:1.2rem;font-weight:600;margin:0 0 1rem}.actions-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.action-button{align-items:center;background-color:var(--action-button-bg);border:2px dashed var(--action-button-border);border-radius:6px;color:inherit;cursor:pointer;display:flex;flex-direction:column;gap:.5rem;padding:1rem;text-decoration:none;transition:all .2s ease}.action-button:hover{background-color:var(--action-button-hover-bg);border-color:var(--action-button-hover-border)}.action-button svg{color:var(--subtitle-color);height:20px;width:20px}.action-button:hover svg{color:var(--title-color)}.action-button span{color:var(--subtitle-color);font-size:.85rem;font-weight:500;text-align:center}.action-button:hover span{color:var(--text-color)}.notification-panel{display:flex;flex-direction:column;gap:.5rem;pointer-events:none;position:fixed;right:1rem;top:5rem;z-index:10000}.notification{background-color:var(--notification-bg);border:1px solid var(--notification-border);border-radius:6px;box-shadow:0 2px 8px #0003;padding:1rem;pointer-events:auto;width:300px}.notification.critical{background-color:var(--notification-critical-bg);color:var(--notification-critical-text)}.notification.success{background-color:var(--notification-success-bg);color:var(--notification-success-text)}.notification.warning{background-color:var(--notification-warning-bg);color:var(--notification-warning-text)}.notification.info{background-color:var(--notification-info-bg);color:var(--notification-info-text)}.notification-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.notification-title{font-size:.9rem;font-weight:600}.notification-close{background:none;border:none;border-radius:50%;color:var(--text-color);cursor:pointer;font-size:1rem;height:24px;line-height:24px;width:24px}.notification-close:hover{background:#00000014}.notification-content{font-size:.85rem}.loading-overlay{align-items:center;background-color:#00000080;display:flex;flex-direction:column;inset:0;justify-content:center;position:fixed;z-index:1000}.loading-spinner{border:3px solid var(--loading-spinner);border-top:3px solid #0000;height:32px;width:32px}.loading-text{color:var(--text-color);font-size:1rem;margin-top:.5rem}.last-updated{align-items:center;color:var(--subtitle-color);display:flex;font-size:.8rem;gap:.5rem;padding:.5rem 1.5rem}.update-indicator{background-color:var(--status-dot-healthy);border-radius:50%;height:8px;width:8px}.incidents-list::-webkit-scrollbar,.user-timeline::-webkit-scrollbar{width:6px}.incidents-list::-webkit-scrollbar-track,.user-timeline::-webkit-scrollbar-track{background:var(--scrollbar-track)}.incidents-list::-webkit-scrollbar-thumb,.user-timeline::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:3px}.incidents-list::-webkit-scrollbar-thumb:hover,.user-timeline::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}@media (max-width:1024px){.dashboard-main-grid{grid-template-columns:1fr}.dashboard-header{text-align:center}.dashboard-header,.dashboard-header-right{flex-direction:column;gap:1rem}.user-grid,.weather-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.notification-panel{top:5.5rem}}@media (max-width:768px){.dashboard-content{padding:1rem}.stats-grid{grid-template-columns:1fr}.actions-grid{grid-template-columns:repeat(2,1fr)}.user-grid,.weather-details,.weather-grid{grid-template-columns:1fr}.dashboard-header-right{align-items:center}.weather-summary{flex-direction:column;gap:.5rem;text-align:center}.notification-panel{right:.75rem;top:6rem}}@media (max-width:480px){.actions-grid{grid-template-columns:1fr}.incident-header{align-items:flex-start;flex-direction:column;gap:.5rem}.user-card,.weather-card{padding:1rem}.weather-main-temp{font-size:2rem}.notification-panel{right:.5rem;top:6.5rem}}.realtime-events-section{background:var(--stat-card-bg);border:2px solid var(--stat-card-border);border-radius:12px;box-shadow:0 4px 8px #0000001a;margin-bottom:20px;padding:20px}.realtime-header{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;margin-bottom:20px}.realtime-header h3{color:var(--title-color);font-size:1.4em;margin:0}.realtime-stats{display:flex;flex-wrap:wrap;gap:10px}.stat-pill{background:var(--stat-card-icon-bg);border:1px solid var(--stat-card-border);border-radius:20px;color:var(--text-color);font-size:.9em;font-weight:600;padding:6px 12px}.stat-pill.critical{background:var(--severity-critical-bg);border-color:var(--severity-critical-text);color:var(--severity-critical-text)}.events-panel{background:var(--content-bg);border:1px solid var(--incident-item-border);border-radius:8px;overflow:hidden}.events-header{align-items:center;background:var(--header-bg);border-bottom:1px solid var(--incident-item-border);color:var(--text-color);display:flex;font-weight:600;justify-content:space-between;padding:12px 16px}.clear-events-btn{background:var(--button-secondary-bg);border:1px solid var(--button-secondary-border);border-radius:6px;color:var(--button-secondary-text);cursor:pointer;font-size:.85em;padding:4px 12px;transition:all .2s ease}.clear-events-btn:hover{background:var(--button-secondary-hover-bg);border-color:var(--button-secondary-hover-border)}.events-list{background:var(--background-color);max-height:400px;overflow-y:auto}.event-item{border-bottom:1px solid var(--header-border);font-family:Courier New,monospace;font-size:.85em;padding:8px 16px;transition:background-color .2s ease}.event-item:hover{background:var(--camera-item-hover-bg)}.event-item:last-child{border-bottom:none}.event-content{background:#0000;border:none;color:var(--text-color);font-family:inherit;font-size:inherit;margin:0;padding:0;white-space:pre-wrap;word-break:break-word}.events-empty{color:var(--subtitle-color);font-style:italic;padding:40px 16px;text-align:center}.events-empty span{font-size:1.1em}@media (max-width:768px){.realtime-header{align-items:flex-start;flex-direction:column}.realtime-stats{justify-content:flex-start;width:100%}.events-list{max-height:300px}.event-item{font-size:.8em;padding:6px 12px}}.public-notice{background:linear-gradient(135deg,#e3f2fd,#f3e5f5);border:1px solid #90caf9;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:1.5rem;padding:1rem}.notice-icon{flex-shrink:0;font-size:1.2rem}.notice-text{color:#1565c0;font-size:.95rem;font-weight:500}.notice-text a{border-bottom:1px solid #0000;color:#d97700;font-weight:600;text-decoration:none;transition:border-color .2s ease}.notice-text a:hover{border-bottom-color:#d97700}.dashboard-dual-container{grid-gap:2rem;align-items:stretch;display:grid;gap:2rem;grid-template-columns:2fr 1fr;margin-bottom:2rem}.dashboard-archive-summary,.dashboard-camera-carousel{min-width:0}@media (max-width:1024px){.dashboard-dual-container{gap:1.5rem;grid-template-columns:1fr}}@media (max-width:768px){.dashboard-dual-container{gap:1rem}}.stat-card-loading{pointer-events:none;-webkit-user-select:none;user-select:none}.loading-spinner-container{align-items:center;display:flex;height:100%;justify-content:center;min-height:120px}.loading-spinner.small{height:24px;width:24px}[data-theme=dark] .loading-spinner{border-color:#d97700 #444 #444}.stats-signin-prompt{background-color:var(--stat-card-bg);border:2px dashed var(--stat-card-border);border-radius:16px;box-shadow:0 4px 16px #00000014;margin-bottom:2rem;padding:3rem 2rem;text-align:center;transition:all .3s ease}.stats-signin-prompt:hover{border-color:var(--title-color);box-shadow:0 8px 32px var(--stat-card-hover-shadow);transform:translateY(-2px)}.incidents-signin-prompt{align-items:center;background-color:var(--stat-card-bg);border:2px dashed var(--stat-card-border);border-radius:16px;box-shadow:0 4px 16px #00000014;display:flex;justify-content:center;min-height:400px;padding:3rem 2rem;text-align:center;transition:all .3s ease}.incidents-signin-prompt:hover{border-color:var(--title-color);box-shadow:0 8px 32px var(--stat-card-hover-shadow);transform:translateY(-2px)}.pems-signup-prompt{background-color:var(--stat-card-bg);border:2px dashed var(--stat-card-border);border-radius:16px;box-shadow:0 4px 16px #00000014;margin-bottom:2rem;padding:3rem 2rem;text-align:center;transition:all .3s ease}.pems-signup-prompt:hover{border-color:var(--title-color);box-shadow:0 8px 32px var(--stat-card-hover-shadow);transform:translateY(-2px)}.signin-prompt-content,.signup-prompt-content{margin:0 auto;max-width:500px}.signin-prompt-header,.signup-prompt-header{align-items:center;display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.signin-prompt-icon,.signup-prompt-icon{align-items:center;background:var(--stat-card-icon-bg);border-radius:16px;color:var(--title-color);display:flex;height:64px;justify-content:center;transition:all .2s ease;width:64px}.signin-prompt-icon svg,.signup-prompt-icon svg{height:32px;width:32px}.signin-prompt-header h3,.signup-prompt-header h3{color:var(--title-color);font-size:1.5rem;font-weight:700;margin:0}.signin-prompt-description,.signup-prompt-description{margin-bottom:2rem;text-align:left}.signin-prompt-description p,.signup-prompt-description p{color:var(--text-color);font-size:1rem;line-height:1.6;margin:0 0 1rem}.signin-prompt-description ul,.signup-prompt-description ul{color:var(--subtitle-color);margin:0;padding-left:1.5rem}.signin-prompt-description li,.signup-prompt-description li{font-size:.9rem;line-height:1.5;margin-bottom:.5rem}.signin-prompt-actions,.signup-prompt-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.signin-btn,.signup-btn{align-items:center;border:2px solid #0000;border-radius:8px;display:inline-flex;font-size:.9rem;font-weight:600;gap:.5rem;justify-content:center;min-width:160px;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s ease}.signin-btn.primary,.signup-btn.primary{background:var(--button-primary-bg);border-color:var(--button-primary-bg);color:var(--button-primary-text)}.signin-btn.primary:hover,.signup-btn.primary:hover{background:var(--button-primary-hover);border-color:var(--button-primary-hover);box-shadow:0 4px 16px #d977004d;transform:translateY(-2px)}.signin-btn.secondary,.signup-btn.secondary{background:var(--button-secondary-bg);border-color:var(--button-secondary-border);color:var(--button-secondary-text)}.signin-btn.secondary:hover,.signup-btn.secondary:hover{background:var(--button-secondary-hover-bg);border-color:var(--button-secondary-hover-border);color:var(--title-color);transform:translateY(-2px)}@media (max-width:768px){.incidents-signin-prompt,.pems-signup-prompt,.stats-signin-prompt{padding:2rem 1.5rem;transform:none}.incidents-signin-prompt:hover,.pems-signup-prompt:hover,.stats-signin-prompt:hover{transform:none}.signin-prompt-icon,.signup-prompt-icon{height:56px;width:56px}.signin-prompt-icon svg,.signup-prompt-icon svg{height:28px;width:28px}.signin-prompt-header h3,.signup-prompt-header h3{font-size:1.3rem}.signin-prompt-actions,.signup-prompt-actions{align-items:center;flex-direction:column}.signin-btn,.signup-btn{max-width:280px;width:100%}}@media (max-width:480px){.incidents-signin-prompt,.pems-signup-prompt,.stats-signin-prompt{margin:1rem 0;padding:1.5rem 1rem}.signin-prompt-description,.signup-prompt-description{text-align:center}.signin-prompt-description ul,.signup-prompt-description ul{padding-left:1rem;text-align:left}}@keyframes fadeInPrompt{0%{opacity:0;transform:translateY(20px)}to{opacity:100%;transform:translateY(0)}}.incidents-signin-prompt,.pems-signup-prompt,.stats-signin-prompt{animation:fadeInPrompt .5s ease-out}.leaflet-image-layer,.leaflet-layer,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-pane,.leaflet-pane>canvas,.leaflet-pane>svg,.leaflet-tile,.leaflet-tile-container,.leaflet-zoom-box{left:0;position:absolute;top:0}.leaflet-container{overflow:hidden}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile{-webkit-user-drag:none;-webkit-user-select:none;user-select:none}.leaflet-tile::selection{background:#0000}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{height:1600px;-webkit-transform-origin:0 0;width:1600px}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-height:none!important;max-width:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer{max-height:none!important;max-width:none!important;padding:0;width:auto}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{box-sizing:border-box;height:0;width:0;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{height:1px;width:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{pointer-events:visiblePainted;pointer-events:auto;position:relative;z-index:800}.leaflet-bottom,.leaflet-top{pointer-events:none;position:absolute;z-index:1000}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{clear:both;float:left}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-pan-anim .leaflet-tile,.leaflet-zoom-anim .leaflet-tile{transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-control,.leaflet-popup-pane{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:grabbing}.leaflet-image-layer,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-image-layer.leaflet-interactive,.leaflet-marker-icon.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{background:#ffffff80;border:2px dotted #38f}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{border-radius:4px;box-shadow:0 1px 5px #000000a6}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;color:#000;display:block;height:26px;line-height:26px;text-align:center;text-decoration:none;width:26px}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:focus,.leaflet-bar a:hover{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom:none;border-bottom-left-radius:4px;border-bottom-right-radius:4px}.leaflet-bar a.leaflet-disabled{background-color:#f4f4f4;color:#bbb;cursor:default}.leaflet-touch .leaflet-bar a{height:30px;line-height:30px;width:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{background:#fff;border-radius:5px;box-shadow:0 1px 5px #0006}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);height:36px;width:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{height:44px;width:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{background:#fff;color:#333;padding:6px 10px 6px 6px}.leaflet-control-layers-scrollbar{overflow-x:hidden;overflow-y:scroll;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{border-top:1px solid #ddd;height:0;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{color:#333;line-height:1.4;padding:0 5px}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:focus,.leaflet-control-attribution a:hover{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;height:.6669em;vertical-align:initial!important;width:1em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{background:#fffc;border:2px solid #777;border-top:none;box-sizing:border-box;line-height:1.1;padding:2px 5px 1px;text-shadow:1px 1px #fff;white-space:nowrap}.leaflet-control-scale-line:not(:first-child){border-bottom:none;border-top:2px solid #777;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-bar,.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers{box-shadow:none}.leaflet-touch .leaflet-bar,.leaflet-touch .leaflet-control-layers{background-clip:padding-box;border:2px solid #0003}.leaflet-popup{margin-bottom:20px;position:absolute;text-align:center}.leaflet-popup-content-wrapper{border-radius:12px;padding:1px;text-align:left}.leaflet-popup-content{font-size:13px;font-size:1.08333em;line-height:1.3;margin:13px 24px 13px 20px;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{height:20px;left:50%;margin-left:-20px;margin-top:-1px;overflow:hidden;pointer-events:none;position:absolute;width:40px}.leaflet-popup-tip{height:17px;margin:-10px auto 0;padding:1px;pointer-events:auto;transform:rotate(45deg);width:17px}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;box-shadow:0 3px 14px #0006;color:#333}.leaflet-container a.leaflet-popup-close-button{background:#0000;border:none;color:#757575;font:16px/24px Tahoma,Verdana,sans-serif;height:24px;position:absolute;right:0;text-align:center;text-decoration:none;top:0;width:24px}.leaflet-container a.leaflet-popup-close-button:focus,.leaflet-container a.leaflet-popup-close-button:hover{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678,M12=0.70710678,M21=-0.70710678,M22=0.70710678);margin:0 auto;width:24px}.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{background-color:#fff;border:1px solid #fff;border-radius:3px;box-shadow:0 1px 3px #0006;color:#222;padding:6px;pointer-events:none;position:absolute;-webkit-user-select:none;user-select:none;white-space:nowrap}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before,.leaflet-tooltip-top:before{background:#0000;border:6px solid #0000;content:"";pointer-events:none;position:absolute}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{border-top-color:#fff;bottom:0;margin-bottom:-12px}.leaflet-tooltip-bottom:before{border-bottom-color:#fff;margin-left:-6px;margin-top:-12px;top:0}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{margin-top:-6px;top:50%}.leaflet-tooltip-left:before{border-left-color:#fff;margin-right:-12px;right:0}.leaflet-tooltip-right:before{border-right-color:#fff;left:0;margin-left:-12px}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}:root{--livefeed-bg:#0f0f0f;--livefeed-text:#f1f1f1;--livefeed-title:#feac34;--livefeed-subtitle:#aaa;--feed-tile-bg:#181818;--feed-tile-border:#0000;--feed-tile-shadow:#0000;--feed-tile-hover-bg:#202020;--feed-details-bg:#181818;--feed-info-text:#f1f1f1;--feed-info-subtext:#aaa;--status-online-bg:#00d562;--status-online-text:#fff;--status-offline-bg:#d97700;--status-offline-text:#fff;--live-feed-overlay-bg:#000000b3;--scrollbar-track:#181818;--scrollbar-thumb:#666;--scrollbar-thumb-hover:#888;--button-bg:#feac34;--button-text:#fff;--button-hover-bg:#f79400;--error-bg:#2d1b1f;--error-text:#f8d7da;--error-border:#842029;--loading-bg:#0f0f0fe6;--metadata-bg:#252525;--metadata-text:#ccc}:root.light-mode{--livefeed-bg:#fff;--livefeed-text:#0f0f0f;--livefeed-title:#feac34;--livefeed-subtitle:#606060;--feed-tile-bg:#fff;--feed-tile-border:#e5e5e5;--feed-tile-shadow:#00000014;--feed-tile-hover-bg:#f9f9f9;--feed-details-bg:#fff;--feed-info-text:#0f0f0f;--feed-info-subtext:#606060;--status-online-bg:#00d562;--status-online-text:#fff;--status-offline-bg:#ff4458;--status-offline-text:#fff;--live-feed-overlay-bg:#00000080;--scrollbar-track:#e5e5e5;--scrollbar-thumb:#999;--scrollbar-thumb-hover:#666;--button-bg:#feac34;--button-text:#fff;--button-hover-bg:#f79400;--error-bg:#f8d7da;--error-text:#721c24;--error-border:#f5c6cb;--loading-bg:#ffffffe6;--metadata-bg:#f2f2f2;--metadata-text:#606060}[data-theme=dark]{--livefeed-bg:#1e1e1e;--livefeed-text:#fff;--livefeed-title:#fa3;--livefeed-subtitle:#ccc;--feed-tile-bg:#3a3a3a;--feed-tile-border:#fa3;--feed-tile-shadow:#ff8c0033;--feed-tile-hover-bg:#333;--feed-details-bg:#2a2a2a;--feed-info-text:#fff;--feed-info-subtext:#999;--status-online-bg:#4f43;--status-online-text:#4f4;--status-offline-bg:#f443;--status-offline-text:#f44;--live-feed-overlay-bg:#000c;--scrollbar-track:#2a2a2a;--scrollbar-thumb:#666;--scrollbar-thumb-hover:#888;--button-bg:#0d6efd;--button-text:#fff;--button-hover-bg:#0b5ed7;--error-bg:#2d1b1f;--error-text:#f8d7da;--error-border:#842029;--loading-bg:#2e2e2ee6;--metadata-bg:#495057;--metadata-text:#adb5bd}.livefeed-page{background-color:#0f0f0f;background-color:var(--livefeed-bg);color:#f1f1f1;color:var(--livefeed-text);font-family:Segoe UI,Arial,sans-serif;min-height:100vh;padding:2rem;padding-top:calc(var(--page-content-offset) + 1.5rem)}.livefeed-header{border-bottom:1px solid #ffffff1a;border-bottom:1px solid var(--livefeed-border,#ffffff1a);margin-bottom:2rem;padding:1.5rem 2rem;text-align:center}.livefeed-page h2{color:#feac34;color:var(--livefeed-title);font-size:2rem;margin:0}.livefeed-subtitle{color:#aaa;color:var(--livefeed-subtitle);font-size:1rem;margin-top:.5rem}.livefeed-controls{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:1rem}.refresh-button,.retry-button{background-color:#feac34;background-color:var(--button-bg);border:none;border-radius:4px;color:#fff;color:var(--button-text);cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:background-color .2s ease}.refresh-button:hover,.retry-button:hover{background-color:#f79400;background-color:var(--button-hover-bg)}.refresh-button:disabled{cursor:not-allowed;opacity:60%}.cors-proxy-button{background-color:#252525;background-color:var(--metadata-bg);border:2px solid #252525;border:2px solid var(--metadata-bg);border-radius:4px;color:#ccc;color:var(--metadata-text);cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .2s ease}.cors-proxy-button:hover{background-color:#feac34;background-color:var(--button-bg);border-color:#feac34;border-color:var(--button-bg);color:#fff;color:var(--button-text)}.cors-proxy-button.active{background-color:#feac34;background-color:var(--livefeed-title);border-color:#feac34;border-color:var(--livefeed-title);color:#fff}.cors-proxy-button.active:hover{background-color:#f79400;background-color:var(--button-hover-bg);border-color:#f79400;border-color:var(--button-hover-bg)}.switch-proxy-button{background-color:#252525;background-color:var(--metadata-bg);border:1px solid #252525;border:1px solid var(--metadata-bg);border-radius:4px;color:#ccc;color:var(--metadata-text);cursor:pointer;font-size:.8rem;padding:.5rem 1rem;transition:all .2s ease}.switch-proxy-button:hover{background-color:#feac34;background-color:var(--button-bg);border-color:#feac34;border-color:var(--button-bg);color:#fff;color:var(--button-text)}.feed-info{font-size:.8rem}.feed-info,.last-refresh{color:#aaa;color:var(--livefeed-subtitle)}.last-refresh{font-size:.7rem;font-style:italic}.status-info{background-color:#181818;background-color:var(--feed-details-bg);border:1px solid #0000;border:1px solid var(--feed-tile-border);border-radius:8px;display:flex;gap:2rem;justify-content:center;margin-bottom:2rem;padding:1rem}.status-item{flex-direction:column;gap:.25rem}.status-label{color:#aaa;color:var(--feed-info-subtext);font-size:.7rem}.status-value{color:#f1f1f1;color:var(--feed-info-text);font-size:.8rem;font-weight:500}.update-frequency{background-color:#000000b3;background-color:var(--live-feed-overlay-bg);border-radius:3px;bottom:.5rem;color:#fff;font-size:.6rem;font-weight:500;left:.5rem;padding:.2rem .4rem;position:absolute}.timelapse-note{background-color:#252525;background-color:var(--metadata-bg);border-radius:6px;margin-top:1rem;padding:1rem;text-align:center}.timelapse-note p{color:#ccc;color:var(--metadata-text);font-size:.8rem;line-height:1.3;margin:0 0 .5rem}.timelapse-note p:last-child{margin-bottom:0}.error-banner{align-items:center;background-color:#2d1b1f;background-color:var(--error-bg);border:1px solid #842029;border:1px solid var(--error-border);border-radius:4px;display:flex;justify-content:space-between;margin-bottom:1rem;padding:.75rem 1rem}.close-error,.error-banner{color:#f8d7da;color:var(--error-text)}.close-error{background:none;border:none;cursor:pointer;font-size:1.2rem;margin-left:1rem;padding:0}.loading-spinner{align-items:center;display:flex;height:200px;justify-content:center}.spinner{animation:spin 1s linear infinite;border:4px solid #0000;border-top:4px solid #feac34;border:4px solid var(--feed-tile-border);border-radius:50%;border-top-color:var(--livefeed-title);height:40px;width:40px}.error-state,.no-feeds-message{padding:3rem 1rem;text-align:center}.error-message{color:#f8d7da;color:var(--error-text);font-size:1.1rem;margin-bottom:1rem}.debug-info{background-color:#252525;background-color:var(--metadata-bg);border-radius:6px;color:#ccc;color:var(--metadata-text);font-size:.9rem;line-height:1.4;margin-bottom:1rem;padding:1rem}.debug-info p{margin:0 0 .5rem}.debug-info p:last-child{margin-bottom:0}.debug-info details{margin-top:.5rem}.debug-info summary{color:#feac34;color:var(--livefeed-title);cursor:pointer;font-weight:500;margin-bottom:.5rem}.debug-info summary:hover{text-decoration:underline}.debug-info a{color:#feac34;color:var(--button-bg);text-decoration:none}.debug-info a:hover{text-decoration:underline}.livefeed-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.feed-tile{background-color:#181818;background-color:var(--feed-tile-bg);border-radius:8px;box-shadow:0 2px 8px #0000;box-shadow:0 2px 8px var(--feed-tile-shadow);display:flex;flex-direction:column;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.feed-tile.clickable{cursor:pointer}.feed-tile:hover{background-color:#202020;background-color:var(--feed-tile-hover-bg);box-shadow:0 4px 12px #0000;box-shadow:0 4px 12px var(--feed-tile-shadow);transform:translateY(-2px)}.feed-tile.clickable:hover .play-overlay{opacity:100%}.feed-image-container{aspect-ratio:16/9;height:200px;position:relative;width:100%}.feed-image,.feed-video{border-radius:8px 8px 0 0;height:100%;object-fit:cover;object-position:center;width:100%}.feed-video{background-color:#000}.live-feed-overlay{background-color:#000000b3;background-color:var(--live-feed-overlay-bg);border-radius:4px;padding:.25rem;position:absolute;right:.5rem;top:.5rem}.status-badge{border-radius:4px;font-size:.7rem;padding:.25rem .5rem;text-transform:uppercase}.status-badge.online{background-color:#00d562;background-color:var(--status-online-bg);color:#fff;color:var(--status-online-text)}.status-badge.offline{background-color:#d97700;background-color:var(--status-offline-bg);color:#fff;color:var(--status-offline-text)}.feed-details{background-color:#181818;background-color:var(--feed-details-bg);border-radius:0 0 8px 8px;flex-grow:1;padding:1rem}.feed-description{color:#aaa;color:var(--feed-info-subtext);font-size:.75rem;font-style:italic;line-height:1.2;margin:0 0 .5rem}.feed-metadata{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.feed-county,.feed-direction,.feed-district,.feed-route{background-color:#252525;background-color:var(--metadata-bg);border-radius:3px;color:#ccc;color:var(--metadata-text);font-size:.7rem;font-weight:500;padding:.2rem .4rem}.feed-milepost{margin-bottom:.5rem}.feed-last-update,.feed-milepost{color:#aaa;color:var(--feed-info-subtext);font-size:.7rem}.feed-last-update{font-style:italic}.play-overlay{left:50%;opacity:0;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);transition:opacity .2s ease}.play-button{background-color:#000000b3;border-radius:50%;color:#fff;font-size:1.5rem;height:60px;padding-left:4px;width:60px}.play-button,.video-modal-overlay{align-items:center;display:flex;justify-content:center}.video-modal-overlay{animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(135deg,#0009,#1e293bcc);bottom:0;left:0;padding:1rem;padding-top:calc(var(--navbar-total-height) + 1rem);position:fixed;right:0;top:0;z-index:1000}.video-modal{animation:slideInUp .4s cubic-bezier(.34,1.56,.64,1);background:#181818;background:var(--feed-tile-bg);border:1px solid #0000;border:1px solid var(--feed-tile-border);border-radius:16px;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #0000;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px var(--feed-tile-border);display:flex;flex-direction:column;max-height:calc(100vh - var(--navbar-total-height) - 2rem);max-width:95vw;overflow:hidden;position:relative;width:1200px}@keyframes slideInUp{0%{opacity:0;transform:translateY(40px) scale(.95)}to{opacity:100%;transform:translateY(0) scale(1)}}.video-modal-header{align-items:flex-start;background:#feac34;background:var(--livefeed-title);border-bottom:1px solid #0000;border-bottom:1px solid var(--feed-tile-border);color:#fff;display:flex;justify-content:space-between;padding:1.5rem 2rem;position:relative}.modal-title-section{flex:1 1;min-width:0}.modal-title{color:#fff;font-size:1.5rem;font-weight:700;line-height:1.2;margin:0 0 .5rem}.modal-subtitle{color:#ffffffe6;font-size:.875rem;font-weight:500;line-height:1.4}.view-mode-selector{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:1px solid #fff3;border-radius:12px;display:flex;gap:.5rem;margin:0 1rem;padding:.25rem}.view-mode-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:#fffc;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.75rem 1rem;transition:all .2s ease;white-space:nowrap}.view-mode-btn:hover{background:#ffffff1a;color:#fff;transform:translateY(-1px)}.view-mode-btn.active{background:#fff;box-shadow:0 4px 14px #00000026;color:#d97700}.view-mode-btn.active:hover{background:#fffffff2;transform:translateY(-1px)}.close-modal{align-items:center;background:none;border:none;border-radius:12px;color:#fffc;cursor:pointer;display:flex;flex-shrink:0;height:44px;justify-content:center;padding:.75rem;transition:all .2s ease;width:44px}.close-modal:hover{background:#ffffff1a;color:#fff;transform:scale(1.05)}.video-modal-content{align-items:center;background:#181818;background:var(--feed-tile-bg);color:#f1f1f1;color:var(--feed-info-text);display:flex;flex:1 1;flex-direction:column;justify-content:center;max-height:calc(100vh - var(--navbar-total-height) - 220px);min-height:300px;overflow:auto;padding:1rem}.video-modal .map-container{margin-bottom:0;max-width:800px;width:100%}.video-modal .camera-map{aspect-ratio:16/9;border:1px solid #0000;border:1px solid var(--feed-tile-border);border-radius:8px;height:auto!important;overflow:hidden;width:100%}.video-modal-content:has(.map-container){padding-bottom:0}.video-container{max-width:800px;padding-bottom:60px;position:relative;width:100%}.modal-video{border-radius:8px;height:auto;width:100%}.video-type-indicator{background-color:#f00c;border-radius:4px;color:#fff;font-size:.8rem;font-weight:500;left:10px;padding:.25rem .5rem;position:absolute;top:10px}.timelapse-container{align-items:center;display:flex;flex-direction:column;gap:1rem;max-width:800px;width:100%}.timelapse-viewer{background-color:#000;border-radius:8px;overflow:hidden;position:relative;width:100%}.timelapse-image{display:block;height:auto;width:100%}.timelapse-info{border-radius:4px;color:#fff;font-size:.8rem;font-weight:600;left:10px;padding:.25rem .5rem;text-shadow:0 1px 2px #00000080}.timelapse-controls,.timelapse-info{background-color:#000c;bottom:10px;position:absolute}.timelapse-controls{align-items:center;border-radius:6px;display:flex;gap:.5rem;padding:8px;right:10px;z-index:10}.timelapse-btn{background-color:#feac34;background-color:var(--button-bg);border:none;border-radius:6px;color:#fff;color:var(--button-text);cursor:pointer;font-size:1rem;min-width:50px;padding:.75rem 1rem;transition:background-color .2s ease}.timelapse-btn:hover:not(:disabled){background-color:#f79400;background-color:var(--button-hover-bg)}.timelapse-btn:disabled{cursor:not-allowed;opacity:50%}.timelapse-btn.primary{background-color:#feac34;background-color:var(--livefeed-title);font-size:1.2rem;padding:.75rem 1.5rem}.timelapse-btn.primary:hover{background-color:#f79400;background-color:var(--button-hover-bg)}.video-modal-info{background-color:#181818;background-color:var(--feed-details-bg);padding:1rem 1.5rem}.video-modal:has(.map-container) .video-modal-info{border-top:1px solid #0000;border-top:1px solid var(--feed-tile-border);margin-top:1rem;padding-top:1rem}.video-modal-content .map-container{margin-bottom:0}.camera-details-modal{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.camera-details-modal p{color:#f1f1f1;color:var(--feed-info-text);font-size:.9rem;margin:0}.camera-details-modal strong{color:#feac34;color:var(--livefeed-title)}@media (max-width:768px){.livefeed-page{padding:1rem;padding-top:calc(var(--page-content-offset) + .5rem)}}@media (max-width:480px){.livefeed-page{padding:1rem;padding-top:calc(var(--page-content-offset) + .5rem)}.livefeed-grid{grid-template-columns:1fr}.feed-image-container{height:180px}.livefeed-controls{flex-direction:column;gap:.5rem}.livefeed-page h2{font-size:1.5rem}.livefeed-subtitle{font-size:.9rem}.feed-image-container{height:160px}.feed-metadata{flex-direction:column;gap:.25rem}.video-modal{max-height:95vh;max-width:95vw}.video-modal-header{padding:.75rem 1rem}.video-modal-header h3{font-size:1rem}.video-modal-content{min-height:300px;padding:.75rem}.timelapse-controls{flex-wrap:wrap;justify-content:center}.timelapse-btn{font-size:.9rem;min-width:45px;padding:.5rem .75rem}.camera-details-modal{gap:.25rem;grid-template-columns:1fr}.camera-details-modal p{font-size:.8rem}.switch-proxy-button{font-size:.7rem;padding:.4rem .75rem}}.leaflet-container{border-radius:8px}.leaflet-container,.leaflet-control{background-color:#181818;background-color:var(--feed-tile-bg);border:1px solid #0000;border:1px solid var(--feed-tile-border)}.leaflet-control,.leaflet-control a{color:#f1f1f1;color:var(--feed-info-text)}.leaflet-control a:hover{background-color:#202020;background-color:var(--feed-tile-hover-bg)}.leaflet-control-attribution{color:#aaa;color:var(--feed-info-subtext);font-size:.7rem}.leaflet-control-attribution,.map-info{background-color:#181818;background-color:var(--feed-details-bg)}.map-info{border-bottom:none;border-radius:0 0 8px 8px;margin-bottom:0;max-height:100px;overflow:hidden;padding:.75rem 1rem;text-align:center}.map-info p{color:#f1f1f1;color:var(--feed-info-text);font-size:.9rem;margin:.5rem 0}.map-info strong{color:#feac34;color:var(--livefeed-title)}.camera-map{aspect-ratio:16/9;border:1px solid #0000;border:1px solid var(--feed-tile-border);border-radius:8px;height:auto!important;overflow:hidden;width:100%}.report-incident-btn{background:#feac34;background:var(--livefeed-title);border:none;border-radius:8px;box-shadow:0 2px 4px #d9770033;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;margin-top:10px;padding:10px 20px;transition:all .2s ease}.report-incident-btn:hover{background:#f79400;background:var(--button-hover-bg);box-shadow:0 4px 8px #d977004d;transform:translateY(-1px)}.incident-form{background:#181818;background:var(--feed-tile-bg);border:1px solid #0000;border:1px solid var(--feed-tile-border);border-radius:8px;margin-top:15px;padding:20px}.incident-form h4{color:#feac34;color:var(--livefeed-title);font-size:1.1rem;font-weight:600;margin:0 0 15px}.incident-form label{color:#f1f1f1;color:var(--feed-info-text);display:block;font-weight:600;margin-bottom:5px}.incident-form select,.incident-form textarea{background:#181818;background:var(--feed-tile-bg);border:1px solid #0000;border:1px solid var(--feed-tile-border);border-radius:6px;color:#f1f1f1;color:var(--feed-info-text);font-size:.9rem;min-height:60px;padding:10px;resize:vertical;width:100%}.incident-form select:focus,.incident-form textarea:focus{border-color:#feac34;border-color:var(--livefeed-title);box-shadow:0 0 0 3px #d977001a;outline:none}.incident-form-actions{display:flex;gap:10px;margin-top:15px}.incident-submit-btn{background:#feac34;background:var(--livefeed-title);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:10px 20px;transition:background-color .2s ease}.incident-submit-btn:hover:not(:disabled){background:#f79400;background:var(--button-hover-bg)}.incident-submit-btn:disabled{cursor:not-allowed;opacity:50%}.incident-cancel-btn{background:#aaa;background:var(--feed-info-subtext);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:10px 20px;transition:background-color .2s ease}.incident-cancel-btn:hover{background:#f1f1f1;background:var(--feed-info-text)}@media (max-width:768px){.video-modal{border-radius:8px;height:calc(100vh - var(--navbar-total-height));margin:0;max-height:calc(100vh - var(--navbar-total-height));max-width:100vw;width:100vw}.video-modal-overlay{padding:.5rem;padding-top:calc(var(--navbar-total-height) + .5rem)}.video-modal-header{align-items:stretch;flex-direction:column;flex-shrink:0;gap:1rem;padding:1rem 1.5rem;position:relative}.modal-title-section{order:1;padding-right:3rem}.modal-title{font-size:1.25rem;margin-bottom:.25rem}.modal-subtitle{font-size:.8rem}.view-mode-selector{justify-content:center;margin:0;order:2}.view-mode-btn{flex:1 1;font-size:.8rem;padding:.6rem .8rem}.close-modal{height:36px;padding:.5rem;position:absolute;right:1rem;top:1rem;width:36px}.video-modal-content{max-height:calc(100vh - var(--navbar-total-height) - 120px);min-height:calc(100vh - var(--navbar-total-height) - 120px);padding:.75rem}.video-modal-info{flex-shrink:0;max-height:150px;overflow-y:auto;padding:1rem}}@media (max-width:480px){.video-modal{border-radius:4px;height:calc(100vh - var(--navbar-total-height));max-height:calc(100vh - var(--navbar-total-height))}.video-modal-overlay{align-items:center;justify-content:center;padding:.25rem;padding-top:calc(var(--navbar-total-height) + .25rem)}.video-modal-header{padding:.75rem 1rem}.modal-title{font-size:1.1rem}.modal-subtitle,.view-mode-btn{font-size:.75rem}.view-mode-btn{padding:.5rem .6rem}.view-mode-btn svg{height:14px;width:14px}.close-modal{height:32px;right:.75rem;top:.75rem;width:32px}.close-modal svg{height:16px;width:16px}.video-modal-content{max-height:calc(100vh - var(--navbar-total-height) - 90px);min-height:calc(100vh - var(--navbar-total-height) - 90px);padding:.5rem}.video-modal-info{max-height:120px;padding:.75rem}.camera-details-modal{gap:.25rem;grid-template-columns:1fr}.camera-details-modal p{font-size:.75rem}}:root{--toastify-color-light:#fff;--toastify-color-dark:#121212;--toastify-color-info:#3498db;--toastify-color-success:#07bc0c;--toastify-color-warning:#f1c40f;--toastify-color-error:#e74d3c;--toastify-color-transparent:#ffffffb3;--toastify-icon-color-info:var(--toastify-color-info);--toastify-icon-color-success:var(--toastify-color-success);--toastify-icon-color-warning:var(--toastify-color-warning);--toastify-icon-color-error:var(--toastify-color-error);--toastify-container-width:fit-content;--toastify-toast-width:320px;--toastify-toast-offset:16px;--toastify-toast-top:max(var(--toastify-toast-offset),env(safe-area-inset-top));--toastify-toast-right:max(var(--toastify-toast-offset),env(safe-area-inset-right));--toastify-toast-left:max(var(--toastify-toast-offset),env(safe-area-inset-left));--toastify-toast-bottom:max(var(--toastify-toast-offset),env(safe-area-inset-bottom));--toastify-toast-background:#fff;--toastify-toast-padding:14px;--toastify-toast-min-height:64px;--toastify-toast-max-height:800px;--toastify-toast-bd-radius:6px;--toastify-toast-shadow:0px 4px 12px #0000001a;--toastify-font-family:sans-serif;--toastify-z-index:9999;--toastify-text-color-light:#757575;--toastify-text-color-dark:#fff;--toastify-text-color-info:#fff;--toastify-text-color-success:#fff;--toastify-text-color-warning:#fff;--toastify-text-color-error:#fff;--toastify-spinner-color:#616161;--toastify-spinner-color-empty-area:#e0e0e0;--toastify-color-progress-light:linear-gradient(90deg,#4cd964,#5ac8fa,#007aff,#34aadc,#5856d6,#ff2d55);--toastify-color-progress-dark:#bb86fc;--toastify-color-progress-info:var(--toastify-color-info);--toastify-color-progress-success:var(--toastify-color-success);--toastify-color-progress-warning:var(--toastify-color-warning);--toastify-color-progress-error:var(--toastify-color-error);--toastify-color-progress-bgo:0.2}.Toastify__toast-container{box-sizing:border-box;color:#fff;display:flex;flex-direction:column;position:fixed;-webkit-transform:translateZ(9999);-webkit-transform:translateZ(var(--toastify-z-index));width:-webkit-fit-content;width:fit-content;width:var(--toastify-container-width);z-index:9999;z-index:var(--toastify-z-index)}.Toastify__toast-container--top-left{left:max(16px,env(safe-area-inset-left));left:var(--toastify-toast-left);top:max(16px,env(safe-area-inset-top));top:var(--toastify-toast-top)}.Toastify__toast-container--top-center{align-items:center;left:50%;top:max(16px,env(safe-area-inset-top));top:var(--toastify-toast-top);transform:translateX(-50%)}.Toastify__toast-container--top-right{align-items:end;right:max(16px,env(safe-area-inset-right));right:var(--toastify-toast-right);top:max(16px,env(safe-area-inset-top));top:var(--toastify-toast-top)}.Toastify__toast-container--bottom-left{bottom:max(16px,env(safe-area-inset-bottom));bottom:var(--toastify-toast-bottom);left:max(16px,env(safe-area-inset-left));left:var(--toastify-toast-left)}.Toastify__toast-container--bottom-center{align-items:center;bottom:max(16px,env(safe-area-inset-bottom));bottom:var(--toastify-toast-bottom);left:50%;transform:translateX(-50%)}.Toastify__toast-container--bottom-right{align-items:end;bottom:max(16px,env(safe-area-inset-bottom));bottom:var(--toastify-toast-bottom);right:max(16px,env(safe-area-inset-right));right:var(--toastify-toast-right)}.Toastify__toast{--y:0;align-items:center;border-radius:6px;border-radius:var(--toastify-toast-bd-radius);box-shadow:0 4px 12px #0000001a;box-shadow:var(--toastify-toast-shadow);box-sizing:border-box;display:flex;flex:1 1 auto;font-family:sans-serif;font-family:var(--toastify-font-family);margin-bottom:1rem;max-height:800px;max-height:var(--toastify-toast-max-height);min-height:64px;min-height:var(--toastify-toast-min-height);padding:14px;padding:var(--toastify-toast-padding);position:relative;touch-action:none;width:320px;width:var(--toastify-toast-width);word-break:break-word;z-index:0}@media only screen and (max-width:480px){.Toastify__toast-container{left:env(safe-area-inset-left);margin:0;width:100vw}.Toastify__toast-container--top-center,.Toastify__toast-container--top-left,.Toastify__toast-container--top-right{top:env(safe-area-inset-top);transform:translateX(0)}.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-right{bottom:env(safe-area-inset-bottom);transform:translateX(0)}.Toastify__toast-container--rtl{left:auto;right:env(safe-area-inset-right)}.Toastify__toast{--toastify-toast-width:100%;border-radius:0;margin-bottom:0}}.Toastify__toast-container[data-stacked=true]{width:320px;width:var(--toastify-toast-width)}.Toastify__toast--stacked{position:absolute;transform:translate3d(0,var(--y),0) scale(var(--s));transition:transform .3s;width:100%}.Toastify__toast--stacked[data-collapsed] .Toastify__close-button,.Toastify__toast--stacked[data-collapsed] .Toastify__toast-body{transition:opacity .1s}.Toastify__toast--stacked[data-collapsed=false]{overflow:visible}.Toastify__toast--stacked[data-collapsed=true]:not(:last-child)>*{opacity:0}.Toastify__toast--stacked:after{bottom:100%;content:"";height:calc(var(--g)*1px);left:0;position:absolute;right:0}.Toastify__toast--stacked[data-pos=top]{top:0}.Toastify__toast--stacked[data-pos=bot]{bottom:0}.Toastify__toast--stacked[data-pos=bot].Toastify__toast--stacked:before{transform-origin:top}.Toastify__toast--stacked[data-pos=top].Toastify__toast--stacked:before{transform-origin:bottom}.Toastify__toast--stacked:before{bottom:0;content:"";height:100%;left:0;position:absolute;right:0;transform:scaleY(3);z-index:-1}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-icon{-webkit-margin-end:10px;display:flex;flex-shrink:0;margin-inline-end:10px;width:22px}.Toastify--animate{animation-duration:.5s;animation-fill-mode:both}.Toastify--animate-icon{animation-duration:.3s;animation-fill-mode:both}.Toastify__toast-theme--dark{background:#121212;background:var(--toastify-color-dark);color:#fff;color:var(--toastify-text-color-dark)}.Toastify__toast-theme--colored.Toastify__toast--default,.Toastify__toast-theme--light{background:#fff;background:var(--toastify-color-light);color:#757575;color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{background:#3498db;background:var(--toastify-color-info);color:#fff;color:var(--toastify-text-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{background:#07bc0c;background:var(--toastify-color-success);color:#fff;color:var(--toastify-text-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{background:#f1c40f;background:var(--toastify-color-warning);color:#fff;color:var(--toastify-text-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{background:#e74d3c;background:var(--toastify-color-error);color:#fff;color:var(--toastify-text-color-error)}.Toastify__progress-bar-theme--light{background:linear-gradient(90deg,#4cd964,#5ac8fa,#007aff,#34aadc,#5856d6,#ff2d55);background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:#bb86fc;background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:#3498db;background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:#07bc0c;background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:#f1c40f;background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:#e74d3c;background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning{background:#ffffffb3;background:var(--toastify-color-transparent)}.Toastify__close-button{background:#0000;border:none;color:#fff;cursor:pointer;opacity:.7;outline:none;padding:0;position:absolute;right:6px;top:6px;transition:.3s ease;z-index:1}.Toastify__toast--rtl .Toastify__close-button{left:6px;right:auto}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:focus,.Toastify__close-button:hover{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{bottom:0;height:100%;left:0;opacity:.7;position:absolute;transform-origin:left;width:100%;z-index:1}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{border-bottom-left-radius:0;left:auto;right:0;transform-origin:right}.Toastify__progress-bar--wrp{border-bottom-left-radius:6px;border-bottom-left-radius:var(--toastify-toast-bd-radius);border-bottom-right-radius:6px;border-bottom-right-radius:var(--toastify-toast-bd-radius);bottom:0;height:5px;left:0;overflow:hidden;position:absolute;width:100%}.Toastify__progress-bar--wrp[data-hidden=true]{opacity:0}.Toastify__progress-bar--bg{height:100%;opacity:.2;opacity:var(--toastify-color-progress-bgo);width:100%}.Toastify__spinner{animation:Toastify__spin .65s linear infinite;border:2px solid #e0e0e0;border-color:var(--toastify-spinner-color-empty-area);border-radius:100%;border-right-color:#616161;border-right-color:var(--toastify-spinner-color);box-sizing:border-box;height:20px;width:20px}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,var(--y),0)}to{opacity:0;transform:translate3d(2000px,var(--y),0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,var(--y),0)}to{opacity:0;transform:translate3d(-2000px,var(--y),0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--bottom-left,.Toastify__bounce-enter--top-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--bottom-right,.Toastify__bounce-enter--top-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--bottom-left,.Toastify__bounce-exit--top-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--bottom-right,.Toastify__bounce-exit--top-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:translate3d(0,var(--y),0) scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{animation-timing-function:ease-in;opacity:0;transform:perspective(400px) rotateX(90deg)}40%{animation-timing-function:ease-in;transform:perspective(400px) rotateX(-20deg)}60%{opacity:1;transform:perspective(400px) rotateX(10deg)}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:translate3d(0,var(--y),0) perspective(400px)}30%{opacity:1;transform:translate3d(0,var(--y),0) perspective(400px) rotateX(-20deg)}to{opacity:0;transform:translate3d(0,var(--y),0) perspective(400px) rotateX(90deg)}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideOutRight{0%{transform:translate3d(0,var(--y),0)}to{transform:translate3d(110%,var(--y),0);visibility:hidden}}@keyframes Toastify__slideOutLeft{0%{transform:translate3d(0,var(--y),0)}to{transform:translate3d(-110%,var(--y),0);visibility:hidden}}@keyframes Toastify__slideOutDown{0%{transform:translate3d(0,var(--y),0)}to{transform:translate3d(0,500px,0);visibility:hidden}}@keyframes Toastify__slideOutUp{0%{transform:translate3d(0,var(--y),0)}to{transform:translate3d(0,-500px,0);visibility:hidden}}.Toastify__slide-enter--bottom-left,.Toastify__slide-enter--top-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--bottom-right,.Toastify__slide-enter--top-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--bottom-left,.Toastify__slide-exit--top-left{animation-duration:.3s;animation-name:Toastify__slideOutLeft;animation-timing-function:ease-in}.Toastify__slide-exit--bottom-right,.Toastify__slide-exit--top-right{animation-duration:.3s;animation-name:Toastify__slideOutRight;animation-timing-function:ease-in}.Toastify__slide-exit--top-center{animation-duration:.3s;animation-name:Toastify__slideOutUp;animation-timing-function:ease-in}.Toastify__slide-exit--bottom-center{animation-duration:.3s;animation-name:Toastify__slideOutDown;animation-timing-function:ease-in}@keyframes Toastify__spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.map-page{animation:fadeIn .6s ease-out;background-color:#0f0f0f;color:#f1f1f1;min-height:100vh;padding-top:var(--page-content-offset);position:relative;width:100%}:root.light-mode .map-page{background-color:#f8f9fa;color:#333}@media (max-width:768px){.map-page{padding-top:var(--page-content-offset)}.map-page .map-container{height:calc(100vh - var(--navbar-total-height) - 380px)}}@media (max-width:480px){.map-page{padding-top:var(--page-content-offset)}.map-page .map-container{height:calc(100vh - var(--navbar-total-height) - 420px)}}.map-error,.map-loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:80vh;text-align:center}.map-loading p{color:#aaa;font-size:1.2rem;margin-top:1rem}.map-error h2{color:#ef4444;margin-bottom:1rem}.map-error p{color:#aaa;margin-bottom:2rem}.retry-button{background:#feac34;border-radius:8px;color:#1e1e1e;font-weight:600;padding:.75rem 2rem;transition:all .2s ease}.retry-button:hover{background:#f79400;transform:translateY(-2px)}.map-controls{animation:slideDown .8s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0f0f0f;border-bottom:1px solid #feac3433;padding:1rem 1.5rem}:root.light-mode .map-controls{background:#fff;border-bottom:1px solid #feac344d}.map-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.map-title-section h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#feac34,#ff8a5b);-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700;margin:0 0 .25rem}.camera-count{align-items:baseline;display:flex;gap:.5rem}.count-number{color:#34d399;font-size:1.25rem;font-weight:700}.count-label{color:#9ca3af;font-size:.875rem;font-weight:500}.control-panels{display:flex;flex-wrap:wrap;gap:1rem}.control-panel{animation:panelSlideUp .6s cubic-bezier(.4,0,.2,1) forwards;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#2a2a2af2;border:1px solid #ffffff1a;border-radius:12px;box-shadow:0 6px 24px #0000004d;flex:1 1;min-width:240px;opacity:0;padding:1rem;transform:translateY(30px);transition:all .4s cubic-bezier(.4,0,.2,1)}.control-panel:first-child{animation-delay:.1s}.control-panel:nth-child(2){animation-delay:.2s}.control-panel:nth-child(3){animation-delay:.3s}@keyframes panelSlideUp{to{opacity:100%;transform:translateY(0)}}.control-panel:hover{border-color:#feac3466;box-shadow:0 16px 48px #00000080,0 0 30px #feac341a;transform:translateY(-4px) scale(1.02)}.panel-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.panel-header h3{color:#e5e7eb;font-size:.9rem;font-weight:600;margin:0}.filter-buttons-grid{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(2,1fr)}.filter-chip{align-items:center;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;color:#9ca3af;cursor:pointer;display:flex;font-size:.8rem;font-weight:500;gap:.4rem;overflow:hidden;padding:.6rem .8rem;position:relative;transition:all .2s ease}.filter-chip:before{background:linear-gradient(45deg,#0000,#ffffff1a);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .2s ease}.filter-chip:hover:before{opacity:100%}.filter-chip:hover{border-color:#feac3466;color:#f3f4f6;transform:translateY(-1px)}.filter-chip.active{background:#feac3426;border-color:#feac34;color:#feac34;font-weight:600}.filter-chip.online.active{background:#34d39926;border-color:#34d399;color:#34d399}.filter-chip.loading.active{background:#feac3426;border-color:#feac34;color:#feac34}.filter-chip.offline.active{background:#ef444426;border-color:#ef4444;color:#ef4444}.chip-indicator{border-radius:50%;height:8px;width:8px}.online-indicator{background:#34d399;box-shadow:0 0 8px #34d39966}.loading-indicator{animation:pulse 2s infinite;background:#feac34;box-shadow:0 0 8px #feac3466}.offline-indicator{background:#ef4444;box-shadow:0 0 8px #ef444466}.chip-label{font-weight:500}.refresh-button{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#feac341a;border:1px solid #feac344d;border-radius:10px;color:#feac34;display:flex;font-size:.8rem;font-weight:600;gap:.4rem;padding:.6rem 1rem;transition:all .3s ease}.refresh-button:hover{background:#feac3433;border-color:#feac34;box-shadow:0 4px 20px #feac3433;transform:translateY(-2px)}.refresh-button:active{transform:translateY(0)}.refresh-button svg{transition:transform .5s ease}.refresh-button:hover svg{transform:rotate(1turn)}.toggle-button{align-items:center;background:#ffffff0d;border:1px solid #ffffff26;border-radius:12px;color:#9ca3af;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.625rem;overflow:hidden;padding:.75rem 1rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.toggle-button:before{background:linear-gradient(90deg,#0000,#ffffff1a,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.toggle-button:hover:before{left:100%}.toggle-button:hover{background:#ffffff1a;border-color:#feac3480;box-shadow:0 4px 16px #feac3426;color:#f3f4f6;transform:translateY(-1px)}.toggle-button.active{background:#feac3433;border-color:#feac34;box-shadow:0 4px 20px #feac3440;color:#feac34;font-weight:600;transform:translateY(-2px)}.toggle-button.satellite.active{background:#3b82f633;border-color:#3b82f6;box-shadow:0 4px 20px #3b82f640;color:#60a5fa;transform:translateY(-2px)}.toggle-button.heatmap.active{background:#34d39933;border-color:#34d399;box-shadow:0 4px 20px #34d39940;color:#34d399;transform:translateY(-2px)}.panel-content{animation:contentFadeIn .5s ease .4s both}@keyframes contentFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:100%;transform:translateY(0)}}.slider-control{margin-bottom:1rem}.slider-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.slider-header label{color:#9ca3af;font-size:.875rem;font-weight:500}.slider-value{color:#34d399;font-size:.875rem;font-weight:600}.modern-slider{-webkit-appearance:none;appearance:none;background:#ffffff1a;border-radius:3px;cursor:pointer;height:6px;outline:none;width:100%}.modern-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#34d399;border:2px solid #1f2937;border-radius:50%;box-shadow:0 4px 12px #34d3994d;cursor:pointer;height:20px;-webkit-transition:all .2s ease;transition:all .2s ease;width:20px}.modern-slider::-webkit-slider-thumb:hover{background:#10b981;box-shadow:0 8px 20px #34d39980;transform:scale(1.2)}.modern-slider.heatmap-slider::-webkit-slider-thumb{background:#34d399}.modern-slider::-moz-range-thumb{background:#34d399;border:2px solid #1f2937;border-radius:50%;box-shadow:0 4px 12px #34d3994d;cursor:pointer;height:20px;width:20px}.traffic-metrics{background:#0003;border:1px solid #ffffff0d;border-radius:12px;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1rem;padding:1rem}.metric{flex:1 1;text-align:center}.metric-value{color:#34d399;font-size:1.25rem;font-weight:700;margin-bottom:.25rem}.metric-value.warning{animation:pulse 2s infinite;color:#feac34}.metric-label{color:#9ca3af;font-size:.75rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.intensity-metric{flex:1.5 1}.intensity-bar-modern{background:#ffffff1a;border-radius:4px;height:8px;margin-top:.5rem;overflow:hidden;position:relative}.intensity-fill-modern{background:linear-gradient(90deg,#34d399,#feac34 60%,#ef4444);border-radius:4px;height:100%;position:relative;transition:width .5s ease}.intensity-fill-modern:after{animation:shimmer 2s infinite;background:linear-gradient(45deg,#0000,#fff3);bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes shimmer{0%{opacity:0;transform:translateX(-100%) skewX(-15deg)}50%{opacity:100%}to{opacity:0;transform:translateX(100%) skewX(-15deg)}}.traffic-legend{margin-top:1rem}.legend-label{color:#9ca3af;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.legend-bar{background:linear-gradient(90deg,#34d399,#feac34 60%,#ef4444 90%,#dc2626);border:1px solid #ffffff1a;border-radius:8px;height:16px;position:relative}.legend-markers{color:#9ca3af;display:flex;font-size:.75rem;justify-content:space-between;margin-top:.5rem}.opacity-slider{-webkit-appearance:none;appearance:none;background:#444;border-radius:2px;height:4px;outline:none;width:100%}.opacity-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#feac34;border-radius:50%;box-shadow:0 2px 4px #0000004d;cursor:pointer;height:16px;-webkit-transition:all .2s ease;transition:all .2s ease;width:16px}.opacity-slider::-webkit-slider-thumb:hover{background:#f79400;transform:scale(1.1)}.opacity-slider::-moz-range-thumb{background:#feac34;border:none;border-radius:50%;box-shadow:0 2px 4px #0000004d;cursor:pointer;height:16px;width:16px}.map-page .map-container{height:calc(100vh - var(--navbar-total-height) - 320px);margin-left:calc(-50vw + 50%);margin-right:calc(-50vw + 50%);overflow:hidden;position:relative;width:100vw}.map-page .leaflet-map{height:100%;width:100%;z-index:1}.leaflet-popup-content-wrapper{background:#2a2a2a;border-radius:8px;color:#fff}:root.light-mode .leaflet-popup-content-wrapper{background:#fff;border:1px solid #e5e5e5;box-shadow:0 10px 25px #0000004d;color:#333}.leaflet-popup-tip{background:#2a2a2a}:root.light-mode .leaflet-popup-tip{background:#fff}.marker-popup{min-width:180px;text-align:center}.marker-popup strong{color:#feac34;display:block;font-size:1rem;margin-bottom:.5rem}.status-text{border-radius:4px;display:inline-block;font-size:.8rem;font-weight:600;margin:.3rem 0;padding:.2rem .5rem;text-transform:uppercase}.status-text.online{background:#4ade8033;color:#4ade80}.status-text.loading{background:#feac3433;color:#feac34}.status-text.offline{background:#ef444433;color:#ef4444}.marker-popup small{color:#aaa;font-style:italic}.camera-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000c;bottom:0;display:flex;justify-content:center;left:0;padding:2rem;position:fixed;right:0;top:0;z-index:10000}.camera-modal{background:#2a2a2a;border-radius:20px;max-width:800px}:root.light-mode .camera-modal{background:#fff;border:1px solid #e5e5e5}.camera-modal-header{align-items:center;background:#1e1e1e;border-bottom:1px solid #444;display:flex;justify-content:space-between;padding:1.5rem 2rem}.camera-modal-header h3{color:#feac34;font-size:1.5rem;margin:0}.camera-modal-close{align-items:center;background:none;border:none;border-radius:50%;color:#aaa;cursor:pointer;display:flex;font-size:2rem;height:40px;justify-content:center;transition:color .2s ease;width:40px}.camera-modal-close:hover{background:#ffffff1a;color:#fff}.camera-modal-content{max-height:70vh;overflow-y:auto;padding:2rem}.camera-image-section,.camera-stream-section{margin-bottom:2rem}.camera-image-section h4,.camera-stream-section h4{color:#feac34;font-size:1.2rem;margin:0 0 1rem}.camera-image,.camera-stream{background:#1e1e1e;border-radius:12px;max-height:400px;object-fit:cover;width:100%}.camera-image-error{background:#1e1e1e;border:2px dashed #444;border-radius:12px;color:#aaa;padding:3rem;text-align:center}.camera-details h4{color:#feac34;font-size:1.2rem;margin:0 0 1rem}.camera-detail-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.camera-detail-item{background:#1e1e1e;border:1px solid #444;border-radius:8px;padding:1rem}.camera-detail-label{color:#aaa;display:block;font-size:.85rem;font-weight:600;letter-spacing:.5px;margin-bottom:.3rem;text-transform:uppercase}.camera-detail-item span:not(.camera-detail-label){color:#fff;font-weight:600}.camera-status-badge{border-radius:6px;font-size:.8rem;font-weight:700;letter-spacing:.5px;padding:.3rem .8rem;text-transform:uppercase}.camera-status-badge.online{background:#4ade80;color:#1e1e1e}.camera-status-badge.loading{background:#feac34;color:#1e1e1e}.camera-status-badge.offline{background:#ef4444;color:#fff}.historical-images{margin-top:2rem}.historical-images h4{color:#feac34;margin:0 0 1rem}.historical-images-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.historical-image{background:#1e1e1e;border:1px solid #444;border-radius:8px;height:120px;object-fit:cover;transition:transform .2s ease;width:100%}.historical-image:hover{transform:scale(1.05)}.map-legend{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#1e1e1ef2;border:1px solid #feac3433;border-radius:16px;bottom:120px;box-shadow:0 8px 32px #0000004d;left:2rem;padding:1.25rem 1.75rem;position:absolute;transition:all .3s ease;z-index:1000}.map-legend h4{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#feac34,#ff8a5b);-webkit-background-clip:text;background-clip:text;font-size:1.1rem;font-weight:700;margin:0 0 1.25rem}.legend-items{display:flex;flex-direction:column;gap:.75rem}.legend-item{color:#e5e7eb;font-size:.875rem;font-weight:500;gap:1rem;padding:.25rem 0;transition:all .2s ease}.legend-item:hover{color:#feac34;transform:translateX(4px)}.legend-color{border:2px solid #1e1e1e;border-radius:50%;box-shadow:0 2px 8px #0000004d;height:18px;transition:all .2s ease;width:18px}.legend-item:hover .legend-color{border-color:#feac34;transform:scale(1.1)}.legend-color.online{background:#4ade80}.legend-color.loading{background:#feac34}.legend-color.offline{background:#ef4444}@media (max-width:1024px){.control-panels{flex-direction:column;gap:1rem}.control-panel{min-width:auto}}@media (max-width:768px){.map-controls{padding:1rem}.map-header{align-items:flex-start;flex-direction:column;gap:1rem;margin-bottom:1rem}.map-title-section h2{font-size:1.5rem}.refresh-button{align-self:stretch;justify-content:center}.control-panel{min-width:auto;padding:1rem}.filter-buttons-grid{gap:.5rem;grid-template-columns:1fr 1fr}.filter-chip{font-size:.8rem;padding:.625rem .75rem}.traffic-metrics{flex-direction:column;gap:.75rem}.metric{align-items:center;display:flex;justify-content:space-between;text-align:left}.metric-value{font-size:1.125rem}.intensity-metric{align-items:stretch;flex-direction:column}.map-container{height:calc(100vh - 200px)}.camera-modal-content,.camera-modal-overlay{padding:1rem}.camera-detail-grid{grid-template-columns:1fr}.historical-images-grid{grid-template-columns:repeat(2,1fr)}.map-legend{bottom:1rem;left:1rem;max-width:none;right:1rem}.legend-items{flex-flow:row wrap;justify-content:space-around}}@media (max-width:480px){.map-controls{padding:.5rem}.camera-modal-header{padding:1rem}.camera-modal-header h3{font-size:1.2rem}.map-container{height:calc(100vh - 160px)}.historical-images-grid{grid-template-columns:1fr}}.camera-modal-content::-webkit-scrollbar{width:8px}.camera-modal-content::-webkit-scrollbar-track{background:#1e1e1e;border-radius:4px}.camera-modal-content::-webkit-scrollbar-thumb{background:#444;border-radius:4px}.camera-modal-content::-webkit-scrollbar-thumb:hover{background:#555}.lane-closures-panel{background:linear-gradient(135deg,#1e1e1ef2,#191919f2)}.lane-closures-panel .panel-header h3{color:#dc2626}.lane-closures-panel .toggle-button.lane-closures{background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff}.lane-closures-panel .toggle-button.lane-closures:hover{background:linear-gradient(135deg,#b91c1c,#991b1b)}.lane-closures-panel .toggle-button.lane-closures.active{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 8px 25px #dc26264d}.lane-closure-loading{align-items:center;display:flex;justify-content:center;min-height:80px;padding:2rem 1rem}.lane-closure-metrics{background:#0003;border:1px solid #ffffff0d;border-radius:12px;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1rem;padding:1rem}:root.light-mode .lane-closure-metrics{background:#fff;border:1px solid #e5e5e5}.lane-closure-metrics .metric-value{color:#dc2626}.lane-closure-metrics .metric-value.warning{animation:pulse 2s infinite;color:#f59e0b}.lane-closure-filters{background:#0000001a;border:1px solid #ffffff0d;border-radius:12px;margin-top:1rem;padding:1rem}:root.light-mode .lane-closure-filters{background:#f8f9fa;border:1px solid #e5e5e5}.filter-section{margin-bottom:1rem}.filter-section:last-child{margin-bottom:0}.filter-section h4{color:#9ca3af;font-size:.875rem;font-weight:600;letter-spacing:.5px;margin:0 0 .75rem;text-transform:uppercase}.active-closure-indicator{background:#dc2626}.upcoming-closure-indicator{background:#f59e0b}.completed-closure-indicator{background:#6b7280}.low-severity-indicator{background:#22c55e}.medium-severity-indicator{background:#f59e0b}.high-severity-indicator{background:#ef4444}.filter-chip.active-closure.active{background:linear-gradient(135deg,#dc2626,#b91c1c);border-color:#dc2626;color:#fff}.filter-chip.upcoming-closure.active{background:linear-gradient(135deg,#f59e0b,#d97706);border-color:#f59e0b;color:#fff}.filter-chip.completed-closure.active{background:linear-gradient(135deg,#6b7280,#4b5563);border-color:#6b7280;color:#fff}.filter-chip.low-severity.active{background:linear-gradient(135deg,#22c55e,#16a34a);border-color:#22c55e;color:#fff}.filter-chip.medium-severity.active{background:linear-gradient(135deg,#f59e0b,#d97706);border-color:#f59e0b;color:#fff}.filter-chip.high-severity.active{background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#ef4444;color:#fff}.lane-closure-popup{color:#1e1e1e;min-width:250px}.lane-closure-popup strong{color:#1e1e1e;display:block;font-weight:700;margin-bottom:.5rem}.severity-text{border-radius:4px;display:inline-block;font-size:.75rem;font-weight:600;margin:.25rem 0;padding:.2rem .5rem;text-transform:uppercase}.severity-text.low{background:#22c55e;color:#fff}.severity-text.medium{background:#f59e0b;color:#fff}.severity-text.high{background:#ef4444;color:#fff}.status-text.active{background:#dc2626;color:#fff}.status-text.upcoming{background:#f59e0b;color:#fff}.status-text.completed{background:#6b7280;color:#fff}.lane-closure-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000c;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:10000}.lane-closure-modal{background:linear-gradient(135deg,#1e1e1e,#0f0f0f);border:1px solid #feac344d;border-radius:16px;box-shadow:0 20px 60px #00000080}:root.light-mode .lane-closure-modal{background:linear-gradient(135deg,#fff,#f8f9fa);border:1px solid #feac3466;box-shadow:0 20px 60px #00000026}.lane-closure-modal-header{align-items:center;background:linear-gradient(135deg,#dc26261a,#0000);border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;padding:1.5rem 2rem}.lane-closure-modal-header h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#dc2626,#f59e0b);-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700;margin:0}.lane-closure-modal-close{align-items:center;background:none;border:none;border-radius:50%;color:#aaa;cursor:pointer;display:flex;font-size:2rem;height:40px;justify-content:center;padding:0;transition:all .2s ease;width:40px}.lane-closure-modal-close:hover{background:#ef444433;color:#ef4444;transform:scale(1.1)}.lane-closure-modal-content{max-height:calc(90vh - 100px);overflow-y:auto;padding:1.5rem 2rem 2rem}.closure-section{background:#ffffff08;border:1px solid #ffffff0d;border-radius:12px;margin-bottom:2rem;padding:1.5rem}.closure-section:last-child{margin-bottom:0}.closure-section h4{color:#feac34;font-size:1.1rem;font-weight:600;letter-spacing:.5px;margin:0 0 1.25rem;text-transform:uppercase}.closure-detail-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.closure-detail-item{align-items:center;background:#0003;border:1px solid #ffffff0d;border-radius:8px;display:flex;justify-content:space-between;padding:.75rem 1rem}:root.light-mode .closure-detail-item{background:#fff;border:1px solid #e5e5e5}.closure-detail-label{color:#9ca3af;font-size:.875rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.closure-detail-value{color:#f1f1f1;font-weight:600;text-align:right}.closure-detail-value.closure-impact{color:#ef4444;font-weight:700}.closure-status-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.status-item{align-items:center;background:#0003;border:1px solid #ffffff0d;border-radius:8px;display:flex;justify-content:space-between;padding:1rem}:root.light-mode .status-item{background:#fff;border:1px solid #e5e5e5}.status-label{color:#9ca3af;font-size:.875rem;font-weight:600}.severity-badge,.status-badge,.status-label{letter-spacing:.5px;text-transform:uppercase}.severity-badge,.status-badge{border-radius:6px;box-shadow:0 2px 8px #0000004d;color:#fff;font-size:.8rem;font-weight:700;padding:.5rem 1rem}.legend-section{margin-bottom:1rem}.legend-section:last-child{margin-bottom:0}.legend-section h5{color:#9ca3af;font-size:.875rem;font-weight:600;letter-spacing:.5px;margin:0 0 .75rem;text-transform:uppercase}@media (max-width:768px){.lane-closure-modal{margin:1rem;max-width:calc(100vw - 2rem)}.lane-closure-modal-header{padding:1rem 1.5rem}.lane-closure-modal-content{padding:1rem 1.5rem 1.5rem}.closure-detail-grid{grid-template-columns:1fr}.closure-detail-item{align-items:flex-start;flex-direction:column;gap:.5rem}.closure-detail-value{text-align:left}.closure-status-grid{grid-template-columns:1fr}}.legend-color.lane-closure-low{background:#22c55e}.legend-color.lane-closure-medium{background:#f59e0b}.legend-color.lane-closure-high{background:#ef4444}@keyframes pulse{0%,to{opacity:100%}50%{opacity:60%}}.filter-button.loading:after{animation:pulse 1.5s infinite;background:currentcolor;border-radius:50%;content:"";height:6px;position:absolute;right:8px;top:50%;transform:translateY(-50%);width:6px}:root.light-mode{--content-bg:#f9f9f9;--incident-id-color:#d97700;--severity-critical-bg:#dc262626;--severity-critical-text:#dc2626;--severity-high-bg:#dc262626;--severity-high-text:#dc2626;--severity-medium-bg:#feac3426;--severity-medium-text:#feac34;--severity-low-bg:#22c55e26;--severity-low-text:#22c55e;--status-active-bg:#f443;--status-active-text:#f44;--status-inprogress-bg:#007bff33;--status-inprogress-text:#007bff;--status-resolved-bg:#4f43;--status-resolved-text:#199019;--action-btn-bg:none;--action-btn-text:#d97700;--action-btn-hover-bg:#d977001a;--modal-header-bg:#d97700;--modal-header-text:#fff;--form-section-title:#d97700;--form-section-border:#d1d1d1;--form-input-bg:#f5f5f5;--form-input-border:#ccc;--form-input-text:#333;--form-error-text:#f44;--form-help-text:#666;--file-upload-border:#ccc;--file-upload-hover-border:#d97700;--file-upload-dragover-bg:#d977000d;--file-upload-text:#666;--file-upload-btn-bg:#0000;--file-upload-btn-text:#d97700;--file-upload-btn-border:#d97700;--uploaded-file-bg:#0000000d;--file-remove-text:#f44;--pagination-bg:#f0f0f0;--pagination-text:#333;--pagination-border:#ccc;--pagination-active-bg:#d97700;--pagination-active-text:#fff;--status-select-bg:#fff;--status-select-border:#ccc;--status-select-text:#333;--confirm-btn-bg:#4f43;--confirm-btn-text:#199019;--confirm-btn-border:#44ff444d;--access-denied-bg:#ff44441a;--access-denied-text:#f44}:root.dark-mode{--button-secondary-hover-bg:#ff8c001a;--content-bg:#1e1e1e;--filter-bg:#3a3a3a;--filter-input-bg:#2a2a2a;--table-bg:#3a3a3a;--table-header-bg:#404040;--table-header-text:#ccc;--table-border:#555;--table-hover-bg:#ff8c000d;--incident-id-color:#fa3;--severity-critical-bg:#f8717133;--severity-critical-text:#f87171;--severity-high-bg:#f8717133;--severity-high-text:#f87171;--severity-medium-bg:#fbbf2433;--severity-medium-text:#ff8a5b;--severity-low-bg:#4ade8033;--severity-low-text:#4ade80;--status-active-bg:#f443;--status-active-text:#f44;--status-inprogress-bg:#007bff33;--status-inprogress-text:#007bff;--status-resolved-bg:#4f43;--status-resolved-text:#4f4;--action-btn-bg:none;--action-btn-text:#fa3;--action-btn-hover-bg:#ff8c001a;--modal-content-bg:#3a3a3a;--modal-header-bg:#fa3;--modal-header-text:#000;--form-section-title:#fa3;--form-section-border:#555;--form-input-bg:#2a2a2a;--form-input-border:#666;--form-input-text:#fff;--form-error-text:#f44;--form-help-text:#999;--file-upload-border:#666;--file-upload-hover-border:#fa3;--file-upload-dragover-bg:#ff8c000d;--file-upload-text:#ccc;--file-upload-btn-bg:#0000;--file-upload-btn-text:#fa3;--file-upload-btn-border:#fa3;--uploaded-file-bg:#ffffff0d;--file-remove-text:#f44;--pagination-bg:#3a3a3a;--pagination-text:#ccc;--pagination-border:#666;--pagination-active-bg:#fa3;--pagination-active-text:#000;--status-select-bg:#2a2a2a;--status-select-border:#666;--status-select-text:#fff;--confirm-btn-bg:#4f43;--confirm-btn-text:#4f4;--confirm-btn-border:#44ff444d;--access-denied-bg:#ff44441a;--access-denied-text:#f44}.incidents-page{background-color:#0f0f0f;color:#f1f1f1;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:100vh;padding-top:var(--page-content-offset)}:root.light-mode .incidents-page{background-color:var(--background-color);color:var(--text-color)}@media (max-width:768px){.incidents-page{padding-top:var(--page-content-offset)}}@media (max-width:480px){.incidents-page{padding-top:var(--page-content-offset)}}.incidents-header{background-color:var(--header-bg);border-bottom:1px solid var(--header-border);flex-wrap:wrap;justify-content:space-between;padding:1.5rem 2rem}.incidents-header,.incidents-title{align-items:center;display:flex;gap:1rem}.incidents-sidebar{color:var(--subtitle-color)}.incidents-title h2{color:var(--title-color);font-size:1.8rem;font-weight:600;margin:0}.incidents-subtitle{color:var(--subtitle-color);font-size:.9rem;margin-top:.25rem}.incidents-actions{align-items:center;display:flex;gap:1rem}.rprt-btn-primary{align-items:center;background-color:var(--button-primary-bg);border:none;border-radius:6px;color:var(--button-primary-text);cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s ease}.rprt-btn-primary svg{height:20px;width:20px}.rprt-btn-primary:hover{background-color:var(--button-primary-hover);transform:translateY(-1px)}.btn-secondary{align-items:center;background-color:var(--button-secondary-bg);border:1px solid var(--button-secondary-border);border-radius:6px;color:var(--button-secondary-text);cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s ease}.btn-secondary svg{height:20px;width:20px}.btn-secondary:hover{background-color:var(--button-secondary-hover-bg);border-color:var(--button-secondary-hover-border);color:var(--text-color)}.incidents-content{background-color:var(--content-bg);display:flex;flex-direction:column;margin:0 auto;max-width:1400px;min-height:100vh;padding:2rem}.incidents-filters{grid-gap:1rem;align-items:center;background-color:var(--filter-bg);border-radius:8px;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem;padding:1.5rem}.filter-group{display:flex;flex-direction:column;gap:.4rem}.filter-label{color:var(--subtitle-color);font-size:.8rem;font-weight:500;margin-bottom:.2rem;white-space:nowrap}.filter-input,.filter-select{background-color:var(--filter-input-bg);border:1px solid var(--filter-border);border-radius:6px;box-sizing:border-box;color:var(--form-input-text);font-family:inherit;font-size:.9rem;height:44px;padding:.75rem;transition:all .2s ease}.filter-input:focus,.filter-select:focus{border-color:var(--title-color);box-shadow:0 0 0 2px var(--button-secondary-hover-bg);outline:none}.filter-input:hover,.filter-select:hover{border-color:var(--title-color)}.filter-input::placeholder{color:var(--filter-placeholder)}.filter-select option{background-color:var(--filter-input-bg);color:var(--form-input-text);padding:.5rem}.incidents-list{background-color:var(--table-bg);border-radius:8px;box-shadow:0 2px 8px #0003;height:auto;max-width:100%;min-height:calc(100vh - 300px);min-width:100%;overflow:visible;width:-webkit-max-content;width:max-content}.incidents-list.small-table{min-height:auto;padding-bottom:.5rem}.incidents-list-header{align-items:center;background-color:var(--table-header-bg);border-bottom:1px solid var(--table-border);display:flex;justify-content:space-between;padding:1rem 1.5rem}.incidents-list-title{color:var(--text-color);font-size:1.2rem;font-weight:600;margin:0}.incidents-count{background-color:var(--severity-medium-bg);border-radius:12px;color:var(--severity-medium-text);font-size:.8rem;font-weight:500;padding:.25rem .75rem}.incidents-table{border-collapse:initial;border-spacing:0;height:auto;table-layout:auto;width:100%}.incidents-table td,.incidents-table th{border-bottom:1px solid var(--table-border);padding:.75rem;vertical-align:middle;white-space:nowrap}.incidents-table th{background-color:var(--table-header-bg);color:var(--table-header-text);font-size:.85rem;font-weight:600;letter-spacing:.5px;text-align:left;text-transform:uppercase}.incidents-table td{vertical-align:middle}.incidents-table tr:hover{background-color:var(--table-hover-bg)}.incident-id{color:var(--incident-id-color);font-weight:600}.incident-type{align-items:center;display:flex;font-weight:500;gap:.5rem}.incident-type svg{color:var(--incident-id-color);height:16px;width:16px}.incident-location{color:var(--text-color);font-size:.9rem}.incident-camera{align-items:center;color:var(--subtitle-color);display:flex;font-family:Courier New,monospace;font-size:.8rem;gap:.5rem}.incident-camera svg{height:16px;width:16px}.severity-badge{border-radius:12px;font-size:.75rem;font-weight:500;padding:.25rem .75rem}.severity-badge.critical{background-color:var(--severity-critical-bg);color:var(--severity-critical-text)}.severity-badge.high{background-color:var(--severity-high-bg);color:var(--severity-high-text)}.severity-badge.medium{background-color:var(--severity-medium-bg);color:var(--severity-medium-text)}.severity-badge.low{background-color:var(--severity-low-bg);color:var(--severity-low-text)}.status-badge{border-radius:12px;font-size:.75rem;font-weight:500;padding:.25rem .75rem}.status-badge.active{background-color:var(--status-active-bg);color:var(--status-active-text)}.status-badge.inprogress{background-color:var(--status-inprogress-bg);color:var(--status-inprogress-text)}.status-badge.resolved{background-color:var(--status-resolved-bg);color:var(--status-resolved-text)}.incident-time{color:var(--subtitle-color);font-size:.85rem}.incident-actions{display:flex;gap:.5rem}.action-btn{background:var(--action-btn-bg);border:none;border-radius:4px;color:var(--action-btn-text);cursor:pointer;padding:.25rem .5rem;transition:all .2s ease}.action-btn svg{height:16px;width:16px}.action-btn:hover{background-color:var(--action-btn-hover-bg)}.modal-overlay{align-items:center;background-color:var(--modal-overlay-bg);display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:2000}.modal-content{background-color:var(--modal-content-bg);border-radius:8px;max-height:90vh;max-width:600px;overflow-y:auto;position:relative;width:100%}.modal-header{align-items:center;background-color:var(--modal-header-bg);border-radius:8px 8px 0 0;color:var(--modal-header-text);display:flex;justify-content:space-between;padding:1.5rem}.modal-title{font-size:1.4rem;font-weight:600;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:50%;color:var(--modal-header-text);cursor:pointer;display:flex;font-size:1.5rem;height:30px;justify-content:center;padding:0;transition:background-color .2s ease;width:30px}.modal-close:hover{background-color:#0000001a}.modal-body{padding:2rem}.incident-form{grid-gap:1.5rem;display:grid;gap:1.5rem}.form-section{grid-gap:1rem;display:grid;gap:1rem}.section-title{border-bottom:1px solid var(--form-section-border);color:var(--form-section-title);font-size:1.1rem;font-weight:600;margin:0 0 .5rem;padding-bottom:.5rem}.form-grid{grid-gap:1rem;display:grid;gap:1rem}.form-grid.two-columns{grid-template-columns:1fr 1fr}.form-grid.three-columns{grid-template-columns:1fr 1fr 1fr}.form-group{gap:.5rem}.form-label{color:var(--subtitle-color);font-size:.9rem;font-weight:500}.form-label.required:after{color:var(--form-error-text);content:" *"}.form-input,.form-select,.form-textarea{background-color:var(--form-input-bg);border:1px solid var(--form-input-border);border-radius:4px;color:var(--form-input-text);font-size:.9rem;padding:.75rem;transition:border-color .2s ease}.form-textarea{min-height:100px;resize:vertical}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--title-color);outline:none}.form-input::placeholder,.form-textarea::placeholder{color:var(--filter-placeholder)}.form-select option{background-color:var(--form-input-bg);color:var(--form-input-text)}.form-error{color:var(--form-error-text)}.form-error,.form-help{font-size:.8rem;margin-top:.25rem}.form-help{color:var(--form-help-text)}.file-upload{border:2px dashed var(--file-upload-border);border-radius:6px;padding:2rem;text-align:center;transition:border-color .2s ease}.file-upload.drag-over,.file-upload:hover{border-color:var(--file-upload-hover-border)}.file-upload.drag-over{background-color:var(--file-upload-dragover-bg)}.file-upload-content{align-items:center;display:flex;flex-direction:column;gap:1rem}.file-upload-content svg{color:var(--file-upload-text);height:24px;width:24px}.file-upload-text{color:var(--file-upload-text);font-size:.9rem}.file-upload-input{display:none}.file-upload-btn{background-color:var(--file-upload-btn-bg);border:1px solid var(--file-upload-btn-border);border-radius:4px;color:var(--file-upload-btn-text);cursor:pointer;font-size:.85rem;padding:.5rem 1rem;transition:all .2s ease}.file-upload-btn:hover{background-color:var(--button-secondary-hover-bg)}.uploaded-files{margin-top:1rem}.uploaded-file{align-items:center;background-color:var(--uploaded-file-bg);border-radius:4px;display:flex;justify-content:space-between;margin-bottom:.5rem;padding:.5rem}.file-name{color:var(--file-upload-text);font-size:.85rem}.file-remove{background:none;border:none;border-radius:2px;color:var(--file-remove-text);cursor:pointer;padding:.25rem}.file-remove svg{height:16px;width:16px}.file-remove:hover{background-color:#ff44441a}.form-actions{border-top:1px solid var(--form-section-border);display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem;padding-top:1rem}.btn-submit{align-items:center;background-color:var(--button-primary-bg);border:none;border-radius:6px;color:var(--button-primary-text);cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.75rem 2rem;transition:all .2s ease}.btn-submit svg{height:20px;width:20px}.btn-submit:disabled{cursor:not-allowed;opacity:50%}.btn-submit:hover:not(:disabled){background-color:var(--button-primary-hover);transform:translateY(-1px)}.btn-cancel{background-color:var(--button-secondary-bg);border:1px solid var(--button-secondary-border);border-radius:6px;color:var(--button-secondary-text);cursor:pointer;font-weight:500;padding:.75rem 2rem;transition:all .2s ease}.btn-cancel:hover{border-color:var(--button-secondary-hover-border);color:var(--text-color)}.loading-spinner{border:2px solid #0000;border-top:2px solid var(--loading-spinner);display:inline-block;height:16px;width:16px}.pagination{flex-wrap:wrap;gap:.5rem;margin-top:1rem;padding:.5rem;width:100%}.pagination-btn{background-color:var(--pagination-bg);border:1px solid var(--pagination-border);border-radius:4px;color:var(--pagination-text);cursor:pointer;font-size:.9rem;padding:.5rem .75rem;transition:all .2s ease}.pagination-btn:disabled{cursor:not-allowed;opacity:50%}.pagination-btn.active,.pagination-btn:hover:not(:disabled){background-color:var(--pagination-active-bg);border-color:var(--pagination-active-bg);color:var(--pagination-active-text)}.pagination-info{color:var(--pagination-text);font-size:.9rem;margin:0 1rem}.loading-message{color:var(--text-color)}.access-denied-message,.loading-message{font-size:1rem;padding:2rem;text-align:center}.access-denied-message{background-color:var(--access-denied-bg);border-radius:8px;color:var(--access-denied-text);margin:2rem}.status-update-group{align-items:center;display:flex;gap:.25rem;margin-left:auto}.status-select{background-color:var(--status-select-bg);border:1px solid var(--status-select-border);border-radius:4px;color:var(--status-select-text);cursor:pointer;font-size:.8rem;min-width:100px;padding:.5rem;transition:all .2s ease}.status-select:focus{border-color:var(--title-color);outline:none}.status-select option{background-color:var(--status-select-bg);color:var(--status-select-text)}.confirm-btn{align-items:center;background-color:var(--confirm-btn-bg);border:1px solid var(--confirm-btn-border);border-radius:4px;color:var(--confirm-btn-text);display:flex;justify-content:center;padding:.5rem;transition:all .2s ease}.confirm-btn:disabled{background-color:initial;border-color:#0000;cursor:not-allowed;opacity:50%}.confirm-btn:hover:not(:disabled){background-color:var(--confirm-btn-bg);color:var(--confirm-btn-text);transform:scale(1.05)}@media (max-width:1024px){.incidents-header{align-items:flex-start;flex-direction:column}.form-grid.three-columns,.form-grid.two-columns,.incidents-filters{grid-template-columns:1fr}.incidents-table td,.incidents-table th{padding:.75rem}}@media (max-width:768px){.incidents-content{padding:1rem}.modal-overlay{padding:.5rem}.modal-body{padding:1rem}.form-actions{flex-direction:column}.btn-cancel,.btn-submit{justify-content:center;width:100%}.incidents-list{height:auto;overflow:visible}.incidents-table{display:block;height:auto}.incidents-table,.incidents-table tbody,.incidents-table td,.incidents-table th,.incidents-table thead,.incidents-table tr{display:block}.incidents-table tr{background-color:var(--form-input-bg);border:1px solid var(--table-border);border-radius:6px;height:auto;margin-bottom:.5rem;overflow:visible;padding:.5rem}.incidents-table thead tr{left:-9999px;position:absolute;top:-9999px}.incidents-table td{align-items:center;border:none;border-bottom:1px solid var(--table-border);display:flex;height:auto;justify-content:space-between;padding:.5rem 0;position:relative}.incidents-table td:last-child{border-bottom:none}.incidents-table td:before{color:var(--subtitle-color);content:attr(data-label);flex:0 0 30%;font-size:.8rem;font-weight:600;text-transform:uppercase}.incidents-table td>*{flex:0 0 65%;text-align:right}.status-update-group{justify-content:flex-end;margin-top:.5rem;width:100%}.status-select{flex-grow:1;max-width:120px}.incidents-table td[data-label=Actions]>div{align-items:flex-end;flex-direction:column}.incidents-table td[data-label=Actions]:before{align-self:flex-start}}::selection{background:#ff8c004d;color:#000}.card{background:#fa3}.shadow{box-shadow:0 2px 8px #0000001a}.incident-details-modal{max-height:90vh;max-width:800px;overflow-y:auto;width:95%}.incident-details-grid{grid-gap:1.5rem;display:grid;gap:1.5rem}.detail-section{background:var(--filter-bg);border:1px solid var(--table-border);border-radius:8px;padding:1.5rem}.detail-section.full-width{grid-column:1/-1}.detail-section-title{border-bottom:2px solid var(--title-color);color:var(--title-color);font-size:1.1rem;font-weight:600;margin:0 0 1rem;padding-bottom:.5rem}.detail-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-label{color:var(--subtitle-color);font-size:.85rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.detail-value{align-items:center;background:var(--content-bg);border:1px solid var(--filter-border);border-radius:4px;color:var(--text-color);display:flex;font-size:1rem;gap:.5rem;min-height:40px;padding:.5rem}.detail-value svg{flex-shrink:0}.description-content{background:var(--content-bg);border:1px solid var(--filter-border);border-radius:6px;margin-top:.5rem;padding:1rem}.description-content p{color:var(--text-color);line-height:1.6;margin:0}.detail-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:.5rem}.detail-action-btn{align-items:center;background:var(--button-primary-bg);border:none;border-radius:6px;color:var(--button-primary-text);cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s ease}.detail-action-btn:hover:not(:disabled){background:var(--button-primary-hover);transform:translateY(-1px)}.detail-action-btn:disabled{background:var(--button-secondary-border);color:var(--subtitle-color);cursor:not-allowed;opacity:60%}:root:not(.light-mode) .detail-section{background:var(--filter-bg);border-color:var(--table-border)}:root:not(.light-mode) .description-content,:root:not(.light-mode) .detail-value{background:var(--background-color);border-color:var(--table-border)}@media (max-width:768px){.incident-details-modal{margin:1rem;max-height:95vh;width:100%}.detail-section{padding:1rem}.detail-grid{gap:.75rem;grid-template-columns:1fr}.detail-actions{flex-direction:column}.detail-action-btn{justify-content:center;width:100%}}.account-page{align-items:center;background:linear-gradient(135deg,#0f0f0f,#1a1a1a);box-sizing:border-box;display:flex;height:calc(100vh - 160px);justify-content:center;left:0;overflow:hidden;position:fixed;top:160px;width:100vw;z-index:1000}:root.light-mode .account-page{background:linear-gradient(135deg,#f8f9fa,#e9ecef)}.auth-container{background-color:#1e1e1e;border-radius:20px;box-shadow:0 20px 60px #0006;display:flex;height:80%;max-height:600px;max-width:1100px;min-height:500px;overflow:hidden;width:90vw}:root.light-mode .auth-container{background-color:#fff;box-shadow:0 20px 60px #00000026}.image-container{flex:1 1;overflow:hidden;position:relative}.auth-image{filter:brightness(.7);height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.auth-image:hover{transform:scale(1.05)}.image-overlay{align-items:center;background:linear-gradient(135deg,#feac3433,#0000004d 50%,#0009);bottom:0;display:flex;flex-direction:column;justify-content:center;left:0;padding:2rem;position:absolute;right:0;text-align:center;top:0}.image-overlay h3{color:#fff;font-size:2.5rem;font-weight:700;margin-bottom:1rem;text-shadow:2px 2px 4px #000000b3}.image-overlay p{color:#f0f0f0;font-size:1.2rem;font-weight:300;line-height:1.4;max-width:300px;text-shadow:1px 1px 2px #000000b3}.login-container{background-color:#1e1e1e;border-radius:0;box-shadow:none;display:flex;flex:1 1;flex-direction:column;height:auto;justify-content:center;padding:3rem;width:auto}.showcase-container{background-color:#1e1e1e;border-radius:15px;box-shadow:0 4px 10px #0000004d;height:auto;padding:2rem;width:500px}.login-container h2{color:#fff;font-size:2rem;margin-bottom:.5rem}.login-container p{color:#aaa;margin-bottom:2rem}.form-group{display:flex;flex-direction:column;margin-bottom:1.5rem}label{color:#ddd;margin-bottom:.5rem}input{background-color:#2a2a2a;border:none;border-radius:8px;box-sizing:border-box;color:#fff;font-size:1rem;padding:.75rem;width:100%}.signup-btn{height:55px;margin-top:1.5rem}.password-row{position:relative}.forgot-link{color:#feac34;cursor:pointer;font-size:.9rem;position:absolute;right:0;top:0}.password-input-container{align-items:center;display:flex;position:relative}.password-input-container input{padding-right:3rem}.password-toggle-btn{align-items:center;background:none;border:none;color:#aaa;cursor:pointer;display:flex;justify-content:center;padding:.25rem;position:absolute;right:.75rem;top:50%;transform:translateY(-50%);transition:color .2s ease;z-index:1}.password-toggle-btn:hover{color:#feac34}.password-toggle-btn:focus{color:#feac34;outline:none}.password-toggle-btn svg{height:20px;width:20px}.divider{background-color:#feac34;height:1px;margin:1rem 0;width:100%}.account-card{background:#ffffff4d;border-radius:15px;box-shadow:0 4px 10px #0000004d;height:auto;padding:2rem;width:500px}.account-card h2{color:#fff;font-size:2rem;margin-bottom:.5rem}.account-card p{color:#aaa;margin-bottom:2rem}.account-info{color:#ddd;margin-bottom:1.5rem}.account-actions{display:flex;justify-content:space-between;margin-top:1rem}.delete-btn,.edit-btn{background-color:#feac34;border:none;border-radius:8px;color:#000;cursor:pointer;font-weight:700;padding:.75rem 1.5rem;transition:background .3s ease}.delete-btn:hover,.edit-btn:hover{background-color:#f79400}@media (max-width:768px){.account-page{height:calc(100vh - 140px);top:140px}.auth-container{flex-direction:column;height:90%;max-height:550px;min-height:450px;width:95vw}.image-container{height:30%;min-height:150px}.image-overlay h3{font-size:1.8rem}.image-overlay p{font-size:.9rem}.login-container{padding:2rem}}@media (max-width:480px){.account-page{height:calc(100vh - 130px);top:130px}.auth-container{border-radius:15px;height:95%;max-height:500px;min-height:400px;width:98vw}.image-container{height:25%;min-height:120px}.image-overlay h3{font-size:1.5rem}.image-overlay p{font-size:.8rem;max-width:200px}.login-container{padding:1.5rem}.login-container h2{font-size:1.6rem}}.signup-page{align-items:center;background:linear-gradient(135deg,#0f0f0f,#1a1a1a);box-sizing:border-box;display:flex;height:calc(100vh - 160px);justify-content:center;left:0;overflow:hidden;position:fixed;top:160px;width:100vw;z-index:1000}.signup-auth-container{background-color:#1e1e1e;border-radius:20px;box-shadow:0 20px 60px #0006;display:flex;height:85%;max-height:750px;max-width:1200px;min-height:650px;overflow:hidden;width:90vw}.signup-image-container{flex:1 1;overflow:hidden;position:relative}.signup-auth-image{filter:brightness(.7);height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.signup-auth-image:hover{transform:scale(1.05)}.signup-image-overlay{align-items:center;background:linear-gradient(135deg,#feac3433,#0000004d 50%,#0009);bottom:0;display:flex;flex-direction:column;justify-content:center;left:0;padding:2rem;position:absolute;right:0;text-align:center;top:0}.signup-image-overlay h3{color:#fff;font-size:2.5rem;font-weight:700;margin-bottom:1rem;text-shadow:2px 2px 4px #000000b3}.signup-image-overlay p{color:#f0f0f0;font-size:1.2rem;font-weight:300;line-height:1.4;max-width:300px;text-shadow:1px 1px 2px #000000b3}.signup-form-container{background-color:#1e1e1e;border-radius:0;box-shadow:none;display:flex;flex:1 1;flex-direction:column;height:auto;justify-content:center;overflow-y:auto;padding:2.5rem;width:auto}.signup-form-container h2{color:#fff;font-size:2rem;margin-bottom:.5rem}.signup-form-container p{color:#aaa;margin-bottom:1.5rem}.signup-form-group{display:flex;flex-direction:column;margin-bottom:1.2rem}.signup-form-group label{color:#ddd;margin-bottom:.5rem}.signup-form-group input{background-color:#2a2a2a;border:none;border-radius:8px;box-sizing:border-box;color:#fff;font-size:1rem;padding:.75rem;width:100%}.signup-btn{background:#feac34;border:none;border-radius:10px;color:#000;cursor:pointer;font-size:1.1rem;font-weight:700;height:50px;margin-top:1rem;transition:background .3s ease;width:100%}.signup-btn:hover{background:#f79400}.signup-text{color:#ccc;font-size:.95rem;margin-top:1.5rem;text-align:center}.signup-link{color:#feac34;cursor:pointer;font-weight:700}.signup-divider{background-color:#feac34;height:1px;margin:1rem 0;width:100%}.success-message{text-align:center}.success-message h2{color:#feac34;margin-bottom:1rem}.success-message p{color:#aaa}.alert{align-items:center;border-radius:8px;display:flex;gap:.5rem;margin-bottom:1rem;padding:1rem}.alert-error{background-color:#ef44441a;border:1px solid #ef44444d;color:#ef4444}.alert svg{flex-shrink:0;height:1.5rem;width:1.5rem}@media (max-width:768px){.signup-page{height:calc(100vh - 140px);top:140px}.signup-auth-container{flex-direction:column;height:95%;max-height:none;min-height:600px;width:95vw}.signup-image-container{height:25%;min-height:180px}.signup-image-overlay h3{font-size:1.8rem}.signup-image-overlay p{font-size:.9rem}.signup-form-container{height:75%;padding:2rem}.signup-form-group{margin-bottom:1rem}}@media (max-width:480px){.signup-page{height:calc(100vh - 130px);top:130px}.signup-auth-container{border-radius:15px;height:98%;min-height:550px;width:98vw}.signup-image-container{height:20%;min-height:140px}.signup-image-overlay h3{font-size:1.5rem}.signup-image-overlay p{font-size:.8rem;max-width:200px}.signup-form-container{height:80%;padding:1.5rem}.signup-form-container h2{font-size:1.6rem}.signup-form-group{margin-bottom:.8rem}.signup-btn{height:45px}}svg{height:16px;width:16px}:root.light-mode{--background-color:#fff;--container-bg:#f9f9f9;--container-border:#d1d1d1;--admin-badge-bg:#d97700;--admin-badge-text:#fff;--section-border:#d1d1d1;--info-label-color:#666;--info-value-color:#333;--input-bg:#f5f5f5;--input-border:#ccc;--input-text:#333;--stat-card-bg:#f0f0f0;--stat-value-color:#d97700;--stat-label-color:#666;--loading-spinner:#d97700;--error-message:#f44;--toggle-bg:#ccc;--toggle-slider-bg:#fff;--toggle-active-bg:#d97700}:root.dark-mode{--background-color:#1b1b1b;--container-bg:#3a3a3a;--container-border:#555;--button-primary-hover:#f79400;--admin-badge-bg:#fa3;--admin-badge-text:#000;--section-border:#555;--info-label-color:#aaa;--info-value-color:#f0f0f0;--input-bg:#2a2a2a;--input-border:#666;--input-text:#fff;--stat-card-bg:#252525;--stat-value-color:#fa3;--stat-label-color:#ccc;--loading-spinner:#fa3;--error-message:#f44;--toggle-bg:#666;--toggle-slider-bg:#fff;--toggle-active-bg:#fa3}.profile-page{background-color:#0f0f0f;color:#f1f1f1;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:calc(100vh - 2rem);padding:calc(160px + 1rem) 1rem 1rem}:root.light-mode .profile-page{background-color:var(--background-color);color:var(--text-color)}@media (max-width:768px){.profile-page{padding-top:calc(140px + 1rem)}}@media (max-width:480px){.profile-page{padding-top:calc(130px + 1rem)}}.profile-container{background-color:var(--container-bg);border-radius:12px;margin:0 auto;max-width:600px;padding:1.5rem}.profile-header{border-bottom:1px solid #ffffff1a;color:#feac34;margin-bottom:1.5rem;padding:1.5rem 2rem;text-align:center}.profile-header h2{color:var(--title-color);font-size:1.8rem;margin-bottom:.4rem}.welcome-message{color:var(--subtitle-color);font-size:1rem}.admin-badge{background-color:var(--admin-badge-bg);border-radius:5px;color:var(--admin-badge-text);font-size:.8rem;font-weight:700;margin-left:.4rem;padding:.15rem .5rem}.profile-section{border-bottom:1px solid var(--section-border);margin-bottom:1.5rem;padding-bottom:1rem}.profile-section h3{color:var(--title-color);font-size:1.2rem;margin-bottom:.8rem;padding-left:.4rem}.info-item,.preference-item{align-items:center;display:flex;justify-content:space-between;margin-bottom:.8rem}.info-label{color:var(--info-label-color);font-weight:700}.info-value{color:var(--info-value-color)}.preference-item label{align-items:center;color:var(--input-text);display:flex;font-size:.9rem;gap:.5rem}.preference-item select{background-color:var(--input-bg);border:1px solid var(--input-border);border-radius:5px;color:var(--input-text);font-size:.9rem;padding:.3rem}.toggle-label{align-items:center;cursor:pointer;display:inline-flex;position:relative}.toggle-input{height:0;opacity:0;width:0}.toggle-slider{background-color:var(--toggle-bg);border-radius:20px;height:20px;position:relative;transition:background-color .3s ease;width:40px}.toggle-slider:before{background-color:var(--toggle-slider-bg);border-radius:50%;content:"";height:16px;left:2px;position:absolute;top:2px;transition:transform .3s ease;width:16px}.toggle-input:checked+.toggle-slider{background-color:var(--toggle-active-bg)}.toggle-input:checked+.toggle-slider:before{transform:translateX(20px)}.toggle-input:focus+.toggle-slider{box-shadow:0 0 0 2px var(--title-color)}.stats-container{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:space-around}.stat-card{background-color:var(--stat-card-bg);border-radius:10px;flex:1 1;min-width:100px;padding:1rem;text-align:center}.stat-value{color:var(--stat-value-color);font-size:1.8rem;font-weight:700}.stat-label{color:var(--stat-label-color);font-size:.9rem;margin-top:.4rem}.button-wrapper{margin-top:.8rem;text-align:center}.profile-actions{display:flex;gap:.8rem;justify-content:space-between;margin-top:1.5rem}button{background-color:var(--button-primary-bg);border:none;border-radius:6px;color:var(--button-primary-text);cursor:pointer;font-size:.9rem;font-weight:700;padding:.6rem 1.2rem;transition:background-color .3s ease}button:hover{background-color:var(--button-primary-hover)}.error-message,.loading-spinner{color:var(--loading-spinner);font-size:1.1rem;margin-top:1.5rem;text-align:center}.error-message{color:var(--error-message)}.stats-item{border-radius:8px;padding:1.5rem;text-align:center;transition:transform .2s ease,box-shadow .2s ease}.stats-item:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.stats-value{color:#3b82f6;color:var(--primary-color,#3b82f6);font-size:2.5rem;font-weight:700;line-height:1;margin-bottom:.5rem}.stats-label{color:#9ca3af;color:var(--text-secondary,#9ca3af);font-size:.875rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.custom-button{background-color:var(--button-primary-bg);border:none;border-radius:6px;color:var(--button-primary-text);cursor:pointer;font-size:.9rem;font-weight:700;padding:.6rem 1.2rem;transition:background-color .3s ease}.custom-button:hover{background-color:var(--button-primary-hover)}.analytics-container{background-color:#0f0f0f;color:#f1f1f1;min-height:100vh;overflow-x:hidden;overflow-y:auto;padding-top:var(--page-content-offset);transition:background-color .3s ease}:root.light-mode .analytics-container{background-color:#f8f9fa;color:#333}@media (max-width:768px){.analytics-container{padding-top:var(--page-content-offset)}}@media (max-width:480px){.analytics-container{padding-top:var(--page-content-offset)}}.analytics-content{margin:0 auto;max-width:1400px;padding:2rem}.analytics-loading{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:100vh}.loading-spinner{border:3px solid #3b82f61a;border-top-color:#3b82f6;height:50px;width:50px}.analytics-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:space-between}.analytics-title h1{font-size:2rem;font-weight:700;margin:0 0 .5rem}.analytics-title p{font-size:1rem;margin:0 0 1.5rem;opacity:70%}.analytics-tabs{background:#0000000d;margin-top:1rem}.dark-mode .analytics-tabs{background:#ffffff0d}.analytics-tabs button{color:#0009;font-size:.9rem;padding:12px 20px}.dark-mode .analytics-tabs button{color:#fff9}.analytics-tabs button:hover{background:#0000000d;color:#000c}.dark-mode .analytics-tabs button:hover{background:#ffffff1a;color:#fffc}.analytics-tabs button.active{box-shadow:0 2px 4px #3b82f640}.pems-analytics-section{margin-top:2rem}.date-range-selector{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 2px #0000000d;display:inline-flex;gap:.5rem;padding:.375rem .625rem}.light-mode .date-range-selector{background:#fff;border-color:#e5e7eb}.dark-mode .date-range-selector{background:#1f2937cc;border-color:#374151}.date-input-group{align-items:center;display:flex;gap:.4rem}.date-input-group label{align-items:center;color:#6b7280;display:flex;font-size:.75rem;font-weight:500;gap:.3rem;white-space:nowrap}.dark-mode .date-input-group label{color:#d1d5db}.date-input-group svg{flex-shrink:0;height:14px;opacity:60%;width:14px}.date-input-group input[type=date]{background:#fff;border:1px solid #e5e7eb;border-radius:6px;color:#374151;cursor:pointer;font-size:.813rem;font-weight:400;height:28px;min-width:110px;padding:.375rem .5rem;text-align:left;transition:all .2s ease}.date-input-group input[type=date]::-webkit-calendar-picker-indicator{border-radius:4px;cursor:pointer;height:20px;padding:4px;width:20px}.date-input-group input[type=date]::-webkit-calendar-picker-indicator:hover{background-color:#0000000d}input[type=date]::-webkit-datetime-edit{font-size:.875rem;padding:0}input[type=date]::-webkit-datetime-edit-fields-wrapper{padding:0}input[type=date]::-webkit-datetime-edit-text{padding:0 .2rem}input[type=date]::-webkit-datetime-edit-day-field,input[type=date]::-webkit-datetime-edit-month-field,input[type=date]::-webkit-datetime-edit-year-field{padding:0}.light-mode .date-input-group input[type=date]{background:#fff;border-color:#e5e7eb;color:#374151}.dark-mode .date-input-group input[type=date]{background:#ffffff0d;border-color:#fff3;color:#e5e7eb}.date-input-group input[type=date]:hover{border-color:#3b82f6}.date-input-group input[type=date]:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a;outline:none}.summary-cards{grid-gap:1rem;gap:1rem;grid-template-columns:repeat(6,1fr)}@media (max-width:1200px){.summary-cards{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}.summary-card{background:#ffffffe6;border:1px solid #0000000d;border-radius:6px;box-shadow:0 1px 3px #0000001a;gap:.5rem;overflow:hidden;padding:.6rem;transition:all .3s ease}.dark-mode .summary-card{background:#1f2937cc;border-color:#ffffff0d}.summary-card.archive-card:hover{background:#ffffffe6;box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.summary-card.archive-card{background:#ffffffe6!important;border:1px solid #0000000d!important}.dark-mode .summary-card.archive-card{background:#1f2937cc!important;border:1px solid #ffffff0d!important}.card-icon{border-radius:4px;height:24px;width:24px}.card-icon svg{height:12px;width:12px}.card-icon.incidents{background:linear-gradient(135deg,#3b82f6,#2563eb)}.card-icon.response{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.card-icon.resolution{background:linear-gradient(135deg,#10b981,#059669)}.card-icon.critical{background:linear-gradient(135deg,#ef4444,#dc2626)}.card-icon.archive{background:linear-gradient(135deg,#feac34,#f79400)}.card-icon.archive-time{background:linear-gradient(135deg,#06b6d4,#0891b2)}.card-icon.archive-storage{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.card-content h3{font-size:.6rem;font-weight:500;line-height:1.1;margin:0 0 .15rem;opacity:70%}.card-value{color:#1f2937;font-size:1.1rem;margin-bottom:.15rem}.dark-mode .card-value{color:#f1f5f9}.card-trend{align-items:center;display:flex;font-size:.875rem;gap:.25rem}.card-trend svg{height:16px;width:16px}.card-trend.up{color:#10b981}.card-trend.down{color:#ef4444}.card-subtitle{font-size:.55rem;line-height:1.1;opacity:70%}.charts-grid{grid-gap:1.5rem;gap:1.5rem;grid-template-columns:repeat(2,1fr)}.chart-container{background:#ffffffe6;border:1px solid #0000000d;border-radius:16px;box-shadow:0 1px 3px #0000001a}.dark-mode .chart-container{background:#1f2937cc;border-color:#ffffff0d}.chart-container.full-width{grid-column:span 2}.chart-container.half-width{grid-column:span 1}.chart-container h2{font-size:1.25rem;font-weight:600;margin:0 0 1rem}.chart-container.archive-trends{border-left:4px solid #feac34}.dark-mode .chart-container.archive-trends{border-left-color:#ff8a5b}.chart-container.archive-analytics{background:linear-gradient(145deg,#fffffff2,#f9fafbe6)}.dark-mode .chart-container.archive-analytics{background:linear-gradient(145deg,#1f2937d9,#111827e6)}.radar-chart-wrapper{height:300px;padding:20px;position:relative;width:100%}.location-list{display:flex;flex-direction:column;gap:.75rem}.location-item{align-items:center;background:#00000005;border-radius:8px;display:flex;justify-content:space-between;padding:.75rem;transition:background .2s ease}.dark-mode .location-item{background:#ffffff05}.location-item:hover{background:#3b82f60d}.location-info{align-items:center;display:flex;gap:.75rem}.location-rank{color:#3b82f6;font-size:.875rem;font-weight:700}.location-name{font-weight:500}.location-stats{align-items:center;display:flex;font-size:.875rem;gap:1rem}.incident-count{opacity:70%}.severity-indicator{border-radius:20px;font-size:.75rem;font-weight:500;padding:.25rem .75rem}.severity-indicator.severity-high{background:#ef44441a;color:#ef4444}.severity-indicator.severity-medium{background:#feac341a;color:#feac34}.severity-indicator.severity-low{background:#10b9811a;color:#10b981}.archive-list{display:flex;flex-direction:column;gap:.75rem}.archive-item{align-items:center;background:#00000005;border-left:3px solid #feac34;border-radius:8px;display:flex;justify-content:space-between;padding:1rem;transition:all .3s ease}.dark-mode .archive-item{background:#ffffff05;border-left-color:#ff8a5b}.archive-item:hover{background:#feac340d;transform:translateX(4px)}.archive-info{align-items:center;display:flex;gap:.75rem}.archive-id{color:#feac34;font-size:.875rem}.archive-type{background:#feac341a;border-radius:4px;color:#feac34;font-size:.75rem;font-weight:500;padding:.25rem .5rem}.archive-date{font-size:.875rem;opacity:70%}.archive-stats{align-items:center;display:flex;gap:.75rem}.status-indicator{border-radius:20px;font-size:.75rem;font-weight:500;padding:.25rem .75rem;text-transform:capitalize}.status-indicator.status-open{background:#3b82f61a;color:#3b82f6}.status-indicator.status-ongoing{background:#feac341a;color:#feac34}.status-indicator.status-resolved{background:#10b9811a;color:#10b981}.status-indicator.status-closed{background:#6b72801a;color:#6b7280}.archive-indicator{align-items:center;color:#feac34;display:flex;gap:.25rem}.archive-indicator svg{height:16px;width:16px}.archive-metrics{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.archive-metric-card{background:#feac340d;border-left:4px solid #feac34;border-radius:12px;padding:1.25rem;transition:all .3s ease}.dark-mode .archive-metric-card{background:#feac341a;border-left-color:#ff8a5b}.archive-metric-card:hover{box-shadow:0 4px 12px #feac3433;transform:translateY(-2px)}.archive-metric-card h4{color:#feac34;font-size:.875rem;font-weight:600;margin:0 0 .5rem}.archive-metric-card .metric-value{font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.archive-metric-card .metric-description{font-size:.75rem;opacity:70%}.archive-filters{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.archive-filter-button{background:#0000;border:1px solid #feac34;border-radius:20px;color:#feac34;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .3s ease}.archive-filter-button.active,.archive-filter-button:hover{background:#feac34;color:#fff}.dark-mode .archive-filter-button{border-color:#ff8a5b;color:#ff8a5b}.dark-mode .archive-filter-button.active,.dark-mode .archive-filter-button:hover{background:#ff8a5b;color:#111827}.trends-table-container{background:#ffffffe6;border:1px solid #0000000d;border-radius:16px;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.dark-mode .trends-table-container{background:#1f2937cc;border-color:#ffffff0d}.trends-table-container h2{font-size:1.25rem;font-weight:600;margin:0 0 1rem}.trends-table{background:none}.trends-table th{border-bottom:2px solid #0000001a;font-size:.875rem;font-weight:600;letter-spacing:.05em;padding:.75rem;text-align:left;text-transform:uppercase}.dark-mode .trends-table th{border-bottom-color:#ffffff1a}.trends-table td{border-bottom:1px solid #0000000d;padding:.75rem}.dark-mode .trends-table td{border-bottom-color:#ffffff0d}.trends-table tr:hover{background:#3b82f605}.percentage-bar{background:#0000000d;border-radius:12px;height:24px;overflow:hidden;position:relative;width:100%}.dark-mode .percentage-bar{background:#ffffff0d}.percentage-fill{height:100%;left:0;position:absolute;top:0;transition:width .5s ease}.percentage-bar span{align-items:center;display:flex;font-size:.75rem;font-weight:500;height:100%;padding:0 .75rem;position:relative;z-index:1}.trend-indicator{align-items:center;border-radius:20px;display:inline-flex;font-size:.875rem;font-weight:500;gap:.25rem;padding:.25rem .75rem}.trend-indicator svg{height:16px;width:16px}.trend-indicator.up{background:#10b9811a;color:#10b981}.trend-indicator.down{background:#ef44441a;color:#ef4444}.trend-indicator.stable{background:#6b72801a;color:#6b7280}.light-mode{background-color:#f8fafc;color:#1e293b}.dark-mode{background-color:#1b1b1b;background-color:var(--background-color,#1b1b1b);color:#e2e8f0}@keyframes archivePulse{0%{opacity:100%;transform:scale(1)}50%{opacity:80%;transform:scale(1.05)}to{opacity:100%;transform:scale(1)}}.archive-new-indicator{animation:archivePulse 2s ease-in-out infinite}.archive-loading{align-items:center;color:#feac34;display:flex;font-size:.875rem;height:200px;justify-content:center}.archive-loading svg{animation:spin 1s linear infinite;height:20px;margin-right:.5rem;width:20px}.archive-empty{align-items:center;color:#6b7280;display:flex;flex-direction:column;height:200px;justify-content:center;text-align:center}.archive-empty svg{height:48px;margin-bottom:1rem;opacity:50%;width:48px}.archive-empty h3{font-size:1.125rem;font-weight:600;margin:0 0 .5rem}.archive-empty p{font-size:.875rem;margin:0;opacity:70%}@media (max-width:1024px){.charts-grid{grid-template-columns:1fr}.chart-container.full-width,.chart-container.half-width{grid-column:span 1}.summary-cards{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}}@media (max-width:768px){.analytics-content{padding:1rem}.analytics-header,.date-range-selector{flex-direction:column}.date-range-selector{gap:.75rem;padding:1rem;width:100%}.date-input-group,.date-input-group input[type=date]{width:100%}.summary-cards{gap:.75rem;grid-template-columns:repeat(2,1fr)}.analytics-title h1{font-size:1.5rem}.card-value{font-size:.9rem}.trends-table{font-size:.875rem}.trends-table td,.trends-table th{padding:.5rem}.archive-filters{justify-content:center}.archive-filter-button{flex:1 1;min-width:120px}.archive-metrics{grid-template-columns:1fr}.archive-stats,.location-stats{align-items:flex-start;flex-direction:column;gap:.5rem}}.analytics-container::-webkit-scrollbar{width:10px}.analytics-container::-webkit-scrollbar-track{background:#0000000d}.dark-mode .analytics-container::-webkit-scrollbar-track{background:#ffffff0d}.analytics-container::-webkit-scrollbar-thumb{background:#0003;border-radius:5px}.dark-mode .analytics-container::-webkit-scrollbar-thumb{background:#fff3}.analytics-container::-webkit-scrollbar-thumb:hover{background:#0000004d}.dark-mode .analytics-container::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.recharts-polar-angle-axis .recharts-text{fill:#6b7280;font-size:11px!important}.dark-mode .recharts-polar-angle-axis .recharts-text{fill:#9ca3af}.recharts-polar-angle-axis-tick{font-size:11px!important}.recharts-polar-angle-axis-tick text{text-anchor:middle;dominant-baseline:central}.recharts-layer.recharts-polar-angle-axis text{font-size:11px!important}@media screen and (min-device-pixel-ratio:0){input[type=date]::-webkit-calendar-picker-indicator{zoom:1.5}}.pems-analytics{background:var(--stat-card-bg);border:1px solid var(--stat-card-border);border-radius:12px;margin-bottom:24px;overflow:hidden}.pems-analytics-error{align-items:center;color:var(--severity-critical-text);display:flex;flex-direction:column;justify-content:center;padding:60px 20px;text-align:center}.pems-analytics-error svg{height:48px;margin-bottom:16px;width:48px}.pems-analytics-error h3{color:var(--text-color);margin:0 0 12px}.pems-analytics-error p{color:var(--subtitle-color);margin:0 0 20px}.retry-button{background:var(--button-primary-bg);border:none;border-radius:6px;color:var(--button-primary-text);cursor:pointer;font-weight:500;padding:12px 24px;transition:background-color .2s ease}.retry-button:hover{background:var(--button-primary-hover)}.analytics-header{background:var(--header-bg);border-bottom:1px solid var(--header-border);padding:24px}.analytics-header h2{align-items:center;color:var(--title-color);display:flex;font-size:1.8rem;gap:12px;margin:0 0 20px}.analytics-header h2 svg{height:28px;width:28px}.analytics-tabs{background:var(--content-bg);border-radius:8px;gap:4px;padding:4px}.analytics-tabs button{background:#0000;border:none;border-radius:6px;color:var(--subtitle-color);flex:1 1;padding:12px 16px}.analytics-tabs button:hover{background:var(--user-card-hover-shadow);color:var(--text-color)}.analytics-tabs button.active{background:var(--title-color);box-shadow:0 2px 8px #00000026;color:var(--button-primary-text)}.analytics-content{padding:24px}.analytics-summary-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:32px}.summary-card{background:var(--user-card-bg);border:1px solid var(--user-card-border);gap:16px;padding:20px;transition:all .2s ease}.summary-card:hover{box-shadow:0 6px 16px #0000001a}.card-icon.primary{background:var(--title-color)}.card-icon.success{background:var(--severity-low-text)}.card-icon.warning{background:var(--severity-medium-text)}.card-icon.info{background:var(--severity-responding-text)}.card-content h3{font-size:1.8rem;font-weight:700;line-height:1}.card-content h3,.card-content p{color:var(--text-color);margin:0 0 4px}.card-content p{font-size:.95rem;font-weight:600}.card-subtitle{color:var(--subtitle-color);font-size:.85rem}.analytics-charts-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));margin-bottom:32px}.chart-container{background:var(--user-card-bg);border:1px solid var(--user-card-border);padding:24px}.chart-container h3{color:var(--text-color);font-size:1.2rem;margin:0 0 8px}.chart-description{color:var(--subtitle-color);font-size:.9rem;line-height:1.5;margin:0 0 20px}.section-description{margin-bottom:32px}.section-description h3{color:var(--text-color);font-size:1.4rem;font-weight:600;margin:0 0 12px}.section-description p{color:var(--subtitle-color);font-size:1rem;line-height:1.6;margin:0}.high-risk-areas-list{margin-top:32px}.high-risk-areas-list h3{color:var(--text-color);font-size:1.2rem;font-weight:600;margin:0 0 20px}.risk-areas-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.risk-area-card{background:var(--incident-item-bg);border:1px solid var(--incident-item-border);border-left:4px solid var(--severity-critical-text);border-radius:8px;padding:16px}.area-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.detector-id{color:var(--title-color);font-family:monospace;font-weight:700}.risk-badge{border-radius:4px;font-size:.75rem;font-weight:600;padding:2px 8px;text-transform:uppercase}.risk-badge.critical{background:var(--severity-critical-bg);color:var(--severity-critical-text)}.risk-badge.high,.risk-badge.medium{background:var(--severity-medium-bg);color:var(--severity-medium-text)}.risk-badge.low{background:var(--severity-low-bg);color:var(--severity-low-text)}.area-location{color:var(--subtitle-color);font-size:.9rem;margin-bottom:12px}.area-metrics{color:var(--text-color);display:flex;font-size:.85rem;justify-content:space-between}.performance-insights{grid-column:1/-1}.performance-insights h3{color:var(--text-color);font-size:1.2rem;font-weight:600;margin:0 0 20px}.insights-list{display:flex;flex-direction:column;gap:20px}.insight-item{align-items:flex-start;background:var(--timeline-item-bg);border-left:4px solid var(--title-color);gap:16px;padding:20px}.insight-icon,.insight-item{border-radius:8px;display:flex}.insight-icon{align-items:center;flex-shrink:0;height:40px;justify-content:center;width:40px}.insight-icon svg{color:#fff;height:20px;width:20px}.insight-content h4{color:var(--text-color);font-size:1rem;font-weight:600;margin:0 0 8px}.insight-content p{color:var(--subtitle-color);font-size:.9rem;line-height:1.5;margin:0}.analytics-footer{align-items:center;background:var(--content-bg);border-top:1px solid var(--header-border);display:flex;justify-content:space-between;padding:20px 24px}.last-update{color:var(--subtitle-color);font-size:.85rem}.refresh-button{background:var(--button-primary-bg);border:none;border-radius:6px;color:var(--button-primary-text);cursor:pointer;font-weight:500;padding:10px 20px;transition:background-color .2s ease}.refresh-button:hover{background:var(--button-primary-hover)}@media (max-width:1024px){.analytics-charts-grid{grid-template-columns:1fr}.analytics-summary-cards{grid-template-columns:repeat(2,1fr)}.risk-areas-grid{grid-template-columns:1fr}}@media (max-width:768px){.analytics-content,.analytics-header{padding:16px}.analytics-summary-cards{grid-template-columns:1fr}.analytics-tabs,.summary-card{flex-direction:column}.summary-card{gap:12px;text-align:center}.chart-container{padding:16px}.analytics-footer{flex-direction:column;gap:12px;text-align:center}}@media (max-width:480px){.analytics-header h2{font-size:1.5rem}.insight-item{flex-direction:column;text-align:center}.area-header{flex-direction:column;gap:8px}.area-metrics{flex-direction:column;gap:4px}}.public-badge{background:var(--stat-card-icon-bg);border:1px solid var(--title-color);border-radius:12px;color:var(--title-color);text-transform:uppercase}.public-badge,.user-role-badge{font-size:.8rem;font-weight:600;letter-spacing:.5px;margin-left:1rem;padding:.3rem .8rem}.user-role-badge{background:var(--status-responding-bg);border:1px solid var(--status-responding-text);border-radius:12px;color:var(--status-responding-text)}.export-button{border-radius:8px;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s ease}.export-button:hover{transform:translateY(-1px)}.weekly-section{padding:1.5rem}.embedded-weekly-trends{margin:1.5rem 0}.upgrade-prompt{background:var(--stat-card-bg);border:2px dashed var(--stat-card-border);border-radius:16px;box-shadow:0 4px 16px #00000014;margin-bottom:2rem;padding:3rem 2rem;text-align:center;transition:all .3s ease}.upgrade-prompt:hover{border-color:var(--title-color);box-shadow:0 8px 32px var(--stat-card-hover-shadow);transform:translateY(-2px)}.upgrade-prompt h4{color:var(--title-color);font-size:1.5rem;font-weight:700;margin:0 0 1rem}.upgrade-prompt p{color:var(--text-color);font-size:1rem;line-height:1.6;margin:0 0 1rem}.upgrade-prompt ul{color:var(--subtitle-color);margin:2rem auto;max-width:400px;padding-left:1.5rem;text-align:left}.upgrade-prompt li{color:var(--subtitle-color);font-size:.9rem;line-height:1.5;margin-bottom:.5rem}.upgrade-cta{align-items:center;background:var(--button-primary-bg);border:2px solid var(--button-primary-bg);border-radius:8px;display:inline-flex;font-weight:600;gap:.5rem;justify-content:center;margin-top:1rem;min-width:160px;padding:.75rem 1.5rem;transition:all .2s ease}.upgrade-cta,.upgrade-cta:hover{color:var(--button-primary-text);text-decoration:none}.upgrade-cta:hover{background:var(--button-primary-hover);border-color:var(--button-primary-hover);box-shadow:0 4px 16px #d977004d;transform:translateY(-2px)}@media (max-width:768px){.analytics-header h2{align-items:flex-start;flex-direction:column;gap:.5rem}.public-badge,.user-role-badge{font-size:.7rem;margin-left:0;padding:.2rem .6rem}.export-button{font-size:.9rem;padding:.5rem 1rem}.upgrade-prompt{padding:1.5rem}.upgrade-prompt h4{font-size:1.1rem}}.lane-closure-heatmap{background:var(--bg-secondary);border-radius:12px;box-shadow:0 4px 6px #0000001a;margin-bottom:1.5rem;padding:1.5rem;width:100%}.lane-closure-heatmap.loading{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:400px}.lane-closure-heatmap.dark{--bg-primary:#1f2937;--bg-secondary:#111827;--text-primary:#f9fafb;--text-secondary:#d1d5db;--border-color:#374151}.lane-closure-heatmap.light{--bg-primary:#fff;--bg-secondary:#f9fafb;--text-primary:#111827;--text-secondary:#6b7280;--border-color:#e5e7eb}.heatmap-controls{display:flex;flex-wrap:wrap;gap:2rem;margin-bottom:2rem}.control-group{display:flex;flex-direction:column;gap:.5rem}.control-group label{font-weight:600}.control-group label,.control-group select{color:var(--text-primary);font-size:.875rem}.control-group select{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;min-width:150px;padding:.5rem .75rem}.control-group select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.heatmap-container{display:flex;gap:.5rem;overflow-x:auto;padding:1rem 0}.heatmap-y-axis{display:flex;flex-direction:column;min-width:100px}.y-axis-label{align-items:center;color:var(--text-secondary);display:flex;font-size:.75rem;font-weight:500;height:32px;padding-right:.5rem;text-align:right}.heatmap-grid{flex:1 1}.heatmap-x-axis{display:flex;margin-bottom:.25rem}.x-axis-label{align-items:center;color:var(--text-secondary);display:flex;font-size:.625rem;font-weight:500;height:20px;justify-content:center;width:20px}.heatmap-cells{display:flex;flex-direction:column}.heatmap-row{display:flex}.heatmap-cell{border-radius:2px;cursor:pointer;height:32px;position:relative;transition:all .2s ease;width:20px}.heatmap-cell:hover{box-shadow:0 2px 8px #0003;transform:scale(1.1);z-index:10}.heatmap-legend{border-top:1px solid var(--border-color);margin-top:2rem;padding-top:1.5rem}.legend-title{color:var(--text-primary);font-size:.875rem;font-weight:600;margin-bottom:1rem}.legend-scale{display:flex;flex-wrap:wrap;gap:1rem}.legend-item{align-items:center;display:flex;gap:.5rem}.legend-color{border:1px solid var(--border-color);border-radius:3px;height:16px;width:16px}.legend-item span{color:var(--text-secondary);font-size:.75rem;font-weight:500}.heatmap-tooltip{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #00000026;margin-top:-10px;padding:.75rem;pointer-events:none;position:fixed;transform:translate(-50%,-100%);z-index:1000}.tooltip-header{color:var(--text-primary);font-size:.875rem;font-weight:600;margin-bottom:.5rem}.tooltip-content{display:flex;flex-direction:column;gap:.25rem}.tooltip-content div{color:var(--text-secondary);font-size:.75rem}@media (max-width:768px){.lane-closure-heatmap{padding:1rem}.heatmap-controls{flex-direction:column;gap:1rem}.control-group select{min-width:100%}.heatmap-container{overflow-x:scroll}.heatmap-y-axis{min-width:80px}.y-axis-label{font-size:.625rem}.x-axis-label{font-size:.5rem;height:16px;width:16px}.heatmap-cell{height:26px;width:16px}.legend-scale{justify-content:center}}@media (max-width:480px){.lane-closure-heatmap{padding:.75rem}.x-axis-label{width:14px}.heatmap-cell{height:24px;width:14px}.legend-scale{flex-direction:column;gap:.5rem}}.lane-closure-analytics{background:var(--bg-primary);border-radius:12px;margin-bottom:2rem;padding:2rem;width:100%}.lane-closure-analytics.loading{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:500px}.lane-closure-analytics.dark{--bg-primary:#111827;--bg-secondary:#1f2937;--bg-tertiary:#374151;--text-primary:#f9fafb;--text-secondary:#d1d5db;--text-tertiary:#9ca3af;--border-color:#374151;--hover-bg:#374151}.lane-closure-analytics.light{--bg-primary:#fff;--bg-secondary:#f9fafb;--bg-tertiary:#f3f4f6;--text-primary:#111827;--text-secondary:#374151;--text-tertiary:#6b7280;--border-color:#e5e7eb;--hover-bg:#f3f4f6}.analytics-header{margin-bottom:2rem}.analytics-header h2{color:var(--text-primary);font-size:1.875rem;font-weight:700;margin:0 0 .5rem}.analytics-header p{color:var(--text-secondary);font-size:1rem;line-height:1.5;margin:0 0 1.5rem}.analytics-tabs{display:flex;flex-wrap:wrap;gap:.5rem}.analytics-tabs button{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;font-size:.875rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.analytics-tabs button:hover{background:var(--hover-bg);color:var(--text-primary)}.analytics-tabs button.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.summary-cards{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.summary-card{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;display:flex;gap:1rem;padding:1.5rem;transition:transform .2s ease,box-shadow .2s ease}.summary-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.card-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.card-icon svg{color:#fff;height:24px;width:24px}.card-icon.primary{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}.card-icon.warning{background:linear-gradient(135deg,#f59e0b,#d97706)}.card-icon.danger{background:linear-gradient(135deg,#ef4444,#dc2626)}.card-icon.info{background:linear-gradient(135deg,#06b6d4,#0891b2)}.card-content{flex:1 1}.card-content h3{color:var(--text-secondary);font-size:.875rem;font-weight:600;letter-spacing:.05em;margin:0 0 .5rem;text-transform:uppercase}.card-value{color:var(--text-primary);font-size:2rem;font-weight:700;line-height:1;margin:0 0 .25rem}.card-subtitle{color:var(--text-tertiary);font-size:.75rem;margin:0}.charts-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:2rem}.chart-container{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem}.chart-container.full-width{grid-column:1/-1}.chart-container h3{color:var(--text-primary);font-size:1.125rem;font-weight:600;margin:0 0 .5rem}.chart-container p{color:var(--text-tertiary);font-size:.875rem;line-height:1.4;margin:0 0 1.5rem}.impact-section,.overview-section,.patterns-section,.routes-section{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:100%;transform:translateY(0)}}.loading-spinner{animation:spin 1s linear infinite;border:3px solid var(--border-color);border-radius:50%;border-top:3px solid #3b82f6;height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:1024px){.charts-grid{grid-template-columns:1fr}.chart-container.full-width{grid-column:1}}@media (max-width:768px){.lane-closure-analytics{padding:1rem}.analytics-header h2{font-size:1.5rem}.summary-cards{gap:1rem;grid-template-columns:1fr}.summary-card{padding:1rem}.card-value{font-size:1.5rem}.analytics-tabs{flex-direction:column}.analytics-tabs button{text-align:center}.chart-container{padding:1rem}.charts-grid{gap:1rem}}@media (max-width:480px){.lane-closure-analytics{padding:.75rem}.analytics-header h2{font-size:1.25rem}.analytics-header p{font-size:.875rem}.summary-card{flex-direction:column;gap:.75rem;text-align:center}.card-icon{height:40px;width:40px}.card-icon svg{height:20px;width:20px}.card-value{font-size:1.25rem}.chart-container{padding:.75rem}}.recharts-tooltip-wrapper{z-index:1000}.recharts-tooltip-content{background:var(--bg-primary)!important;border:1px solid var(--border-color)!important;border-radius:8px!important;box-shadow:0 4px 12px #00000026!important}.recharts-tooltip-label{color:var(--text-primary)!important;font-weight:600!important}.recharts-tooltip-item{color:var(--text-secondary)!important}.recharts-legend-wrapper{padding-top:1rem!important}.recharts-legend-item{margin-right:1rem!important}.recharts-legend-item-text{color:var(--text-secondary)!important;font-size:.875rem!important}:root.light-mode{--background-color:#f9f9f9;--text-color:#333;--title-color:#d97700;--subtitle-color:#666;--card-bg:#fff;--card-border:#ccc;--card-shadow:#0000001a;--card-hover-bg:#f5f5f5;--header-bg:#f5f5f5;--header-border:#d1d1d1;--button-primary-bg:#d97700;--button-primary-text:#fff;--button-primary-hover:#c06800;--button-secondary-bg:#0000;--button-secondary-text:#333;--button-secondary-border:#999;--button-secondary-hover-bg:#d977001a;--button-secondary-hover-border:#d97700;--filter-bg:#f0f0f0;--filter-border:#ccc;--filter-input-bg:#fff;--filter-placeholder:#999;--table-bg:#fff;--table-header-bg:#e5e5e5;--table-header-text:#333;--table-border:#d1d1d1;--table-hover-bg:#d977000d;--severity-critical-bg:#f443;--severity-critical-text:#f44;--severity-medium-bg:#d9770033;--severity-medium-text:#d97700;--severity-low-bg:#4f43;--severity-low-text:#199019;--modal-overlay-bg:#00000080;--modal-content-bg:#fff;--json-view-bg:#f5f5f5;--json-view-text:#333;--json-view-border:#ccc;--border-light:#e5e5e5;--border-default:#d1d1d1;--surface-elevated:#fff;--surface-overlay:#00000005}:root.dark-mode{--background-color:#1e1e1e;--text-color:#fff;--title-color:#fa3;--subtitle-color:#ccc;--card-bg:#2a2a2a;--card-border:#666;--card-shadow:#0000004d;--card-hover-bg:#333;--header-bg:#1a1a1a;--header-border:#404040;--button-primary-bg:#fa3;--button-primary-text:#000;--button-primary-hover:#fa3;--button-secondary-bg:#0000;--button-secondary-text:#ccc;--button-secondary-border:#666;--button-secondary-hover-bg:#ffaa331a;--button-secondary-hover-border:#fa3;--filter-bg:#2a2a2a;--filter-border:#666;--filter-input-bg:#333;--filter-placeholder:#999;--table-bg:#2a2a2a;--table-header-bg:#333;--table-header-text:#fff;--table-border:#666;--table-hover-bg:#ffaa331a;--severity-critical-bg:#f443;--severity-critical-text:#f66;--severity-medium-bg:#fa33;--severity-medium-text:#fa3;--severity-low-bg:#4f43;--severity-low-text:#4f4;--modal-overlay-bg:#000c;--modal-content-bg:#2a2a2a;--json-view-bg:#333;--json-view-text:#fff;--json-view-border:#666;--border-light:#404040;--border-default:#666;--surface-elevated:#333;--surface-overlay:#ffffff0d}.archives-page{--text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px #0000001a;--shadow-lg:0 10px 15px #0000001a;--shadow-xl:0 20px 25px #0000001a;background-color:#0f0f0f;color:#f1f1f1;font-family:Segoe UI,Arial,sans-serif;line-height:1.6;min-height:100vh;padding:2rem;padding-top:calc(var(--page-content-offset) + 1.5rem);transition:all .3s ease}.archives-page .loading-message{align-items:center;color:var(--text-color);display:flex;flex-direction:column;gap:var(--space-6);height:60vh;justify-content:center}.archives-page .loading-spinner{animation:archivesSpin 1s cubic-bezier(.68,-.55,.265,1.55) infinite;border-top:3px solid var(--border-light);border:3px solid var(--border-light);border-radius:50%;border-top-color:var(--title-color);height:48px;width:48px}@keyframes archivesSpin{0%{transform:rotate(0deg) scale(1)}50%{transform:rotate(180deg) scale(1.1)}to{transform:rotate(1turn) scale(1)}}.archives-page .error-message,.archives-page .no-data-message{background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;box-shadow:var(--shadow-md);color:var(--text-color);margin:var(--space-8) auto;max-width:500px;padding:var(--space-10);text-align:center}.archives-page .error-message{background:var(--severity-critical-bg);border-color:var(--severity-critical-text)}.archives-page .retry-button{align-items:center;background:var(--button-primary-bg);border:none;border-radius:12px;box-shadow:var(--shadow-sm);color:var(--button-primary-text);cursor:pointer;display:inline-flex;font-size:var(--text-sm);font-weight:600;gap:var(--space-2);padding:var(--space-3) var(--space-6);transition:all .3s ease}.archives-page .retry-button:hover{background:var(--button-primary-hover);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.header{align-items:flex-start;background:var(--card-bg);border:1px solid var(--card-border);border-radius:20px;box-shadow:var(--shadow-md);display:flex;justify-content:space-between;margin-bottom:var(--space-8);overflow:hidden;padding:var(--space-8);position:relative}.header:before{background:linear-gradient(90deg,#0000 0,var(--title-color) 50%,#0000 100%);content:"";height:2px;left:0;opacity:80%;position:absolute;right:0;top:0}.header-content h2{align-items:center;color:var(--title-color);display:flex;font-size:var(--text-3xl);font-weight:700;gap:var(--space-4);margin:0}.header-content p{color:var(--subtitle-color);font-size:var(--text-base);font-weight:400;margin:var(--space-2) 0 0}.header-actions{align-items:center;display:flex;gap:var(--space-4)}.records-count{background:var(--severity-medium-bg);border:1px solid var(--border-default);border-radius:20px;color:var(--severity-medium-text);padding:var(--space-2) var(--space-4)}.export-button,.records-count{font-size:var(--text-sm);font-weight:600}.export-button{align-items:center;background:var(--button-primary-bg);border:none;border-radius:12px;box-shadow:var(--shadow-sm);color:var(--button-primary-text);cursor:pointer;display:flex;gap:var(--space-2);padding:var(--space-3) var(--space-6);transition:all .3s ease}.export-button:hover{background:var(--button-primary-hover);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.filters-container{background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;box-shadow:var(--shadow-md);margin-bottom:var(--space-8);padding:var(--space-6)}.basic-filters{grid-gap:var(--space-4);align-items:end;display:grid;gap:var(--space-4);grid-template-columns:2fr repeat(4,1fr)}.search-input-container{position:relative}.search-icon{color:var(--filter-placeholder);left:var(--space-4);position:absolute;top:50%;transform:translateY(-50%);z-index:2}.search-input{background:var(--filter-input-bg);border:1px solid var(--filter-border);border-radius:12px;box-shadow:var(--shadow-sm);box-sizing:border-box;color:var(--text-color);font-size:var(--text-base);height:48px;padding:var(--space-4) var(--space-4) var(--space-4) var(--space-12);transition:all .3s ease;width:100%}.search-input:focus{border-color:var(--title-color);box-shadow:0 0 0 3px #d977001a;outline:none;transform:translateY(-1px)}.archives-page .date-input,.archives-page .filter-select,.archives-page .text-input{background:var(--filter-input-bg);border:1px solid var(--filter-border);border-radius:12px;box-shadow:var(--shadow-sm);box-sizing:border-box;color:var(--text-color);font-size:var(--text-base);height:48px;padding:var(--space-4);transition:all .3s ease}.archives-page .date-input:focus,.archives-page .filter-select:focus,.archives-page .text-input:focus{border-color:var(--title-color);box-shadow:0 0 0 3px #d977001a;outline:none;transform:translateY(-1px)}.advanced-filter-toggle{align-items:center;background:var(--button-secondary-bg);border:1px solid var(--button-secondary-border);border-radius:12px;color:var(--button-secondary-text);cursor:pointer;display:flex;font-weight:500;gap:var(--space-2);padding:var(--space-4) var(--space-6);transition:all .3s ease}.advanced-filter-toggle:hover{background:var(--button-secondary-hover-bg);border-color:var(--button-secondary-hover-border);transform:translateY(-1px)}.advanced-filters{grid-gap:var(--space-6);border-top:1px solid var(--border-light);display:grid;gap:var(--space-6);margin-top:var(--space-6);padding-top:var(--space-6)}.filter-section{grid-gap:var(--space-4);display:grid;gap:var(--space-4)}.filter-section label{color:var(--title-color);font-size:var(--text-sm);font-weight:600;letter-spacing:.05em;text-transform:uppercase}.filter-section>div{grid-gap:var(--space-3);display:grid;gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.filter-actions{justify-content:space-between;margin-top:var(--space-4)}.clear-button,.filter-actions{align-items:center;display:flex}.clear-button{background:var(--severity-critical-bg);border:1px solid var(--severity-critical-text);border-radius:12px;color:var(--severity-critical-text);cursor:pointer;font-weight:600;gap:var(--space-2);padding:var(--space-3) var(--space-6);transition:all .3s ease}.clear-button:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.search-help-text{color:var(--subtitle-color);font-size:var(--text-sm);font-style:italic}.view-controls{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--space-8)}.view-mode-toggle{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;box-shadow:var(--shadow-sm);display:flex;padding:var(--space-1)}.view-mode-button{background:#0000;border:none;border-radius:10px;color:var(--subtitle-color);cursor:pointer;font-size:var(--text-sm);font-weight:500;padding:var(--space-3) var(--space-6);transition:all .3s ease}.view-mode-button.active{background:var(--button-primary-bg);box-shadow:var(--shadow-sm);color:var(--button-primary-text);transform:translateY(-1px)}.pagination-info{color:var(--subtitle-color);font-size:var(--text-sm);font-weight:500}.cards-container{grid-gap:var(--space-8);display:grid;gap:var(--space-8);grid-template-columns:repeat(auto-fit,minmax(450px,1fr));margin-bottom:var(--space-8)}.archive-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:20px;box-shadow:var(--shadow-md);overflow:hidden;position:relative;transition:all .4s ease}.archive-card:before{background:linear-gradient(90deg,var(--title-color) 0,var(--button-primary-hover) 100%);content:"";height:2px;left:0;position:absolute;right:0;top:0}.archive-card:hover{border-color:var(--title-color);box-shadow:var(--shadow-xl);transform:translateY(-8px) scale(1.02)}.card-header{align-items:flex-start;background:var(--header-bg);border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:var(--space-6)}.card-header-left{gap:var(--space-4)}.archive-id,.card-header-left{align-items:center;display:flex}.archive-id{color:var(--title-color);font-family:SF Mono,Monaco,Cascadia Code,monospace;font-size:var(--text-lg);font-weight:700;gap:var(--space-2)}.archives-page .severity-badge{border:1px solid;border-radius:20px;font-size:var(--text-xs);font-weight:700;letter-spacing:.05em;padding:var(--space-2) var(--space-4);text-transform:uppercase}.archives-page .severity-low{background:var(--severity-low-bg);border-color:var(--severity-low-text);color:var(--severity-low-text)}.archives-page .severity-medium{background:var(--severity-medium-bg);border-color:var(--severity-medium-text);color:var(--severity-medium-text)}.archives-page .severity-high{background:var(--severity-critical-bg);border-color:var(--severity-critical-text);color:var(--severity-critical-text)}.card-header-right{color:var(--subtitle-color);font-size:var(--text-sm);text-align:right}.archive-type{color:var(--text-color);font-weight:600;text-transform:capitalize}.camera-info{align-items:center;color:var(--subtitle-color);display:flex;font-size:var(--text-xs);gap:var(--space-1);margin-top:var(--space-1)}.card-content{padding:var(--space-6)}.archive-title{color:var(--title-color);font-size:var(--text-xl);font-weight:700;margin:0 0 var(--space-4) 0}.archive-detail{color:var(--text-color);font-size:var(--text-base);line-height:1.5;margin:var(--space-2) 0}.archive-coordinates{background:var(--filter-bg);border:1px solid var(--border-light);border-radius:8px;color:var(--subtitle-color);font-family:SF Mono,monospace;font-size:var(--text-sm);margin:var(--space-3) 0;padding:var(--space-2) var(--space-3)}.tags-container{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-2);margin:var(--space-4) 0}.tag{background:var(--severity-medium-bg);border:1px solid var(--border-default);border-radius:12px;color:var(--severity-medium-text);font-size:var(--text-xs);font-weight:500;padding:var(--space-1) var(--space-3)}.archive-search-text{background:var(--filter-bg);border-left:3px solid var(--title-color);border-radius:12px;color:var(--text-color);font-size:var(--text-sm);line-height:1.6;margin-top:var(--space-4);padding:var(--space-4)}.card-footer{align-items:center;background:var(--header-bg);border-top:1px solid var(--border-light);display:flex;gap:var(--space-4);justify-content:space-between;padding:var(--space-6)}.archive-meta{color:var(--subtitle-color)}.archive-meta,.expand-button{font-size:var(--text-sm);font-weight:500}.expand-button{align-items:center;background:var(--button-secondary-bg);border:1px solid var(--button-secondary-border);border-radius:12px;color:var(--button-secondary-text);cursor:pointer;display:flex;gap:var(--space-2);padding:var(--space-3) var(--space-4);transition:all .3s ease}.expand-button:hover{background:var(--button-secondary-hover-bg);border-color:var(--button-secondary-hover-border);color:var(--title-color);transform:translateY(-1px)}.expanded-content{border-top:1px solid var(--border-light);margin-top:var(--space-6);padding-top:var(--space-6)}.json-section{margin-bottom:var(--space-6)}.json-section h5{color:var(--title-color);font-size:var(--text-sm);font-weight:600;letter-spacing:.05em;margin:0 0 var(--space-3) 0;text-transform:uppercase}.json-view{background:var(--json-view-bg);border:1px solid var(--json-view-border);border-radius:12px;color:var(--json-view-text);font-family:SF Mono,monospace;font-size:var(--text-sm);max-height:300px;overflow-x:auto;overflow-y:auto;padding:var(--space-4)}.table-container{background:var(--table-bg);border:1px solid var(--table-border);border-radius:16px;box-shadow:var(--shadow-md);margin-bottom:var(--space-8);overflow:hidden}.archives-table{border-collapse:collapse;width:100%}.table-header th{background:var(--table-header-bg);border-bottom:1px solid var(--table-border);color:var(--table-header-text);font-size:var(--text-sm);font-weight:600;letter-spacing:.05em;padding:var(--space-4);text-align:left;text-transform:uppercase}.table-row{transition:all .2s ease}.table-row:hover{background:var(--table-hover-bg)}.table-cell{border-bottom:1px solid var(--table-border);color:var(--text-color);font-size:var(--text-base);padding:var(--space-4);vertical-align:middle}.table-cell.id{color:var(--title-color);font-family:SF Mono,monospace;font-weight:700}.table-action-button{align-items:center;background:var(--button-secondary-bg);border:1px solid var(--button-secondary-border);border-radius:8px;color:var(--button-secondary-text);cursor:pointer;display:flex;font-size:var(--text-sm);gap:var(--space-1);padding:var(--space-2) var(--space-3);transition:all .3s ease}.table-action-button:hover{background:var(--button-secondary-hover-bg);border-color:var(--button-secondary-hover-border);color:var(--title-color)}.detailed-container{display:flex;flex-direction:column;gap:var(--space-8)}.detailed-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:20px;box-shadow:var(--shadow-lg);overflow:hidden;transition:all .4s ease}.detailed-header{background:var(--header-bg);border-bottom:1px solid var(--border-light);padding:var(--space-8)}.detailed-header h3{align-items:center;color:var(--title-color);display:flex;font-size:var(--text-2xl);font-weight:700;gap:var(--space-4);margin:0 0 var(--space-3) 0}.detailed-meta{color:var(--subtitle-color);font-size:var(--text-base);font-weight:500}.detailed-content{padding:var(--space-8)}.metadata-grid{grid-gap:var(--space-8);display:grid;gap:var(--space-8);grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:var(--space-8)}.metadata-section{background:var(--filter-bg);border:1px solid var(--border-light);border-radius:16px;padding:var(--space-6);transition:all .3s ease}.metadata-section:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.metadata-section h4{align-items:center;color:var(--title-color);display:flex;font-size:var(--text-lg);font-weight:700;gap:var(--space-2);margin:0 0 var(--space-4) 0}.metadata-section p{color:var(--text-color);font-size:var(--text-base);line-height:1.5;margin:var(--space-2) 0}.tags-display{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-3)}.metadata-tag{background:var(--severity-medium-bg);border:1px solid var(--border-default);border-radius:12px;color:var(--severity-medium-text);font-size:var(--text-xs);font-weight:600;padding:var(--space-2) var(--space-3)}.search-analytics-section{background:var(--filter-bg);border:1px solid var(--border-default);border-radius:16px;margin-top:var(--space-6);padding:var(--space-8)}.search-analytics-section h4{color:var(--title-color);font-size:var(--text-xl);font-weight:700;margin:0 0 var(--space-4) 0}.analytics-features{color:var(--text-color)}.feature-grid{grid-gap:var(--space-3);display:grid;gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:var(--space-4)}.feature-item{background:var(--card-bg);border:1px solid var(--border-light);border-radius:12px;font-size:var(--text-sm);font-weight:500;padding:var(--space-3) var(--space-4);transition:all .3s ease}.feature-item:hover{background:var(--table-hover-bg);border-color:var(--title-color);transform:translateY(-1px)}.pagination{align-items:center;display:flex;gap:var(--space-2);justify-content:center;margin-top:var(--space-8);padding:var(--space-4)}.pagination-button{background:var(--button-secondary-bg);border:1px solid var(--button-secondary-border);border-radius:12px;color:var(--button-secondary-text);cursor:pointer;font-size:var(--text-sm);font-weight:500;padding:var(--space-3) var(--space-5);transition:all .3s ease}.pagination-button:hover:not(:disabled){background:var(--button-primary-bg);border-color:var(--button-primary-bg);box-shadow:var(--shadow-sm);color:var(--button-primary-text);transform:translateY(-1px)}.pagination-button:disabled{cursor:not-allowed;opacity:40%}.pagination-info-text{color:var(--subtitle-color);font-size:var(--text-sm);font-weight:500;margin:0 var(--space-4)}@media (max-width:1024px){.archives-page{padding:var(--space-4);padding-top:calc(140px + var(--space-4))}}@media (max-width:480px){.archives-page{padding:var(--space-4);padding-top:calc(130px + var(--space-4))}.basic-filters{gap:var(--space-3)}.basic-filters,.cards-container,.metadata-grid{grid-template-columns:1fr}}@media (max-width:768px){.header{flex-direction:column;gap:var(--space-4);text-align:center}.header-actions{flex-direction:column;width:100%}.view-controls{flex-direction:column;gap:var(--space-4)}.archive-card{border-radius:16px;margin:0 -1rem}.table-container{overflow-x:auto}}.archives-signin-container{align-items:center;display:flex;justify-content:center;min-height:calc(100vh - 200px);padding:var(--space-8) var(--space-4)}.archives-signin-content{animation:fadeInArchives .6s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--card-bg);border:1px solid var(--border-color);border-radius:20px;box-shadow:0 8px 32px #0000001f;max-width:600px;padding:var(--space-8) var(--space-6);text-align:center;transition:all .3s ease;width:100%}.archives-signin-content:hover{box-shadow:0 12px 48px #00000026;transform:translateY(-2px)}.signin-header{align-items:center;display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-8)}.signin-header svg{color:var(--primary-color);opacity:80%}.signin-header h2{color:var(--primary-color);font-size:2rem;font-weight:700;line-height:1.2;margin:0}.signin-header p{color:var(--text-secondary);font-size:1.1rem;font-weight:500;margin:0}.signin-description{margin-bottom:var(--space-8);text-align:left}.signin-description>p{color:var(--text-primary);font-size:1rem;font-weight:500;margin:0 0 var(--space-4) 0}.signin-description ul{color:var(--text-secondary);margin:0;padding-left:var(--space-6)}.signin-description li{font-size:.95rem;line-height:1.5;margin-bottom:var(--space-3)}.signin-actions{display:flex;flex-wrap:wrap;gap:var(--space-4);justify-content:center;margin-bottom:var(--space-6)}.archives-signin-content .signin-btn{align-items:center;border:2px solid #0000;border-radius:12px;display:inline-flex;font-size:.95rem;font-weight:600;gap:var(--space-2);justify-content:center;min-width:180px;padding:var(--space-3) var(--space-6);text-decoration:none;transition:all .2s ease}.archives-signin-content .signin-btn.primary{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.archives-signin-content .signin-btn.primary:hover{background:var(--primary-hover);border-color:var(--primary-hover);box-shadow:0 4px 16px #d977004d;transform:translateY(-2px)}.archives-signin-content .signin-btn.secondary{background:#0000;border-color:var(--primary-color);color:var(--primary-color)}.archives-signin-content .signin-btn.secondary:hover{background:#d977001a;box-shadow:0 4px 16px #d9770026;transform:translateY(-2px)}.signin-footer{border-top:1px solid var(--border-color);margin-top:var(--space-4);padding-top:var(--space-4)}.signin-footer p{color:var(--text-secondary);font-size:.9rem;font-style:italic;margin:0}@media (max-width:768px){.archives-signin-container{min-height:calc(100vh - 160px);padding:var(--space-6) var(--space-4)}.archives-signin-content{padding:var(--space-6) var(--space-4);transform:none}.archives-signin-content:hover{transform:none}.signin-header h2{font-size:1.75rem}.signin-header svg{height:40px;width:40px}.signin-actions{align-items:center;flex-direction:column}.archives-signin-content .signin-btn{max-width:300px;width:100%}.signin-description{text-align:center}.signin-description ul{padding-left:var(--space-4);text-align:left}}@media (max-width:480px){.archives-signin-content{border-radius:16px;padding:var(--space-4) var(--space-3)}.signin-header{margin-bottom:var(--space-6)}.signin-header h2{font-size:1.5rem}.signin-description{margin-bottom:var(--space-6)}}@keyframes fadeInArchives{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:100%;transform:translateY(0) scale(1)}}:root{--primary-color:#fa3;--primary-hover:#f79400;--primary-muted:#ffaa331a;--background-color:#1b1b1b;--surface-color:#2a2a2a;--surface-elevated:#333;--surface-hover:#ffffff0d;--text-primary:#fff;--text-secondary:#b3b3b3;--text-tertiary:grey;--text-accent:#fa3;--border-subtle:#ffffff1a;--border-default:#ffffff26;--border-strong:#fff3;--border-accent:#fa3;--shadow-subtle:0 1px 3px #0003;--shadow-medium:0 4px 12px #0000004d;--shadow-strong:0 8px 24px #0006;--space-xs:0.25rem;--space-sm:0.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--transition-fast:150ms ease-out;--transition-medium:250ms ease-out;--transition-slow:400ms ease-out}@media (prefers-color-scheme:light){:root{--primary-color:#d97700;--primary-hover:#c06800;--primary-muted:#d977001a;--background-color:#fff;--surface-color:#f8f9fa;--surface-elevated:#fff;--surface-hover:#00000008;--text-primary:#1a1a1a;--text-secondary:#6b7280;--text-tertiary:#9ca3af;--text-accent:#d97700;--border-subtle:#00000014;--border-default:#0000001f;--border-strong:#00000029;--border-accent:#d97700;--shadow-subtle:0 1px 3px #0000001a;--shadow-medium:0 4px 12px #00000026;--shadow-strong:0 8px 24px #0003}}*{box-sizing:border-box}.help-page{background-color:#0f0f0f;color:#f1f1f1;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;font-size:16px;font-weight:400;letter-spacing:-.01em;line-height:1.5;min-height:100vh;padding-top:var(--page-content-offset)}@media (max-width:768px){.help-page{padding-top:var(--page-content-offset)}}@media (max-width:480px){.help-page{padding-top:var(--page-content-offset)}}.help-header{background:#2a2a2a;background:var(--surface-color);border-bottom:1px solid #ffffff26;border-bottom:1px solid var(--border-default);padding:2rem 1.5rem;padding:var(--space-xl) var(--space-lg);text-align:left}.help-main-title{color:#fff;color:var(--text-primary);font-size:2rem;font-weight:600;letter-spacing:-.02em;margin:0 0 .5rem;margin:0 0 var(--space-sm) 0}.help-main-subtitle{color:#b3b3b3;color:var(--text-secondary);font-size:1rem;font-weight:400;margin:0 auto;max-width:480px}.help-container{margin:0 auto;max-width:1024px;padding:0 1.5rem 4rem;padding:0 var(--space-lg) var(--space-3xl)}.help-search-container{margin:3rem auto 2rem;margin:var(--space-2xl) auto var(--space-xl);max-width:400px;position:relative}.help-search-icon{color:grey;color:var(--text-tertiary);height:20px;left:1rem;left:var(--space-md);pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);width:20px}.help-search-input{background:#333;background:var(--surface-elevated);border:1px solid #ffffff26;border:1px solid var(--border-default);border-radius:12px;border-radius:var(--radius-lg);box-shadow:none;color:#fff;color:var(--text-primary);font-size:1rem;padding:1rem 1rem 1rem 3rem;padding:var(--space-md) var(--space-md) var(--space-md) 3rem;transition:all .15s ease-out;transition:all var(--transition-fast);width:100%}.help-search-input:focus{border-color:#fa3;border-color:var(--border-accent);box-shadow:0 0 0 3px #ffaa331a;box-shadow:0 0 0 3px var(--primary-muted);outline:none}.help-search-input::placeholder{color:grey;color:var(--text-tertiary);font-weight:400}.help-sections-container{display:flex;flex-direction:column;gap:.5rem;gap:var(--space-sm);margin-bottom:3rem;margin-bottom:var(--space-2xl)}.help-section-card{background:#333;background:var(--surface-elevated);border:1px solid #ffffff1a;border:1px solid var(--border-subtle);border-radius:12px;border-radius:var(--radius-lg);overflow:hidden;transition:all .25s ease-out;transition:all var(--transition-medium)}.help-section-card:hover{border-color:#ffffff26;border-color:var(--border-default);box-shadow:0 1px 3px #0003;box-shadow:var(--shadow-subtle)}.help-section-card.expanded{border-color:#fa3;border-color:var(--border-accent);box-shadow:0 4px 12px #0000004d;box-shadow:var(--shadow-medium)}.help-section-header{align-items:center;background:#0000;border:none;color:#fff;color:var(--text-primary);cursor:pointer;display:flex;font-family:inherit;justify-content:space-between;padding:1.5rem;padding:var(--space-lg);text-align:left;transition:background-color .15s ease-out;transition:background-color var(--transition-fast);width:100%}.help-section-header:hover{background:#ffffff0d;background:var(--surface-hover)}.help-section-header:focus{outline:2px solid #fa3;outline:2px solid var(--border-accent);outline-offset:-2px}.help-section-header-left{align-items:center;display:flex;flex:1 1;gap:1rem;gap:var(--space-md)}.help-section-icon{color:#fa3;color:var(--text-accent);flex-shrink:0;height:20px;width:20px}.help-section-title{color:#fff;color:var(--text-primary);font-size:1.125rem;font-weight:500;letter-spacing:-.01em;margin:0}.help-section-chevron{color:grey;color:var(--text-tertiary);flex-shrink:0;height:20px;transition:all .25s ease-out;transition:all var(--transition-medium);width:20px}.help-section-card.expanded .help-section-chevron{color:#fa3;color:var(--text-accent);transform:rotate(180deg)}.help-section-content{animation:slideDown ease-out .4s ease-out;animation:slideDown var(--transition-slow) ease-out;background:#2a2a2a;background:var(--surface-color)}.help-section-content-inner{padding:1.5rem;padding:var(--space-lg)}.help-qa-list{display:flex;flex-direction:column;gap:2rem;gap:var(--space-xl)}.help-qa-question{color:#fff;color:var(--text-primary);font-size:1.0625rem;font-weight:500;line-height:1.4;margin:0 0 .5rem;margin:0 0 var(--space-sm) 0}.help-qa-answer{color:#b3b3b3;color:var(--text-secondary);font-size:.9375rem;line-height:1.6;margin:0}.help-quick-access{background:#333;background:var(--surface-elevated);border:1px solid #ffffff26;border:1px solid var(--border-default);border-radius:12px;border-radius:var(--radius-lg);margin-bottom:2rem;margin-bottom:var(--space-xl);padding:2rem;padding:var(--space-xl)}.help-quick-access-title{color:#fff;color:var(--text-primary);font-size:1.25rem;font-weight:500;letter-spacing:-.01em;margin:0 0 1.5rem;margin:0 0 var(--space-lg) 0;text-align:center}.help-quick-access-grid{grid-gap:1rem;grid-gap:var(--space-md);display:grid;gap:1rem;gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.help-quick-access-item{align-items:center;background:#2a2a2a;background:var(--surface-color);border:1px solid #ffffff1a;border:1px solid var(--border-subtle);border-radius:8px;border-radius:var(--radius-md);color:inherit;cursor:pointer;display:flex;flex-direction:column;gap:.5rem;gap:var(--space-sm);padding:1.5rem;padding:var(--space-lg);text-decoration:none;transition:all .15s ease-out;transition:all var(--transition-fast)}.help-quick-access-item:hover{background:#ffffff0d;background:var(--surface-hover);border-color:#ffffff26;border-color:var(--border-default);transform:translateY(-1px)}.help-quick-access-icon{color:#fa3;color:var(--text-accent);height:24px;width:24px}.help-quick-access-label{color:#fff;color:var(--text-primary);font-size:.9375rem;font-weight:450;text-align:center}.help-contact-support{margin-top:3rem;margin-top:var(--space-2xl)}.help-contact-card{background:#333;background:var(--surface-elevated);border:1px solid #ffffff26;border:1px solid var(--border-default);border-radius:12px;border-radius:var(--radius-lg);padding:2rem;padding:var(--space-xl);text-align:center}.help-contact-title{color:#fff;color:var(--text-primary);font-size:1.25rem;font-weight:500;margin:0 0 1rem;margin:0 0 var(--space-md) 0}.help-contact-description{color:#b3b3b3;color:var(--text-secondary);font-size:1rem;line-height:1.5;margin:0 0 1.5rem;margin:0 0 var(--space-lg) 0}.help-contact-footer{border-top:1px solid #ffffff1a;border-top:1px solid var(--border-subtle);color:grey;color:var(--text-tertiary);font-size:.875rem;margin:0;padding-top:1rem;padding-top:var(--space-md)}@keyframes slideDown{0%{max-height:0;opacity:0;transform:translateY(-4px)}to{max-height:2000px;opacity:100%;transform:translateY(0)}}@media (max-width:768px){.help-header{padding:1.5rem 1rem;padding:var(--space-lg) var(--space-md)}.help-main-title{font-size:1.75rem}.help-container{padding:0 1rem 2rem;padding:0 var(--space-md) var(--space-xl)}.help-section-content-inner,.help-section-header{padding:1rem;padding:var(--space-md)}.help-quick-access{padding:1.5rem;padding:var(--space-lg)}.help-quick-access-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.help-contact-card{padding:1.5rem;padding:var(--space-lg)}}@media (max-width:480px){.help-main-title{font-size:1.5rem}.help-quick-access-grid{grid-template-columns:1fr 1fr}.help-search-input{padding:.5rem .5rem .5rem 2.5rem;padding:var(--space-sm) var(--space-sm) var(--space-sm) 2.5rem}.help-search-icon{height:18px;left:.5rem;left:var(--space-sm);width:18px}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-contrast:high){:root{--border-default:#fff;--text-secondary:#fff;--text-tertiary:#ccc}}.incident-management-page{background-color:#0f0f0f;color:#f1f1f1;font-family:Segoe UI,sans-serif;min-height:100vh;padding:calc(160px + 2rem) 2rem 2rem}@media (max-width:768px){.incident-management-page{padding-top:calc(140px + 2rem)}}@media (max-width:480px){.incident-management-page{padding-top:calc(130px + 2rem)}}.header-container{align-items:center;background:#000;display:flex;justify-content:space-between;margin-bottom:2rem;position:relative}.header-container h2{left:50%;margin:0;position:absolute;transform:translateX(-50%)}.incident-management-page h2{color:#feac34;font-size:2rem;margin-bottom:2rem;text-align:left}.back-button{background:#feac34;border:none;border-radius:10px;color:#000;cursor:pointer;font-size:.9rem;font-weight:700;padding:.5rem 1rem;transition:background .3s ease}.back-button:hover{background:#f79400}.incident-table{background-color:#1e1e1e;border-collapse:initial;border-radius:12px;border-spacing:0;box-shadow:0 4px 10px #0000004d;overflow:hidden;width:100%}.incident-table td,.incident-table th{border-bottom:1px solid #333;padding:1rem;text-align:left}.incident-table th{background-color:#2a2a2a;color:#ddd;font-weight:700}.incident-table tr:last-child td{border-bottom:none}.incident-table tr:hover{background-color:#2e2e2e}.incident-table select{background-color:#2a2a2a;border:none;border-radius:8px;box-sizing:border-box;color:#fff;cursor:pointer;font-size:1rem;padding:.5rem;width:100%}.incident-table select:focus{box-shadow:0 0 5px #ffae3680;outline:none}.incident-table button{background:#feac34;border:none;border-radius:10px;color:#000;cursor:pointer;font-size:.9rem;font-weight:700;padding:.5rem 1rem;transition:background .3s ease}.incident-table button:hover{background:#f79400}.incident-card{background:#ffffff4d;border:none;border-radius:12px;box-shadow:0 4px 10px #0000004d;margin-bottom:1.5rem;padding:1.5rem}.incident-card h3{color:#000;font-size:1.5rem;margin-bottom:1rem}.incident-card p{color:#333;font-size:1rem;margin:.5rem 0}.access-denied-message,.error-message,.loading-message{background-color:#1e1e1e;border-radius:12px;box-shadow:0 4px 10px #0000004d;color:#fff;font-size:1.2rem;margin:2rem auto;max-width:500px;padding:2rem;text-align:center}@media (max-width:768px){.incident-table{font-size:.9rem}.incident-table td,.incident-table th{padding:.75rem}.incident-table button,.incident-table select{font-size:.85rem;padding:.4rem}.back-button{text-align:center;width:100%}}
/*# sourceMappingURL=main.9c9394fa.css.map*/