:root{--bg-color: #050507;--surface-color: rgba(18, 18, 24, .7);--surface-border: rgba(255, 255, 255, .08);--accent-color: #d12e9b;--accent-glow: rgba(209, 46, 155, .4);--text-primary: #ffffff;--text-secondary: #a0a0b8;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--font-family: "Inter", system-ui, -apple-system, sans-serif;--sidebar-width: 380px;--sidebar-mobile-height: 45vh}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--bg-color);color:var(--text-primary);overflow:hidden;height:100vh;height:100dvh;width:100vw}#root{height:100%}.app-container{display:flex;height:100vh;height:100dvh;width:100vw;position:relative}.map-viewport{width:100%;height:100%;position:relative}.sidebar{width:var(--sidebar-width);height:100%;background:var(--surface-color);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-right:1px solid var(--surface-border);display:flex;flex-direction:column;z-index:1000;box-shadow:20px 0 50px #00000080;transition:margin-left .3s cubic-bezier(.4,0,.2,1);padding-top:env(safe-area-inset-top,0px)}.app-container.no-sidebar .sidebar{margin-left:calc(-1 * var(--sidebar-width))}.sidebar-header{padding:24px;border-bottom:1px solid var(--surface-border)}.logo-container{display:flex;align-items:center;gap:12px;margin-bottom:20px}.logo-icon{color:var(--accent-color);filter:drop-shadow(0 0 8px var(--accent-glow))}.logo-text{font-size:1.5rem;font-weight:800;letter-spacing:-.5px;background:linear-gradient(135deg,#fff,#a0a0b8);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.search-container{position:relative}.search-input{width:100%;background:#0000004d;border:1px solid var(--surface-border);border-radius:12px;padding:12px 16px 12px 44px;color:#fff;font-size:.95rem;transition:all .3s ease}.search-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px var(--accent-glow)}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-secondary)}.train-list{flex:1;overflow-y:auto;padding:16px}.train-list::-webkit-scrollbar{width:6px}.train-list::-webkit-scrollbar-thumb{background:var(--surface-border);border-radius:10px}.train-card{background:#ffffff08;border:1px solid var(--surface-border);border-radius:16px;padding:16px;margin-bottom:12px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.train-card:hover{background:#ffffff0f;border-color:var(--accent-color);transform:translateY(-2px)}.train-card.active{background:#d12e9b1a;border-color:var(--accent-color);box-shadow:0 8px 24px #0003}.train-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.train-code{font-weight:700;font-size:1.1rem;color:#fff}.delay-badge{padding:4px 8px;border-radius:6px;font-size:.75rem;font-weight:700;text-transform:uppercase}.delay-badge.on-time{background:#10b98126;color:#10b981}.delay-badge.delayed{background:#ef444426;color:#ef4444}.delay-badge.critical{background:#ef44444d;color:#ff4d4d;border:1px solid #ef4444;animation:alarm-pulse 1.5s infinite}@keyframes alarm-pulse{0%{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.98);box-shadow:0 0 8px #ef444466}to{opacity:1;transform:scale(1)}}.train-route{font-size:.85rem;color:var(--text-secondary);line-height:1.4;margin-bottom:12px}.train-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;font-size:.8rem}.stat-item{display:flex;align-items:center;gap:6px;color:var(--text-secondary)}.stat-value{color:#fff;font-weight:600}.map-viewport{position:relative;overflow:hidden}.map-controls-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1000}.show-sidebar-btn{position:absolute!important;z-index:2000!important;top:calc(20px + env(safe-area-inset-top,0px));left:20px;background:var(--surface-color);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--surface-border);box-shadow:0 4px 12px #0000004d}.map-controls-overlay>div,.map-controls-overlay>button{pointer-events:auto}.map-layer-selector{display:flex;align-items:center;gap:4px}.drag-handle{display:flex;align-items:center;justify-content:center;color:var(--text-secondary);cursor:grab;padding:4px 2px;opacity:.5;transition:opacity .2s}.drag-handle:hover{opacity:1}.drag-handle:active{cursor:grabbing}.layer-group{display:flex;gap:2px}.layer-btn{background:transparent;border:none;padding:8px 12px;border-radius:8px;color:var(--text-secondary);display:flex;align-items:center;gap:8px;cursor:pointer;transition:all .2s ease;font-size:.75rem;font-weight:500}.layer-btn:hover{background:#ffffff0d;color:#fff}.layer-btn.active{background:var(--accent-color);color:#fff;box-shadow:0 0 10px var(--accent-glow)}.layer-divider{width:1px;height:20px;background:var(--surface-border);margin:0 4px}.weather-toggle.active{background:#3b82f6;color:#fff;box-shadow:0 0 10px #3b82f666}@media(max-width:768px){.app-container{flex-direction:column-reverse}.sidebar{width:100%;height:var(--sidebar-mobile-height);border-right:none;border-top:1px solid var(--surface-border);transition:margin-bottom .3s cubic-bezier(.4,0,.2,1)}.sidebar.hidden{height:0;overflow:hidden}.app-container.no-sidebar .sidebar{margin-bottom:calc(-1 * var(--sidebar-mobile-height))}.sidebar.full{height:90vh}.map-viewport{flex:1}.sidebar.tracking-mobile{height:auto;max-height:40vh;border-top:2px solid var(--accent-color)}.sidebar.tracking-mobile .sidebar-header{display:none}.sidebar.tracking-mobile .train-list{margin-top:0!important;padding:8px}.app-container:has(.sidebar.tracking-mobile) .map-viewport{height:calc(100vh - 160px)}.app-container.no-sidebar .alert-grid-container{bottom:30px;left:12px;right:auto;width:fit-content;padding:12px}.refresh-indicator{bottom:12px;right:12px}.app-container.tracking-active .alert-grid-container{bottom:30px}.app-container.tracking-active .refresh-indicator{bottom:2px}.logo-text{font-size:1.2rem}.sidebar-header{padding:16px}.train-list{padding:12px}.layer-btn span{display:none}.zoom-controls{display:flex;flex-direction:column;gap:8px;background:var(--surface-color);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--surface-border);border-radius:12px;padding:6px;box-shadow:0 4px 12px #0000004d}.zoom-btn{width:38px;height:38px;border-radius:10px}.map-layer-selector{padding:0;background:transparent;border:none;box-shadow:none}.map-layer-selector .layer-group{background:var(--surface-color);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--surface-border);border-radius:12px;padding:4px;display:flex;align-items:center;gap:4px;height:38px;box-sizing:border-box}.floating-actions{display:flex;flex-direction:column;gap:8px;background:var(--surface-color);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--surface-border);border-radius:12px;padding:6px;box-shadow:0 4px 12px #0000004d}.no-portrait{display:flex!important}.action-btn{width:38px;height:38px;border-radius:10px}.show-sidebar-btn{top:190px!important;left:15px!important;right:auto!important;width:40px!important;height:40px!important;margin:0!important}.alert-grid-container{bottom:30px;left:12px;right:auto;width:fit-content;padding:12px}.refresh-indicator{bottom:4px;right:12px;z-index:1001;background:#050507cc;font-size:.65rem;padding:4px 10px}}@media(max-width:950px)and (orientation:landscape){.zoom-controls{flex-direction:column!important;top:110px!important;right:20px!important;gap:8px!important}.floating-actions{flex-direction:column!important;top:190px!important;right:20px!important;gap:8px!important}.zoom-btn,.action-btn,.show-sidebar-btn{width:32px!important;height:32px!important;border-radius:8px!important}.zoom-btn svg,.action-btn svg{width:16px!important;height:16px!important}.map-layer-selector{top:110px!important;left:20px!important;right:auto!important}.show-sidebar-btn{top:110px!important;left:20px!important}.show-sidebar-btn{left:75px!important}.sidebar{padding-top:60px!important}}.refresh-indicator{position:absolute;bottom:24px;right:24px;background:var(--surface-color);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:8px 16px;border-radius:100px;border:1px solid var(--surface-border);display:flex;align-items:center;gap:8px;font-size:.8rem;z-index:1000;color:var(--text-secondary)}.pulse-dot{width:8px;height:8px;background:var(--success);border-radius:50%;box-shadow:0 0 10px var(--success);animation:pulse 2s infinite}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:.5}to{transform:scale(1);opacity:1}}.leaflet-container{background:#0a0a0c!important}.leaflet-popup-content-wrapper{background:var(--surface-color)!important;-webkit-backdrop-filter:blur(12px)!important;backdrop-filter:blur(12px)!important;color:#fff!important;border:1px solid var(--surface-border)!important;border-radius:12px!important}.leaflet-popup-tip{background:var(--surface-color)!important}.leaflet-tooltip{background:#0c0c12f2!important;backdrop-filter:blur(8px)!important;-webkit-backdrop-filter:blur(8px)!important;border:1px solid rgba(209,46,155,.5)!important;border-radius:8px!important;padding:6px 10px!important;color:#fff!important;box-shadow:0 8px 24px #00000080!important;font-family:Inter,system-ui,sans-serif!important;font-size:.75rem!important;font-weight:600!important}.leaflet-tooltip-top:before{border-top-color:#d12e9b80!important}.leaflet-tooltip-bottom:before{border-bottom-color:#d12e9b80!important}.leaflet-tooltip-left:before{border-left-color:#d12e9b80!important}.leaflet-tooltip-right:before{border-right-color:#d12e9b80!important}.custom-train-marker{background:none;border:none}.marker-wrapper{position:relative;width:32px;height:32px;background:var(--accent-color);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 0 15px var(--accent-glow);border:2px solid white;cursor:pointer;transition:transform .2s ease}.marker-wrapper:hover{transform:scale(1.2);z-index:2000}.marker-wrapper.delayed{background:var(--danger);box-shadow:0 0 15px #ef444466}.marker-wrapper.parked{background:var(--success);box-shadow:0 0 15px #10b98166}.parked-indicator{position:absolute;top:-8px;right:-8px;background:#fff;color:var(--success);width:16px;height:16px;border-radius:50%;font-size:.65rem;font-weight:800;display:flex;align-items:center;justify-content:center;border:1px solid var(--success);box-shadow:0 2px 4px #0003;z-index:2}.toolbar-unified{display:flex;flex-direction:column;align-items:center;gap:4px;background:var(--surface-color);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--surface-border);border-radius:12px;padding:4px;box-shadow:0 4px 12px #0000004d;pointer-events:auto}.zoom-controls{z-index:1000}.zoom-btn{width:40px;height:40px;background:transparent;border:1px solid transparent;border-radius:10px;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.zoom-btn:hover{background:#ffffff0d;transform:scale(1.05)}.zoom-btn:active{transform:translateY(0)}.alert-grid-container{position:absolute;bottom:24px;left:24px;background:var(--surface-color);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--surface-border);padding:12px;border-radius:12px;z-index:900;box-shadow:0 8px 32px #0006}.alert-grid-header{font-size:.65rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);margin-bottom:8px;display:flex;justify-content:space-between}.alert-grid{display:grid;grid-template-columns:repeat(20,12px);grid-template-rows:repeat(5,12px);gap:4px}.floating-actions{z-index:1000}.action-btn{width:40px;height:40px;background:transparent;border:1px solid transparent;border-radius:10px;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.action-btn:hover{background:#ffffff0d;transform:scale(1.05)}.action-btn.active{background:var(--accent-color);border:1px solid rgba(255,255,255,.5);box-shadow:0 0 15px var(--accent-glow)}.refresh-indicator.presentation{bottom:24px;left:24px;right:auto}.animate-spin-slow{animation:spin-slow 4s linear infinite}@keyframes spin-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes flash-hint{0%,to{transform:scale(1)}50%{transform:scale(1.2);background-color:#fff;color:var(--accent-color);box-shadow:0 0 20px #fff}}.flash-hint{animation:flash-hint .4s ease-in-out 3;z-index:1100!important}.alert-square{width:12px;height:12px;border-radius:2px;background:#ffffff0d;transition:all .2s ease;position:relative;cursor:help}.alert-square.new{background:var(--success);box-shadow:0 0 8px var(--success)}.alert-square.exit{background:var(--danger);box-shadow:0 0 8px var(--danger)}.alert-square.expired{background:#ffffff26;box-shadow:none;opacity:.5}.alert-square:hover{transform:scale(1.3);z-index:10;outline:1px solid white}.alert-tooltip{position:absolute;bottom:100%;left:0;background:#1a1a24;border:1px solid var(--surface-border);padding:8px 12px;border-radius:8px;width:200px;pointer-events:none;visibility:hidden;opacity:0;transition:opacity .2s ease;z-index:2000;color:#fff;margin-bottom:10px;box-shadow:0 4px 20px #00000080;font-size:.75rem}.alert-square:hover .alert-tooltip{visibility:visible;opacity:1}.alert-tooltip-title{font-weight:700;margin-bottom:4px;display:block}.alert-tooltip-desc{color:var(--text-secondary);line-height:1.3}.help-container{position:absolute;right:14px;top:50%;transform:translateY(-50%);display:flex;align-items:center}.help-icon{color:var(--text-secondary);cursor:help;transition:all .2s ease}.help-icon:hover{color:var(--accent-color)}.search-help-tooltip{position:absolute;top:calc(100% + 15px);right:-5px;width:260px;background:#08080a;border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:16px;box-shadow:0 15px 40px #000000b3;z-index:2000;pointer-events:none;opacity:0;visibility:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);transform:translateY(-8px)}.help-container:hover .search-help-tooltip{opacity:1;visibility:visible;transform:translateY(0)}.search-help-tooltip h4{color:var(--accent-color);font-size:.85rem;margin-bottom:10px;display:flex;align-items:center;gap:8px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.search-help-tooltip ul{list-style:none;padding:0;margin:0}.search-help-tooltip li{font-size:.8rem;color:var(--text-secondary);margin-bottom:10px;line-height:1.4;border-bottom:1px solid rgba(255,255,255,.05);padding-bottom:8px}.search-help-tooltip li:last-child{border-bottom:none;margin-bottom:0}.search-help-tooltip b{color:#fff;font-weight:600}.station-train-row{display:flex;justify-content:space-between;background:#ffffff08;padding:6px 8px;border-radius:4px;font-size:.8rem;cursor:pointer;transition:all .2s ease;border:1px solid transparent;margin-bottom:2px}.station-train-row:hover{background:#d12e9b26;border-color:#d12e9b4d;transform:translate(4px)}.station-train-row strong{color:var(--accent-color)}
