.canvas-container{width:100%;height:100%;display:flex;align-items:flex-start;justify-content:center;overflow:hidden;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);position:relative;padding-top:0;-webkit-user-select:none;user-select:none}canvas{display:block;cursor:inherit;box-shadow:0 4px 20px #0000001a;border-radius:8px;margin:0;background:#fff;pointer-events:none}.info-panel{background:#111827;padding:24px;border-radius:0;border:1px solid #1f2937;margin-bottom:0;box-shadow:none}.panel-section{display:flex;flex-direction:column;gap:20px}.panel-title{font-size:11px;font-weight:600;color:#9ca3af;margin:0 0 4px;letter-spacing:.05em;text-transform:uppercase;display:flex;align-items:center;gap:0;font-family:Inter,-apple-system,sans-serif}.panel-subtitle{font-size:13px;color:#e5e7eb;margin-bottom:0;font-weight:500;letter-spacing:-.01em;font-variant-numeric:tabular-nums}.panel-divider{height:1px;background:#1f2937;margin:0;border:none}.section-label{font-size:10px;font-weight:600;margin:0 0 12px;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;font-family:Inter,-apple-system,sans-serif}.fire-status{background:#0f172a;padding:12px 16px;border-radius:6px;border:1px solid #1f2937}.status-label{font-size:13px;font-weight:500;color:#e5e7eb;font-variant-numeric:tabular-nums}.recommended-section{background:#0f172a;padding:16px;border-radius:6px;border:1px solid #1f2937;margin:0}.route-info{font-size:13px;line-height:1.6;color:#e5e7eb}.route-path{font-size:12px;color:#e5e7eb;margin:8px 0;word-break:break-all;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,monospace;background:#0b1220;padding:10px 12px;border-radius:4px;border:1px solid #1f2937;font-variant-numeric:tabular-nums}.no-route-section{margin:0;text-align:center;padding:24px;background:#1f2937;border-radius:6px;border:1px solid #b91c1c}.no-route-section h2{color:#fecaca;font-size:13px;font-weight:600;margin:4px 0;letter-spacing:.01em}.all-routes-section{background:#0f172a;padding:16px;border-radius:6px;box-shadow:none;margin:0;border:1px solid #1f2937}.route-item{margin:8px 0;padding:12px;font-size:12px;background:#0b1220;border-radius:4px;border:1px solid #1f2937;transition:border-color .15s ease,background-color .15s ease}.route-item:hover{border-color:#334155;background:#111827}.controls-section{background:#0f172a;padding:16px;border-radius:6px;margin-top:auto;border:1px solid #1f2937}.control-item{font-size:12px;margin:8px 0;color:#e5e7eb;padding:6px 0;border-bottom:1px solid #1f2937;display:flex;justify-content:space-between;align-items:center;font-weight:400}.control-item:last-child{border-bottom:none}@keyframes flash{0%,to{opacity:1}50%{opacity:.5}}.app-header{height:72px;background:linear-gradient(180deg,#1e293b,#0f172a);color:#f1f5f9;display:flex;align-items:center;justify-content:space-between;padding:0 24px;box-shadow:0 2px 8px #0000004d,0 1px #ffffff0d inset;border-bottom:1px solid rgba(148,163,184,.1);z-index:1000;position:fixed;top:0;left:0;right:0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-left{flex:0 0 auto;display:flex;align-items:center;min-width:280px}.logo{display:flex;align-items:center;gap:12px}.logo-icon-wrapper{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#3b82f626,#9333ea26);border-radius:8px;border:1px solid rgba(148,163,184,.2)}.logo-icon{width:24px;height:24px;color:#60a5fa}.logo-text h1{margin:0;font-size:18px;font-weight:600;line-height:1.3;color:#f8fafc;letter-spacing:-.01em}.logo-text p{margin:0;font-size:11px;color:#94a3b8;font-weight:400;letter-spacing:.02em}.header-center{flex:1 1 auto;display:flex;justify-content:center;padding:0 24px;min-width:0}.status-indicators{display:flex;gap:0;align-items:center;background:#0f172a66;padding:8px 12px;border-radius:10px;border:1px solid rgba(148,163,184,.15);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.status-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:0 12px;min-width:fit-content}.status-item .status-content{display:flex;flex-direction:column;align-items:center;gap:2px}.status-divider{width:1px;height:32px;background:#94a3b833;margin:0 4px}.status-label{font-size:10px;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em;font-weight:500;white-space:nowrap}.status-value{font-size:15px;font-weight:600;color:#f8fafc;line-height:1.2;font-variant-numeric:tabular-nums}.status-item.danger .status-value{color:#fca5a5}.status-item.running .status-value{color:#86efac}.status-item.paused .status-value{color:#fde047}.status-indicator-dot{width:8px;height:8px;border-radius:50%;margin-top:2px}.status-indicator-dot.running{background:#22c55e;box-shadow:0 0 8px #22c55e80}.status-indicator-dot.paused{background:#eab308;box-shadow:0 0 8px #eab30880}.time-progress-bar{width:100px;height:4px;background:#1e293b99;border-radius:2px;margin-top:6px;overflow:hidden;border:1px solid rgba(148,163,184,.1)}.time-progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#8b5cf6);border-radius:2px;transition:width .3s ease-out;box-shadow:0 0 4px #3b82f666}.status-item.speed-control{padding:0 8px}.speed-selector{display:flex;gap:3px;margin-top:4px;background:#0f172a80;padding:2px;border-radius:6px;border:1px solid rgba(148,163,184,.1)}.speed-btn{padding:4px 8px;background:transparent;border:none;border-radius:4px;color:#cbd5e1;font-size:10px;font-weight:600;cursor:pointer;transition:all .15s ease;font-variant-numeric:tabular-nums;min-width:32px}.speed-btn:hover{background:#94a3b826;color:#f8fafc}.speed-btn.active{background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;box-shadow:0 2px 4px #3b82f64d}.header-right{flex:0 0 auto;min-width:fit-content}.header-controls{display:flex;gap:6px;align-items:center}.control-divider{width:1px;height:24px;background:#94a3b833;margin:0 4px}.control-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#1e293b99;border:1px solid rgba(148,163,184,.2);border-radius:8px;color:#e2e8f0;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.control-btn:hover:not(:disabled){background:#334155cc;border-color:#94a3b84d;transform:translateY(-1px);box-shadow:0 2px 8px #0003}.control-btn:active:not(:disabled){transform:translateY(0)}.control-btn:disabled{opacity:.4;cursor:not-allowed;background:#1e293b4d}.control-btn.primary{background:linear-gradient(135deg,#3b82f633,#9333ea33);border-color:#3b82f64d;color:#93c5fd}.control-btn.primary:hover:not(:disabled){background:linear-gradient(135deg,#3b82f64d,#9333ea4d);border-color:#3b82f680;color:#dbeafe}.control-btn.active{background:linear-gradient(135deg,#22c55e33,#10b98133);border-color:#22c55e66;color:#86efac}.control-btn.active:hover:not(:disabled){background:linear-gradient(135deg,#22c55e4d,#10b9814d);border-color:#22c55e80}.control-btn.secondary{background:#1e293b66;border-color:#94a3b826}.control-btn.secondary:hover:not(:disabled){background:#33415599;border-color:#94a3b840}.btn-icon{font-size:14px;line-height:1;display:flex;align-items:center;justify-content:center}.btn-text{font-size:13px;font-weight:500}.control-btn.paused{color:#fde047}@media (max-width: 1400px){.header-left{min-width:240px}.logo-text h1{font-size:16px}.logo-text p{font-size:10px}.status-indicators{padding:6px 10px}.status-item{padding:0 10px}.control-btn{padding:7px 12px;font-size:12px}.btn-text{font-size:12px}}@media (max-width: 1200px){.app-header{padding:0 16px;height:68px}.header-left{min-width:200px}.logo-icon-wrapper{width:36px;height:36px}.logo-icon{width:20px;height:20px}.logo-text h1{font-size:15px}.logo-text p{font-size:9px}.header-center{padding:0 16px}.status-indicators{padding:6px 8px;gap:0}.status-item{padding:0 8px}.status-value{font-size:14px}.status-label{font-size:9px}.time-progress-bar{width:80px}.speed-btn{padding:3px 6px;font-size:9px;min-width:28px}.control-btn{padding:6px 10px;font-size:11px}.btn-icon{font-size:12px}.btn-text{font-size:11px}.header-controls{gap:4px}}@media (max-width: 992px){.logo-text p{display:none}.status-item .status-content{gap:1px}.time-progress-bar{width:60px;height:3px}.btn-text{display:none}.control-btn{padding:8px;min-width:36px;justify-content:center}.control-divider{display:none}}.statistics-panel{background:#111827;border-radius:0;padding:24px;margin-bottom:0;border:1px solid #1f2937;box-shadow:none}.panel-title{font-size:11px;font-weight:600;margin:0 0 20px;color:#9ca3af;letter-spacing:.05em;text-transform:uppercase;display:flex;align-items:center;gap:0;font-family:Inter,-apple-system,sans-serif}.stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:20px}.stat-card{background:#0f172a;border-radius:6px;padding:14px;display:flex;flex-direction:column;gap:8px;border:1px solid #1f2937;transition:border-color .15s ease,background-color .15s ease}.stat-card:hover{border-color:#334155;background:#111827}.stat-icon{width:32px;height:32px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:16px;background:#0b1220;border:1px solid #1f2937;flex-shrink:0;color:#e5e7eb}.stat-content{flex:1;min-width:0}.stat-value{font-size:20px;font-weight:600;line-height:1.2;color:#e5e7eb;font-variant-numeric:tabular-nums;letter-spacing:-.02em}.stat-label{font-size:11px;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;margin-top:2px;font-weight:500;font-family:Inter,-apple-system,sans-serif}.stat-trend{font-size:11px;color:#9ca3af;margin-top:2px}.recommended-stats{background:#0f172a;border-radius:6px;padding:16px;border:1px solid #1f2937;box-shadow:none}.section-title{font-size:10px;font-weight:600;margin:0 0 12px;color:#9ca3af;letter-spacing:.05em;text-transform:uppercase;font-family:Inter,-apple-system,sans-serif}.route-stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.route-stat{display:flex;flex-direction:column;gap:4px}.route-stat-label{font-size:10px;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;font-weight:500;font-family:Inter,-apple-system,sans-serif}.route-stat-value{font-size:14px;font-weight:600;color:#e5e7eb;font-variant-numeric:tabular-nums;letter-spacing:-.01em}.legend-panel{background:#111827;border-radius:0;padding:24px;margin-bottom:0;box-shadow:none;border:1px solid #1f2937}.legend-title{font-size:11px;font-weight:600;margin:0 0 20px;color:#9ca3af;letter-spacing:.05em;text-transform:uppercase;display:flex;align-items:center;gap:0;font-family:Inter,-apple-system,sans-serif}.legend-section{margin-bottom:20px}.legend-section:last-child{margin-bottom:0}.legend-section-title{font-size:10px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;margin:0 0 12px;font-family:Inter,-apple-system,sans-serif}.legend-items{display:flex;flex-direction:column;gap:10px}.legend-item{display:flex;align-items:center;gap:12px;padding:0}.legend-color{width:24px;height:16px;border-radius:3px;border:1px solid #1f2937;flex-shrink:0;box-shadow:none}.legend-icon{font-size:12px;width:24px;text-align:center;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:600;font-family:Inter,-apple-system,sans-serif;color:#e5e7eb}.legend-text{flex:1}.legend-label{font-size:12px;font-weight:500;color:#e5e7eb;line-height:1.4;letter-spacing:-.01em}.legend-description{font-size:11px;color:#9ca3af;margin-top:2px}.legend-route{width:40px;height:3px;border-radius:2px;flex-shrink:0;box-shadow:none}.legend-route.recommended{background:#10b981}.legend-route.alternative{background:#6b7280}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #eee}.modal-header h2{margin:0;font-size:24px;color:#1e3c72}.modal-close{background:none;border:none;font-size:32px;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.modal-close:hover{background:#f0f0f0;color:#333}.modal-body{padding:20px}.setting-group{margin-bottom:24px}.setting-label{display:block;font-size:14px;font-weight:600;color:#333;margin-bottom:8px}.setting-description{display:block;font-size:12px;font-weight:400;color:#888;margin-top:4px}.setting-slider{width:100%;height:6px;border-radius:3px;background:#e0e0e0;outline:none;-webkit-appearance:none}.setting-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#2a5298;cursor:pointer}.setting-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#2a5298;cursor:pointer;border:none}.setting-value{text-align:right;font-size:12px;color:#666;margin-top:4px}.toggle-switch{position:relative;display:inline-block;width:50px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;transition:.3s;border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:#2a5298}.toggle-switch input:checked+.toggle-slider:before{transform:translate(26px)}.setting-select{width:100%;padding:10px;border:1px solid #ddd;border-radius:6px;font-size:14px;background:#fff;cursor:pointer}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px;border-top:1px solid #eee}.btn-primary,.btn-secondary{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:#2a5298;color:#fff}.btn-primary:hover{background:#1e3c72;transform:translateY(-1px);box-shadow:0 4px 8px #0003}.btn-secondary{background:#f0f0f0;color:#333}.btn-secondary:hover{background:#e0e0e0}.time-chart{background:#111827;border-radius:0;padding:24px;margin-bottom:0;box-shadow:none;border:1px solid #1f2937}.chart-title{font-size:11px;font-weight:600;margin:0 0 16px;color:#9ca3af;letter-spacing:.05em;text-transform:uppercase;display:flex;align-items:center;gap:0;font-family:Inter,-apple-system,sans-serif}.chart-container{position:relative;background:#0f172a;border-radius:6px;padding:16px;border:1px solid #1f2937}.chart-svg{display:block;width:100%;height:80px}.chart-line{opacity:1;stroke-linecap:round;stroke-linejoin:round}.current-time-indicator{opacity:1;stroke-dasharray:4,4;animation:pulse 1.5s ease-in-out infinite;stroke:#9ca3af}@keyframes pulse{0%,to{opacity:.6;stroke-width:1.5}50%{opacity:1;stroke-width:2}}.chart-legend{display:flex;gap:20px;margin-top:12px;justify-content:flex-start}.legend-item{display:flex;align-items:center;gap:8px;font-size:11px;color:#cbd5e1;font-weight:500}.legend-color{width:16px;height:3px;border-radius:2px;box-shadow:none}.chart-labels{display:flex;justify-content:space-between;margin-top:8px;font-size:10px;color:#9ca3af;font-weight:500;font-variant-numeric:tabular-nums;font-family:Inter,-apple-system,sans-serif}:root{--header-height: 72px;--content-gap: 0px}.app{width:100vw;min-height:100vh;padding-top:calc(var(--header-height) + var(--content-gap));display:flex;flex-direction:column;background:radial-gradient(circle at top left,#1f2937 0,#0f172ae6,#0f172a 60%),radial-gradient(circle at bottom right,#0f172a 0,#020617 55%);color:#e5e7eb;overflow:hidden}.main-container{display:flex;width:100%;height:calc(100vh - var(--header-height) - var(--content-gap));overflow:hidden;gap:20px;padding:18px 20px 26px;box-sizing:border-box}.canvas-wrapper{flex:1;position:relative;background:radial-gradient(circle at top left,#e5f2ff 0,#f3f4f6 40%,#e5e7eb);overflow:hidden;border-radius:18px;box-shadow:0 22px 55px #0f172aa6,0 0 0 1px #94a3b859}.sidebar{width:390px;max-width:32%;background:#0f172a;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:0;padding:0;-webkit-backdrop-filter:none;backdrop-filter:none;border-left:1px solid #1f2937;box-shadow:-2px 0 12px #00000040}.controls-overlay{position:absolute;top:10px;left:50%;transform:translate(-50%);background-color:#fffffff2;padding:10px 20px;border-radius:5px;box-shadow:0 2px 10px #0003;z-index:1000}.control-hint{font-size:14px;font-weight:700;color:#333}.route-change-alert{position:absolute;top:20px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#f44,#c00);padding:12px 24px;border-radius:8px;box-shadow:0 4px 20px #ff000080;z-index:1001;animation:flash-alert .5s ease-in-out 3;border:2px solid rgba(255,255,255,.3)}.alert-text{font-size:18px;font-weight:700;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.3);letter-spacing:.5px}@media (max-width: 1200px){.sidebar{width:360px;max-width:40%}}@media (max-width: 992px){.app{padding-top:var(--header-height)}.main-container{flex-direction:column;height:auto}.canvas-wrapper{min-height:380px}.sidebar{width:100%;max-width:100%}}@media (max-width: 640px){.main-container{padding:12px;gap:12px}.canvas-wrapper{border-radius:14px}.sidebar{padding:0}}@keyframes flash-alert{0%,to{opacity:1;transform:translate(-50%) scale(1)}50%{opacity:.8;transform:translate(-50%) scale(1.05)}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;overflow:hidden;font-feature-settings:"cv02","cv03","cv04","cv11";letter-spacing:-.011em}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
