*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow:hidden;background:#0f0f14;color:#e0e0e8;font-family:system-ui,-apple-system,sans-serif}#app{width:100%;height:100%;display:flex;flex-direction:column}.toolbar{display:flex;align-items:center;gap:6px;padding:6px 10px;background:#1a1a24;border-bottom:1px solid #2a2a36;flex-shrink:0;z-index:10}.toolbar-btn{background:#252535;color:#c0c0c8;border:1px solid #3a3a48;border-radius:4px;padding:4px 10px;font-size:12px;cursor:pointer;white-space:nowrap}.toolbar-btn:hover{background:#303045;color:#e0e0e8}.toolbar-select{background:#252535;color:#c0c0c8;border:1px solid #3a3a48;border-radius:4px;padding:4px 8px;font-size:12px;max-width:200px}.toolbar-info{font-size:11px;color:#666680;padding:0 6px;font-variant-numeric:tabular-nums}.canvas-container{position:relative;flex:1;overflow:hidden}.canvas-container canvas.main-canvas{position:absolute;top:0;left:0;width:100%;height:100%}.drop-overlay{position:absolute;inset:0;background:#5b8def26;border:2px dashed #5b8def;display:flex;align-items:center;justify-content:center;font-size:18px;color:#5b8def;z-index:50;pointer-events:none;opacity:0;transition:opacity .15s}.drop-overlay.active{opacity:1}.popover{position:absolute;width:280px;max-height:420px;background:#12121cf7;color:#e0e0e8;border:1px solid rgba(255,255,255,.12);border-radius:8px;font-size:12px;font-family:system-ui,sans-serif;line-height:1.5;box-shadow:0 8px 30px #00000080;z-index:200;overflow:hidden;display:none;flex-direction:column}.popover[style*="display: block"]{display:flex}.popover-header{display:flex;align-items:center;gap:8px;padding:10px 12px 6px;border-bottom:1px solid rgba(255,255,255,.06)}.popover-route{font-weight:700;font-size:14px}.popover-trip-id{color:#888;font-size:11px;flex:1}.popover-close{background:none;border:none;color:#888;font-size:18px;cursor:pointer;padding:0 2px;line-height:1}.popover-close:hover{color:#e0e0e8}.popover-summary{padding:8px 12px;border-bottom:1px solid rgba(255,255,255,.06)}.popover-times{color:#999;font-size:11px}.popover-clicked{padding:8px 12px;background:#5b8def14;border-bottom:1px solid rgba(255,255,255,.06)}.popover-label{color:#888;font-size:10px;text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}.popover-stops-header{padding:6px 12px 2px;color:#888;font-size:10px;text-transform:uppercase;letter-spacing:.05em}.popover-stops{padding:4px 12px 10px;overflow-y:auto;max-height:200px;font-size:11px}.popover-stops>div{padding:2px 0}.popover-stop-time{color:#999;font-variant-numeric:tabular-nums;display:inline-block;min-width:80px}.popover-stop-current{color:#5b8def;font-weight:600}.popover-stop-current .popover-stop-time{color:#5b8def}body.light{background:#fff;color:#1a1a2e}body.light .toolbar{background:#f5f5f8;border-color:#d0d0d8}body.light .toolbar-btn{background:#e8e8ee;color:#333;border-color:#c0c0c8}body.light .toolbar-btn:hover{background:#dddde5}body.light .toolbar-select{background:#e8e8ee;color:#333;border-color:#c0c0c8}body.light .toolbar-info{color:#666680}body.light .popover{background:#fffffff7;color:#1a1a2e;border-color:#0000001f}body.light .popover-close{color:#999}body.light .popover-close:hover{color:#333}body.light .popover-clicked{background:#3b6de014}
