@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";@import "https://unpkg.com/leaflet@1.9.4/dist/leaflet.css";:root{--bg-primary:#fff;--bg-secondary:#f5f5f5;--text-primary:#202124;--text-secondary:#5f6368;--accent-primary:#1a73e8;--accent-hover:#1557b0;--danger:#ea4335;--success:#34a853;--border-color:#dadce0;--glass-bg:#fffffff2;--glass-border:#00000014;--shadow-sm:0 1px 2px #0000001a;--shadow-md:0 2px 8px #00000026;--sidebar-width:380px}*{box-sizing:border-box;margin:0;padding:0}html,body{max-width:100vw;height:100vh;overflow:hidden}body{background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;flex-direction:column;font-family:Outfit,sans-serif;display:flex}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:inherit}.glass-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);box-shadow:var(--shadow-md);border-radius:16px}.btn-primary{background:linear-gradient(135deg, var(--accent-primary), var(--accent-hover));color:#fff;cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:.9rem;font-weight:600;transition:box-shadow .2s;display:inline-flex}.btn-primary:hover{box-shadow:0 2px 8px #1a73e84d}.btn-secondary{color:var(--text-primary);border:1px solid var(--border-color);cursor:pointer;background:#fff;border-radius:8px;padding:12px 24px;font-size:.9rem;font-weight:500;transition:background .2s}.btn-secondary:hover{background:var(--bg-secondary)}.input-group{flex-direction:column;gap:8px;margin-bottom:20px;display:flex}.input-group label{color:var(--text-secondary);font-size:.9rem;font-weight:500}.input-control{border:1px solid var(--border-color);color:var(--text-primary);background:#fff;border-radius:8px;outline:none;padding:12px 16px;transition:border-color .2s}.input-control:focus{border-color:var(--accent-primary);box-shadow:0 0 0 2px #1a73e826}input[type=range]{-webkit-appearance:none;background:0 0;width:100%}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent-primary);cursor:pointer;border-radius:50%;width:20px;height:20px;margin-top:-8px;box-shadow:0 1px 4px #0003}input[type=range]::-webkit-slider-runnable-track{cursor:pointer;background:var(--border-color);border-radius:2px;width:100%;height:4px}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.4s ease-out forwards fadeIn}.map-sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);border-right:1px solid var(--border-color);z-index:1;background:#fff;flex-direction:column;height:100%;transition:transform .3s;display:flex}@media (width<=768px){.map-sidebar{z-index:900;position:fixed;top:70px;bottom:0;left:0;transform:translate(-100%);box-shadow:4px 0 20px #0003}.map-sidebar.open{transform:translate(0)}.sidebar-backdrop{z-index:899;background:#0006;display:none;position:fixed;inset:70px 0 0}.sidebar-backdrop.open{display:block}}.sidebar-header{border-bottom:1px solid var(--border-color);color:var(--text-primary);align-items:center;gap:10px;padding:16px 20px;font-size:1rem;font-weight:600;display:flex}.sidebar-filters{border-bottom:1px solid var(--border-color);flex-direction:column;gap:12px;padding:16px 20px;display:flex}.sidebar-filters h3{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.85rem;font-weight:600}.filter-row{flex-direction:column;gap:4px;display:flex}.filter-row label{color:var(--text-secondary);font-size:.8rem;font-weight:500}.filter-row select{border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;background:#fff;border-radius:8px;outline:none;padding:8px 12px;font-size:.85rem}.filter-row select:focus{border-color:var(--accent-primary)}.severity-header{justify-content:space-between;align-items:center;display:flex}.severity-header span{color:var(--text-secondary);font-size:.8rem}.filter-reset{color:var(--accent-primary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:4px;padding:4px 0;font-size:.8rem;font-weight:500;display:inline-flex}.filter-reset:hover{text-decoration:underline}.sidebar-list{flex:1;padding:0;overflow-y:auto}.sidebar-list-header{color:var(--text-secondary);border-bottom:1px solid var(--border-color);text-transform:uppercase;letter-spacing:.5px;padding:12px 20px;font-size:.85rem;font-weight:600}.sidebar-list-empty{text-align:center;color:var(--text-secondary);padding:40px 20px;font-size:.9rem}.road-list-item{border-bottom:1px solid var(--border-color);cursor:pointer;padding:14px 20px;transition:background .15s}.road-list-item:hover{background:#f8f9fa}.road-list-item:active{background:#e8f0fe}.road-item-header{justify-content:space-between;align-items:flex-start;margin-bottom:4px;display:flex}.road-item-name{color:var(--text-primary);font-size:.95rem;font-weight:600;line-height:1.3}.road-item-distance{color:var(--text-secondary);white-space:nowrap;flex-shrink:0;margin-left:8px;padding-top:2px;font-size:.8rem}.road-item-address{color:var(--text-secondary);-webkit-line-clamp:1;-webkit-box-orient:vertical;margin-bottom:8px;font-size:.8rem;display:-webkit-box;overflow:hidden}.road-item-badges{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.road-item-badge{border-radius:12px;align-items:center;gap:4px;padding:2px 8px;font-size:.75rem;font-weight:600;display:inline-flex}.map-controls{z-index:1000;box-shadow:var(--shadow-md);border-radius:8px;flex-direction:column;display:flex;position:absolute;bottom:30px;right:20px;overflow:hidden}.map-controls button{cursor:pointer;width:40px;height:40px;color:var(--text-primary);background:#fff;border:none;justify-content:center;align-items:center;font-size:1.3rem;transition:background .15s;display:flex}.map-controls button:hover{background:#f1f3f4}.map-controls button:not(:last-child){border-bottom:1px solid var(--border-color)}.map-controls .locate-btn{border-top:1px solid var(--border-color);color:var(--accent-primary)}.map-area{flex:1;position:relative}.sidebar-toggle{z-index:500;border:1px solid var(--border-color);width:40px;height:40px;box-shadow:var(--shadow-md);cursor:pointer;color:var(--text-primary);background:#fff;border-radius:8px;justify-content:center;align-items:center;font-size:1.2rem;display:none;position:absolute;top:10px;left:10px}@media (width<=768px){.sidebar-toggle{display:flex}}.map-container{flex:1;display:flex;position:relative;overflow:hidden}.navbar{z-index:1000;border-bottom:1px solid var(--border-color);height:70px;box-shadow:var(--shadow-sm);background:#fff;justify-content:space-between;align-items:center;padding:0 5%;display:flex;position:fixed;top:0;left:0;right:0}@media (width<=768px){.navbar{height:56px;padding:0 12px}.navbar .btn-primary{padding:8px 14px;font-size:.8rem}}.logo{color:var(--text-primary);align-items:center;gap:8px;font-size:1.3rem;font-weight:700;display:inline-flex}@media (width<=768px){.logo{gap:4px;font-size:1rem}.logo svg{width:20px;height:20px}}.main-container{flex-direction:column;height:100vh;padding-top:70px;display:flex;position:relative;overflow-y:auto}@media (width<=768px){.main-container{padding-top:56px}}#root{text-align:left;box-sizing:border-box;border:none;flex-direction:column;width:100%;max-width:100%;min-height:100svh;margin:0;display:flex}@media (width<=768px){.map-controls{bottom:16px;right:10px}.map-controls button{width:36px;height:36px;font-size:1.1rem}.glass-panel{border-radius:12px;padding:1rem!important}}.leaflet-popup-content-wrapper{color:var(--text-primary);background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000026}.leaflet-popup-tip{background:#fff}.leaflet-container a.leaflet-popup-close-button{color:var(--text-secondary);top:8px!important;right:6px!important}.leaflet-popup-content{margin:12px}.marker-cluster-custom{background:0 0!important;border:none!important}.marker-cluster-small{background-color:#34a8534d}.marker-cluster-small div{background-color:#34a85399}.marker-cluster-medium{background-color:#fbbc044d}.marker-cluster-medium div{background-color:#fbbc0499}.marker-cluster-large{background-color:#ea43354d}.marker-cluster-large div{background-color:#ea433599}
