*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#08080f;--surface:#12121e;--card:#222236;--border:#363650;--text:#dcdce8;--text-secondary:#9494b0;--text-muted:#606078;--white:#f5f5ff;--elizabeth:#9b6ec6;--overground:#ef8c30;--district:#2ecc71;--urgent:#ef4444;--soon:#f59e0b;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--text);background:var(--bg);font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,system-ui,sans-serif;font-size:16px;line-height:1.5}[data-theme=light]{--bg:#eaeaf0;--surface:#fff;--card:#f2f2f8;--border:#d8d8e2;--text:#3a3a4a;--text-secondary:#6a6a80;--text-muted:#9a9ab0;--white:#111118;--elizabeth:#7040a8;--overground:#c86010;--district:#18884a;--urgent:#dc2626;--soon:#d97706}body{min-height:100dvh}#root{background:var(--surface);min-height:100dvh;margin:0 auto}.app{padding:env(safe-area-inset-top,16px) 16px env(safe-area-inset-bottom,16px);flex-direction:column;min-height:100dvh;display:flex}@media (width>=768px){.app{padding:24px 40px}}.loading-screen{justify-content:center;align-items:center;gap:16px}.loading-screen p{color:var(--text-secondary);font-size:14px}.spinner{border:3px solid var(--border);border-top-color:var(--elizabeth);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}header{text-align:center;padding:16px 0 20px}.header-bar{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}header h1{letter-spacing:-.5px;color:var(--white);font-size:26px;font-weight:700}header .sub{color:var(--text-secondary);margin-top:2px;font-size:13px}@media (width>=768px){header{padding:24px 0 28px}header h1{font-size:34px}header .sub{font-size:15px}}.data-btn{border:1px solid var(--border);background:var(--card);color:var(--text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;white-space:nowrap;border-radius:10px;padding:7px 12px;font-family:inherit;font-size:12px;font-weight:600;transition:background .2s,border-color .2s}.data-btn:hover{border-color:var(--text-muted)}@media (width>=768px){.data-btn{padding:9px 16px;font-size:13px}}.theme-toggle{border:1px solid var(--border);background:var(--card);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:10px;justify-content:center;align-items:center;font-size:18px;transition:background .2s,border-color .2s;display:flex}.theme-toggle:hover{border-color:var(--text-muted)}@media (width>=768px){.theme-toggle{width:40px;height:40px}}.prediction{text-align:center;background:var(--card);border:1px solid var(--border);margin-bottom:24px;border-radius:12px;flex-direction:column;gap:2px;max-width:440px;margin-inline:auto;padding:16px;display:flex}.prediction-pct{color:var(--soon);font-size:36px;font-weight:800;line-height:1.1}.prediction-label{color:var(--text);font-size:14px;font-weight:600}.prediction-note{color:var(--text-muted);margin-top:4px;font-size:11px;font-style:italic}.toggle{background:var(--bg);border-radius:14px;width:100%;max-width:440px;margin:0 auto 28px;padding:4px;display:flex}.toggle button{color:var(--text-muted);cursor:pointer;white-space:nowrap;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:11px;flex:1;justify-content:center;align-items:center;gap:6px;padding:12px 6px;font-family:inherit;font-size:clamp(12px,3.5vw,14px);font-weight:600;transition:background .2s,color .2s,box-shadow .2s;display:flex}.toggle button.on{background:var(--card);color:var(--white);box-shadow:0 2px 12px #00000026}@media (width>=768px){.toggle button{padding:14px 12px;font-size:15px}}.dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.line-group{margin-bottom:20px}@media (width>=768px){.line-group{margin-bottom:28px}}.line-label{align-items:center;gap:8px;margin-bottom:10px;font-size:14px;font-weight:700;display:flex}@media (width>=768px){.line-label{margin-bottom:12px;font-size:16px}}.line-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.line-columns{grid-template-columns:1fr;gap:8px;display:grid}@media (width>=768px){.line-columns{grid-template-columns:1fr 1fr;gap:16px}}.col h3{text-transform:uppercase;letter-spacing:1.6px;color:var(--text-muted);margin-bottom:6px;font-size:10px;font-weight:700}@media (width>=768px){.col h3{margin-bottom:8px;font-size:11px}}.col-cards{flex-direction:column;gap:6px;display:flex}.no-data{background:var(--card);border-left:4px solid var(--border);color:var(--text-muted);text-align:center;border-radius:10px;justify-content:center;align-items:center;min-height:52px;padding:14px 16px;font-size:13px;display:flex}@media (width>=768px){.no-data{min-height:58px;padding:16px 20px}}.card{background:var(--card);border-left:4px solid;border-radius:10px;justify-content:space-between;align-items:center;min-height:52px;padding:14px 16px;display:flex}@media (width>=768px){.card{min-height:58px;padding:16px 20px}}.plat{color:var(--text);align-items:center;gap:6px;font-size:15px;display:flex}.lift-tag{text-transform:uppercase;letter-spacing:.5px;background:var(--overground);color:#fff;border-radius:4px;padding:2px 5px;font-size:10px;font-weight:700;line-height:1}@media (width>=768px){.plat{font-size:16px}}.time{font-variant-numeric:tabular-nums;color:var(--white);text-align:right;min-width:90px;font-size:24px;font-weight:700;line-height:1;transition:color .3s}.time.departed{color:var(--urgent);font-size:14px}.time.no-data-text{color:var(--text-muted);font-size:12px;font-weight:500}@media (width>=768px){.time{font-size:28px}.time.departed{font-size:20px}}.error{text-align:center;margin-bottom:20px;background:#ef44441f;border:1px solid #ef444440;border-radius:10px;max-width:440px;margin-inline:auto;padding:14px 16px}.error p{color:var(--urgent);font-size:14px;font-weight:600}footer{text-align:center;color:var(--text-muted);margin-top:auto;padding:20px 0 8px;font-size:12px}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:16px;width:100%;max-width:360px;padding:28px 24px}.modal h2{color:var(--white);margin-bottom:8px;font-size:20px;font-weight:700}.modal-context{color:var(--text-secondary);margin-bottom:24px;font-size:13px}.modal-actions{gap:12px;display:flex}.modal-btn{cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:12px;flex:1;padding:14px;font-family:inherit;font-size:16px;font-weight:700;transition:opacity .2s}.modal-btn:disabled{opacity:.5;cursor:not-allowed}.modal-btn.yes{background:var(--district);color:#fff}.modal-btn.no{background:var(--urgent);color:#fff}.modal-result{padding:8px 0;font-size:18px;font-weight:700}.modal-result.success{color:var(--district)}.modal-result.error{color:var(--urgent)}
