@font-face{font-family:Poppins;src:url(/assets/Poppins-Regular-CTKNfV9P.ttf)format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Poppins;src:url(/assets/Poppins-Medium-Cxde2ZoM.ttf)format("truetype");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:Poppins;src:url(/assets/Poppins-SemiBold-B_fPDAUb.ttf)format("truetype");font-weight:600;font-style:normal;font-display:swap}@font-face{font-family:Poppins;src:url(/assets/Poppins-Bold-qTAUjFF7.ttf)format("truetype");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:Poppins;src:url(/assets/Poppins-ExtraBold-W_qeO1XX.ttf)format("truetype");font-weight:800;font-style:normal;font-display:swap}@font-face{font-family:Poppins;src:url(/assets/Poppins-Black-yHqY0KRU.ttf)format("truetype");font-weight:900;font-style:normal;font-display:swap}:root{--bg-color:#f3f5f8;--card-bg:#fff;--text-main:#1e293b;--text-muted:#64748b;--brand-color:#0d9488;--brand-color-light:#ccfbf1;--success:#16a34a;--warning:#f59e0b;--danger:#ef4444;--border-color:#e2e8f0;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-md:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a}h1,h2,h3,h4,h5,h6,p,m{margin:0}:root{--bg-color:#f1f5f9;--card-bg:#fff;--text-main:#1e293b;--text-muted:#64748b;--brand-color:#0d9488;--brand-blue:#3b82f6;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--border-color:#e2e8f0;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-md:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a}body{background-color:var(--bg-color);color:var(--text-main);box-sizing:border-box;-webkit-font-smoothing:antialiased;margin:0;padding:0;font-family:Poppins,system-ui,sans-serif}*,:before,:after{box-sizing:inherit}img,svg{max-width:100%;display:block}h1,h2,h3,h4,h5,h6,p{margin:0}.app-container{flex-direction:column;min-height:100vh;display:flex}.app-container.mobile-google-maps-mode{height:100dvh;overflow:hidden}.header{-webkit-backdrop-filter:blur(24px);z-index:1000;background:#ffffffbf;border:1px solid #fff6;border-radius:9999px;justify-content:space-between;align-items:center;width:94%;max-width:none;height:64px;padding:0 1.5rem;transition:all .3s;display:flex;position:fixed;top:20px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #1e293b1a}.header-left{align-items:center;gap:1rem;display:flex}.logo{color:var(--text-main);align-items:center;gap:.5rem;font-size:1.25rem;font-weight:800;display:flex}.logo-text{font-family:Poppins,system-ui,sans-serif;font-size:1.25rem;font-weight:800}.logo-text-zero{color:var(--brand-color)}.logo-text-route{color:var(--brand-blue)}.logo-image{object-fit:contain;width:80px;height:80px;display:block}.header-subtitle{color:var(--text-muted);border-left:1px solid var(--border-color);white-space:nowrap;margin-left:1rem;padding-left:1rem;font-size:.875rem}.mobile-menu-btn{cursor:pointer;color:var(--text-main);display:none}.header-right{align-items:center;gap:1.25rem;display:flex}.system-status{color:var(--text-muted);align-items:center;gap:.5rem;font-size:.875rem;display:flex}.status-dot{background-color:var(--success);border-radius:50%;width:8px;height:8px}.header-icon{color:var(--text-muted);cursor:pointer;transition:color .2s}.header-icon:hover{color:var(--text-main)}.avatar{cursor:pointer;background-color:#e2e8f0;border-radius:50%;width:36px;height:36px;overflow:hidden}.avatar img{object-fit:cover;width:100%;height:100%}.main-layout{display:none}.glass-panel{-webkit-backdrop-filter:blur(24px);background:#ffffffbf;border:1px solid #fff6;box-shadow:0 8px 32px #00000014}.desktop-floating-panel{z-index:20;border-radius:24px;flex-direction:column;gap:1.5rem;width:420px;padding:1.5rem;transition:all .3s;display:flex;position:absolute;inset:104px 3% 20px auto;overflow-y:auto}.desktop-floating-panel::-webkit-scrollbar{width:6px}.desktop-floating-panel::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.card{-webkit-backdrop-filter:blur(24px);background:#ffffffd9;border:1px solid #fffc;border-radius:16px;flex-direction:column;display:flex;box-shadow:0 8px 32px #0000000d}.card-header{border-bottom:1px solid #0000;padding:1.25rem 1.5rem 1rem}.card-title{color:var(--text-main);font-size:1rem;font-weight:600}.card-body{padding:1rem 1.5rem 1.5rem}.left-sidebar{flex-direction:column;display:flex}.control-group{margin-bottom:1.5rem}.control-label{color:var(--text-main);margin-bottom:.75rem;font-size:.875rem;font-weight:500;display:block}input[type=range]{appearance:none;background:#cbd5e180;border-radius:4px;outline:none;width:100%;height:8px}input[type=range]::-webkit-slider-thumb{appearance:none;border:3px solid var(--brand-color);cursor:pointer;background:#fff;border-radius:50%;width:22px;height:22px;margin-top:-7px;transition:transform .2s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #0003}input[type=range]::-webkit-slider-runnable-track{cursor:pointer;border-radius:4px;width:100%;height:8px}input[type=range]:active::-webkit-slider-thumb{transform:scale(1.15)}.slider-green::-webkit-slider-thumb{border-color:var(--success)}.slider-blue::-webkit-slider-thumb{border-color:var(--brand-blue)}.slider-teal::-webkit-slider-thumb{border-color:var(--brand-color)}.input-with-unit{align-items:center;display:flex;position:relative}.input-with-unit input{border:1px solid var(--border-color);text-align:left;width:100%;color:var(--text-main);border-radius:6px;padding:.625rem 2.5rem .625rem .625rem;font-family:inherit;font-size:.875rem;font-weight:600}.input-with-unit .unit{color:var(--text-muted);font-size:.875rem;position:absolute;right:.75rem}.btn-primary{color:#fff;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;background:linear-gradient(#60a5fa,#2563eb);border:none;border-radius:9999px;width:100%;margin-top:1rem;padding:.85rem;font-family:Poppins,system-ui,sans-serif;font-size:.8125rem;font-weight:700;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #2563eb4d}.btn-primary:active{transform:translateY(1px);box-shadow:0 2px 4px -1px #2563eb4d}.btn-green{background:linear-gradient(#10b981,#059669);box-shadow:0 4px 6px -1px #10b9814d}.btn-green:active{background:linear-gradient(#0ea5e9,#0d9488);transform:translateY(1px)}.map-background-wrapper{z-index:0;position:fixed;inset:0}.map-background-wrapper .leaflet-container{border-radius:0}.insights-body{flex:1;padding:0}.insights-content{flex:1;align-items:stretch;gap:2rem;padding:0 1.5rem 1rem;display:flex}.chart-wrapper{flex:1;width:99%;min-height:200px;margin-bottom:1rem}.chart-legend{color:var(--text-main);justify-content:center;align-items:center;gap:1rem;padding-bottom:.5rem;font-size:.75rem;display:flex}.legend-item{align-items:center;gap:.4rem;display:flex}.legend-color{border-radius:50%;width:8px;height:8px}.info-row{justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.875rem;display:flex}.info-label{color:var(--text-muted)}.info-value{color:var(--text-main);font-weight:500}.info-value.bold{font-weight:600}.info-value.green{color:var(--success);font-size:1.25rem;font-weight:700}.info-value.moderate{color:var(--brand-color)}.route-path{letter-spacing:.02em;font-size:.8125rem}.desktop-nav{position:relative}.nav-item-container{align-items:center;display:flex;position:relative}@keyframes popupFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.nav-popup{-webkit-backdrop-filter:blur(24px);z-index:1000;background:#ffffffbf;border:1px solid #fff6;border-radius:16px;width:280px;margin-top:15px;padding:1.25rem;animation:.2s ease-out popupFadeIn;position:absolute;top:100%;right:0;box-shadow:0 12px 32px #0000001f}.nav-popup h4{border-bottom:1px solid var(--border-color);color:var(--text-main);margin-bottom:.75rem;padding-bottom:.5rem;font-size:.875rem;font-weight:600}.nav-popup ul{margin:0;padding:0;list-style:none}.nav-popup li{color:var(--text-muted);cursor:pointer;align-items:center;gap:.5rem;padding:.5rem 0;font-size:.8125rem;display:flex}.nav-popup li:hover{color:var(--text-main)}.dot{border-radius:50%;width:6px;height:6px}.dot.green{background-color:var(--success)}.dot.blue{background-color:var(--brand-blue)}.dot.yellow{background-color:var(--warning)}.mobile-dropdown-nav{-webkit-backdrop-filter:blur(24px);z-index:1000;background:#ffffffbf;border:1px solid #fff6;border-radius:20px;width:94%;padding:.5rem 0;animation:.2s ease-out popupFadeIn;position:absolute;top:86px;left:3%;box-shadow:0 12px 32px #0000001f}.mobile-nav-item{cursor:pointer;color:var(--text-main);border-bottom:1px solid #e2e8f080;padding:1rem 1.5rem;font-weight:500}.mobile-nav-item:last-child{border-bottom:none}.mobile-popup-content{color:var(--text-muted);background:#fff6;padding:.5rem 1.5rem 1rem;font-size:.875rem}.mobile-popup-content li{margin-bottom:.5rem;list-style-type:none}.leaflet-container{z-index:1;border-radius:8px;width:100%;height:100%}.leaflet-top.leaflet-right .leaflet-control{margin-top:110px!important;margin-right:12px!important}.leaflet-top.leaflet-left .leaflet-control-zoom{display:none!important}.mobile-map-full .leaflet-container{border-radius:0}.modal-overlay{-webkit-backdrop-filter:blur(12px);z-index:2000;background:#fff3;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-content{-webkit-backdrop-filter:blur(24px);background:#ffffffbf;border:1px solid #fffc;border-radius:32px;width:100%;max-width:440px;padding:2.5rem;box-shadow:0 32px 64px #00000026}.modal-title{letter-spacing:-.02em;color:var(--text-main);align-items:center;margin-bottom:2rem;font-size:1.5rem;font-weight:800;display:flex}.modern-search-input input{text-align:left;width:100%;color:var(--text-main);font-family:inherit;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:inset 0 2px 6px #00000005;background:#ffffff80!important;border:1px solid #fffc!important;border-radius:9999px!important;padding:1rem 1.25rem 1rem 3rem!important;font-size:1rem!important;font-weight:500!important}.modern-search-input input:focus{outline:none;box-shadow:0 0 0 4px #3b82f633,inset 0 2px 6px #00000005;border-color:var(--brand-blue)!important;background:#ffffffe6!important}.btn-cancel{color:var(--text-main);box-shadow:none;background:#ffffff80;border:1px solid #fffc}.btn-cancel:hover{background:#ffffffe6;transform:translateY(-1px)}.bottom-sheet{z-index:100;-webkit-backdrop-filter:blur(24px);background:#ffffffbf;border-top:1px solid #fff6;border-top-left-radius:24px;border-top-right-radius:24px;flex-direction:column;transition:transform .3s cubic-bezier(.2,.8,.2,1);display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 20px #00000026}.bottom-sheet.collapsed{transform:translateY(calc(100% - 23dvh))}.bottom-sheet.expanded{height:85dvh;transform:translateY(0)}.bottom-sheet-handle{cursor:pointer;touch-action:pan-y;border-top-left-radius:24px;border-top-right-radius:24px;flex-direction:column;align-items:center;padding:1.5rem 1rem 1rem;display:flex}.handle-bar{background:#94a3b8;border-radius:3px;width:50px;height:5px}.bottom-sheet-content{flex-direction:column;flex:1;gap:1.5rem;padding:1rem 1.5rem 2rem;display:flex;overflow-y:auto}.bottom-sheet-content::-webkit-scrollbar{display:none}@media (width<=992px){.desktop-floating-panel{width:340px}}@media (width<=768px){.header{-webkit-backdrop-filter:blur(24px);background:#ffffffbf;border:1px solid #fff6;border-radius:9999px;width:94%;height:60px;padding:0 1.25rem;position:fixed;top:16px;left:3%;transform:none;box-shadow:0 8px 32px #1e293b1a}.header-subtitle,.header-right{display:none}.mobile-menu-btn{display:block}.insights-content{flex-direction:column}.leaflet-top.leaflet-right .leaflet-control{margin-top:10vh!important;margin-right:1.25rem!important}.logo-text{position:absolute;left:50%;transform:translate(-50%)}}.suggestions-dropdown{-webkit-backdrop-filter:blur(32px);z-index:3000;background:#fffffff2;border:1px solid #fffc;border-radius:20px;flex-direction:column;max-height:240px;margin-top:12px;padding:.5rem;display:flex;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 16px 40px #00000026}.suggestions-dropdown::-webkit-scrollbar{width:6px}.suggestions-dropdown::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.suggestion-item{cursor:pointer;color:var(--text-main);text-align:left;border-radius:12px;align-items:center;gap:.75rem;padding:.85rem 1rem;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.suggestion-item:hover{color:var(--brand-blue);background:#3b82f61a}.preset-pill{color:var(--text-main);cursor:pointer;background:0 0;border:1px solid #94a3b866;border-radius:9999px;padding:.4rem .9rem;font-family:Poppins,system-ui,sans-serif;font-size:.75rem;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1)}.preset-pill:hover{background:#94a3b81a;border-color:#94a3b899}.preset-pill.active{color:var(--brand-blue);border-color:var(--brand-blue);background:#3b82f61a}.desktop-center-nav{align-items:center;gap:2.5rem;display:flex}.nav-link{color:var(--text-muted);font-size:.9375rem;font-weight:600;text-decoration:none;transition:color .2s;position:relative}.nav-link:hover{color:var(--text-main)}.nav-link.active{color:var(--brand-blue)}.nav-link.active:after{content:"";background-color:var(--brand-blue);border-radius:3px 3px 0 0;width:100%;height:3px;position:absolute;bottom:-22px;left:0}.header-status{flex-direction:column;justify-content:center;align-items:flex-end;margin-right:.5rem;display:flex}.nav-separator{background-color:#94a3b84d;width:1px;height:28px;margin:0 1rem}.control-select{border:1px solid var(--border-color);width:100%;color:var(--text-main);background:#ffffffbf;border-radius:10px;outline:none;padding:.65rem .75rem;font-family:inherit;font-size:.875rem;font-weight:500}.control-select:focus{border-color:var(--brand-blue);box-shadow:0 0 0 3px #3b82f626}.toggle-row{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.platoon-toggle{border:1px solid var(--border-color);color:var(--text-main);cursor:pointer;background:#ffffffbf;border-radius:9999px;padding:.35rem .75rem;font-size:.75rem;font-weight:700;transition:all .2s}.platoon-toggle.enabled{color:#047857;background:#10b98126;border-color:#10b98180}.projection-pill{background:#ffffffa6;border:1px solid #94a3b840;border-radius:12px;justify-content:space-between;align-items:center;margin-top:.9rem;padding:.6rem .75rem;font-size:.8125rem;display:flex}.projection-pill strong{color:#047857;font-size:.85rem}.mini-note{color:var(--text-muted);margin-top:.75rem;margin-bottom:0;font-size:.74rem}.summary-grid{grid-template-columns:1fr;gap:.15rem;display:grid}.map-legend{color:var(--text-muted);border-top:1px solid #e2e8f0b3;flex-direction:column;gap:.38rem;margin-top:.45rem;padding-top:.55rem;font-size:.75rem;display:flex}.map-legend>div{align-items:center;gap:.4rem;display:flex}.legend-dot{border-radius:50%;width:9px;height:9px;display:inline-block}
