:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#242424;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}body{width:100vw;height:100vh;margin:0;padding:0;overflow:hidden}#app{width:100%;height:100%}.header.svelte-oiwvqb{background-color:#1e1e1e;border-bottom:1px solid #333;justify-content:space-between;align-items:center;height:64px;padding:0 1.5rem;display:flex}.search-bar.svelte-oiwvqb input:where(.svelte-oiwvqb){color:#e0e0e0;background-color:#2a2a2a;border:1px solid #444;border-radius:4px;width:300px;padding:.5rem 1rem}.user-profile.svelte-oiwvqb{align-items:center;gap:1rem;display:flex}.avatar.svelte-oiwvqb{background-color:#646cff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.875rem;font-weight:700;display:flex}.logout-btn.svelte-oiwvqb{color:#ccc;cursor:pointer;background:0 0;border:1px solid #444;border-radius:4px;padding:.25rem .75rem;font-size:.8rem;transition:all .2s}.logout-btn.svelte-oiwvqb:hover{color:#fff;background-color:#333;border-color:#666}.app-sidebar.svelte-181dlmc{box-sizing:border-box;background-color:#242424;border-right:1px solid #333;flex-direction:column;width:240px;padding:1rem 0;display:flex}ul.svelte-181dlmc{margin:0;padding:0;list-style:none}li.svelte-181dlmc{margin-bottom:.5rem}a.svelte-181dlmc{color:#ccc;padding:.75rem 1.5rem;text-decoration:none;transition:background-color .2s,color .2s;display:block}a.svelte-181dlmc:hover{color:#fff;background-color:#333}.layout.svelte-1325jhu{flex-direction:column;width:100vw;height:100vh;display:flex;overflow:hidden}.layout-body.svelte-1325jhu{flex:1;display:flex;overflow:hidden}.content.svelte-1325jhu{color:#e0e0e0;background-color:#121212;flex:1;padding:1.5rem;overflow-y:auto}.dashboard-content.svelte-1thed0a{max-width:1200px;margin:0 auto;padding:1.5rem}.widgets.svelte-1thed0a{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem;margin-top:2rem;display:grid}.card.svelte-1thed0a{background-color:#333;border-radius:8px;padding:1.5rem;box-shadow:0 4px 6px #0000001a}h2.svelte-1thed0a{margin-top:0}h3.svelte-1thed0a{color:#646cff;margin-top:0}.page-container.svelte-kvx99g{padding:1rem}h2.svelte-kvx99g{margin-bottom:1.5rem}.trains-grid.svelte-kvx99g{flex-direction:column;gap:1rem;display:flex}.train-card.svelte-kvx99g{background-color:#1e1e1e;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0003}.train-header.svelte-kvx99g{cursor:pointer;justify-content:space-between;align-items:center;padding:1.5rem;transition:background-color .2s;display:flex}.train-header.svelte-kvx99g:hover{background-color:#2a2a2a}.line-badge.svelte-kvx99g{color:#aaa;background-color:#333;border-radius:4px;padding:.25rem .5rem;font-size:.875rem}.train-status.svelte-kvx99g{text-transform:capitalize;align-items:center;gap:.5rem;display:flex}.status-indicator.svelte-kvx99g{background-color:#ccc;border-radius:50%;width:10px;height:10px;display:block}.status-indicator.active.svelte-kvx99g,.status-indicator.online.svelte-kvx99g{background-color:#4cc9f0}.status-indicator.maintenance.svelte-kvx99g{background-color:#f72585}.status-indicator.inactive.svelte-kvx99g,.status-indicator.offline.svelte-kvx99g{background-color:#7209b7}.camera-status.svelte-kvx99g{text-transform:capitalize;font-weight:500}.camera-status.online.svelte-kvx99g{color:#4cc9f0}.camera-status.offline.svelte-kvx99g{color:#7209b7}.camera-status.maintenance.svelte-kvx99g{color:#f72585}.cameras-grid.svelte-kvx99g{background-color:#1a1a1a;border-top:1px solid #333;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;padding:0 1.5rem 1.5rem;display:grid}.camera-item.svelte-kvx99g{background-color:#000;border-radius:6px;overflow:hidden}.camera-preview.svelte-kvx99g{background-color:#111;justify-content:center;align-items:center;height:160px;display:flex;position:relative;overflow:hidden}.stream-video.svelte-kvx99g{object-fit:cover;width:100%;height:100%}.placeholder-stream.svelte-kvx99g{color:#666;flex-direction:column;align-items:center;gap:.5rem;display:flex}.no-signal.svelte-kvx99g{color:#444;text-transform:uppercase;letter-spacing:1px;font-size:.75rem}.live-badge.svelte-kvx99g{color:#fff;background-color:#ff0000b3;border-radius:4px;padding:2px 6px;font-size:.75rem;font-weight:700;position:absolute;top:8px;right:8px}.camera-footer.svelte-kvx99g{background-color:#222;justify-content:space-between;padding:.75rem;font-size:.875rem;display:flex}.camera-pos.svelte-kvx99g{text-transform:capitalize;color:#ccc}.status-text.svelte-kvx99g{font-weight:500}.page-container.svelte-sjiyvi{flex-direction:column;height:100%;padding:1rem;display:flex;position:relative}h2.svelte-sjiyvi{color:#fff;margin-bottom:1.5rem}.table-container.svelte-sjiyvi{background-color:#1e1e1e;border-radius:8px;flex:1;overflow-y:auto;box-shadow:0 4px 6px #0003}table.svelte-sjiyvi{border-collapse:collapse;width:100%;min-width:800px}th.svelte-sjiyvi,td.svelte-sjiyvi{text-align:left;border-bottom:1px solid #333;padding:1rem}th.svelte-sjiyvi{z-index:10;color:#e0e0e0;background-color:#2a2a2a;font-weight:600;position:sticky;top:0}tr.svelte-sjiyvi:hover{background-color:#2a2a2a}.thumbnail-wrapper.svelte-sjiyvi{background-color:#000;border-radius:4px;width:120px;height:68px;overflow:hidden}.thumbnail-wrapper.svelte-sjiyvi img:where(.svelte-sjiyvi){object-fit:cover;width:100%;height:100%}.action-btn.svelte-sjiyvi{cursor:pointer;border:none;border-radius:4px;margin-right:.5rem;padding:.5rem 1rem;font-size:.875rem;transition:background-color .2s}.action-btn.play.svelte-sjiyvi{color:#fff;background-color:#646cff}.action-btn.play.svelte-sjiyvi:hover{background-color:#535bf2}.action-btn.download.svelte-sjiyvi{color:#ccc;background-color:#333;border:1px solid #555}.action-btn.download.svelte-sjiyvi:hover{color:#fff;background-color:#444}.modal-backdrop.svelte-sjiyvi{z-index:1000;background-color:#000000d9;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.modal-content.svelte-sjiyvi{background-color:#1a1a1a;border-radius:8px;width:90%;max-width:960px;overflow:hidden;box-shadow:0 10px 25px #00000080}.modal-header.svelte-sjiyvi{border-bottom:1px solid #333;justify-content:space-between;align-items:center;padding:1rem;display:flex}.modal-header.svelte-sjiyvi h3:where(.svelte-sjiyvi){color:#eee;margin:0;font-size:1.1rem}.close-btn.svelte-sjiyvi{color:#999;cursor:pointer;background:0 0;border:none;padding:0 .5rem;font-size:1.5rem;line-height:1}.close-btn.svelte-sjiyvi:hover{color:#fff}.video-player-wrapper.svelte-sjiyvi{aspect-ratio:16/9;background-color:#000;width:100%}.main-video.svelte-sjiyvi{width:100%;height:100%}.loading.svelte-sjiyvi,.error.svelte-sjiyvi{text-align:center;color:#888;padding:2rem}.error.svelte-sjiyvi{color:#ff4d4d}.login-container.svelte-110obhz{background-color:#121212;background-image:radial-gradient(circle,#1a1a1a 0%,#121212 100%);justify-content:center;align-items:center;width:100vw;height:100vh;display:flex}.login-card.svelte-110obhz{background-color:#1e1e1e;border:1px solid #333;border-radius:12px;width:100%;max-width:400px;padding:2.5rem;box-shadow:0 8px 24px #0006}.logo-area.svelte-110obhz{text-align:center;margin-bottom:2rem}h1.svelte-110obhz{color:#fff;margin:0;font-size:1.5rem}p.svelte-110obhz{color:#888;margin:.5rem 0 0;font-size:.875rem}.form-group.svelte-110obhz{margin-bottom:1.5rem}label.svelte-110obhz{color:#ccc;margin-bottom:.5rem;font-size:.875rem;display:block}input.svelte-110obhz{color:#fff;box-sizing:border-box;background-color:#2a2a2a;border:1px solid #444;border-radius:6px;width:100%;padding:.75rem;font-size:1rem;transition:border-color .2s}input.svelte-110obhz:focus{border-color:#646cff;outline:none}button.svelte-110obhz{color:#fff;cursor:pointer;background-color:#646cff;border:none;border-radius:6px;width:100%;padding:.75rem;font-size:1rem;font-weight:600;transition:background-color .2s}button.svelte-110obhz:hover:not(:disabled){background-color:#535bf2}button.svelte-110obhz:disabled{opacity:.7;cursor:not-allowed}.error-message.svelte-110obhz{color:#ff4d4d;text-align:center;background-color:#ff4d4d1a;border-radius:6px;margin-bottom:1.5rem;padding:.75rem;font-size:.875rem}body{color:#e0e0e0;background-color:#1a1a1a;margin:0;padding:0;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif}
