@import "https://fonts.googleapis.com/css2?family=Montserrat:wght@100..900&display=swap";
:root{--background:#000;--foreground:#fff;--sidebar-width:380px;--nebula-accent:#f03;--glass-bg:#050000e6;--glass-blur:blur(30px)saturate(200%);--glass-border:#ff003340;--shadow-quantum:0 10px 40px #000000e6;--shadow-glow:0 0 15px #f036}*{box-sizing:border-box;-webkit-font-smoothing:antialiased;margin:0;padding:0;font-weight:900;font-family:Montserrat,sans-serif!important}html,body{background:#000;width:100vw;height:100vh;overflow:hidden}.main-container{width:100vw;height:100vh;position:relative;overflow:hidden}.map-container{z-index:1;background:#000;position:absolute;inset:0}.sidebar{z-index:2000;background:var(--glass-bg);width:340px;-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);box-shadow:var(--shadow-quantum);will-change:transform;border-radius:28px;flex-direction:column;transition:transform .6s cubic-bezier(.19,1,.22,1);display:flex;position:absolute;top:20px;bottom:20px;left:20px;overflow:hidden}.sidebar.closed{transform:translate(calc(-100% - 40px))}.sidebar.open{transform:translate(0)}.sidebar-header{background:#0003;padding:24px}.header-top-row{justify-content:space-between;align-items:center;gap:15px;margin-bottom:20px;display:flex}.sidebar-logo-shell{background:var(--nebula-accent);box-shadow:var(--shadow-glow);white-space:nowrap;letter-spacing:-.5px;border-radius:14px;padding:6px 14px;font-size:1.1rem;font-weight:900;color:#000!important}.tab-bubble-container{background:#ffffff0d;border:1px solid #ffffff08;border-radius:16px;flex:1;padding:4px;display:flex;position:relative}.tab-bubble-indicator{background:var(--nebula-accent);z-index:1;border-radius:12px;transition:left .4s cubic-bezier(.19,1,.22,1),width .3s;position:absolute;top:4px;bottom:4px;box-shadow:0 4px 15px #f036}.tab-bubble-btn{color:#fff6;cursor:pointer;text-transform:uppercase;z-index:2;background:0 0;border:none;border-radius:12px;flex:1;padding:8px 5px;font-size:.65rem;font-weight:900;transition:all .3s;position:relative}.tab-bubble-btn.active{color:#fff}.favorites-header{color:#fff;text-transform:uppercase;letter-spacing:1.5px;border-left:3px solid var(--nebula-accent);margin-top:10px;padding-left:4px;font-size:.9rem;font-weight:900}.search-input{border:1px solid var(--glass-border);color:#fff;background:#ffffff08;border-radius:16px;outline:none;width:100%;margin-top:15px;padding:14px 20px;font-size:.85rem;transition:all .3s}.search-input:focus{border-color:var(--nebula-accent);box-shadow:var(--shadow-glow);background:#ffffff0d}.route-list{scrollbar-width:none;flex:1;padding:15px 20px;overflow-y:auto}.route-list::-webkit-scrollbar{display:none}.route-item{cursor:pointer;color:#fff;background:#ffffff05;border:1px solid #ffffff0d;border-radius:18px;align-items:center;gap:15px;width:100%;margin-bottom:10px;padding:14px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.route-item:hover{background:#ff003314;border-color:#ff00334d;transform:scale(1.02)translate(5px)}.route-badge{text-align:center;border-radius:12px;min-width:55px;padding:6px 12px;font-weight:900;box-shadow:0 4px 10px #0000004d}.system-status-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);z-index:9999;box-shadow:var(--shadow-quantum);background:#050000d9;border-radius:40px;align-items:center;gap:12px;padding:6px 14px;display:flex;position:fixed;top:15px;right:15px}.status-indicator{background:#ff003326;border-radius:20px;align-items:center;gap:6px;padding:4px 10px;display:flex}.status-dot{background:#f03;border-radius:50%;width:6px;height:6px}.status-dot.online{background:var(--nebula-accent);box-shadow:0 0 8px var(--nebula-accent);animation:2s infinite pulse-dot}@keyframes pulse-dot{0%{transform:scale(.9);box-shadow:0 0 #ff0033b3}70%{transform:scale(1.1);box-shadow:0 0 0 15px #f030}to{transform:scale(.9);box-shadow:0 0 #f030}}.status-text{color:#fff;letter-spacing:.5px;font-size:.55rem;font-weight:900}.status-buses-count{color:#fff;opacity:.8;letter-spacing:.5px;text-transform:uppercase;font-size:.55rem;font-weight:900}.leaflet-popup-content-wrapper{background:var(--glass-bg)!important;-webkit-backdrop-filter:blur(25px)!important;backdrop-filter:blur(25px)!important;border:1px solid var(--glass-border)!important;color:#fff!important;box-shadow:var(--shadow-quantum)!important;border-radius:28px!important}.leaflet-popup-tip{background:#000!important}.leaflet-popup-close-button{color:#fff!important;text-align:center!important;background:#f03c!important;border:2px solid #000!important;border-radius:50%!important;justify-content:center!important;align-items:center!important;width:32px!important;height:32px!important;font-size:24px!important;line-height:28px!important;transition:all .2s!important;display:flex!important;top:-10px!important;right:-10px!important;box-shadow:0 4px 10px #00000080!important}.leaflet-popup-close-button:hover{background:#f03!important;transform:scale(1.1)!important}.fav-btn{color:#fff;cursor:pointer;background:#ffffff14;border:1px solid #fff3;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;min-width:34px;height:34px;min-height:34px;font-size:1rem;transition:all .3s;display:flex}.fav-btn.active{background:var(--nebula-accent);border-color:var(--nebula-accent);box-shadow:0 0 15px #ff003380}.map-controls-container{z-index:1000;flex-direction:column;gap:12px;display:flex;position:absolute;top:100px;right:25px}.stops-toggle-btn{cursor:pointer;background:var(--glass-bg)!important;-webkit-backdrop-filter:var(--glass-blur)!important;backdrop-filter:var(--glass-blur)!important;border:1px solid var(--glass-border)!important;color:#fff!important;width:44px!important;height:44px!important;box-shadow:var(--shadow-quantum)!important;border-radius:50%!important;justify-content:center!important;align-items:center!important;font-size:1.2rem!important;font-weight:900!important;transition:all .3s!important;display:flex!important}.stops-toggle-btn:hover{transform:scale(1.1);border-color:var(--nebula-accent)!important}.leaflet-control-zoom a{background:var(--glass-bg)!important;-webkit-backdrop-filter:var(--glass-blur)!important;backdrop-filter:var(--glass-blur)!important;border:1px solid var(--glass-border)!important;color:#fff!important;border-radius:50%!important;justify-content:center!important;align-items:center!important;width:44px!important;height:44px!important;margin-bottom:5px!important;font-weight:900!important;line-height:44px!important;transition:all .3s!important;display:flex!important}.leaflet-control-zoom a:hover{background:var(--nebula-accent)!important;color:#fff!important}.custom-bus-marker-container{will-change:transform;z-index:1000!important;transition:transform .5s linear!important}.rotated-bus-wrapper{will-change:transform}.map-interacting .custom-bus-marker-container{transition:none!important}.balloon-bus-marker{flex-direction:column;align-items:center;display:flex}.balloon-label{color:#fff;z-index:2;white-space:nowrap;border:1px solid #fff6;border-radius:20px;margin-bottom:-5px;padding:4px 10px;font-size:.8rem;font-weight:900;position:relative;box-shadow:0 4px 8px #00000080}.rotated-bus-wrapper{transition:transform .5s ease-out}.bus-mini-pill{white-space:nowrap!important;border:1px solid #fff6!important;border-radius:20px!important;justify-content:center!important;align-items:center!important;padding:4px 10px!important;display:flex!important;box-shadow:0 4px 10px #00000080!important}.mobile-floating-dock{-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);border:1px solid var(--glass-border);z-index:5000;width:90%;max-width:450px;box-shadow:var(--shadow-quantum);background:#050000f2;border-radius:35px;padding:8px;display:none;position:fixed;bottom:20px;left:50%;transform:translate(-50%)}.dock-container{justify-content:space-around;align-items:center;display:flex}.dock-item{color:#ffffff80;background:0 0;border:none;border-radius:25px;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;padding:8px 12px;transition:all .3s;display:flex}.dock-item.active{background:var(--nebula-accent);color:#000;box-shadow:0 5px 15px #f036}.dock-item .icon{font-size:1.2rem}.dock-item .label{text-transform:uppercase;font-size:.55rem;font-weight:900}@media (max-width:768px){.sidebar{border-radius:35px;width:calc(100% - 30px);height:55vh;transition:transform .6s cubic-bezier(.19,1,.22,1);top:auto;bottom:95px;left:15px}.sidebar.closed{transform:translateY(calc(100% + 100px))!important}.sidebar.open{transform:translateY(0)!important}.mobile-floating-dock{display:block}.map-controls-container{display:none!important}.system-status-card{padding:6px 12px;top:10px;right:10px}.status-metrics{display:none}}.sidebar-footer{text-align:center;background:#0000001a;padding:15px}.settings-drawer{background:var(--glass-bg);-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);border-top:1px solid var(--glass-border);z-index:10001;color:#fff;border-radius:35px 35px 0 0;width:100%;padding:20px;animation:.3s cubic-bezier(.19,1,.22,1) slideUp;position:fixed;bottom:0;left:0;transform:translateY(0)}.settings-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.settings-header h3{margin:0;font-size:1.2rem;font-weight:900}.settings-header .close-btn{color:#fff;cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.2rem;display:flex}.setting-card{cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:20px;align-items:center;gap:15px;margin-bottom:12px;padding:15px;display:flex}.setting-card .icon{font-size:1.5rem}.setting-card .text strong{margin-bottom:5px;font-size:1rem;display:block}.setting-card .text p{color:#fff9;margin:0;font-size:.8rem}.lang-group{gap:8px;margin-top:8px;display:flex}.lang-group button{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #fff3;border-radius:12px;padding:6px 12px;font-weight:700}.lang-group button.active{background:var(--nebula-accent);border-color:var(--nebula-accent)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.daan1k-credit{opacity:.4;letter-spacing:1px;font-size:.7rem}.user-loc-dot{background-color:#f03;border:2px solid #fff;border-radius:50%;width:16px;height:16px;animation:1.5s infinite pulse-dot;box-shadow:0 0 10px #f03c}
