/*! tailwindcss v4.2.1 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--ease-in-out:cubic-bezier(.4, 0, .2, 1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.invisible{visibility:hidden}.visible{visibility:visible}.fixed{position:fixed}.relative{position:relative}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.table{display:table}.flex-shrink{flex-shrink:1}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.rounded{border-radius:.25rem}.border{border-style:var(--tw-border-style);border-width:1px}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}}:root{--bg:#f0f4ff;--surface:#fff;--surface2:#f9fafb;--border:#e5e7eb;--text-primary:#111827;--text-secondary:#6b7280;--text-muted:#9ca3af;--text-faint:#d1d5db;--accent:#2563eb;--accent-bg:#eff6ff;--accent-text:#1d4ed8;--muni-bg:#fde8e8;--muni-text:#b91c2c;--bart-bg:#dbeafe;--bart-text:#1d4ed8;--walk-bg:#fef3c7;--walk-text:#92400e;--shadow:0 4px 24px #00000012;--shadow-sm:0 2px 10px #0000000d}[data-theme=dark]{--bg:#0f1117;--surface:#1c2030;--surface2:#252a3a;--border:#ffffff12;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--text-faint:#374151;--accent:#3b82f6;--accent-bg:#3b82f61f;--accent-text:#60a5fa;--muni-bg:#cc384726;--muni-text:#f8a0a8;--bart-bg:#3b82f626;--bart-text:#93c5fd;--walk-bg:#fbbf241f;--walk-text:#fcd34d;--shadow:0 4px 24px #0000004d;--shadow-sm:0 2px 10px #0003}*{box-sizing:border-box}html{overflow-x:hidden}body{background:var(--bg);color:var(--text-primary);margin:0;padding:0;font-family:IBM Plex Sans,system-ui,sans-serif;transition:background .2s,color .2s;overflow-x:hidden}.page-wrap{flex-direction:column;gap:16px;max-width:900px;margin:0 auto;padding:16px 16px 40px;display:flex}.app-header{background:var(--surface);border-bottom:1px solid var(--border);z-index:10;justify-content:space-between;align-items:center;width:100%;padding:14px 20px;display:flex;position:fixed;top:0}.header-spacer{height:53px}.header-logo{letter-spacing:-.4px;color:var(--text-primary);align-items:center;gap:8px;font-size:17px;font-weight:700;text-decoration:none;display:flex}.header-logo-icon{border-radius:6px;width:24px;height:24px}.header-logo-accent{color:var(--accent)}.header-actions{align-items:center;gap:8px;display:flex}.icon-btn{background:var(--surface2);border:1px solid var(--border);cursor:pointer;width:34px;height:34px;color:var(--text-secondary);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:15px;transition:background .15s;display:flex}.icon-btn:hover{background:var(--border)}.icon-btn svg{width:15px;height:15px}.agency-badge{letter-spacing:.02em;text-transform:uppercase;border-radius:3px;padding:1px 5px;font-size:9px;font-weight:500;display:inline-block}.agency-badge.muni{background:var(--muni-bg);color:var(--muni-text)}.agency-badge.bart{background:var(--bart-bg);color:var(--bart-text)}.agency-badge.walk{background:var(--walk-bg);color:var(--walk-text)}.error-row{color:var(--text-muted);text-align:center;cursor:pointer;background:0 0;border:none;width:100%;padding:10px 18px 14px;font-family:inherit;font-size:12px}.commute-group{background:var(--surface);box-shadow:var(--shadow);border:1px solid var(--border);border-radius:20px;padding:16px 14px}.group-header{justify-content:space-between;align-items:center;margin-bottom:12px;padding:0 4px;display:flex}.group-label-row{align-items:center;gap:8px;display:flex}.group-icon{flex-shrink:0;font-size:20px;line-height:1}.group-label{color:var(--text-primary);font-size:15px;font-weight:600}.group-status{align-items:center;gap:6px;display:flex}.live-dot{background:#1d9e75;border-radius:50%;flex-shrink:0;width:6px;height:6px;animation:2s infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.3}}.group-status-text{color:var(--text-muted);font-size:11px}.dot-indicators{justify-content:center;gap:5px;margin-bottom:12px;display:flex}.dot-indicator{background:var(--border);cursor:pointer;border:none;border-radius:3px;width:6px;height:6px;padding:0;transition:all .3s}.dot-indicator.active{background:var(--text-secondary);width:12px}.dot-indicator.active.best{background:#185fa5}[data-theme=dark] .dot-indicator.active.best{background:var(--accent)}.embla-viewport{-webkit-user-select:none;user-select:none;overflow:hidden}.embla-container{align-items:stretch;gap:8px;display:flex}.embla-slide{flex:0 0 160px;min-width:0;display:flex}.embla-slide .dep-card{flex:1}.dep-card{background:var(--surface2);border:.5px solid var(--border);border-radius:12px;width:160px;padding:12px 14px}.dep-card.past{opacity:.5}.dep-card-header{justify-content:space-between;align-items:flex-end;display:flex}.dep-card-route-info{flex-direction:column;gap:2px;min-width:0;display:flex}.dep-card-route-info .agency-badge{align-self:flex-start;margin-left:-5px}.dep-card-route{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.dep-card.best{border:2px solid #185fa5}[data-theme=dark] .dep-card.best{border-color:var(--accent)}.dep-card-countdown-area{text-align:right;flex-shrink:0}.dep-card-countdown{color:var(--text-primary);font-size:28px;font-weight:500;line-height:1;transition:opacity .15s}.dep-card-countdown.fading{opacity:0}.dep-card-countdown.best{color:#185fa5}[data-theme=dark] .dep-card-countdown.best{color:var(--accent)}@keyframes pulse-now{0%,to{text-shadow:0 0 4px #d9aa1e33}50%{text-shadow:0 0 16px #d9aa1e99,0 0 32px #d9aa1e40}}.dep-card-countdown.best.now{animation:2s ease-in-out infinite pulse-now}.dep-card-countdown.past{color:var(--text-muted)}.dep-card-countdown-unit{color:var(--text-secondary);margin-left:1px;font-size:13px;font-weight:400}.dep-card-divider{border:none;border-top:1px solid var(--border);margin-top:10px;margin-bottom:0}.dep-card-steps{padding-top:8px}.dep-step{gap:8px;padding-bottom:7px;display:flex}.dep-step:last-child{padding-bottom:0}.dep-step-icon-col{flex-direction:column;flex-shrink:0;align-items:center;width:12px;display:flex}.dep-step-icon{color:var(--text-secondary);line-height:0}.dep-card.past .dep-step-icon{color:var(--text-muted)}.dep-step-line{background:var(--border);width:1px;height:8px;margin-top:2px}.dep-step-content{flex:1;justify-content:space-between;align-items:baseline;gap:4px;min-width:0;display:flex}.dep-step-label{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:10px;overflow:hidden}.dep-card.past .dep-step-label{color:var(--text-muted)}.dep-step-time{color:var(--text-secondary);white-space:nowrap;flex-shrink:0;font-size:10px;font-weight:400}.dep-step-time.bold{color:var(--text-primary);font-weight:500}.dep-step-time.best-highlight{color:#185fa5;font-weight:500}[data-theme=dark] .dep-step-time.best-highlight{color:var(--accent)}.dep-card.past .dep-step-time{color:var(--text-muted)!important;font-weight:400!important}.carousel-nav{justify-content:center;gap:32px;margin-top:14px;display:flex}.carousel-nav-btn{border:.5px solid var(--border);background:var(--surface);cursor:pointer;width:32px;height:32px;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;transition:opacity .15s;display:flex}.carousel-nav-btn:disabled{opacity:.3;cursor:default}.trip-tracker-backdrop{z-index:50;opacity:0;pointer-events:none;background:#0006;transition:opacity .3s;position:fixed;top:0;right:0;bottom:0;left:0}.trip-tracker-backdrop.visible{opacity:1;pointer-events:auto}.trip-tracker-sheet{background:var(--surface);box-shadow:none;z-index:51;-webkit-overflow-scrolling:touch;border-radius:0;padding:12px 20px 32px;transition:transform .3s;position:fixed;top:0;right:0;bottom:0;left:0;overflow-y:auto;transform:translateY(100%)}.trip-tracker-sheet.visible{transform:translateY(0)}.trip-tracker-handle{background:var(--border);border-radius:2px;width:36px;height:4px;margin:0 auto 16px}.trip-tracker-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.trip-tracker-route{align-items:center;gap:8px;display:flex}.trip-tracker-route-name{color:var(--text-primary);font-size:18px;font-weight:600}.trip-tracker-arrow{color:var(--text-muted);font-size:14px}.trip-tracker-dest{color:var(--text-secondary);font-size:14px}.trip-chip{white-space:nowrap;border-radius:999px;flex-shrink:0;align-items:center;margin-left:auto;padding:6px 12px;font-size:12px;font-weight:600;display:inline-flex}.trip-chip.chip-on-time{background:var(--accent)}@supports (color:color-mix(in lab,red,red)){.trip-chip.chip-on-time{background:color-mix(in srgb,var(--accent) 15%,transparent)}}.trip-chip.chip-on-time{color:var(--accent)}.trip-chip.chip-late-mild{color:#b45309;background:#f59e0b2e}.trip-chip.chip-late-heavy{color:#b91c1c;background:#dc26262e}.trip-chip.chip-early{background:var(--text-muted)}@supports (color:color-mix(in lab,red,red)){.trip-chip.chip-early{background:color-mix(in srgb,var(--text-muted) 12%,transparent)}}.trip-chip.chip-early{color:var(--text-secondary)}[data-theme=dark] .trip-chip.chip-late-mild{color:#fbbf24}[data-theme=dark] .trip-chip.chip-late-heavy{color:#f87171}.trip-timeline{padding:0 4px}.trip-row-wrapper{position:relative}.trip-row{cursor:pointer;text-align:left;width:100%;min-height:56px;color:var(--text-primary);background:0 0;border:none;border-radius:10px;align-items:stretch;gap:12px;margin-bottom:8px;padding:10px 4px;transition:background .15s;display:flex}.trip-row:hover{background:var(--text-primary)}@supports (color:color-mix(in lab,red,red)){.trip-row:hover{background:color-mix(in srgb,var(--text-primary) 4%,transparent)}}.trip-row.active{background:var(--accent)}@supports (color:color-mix(in lab,red,red)){.trip-row.active{background:color-mix(in srgb,var(--accent) 8%,transparent)}}.trip-row.past{opacity:.4}.trip-row-time-col{width:64px;color:var(--text-primary);flex-shrink:0;align-items:center;font-size:16px;font-weight:600;display:flex}.trip-row-icon-col{flex-direction:column;flex-shrink:0;align-items:center;width:32px;display:flex}.trip-row-icon{background:var(--surface2);width:32px;height:32px;color:var(--text-secondary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.trip-row.checked .trip-row-icon{background:var(--accent);color:var(--surface)}.trip-row-icon-check{font-size:16px;font-weight:700;line-height:1}.trip-row-line{background:var(--border);flex:1;width:2px;min-height:8px;margin-top:4px}.trip-row-line.active{background:linear-gradient(to bottom,transparent 0%,var(--accent) 50%,transparent 100%);background-size:100% 200%;animation:1.5s linear infinite trip-line-flow}@media(prefers-reduced-motion:reduce){.trip-row-line.active{background:var(--accent);animation:none}}@keyframes trip-line-flow{0%{background-position:0 -100%}to{background-position:0 100%}}.trip-row-label-col{flex-direction:column;flex:1;justify-content:center;min-width:0;display:flex}.trip-row-label{color:var(--text-primary);font-size:15px;font-weight:500}.trip-row.past .trip-row-label,.trip-row.past .trip-row-time-col{color:var(--text-secondary)}.trip-row-sub{color:var(--text-secondary);margin-top:2px;font-size:12px}.dep-step-duration{color:var(--text-secondary);margin-right:2px;font-size:10px}.trip-now-indicator{background:var(--accent);height:2px;left:96px;right:4px;top:calc(28px + var(--now-fraction) * (100% - 28px));opacity:.6;position:absolute}.trip-now-indicator:before{content:"";background:var(--accent);border-radius:50%;width:8px;height:8px;position:absolute;top:-3px;left:-4px}.departure-board-section{border-top:1px solid var(--border);margin-top:20px;padding-top:20px}.departure-board-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.departure-board-label{color:var(--text-muted);text-transform:lowercase;letter-spacing:.3px;font-size:11px;font-weight:500}.departure-board-meta{align-items:center;gap:8px;display:flex}.departure-board-updated{color:var(--text-muted);font-size:10px}.departure-board-refresh{background:var(--surface2);cursor:pointer;width:32px;height:32px;color:var(--text-secondary);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.departure-board{background:var(--surface2);border:1px solid var(--border);border-radius:12px;overflow:hidden}.departure-board-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:10px 14px;display:flex}.departure-board-row:last-child{border-bottom:none}.departure-board-row.highlighted{background:var(--accent-bg)}.departure-board-route-badge{border-radius:6px;justify-content:center;align-items:center;min-width:36px;padding:2px 6px;font-size:13px;font-weight:600;display:inline-flex}.departure-board-route-badge.muni{background:var(--muni-bg);color:var(--muni-text)}.departure-board-route-badge.bart{background:var(--bart-bg);color:var(--bart-text)}.departure-board-destination{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:13px;overflow:hidden}.departure-board-minutes{color:var(--text-primary);text-align:right;min-width:32px;font-size:16px;font-weight:600}.departure-board-minutes.now{color:#16a34a}[data-theme=dark] .departure-board-minutes.now{color:#4ade80}.departure-board-unit{color:var(--text-muted);margin-left:1px;font-size:11px;font-weight:500}.departure-board-empty{text-align:center;color:var(--text-muted);padding:24px 0;font-size:13px}.dep-card{cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .1s}.dep-card:active{transform:scale(.97)}.carousel-skeleton{gap:8px;padding:0;display:flex}.carousel-skeleton-card{border-radius:12px;flex-shrink:0;width:160px;height:140px}.carousel-error{text-align:center;padding:20px 0}.carousel-empty{text-align:center;color:var(--text-muted);padding:20px 0;font-size:12px}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes fadeIn{to{opacity:1}}@keyframes breathe{0%,to{opacity:1}50%{opacity:.5}}.skeleton-card{background:var(--surface);border:1px solid var(--border);opacity:0;border-radius:20px;padding:16px 18px;animation:.3s forwards fadeIn}.skeleton-shimmer{background:linear-gradient(90deg,#0000000a 25%,#00000014,#0000000a 75%) 0 0/200% 100%;border-radius:8px;animation:1.5s infinite shimmer}[data-theme=dark] .skeleton-shimmer{background:linear-gradient(90deg,#ffffff0a 25%,#ffffff14,#ffffff0a 75%) 0 0/200% 100%;animation:1.5s infinite shimmer}.skeleton-label-bar{width:35%;height:10px;margin-bottom:14px}.skeleton-hero-bar{border-radius:12px;width:100%;height:80px;margin-bottom:10px}.skeleton-tile-row{gap:8px;display:flex}.skeleton-tile-bar{border-radius:12px;flex:1;height:72px}.empty-state{text-align:center;background:var(--surface);border:1px solid var(--border);min-height:60vh;box-shadow:var(--shadow);color:var(--text-secondary);border-radius:20px;flex-direction:column;justify-content:center;align-items:center;padding:40px 24px;display:flex}.empty-icon{opacity:.5;margin-bottom:16px;font-size:40px}.empty-heading{color:var(--text-secondary);margin-bottom:20px;font-size:16px;font-weight:600}.btn-primary{background:var(--accent);color:#fff;cursor:pointer;letter-spacing:-.2px;border:none;border-radius:12px;width:100%;padding:12px 20px;font-family:inherit;font-size:14px;font-weight:600}.btn-primary:hover{opacity:.9}.btn-secondary{background:var(--surface2);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;text-align:left;border-radius:12px;width:100%;padding:11px 16px;font-family:inherit;font-size:14px;font-weight:500}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.add-card{border:2px dashed var(--border);cursor:pointer;background:0 0;border-radius:20px;justify-content:center;align-items:center;width:100%;padding:20px;font-family:inherit;display:flex}.add-card:hover{border-color:var(--accent)}.add-card-label{color:var(--text-muted);align-items:center;gap:6px;font-size:14px;font-weight:600;display:flex}.add-card:hover .add-card-label{color:var(--accent)}.edit-view{max-width:900px;margin:0 auto;padding:0 16px 40px}.edit-header{border-bottom:1px solid var(--border);align-items:center;gap:12px;margin-bottom:20px;padding:16px 0 14px;display:flex}.back-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:13px;font-weight:600}.edit-title{color:var(--text-primary);font-size:15px;font-weight:700}.field{flex-direction:column;gap:4px;margin-bottom:16px;display:flex}.field label{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;font-size:11px;font-weight:700}.field input,.field select{background:var(--surface2);border:1px solid var(--border);color:var(--text-primary);border-radius:12px;outline:none;padding:10px 14px;font-family:inherit;font-size:14px}.field input:focus,.field select:focus{border-color:var(--accent)}.field-hint{color:var(--text-muted);margin-top:2px;font-size:11px}.field-hint a{color:var(--accent)}.commute-edit-row,.stop-edit-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:13px 0;display:flex}.commute-edit-label,.stop-edit-label{color:var(--accent);flex:1;font-size:14px;font-weight:600;text-decoration:none}.commute-edit-actions,.stop-edit-actions{gap:8px;display:flex}.commute-edit-actions button,.stop-edit-actions button{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 6px;font-family:inherit;font-size:13px}.commute-edit-actions button:hover,.stop-edit-actions button:hover{color:var(--text-primary);background:var(--surface2)}.stops-list{border-top:1px solid var(--border);margin-bottom:4px;padding-top:4px}.add-stop-buttons{flex-direction:column;gap:8px;margin-top:16px;display:flex}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{flex-direction:column;align-items:center;gap:1.5rem;width:min(100%,360px);padding:2.5rem 2rem;display:flex}.login-title{color:var(--text-primary);letter-spacing:-.02em;font-size:2rem;font-weight:700}.login-accent{color:var(--accent)}.login-form{flex-direction:column;gap:.75rem;width:100%;display:flex}.login-input{background:var(--surface);border:1px solid var(--border);width:100%;color:var(--text-primary);border-radius:6px;outline:none;padding:.75rem 1rem;font-family:inherit;font-size:1rem}.login-input:focus{border-color:var(--accent)}.login-btn{background:var(--accent);color:#fff;cursor:pointer;letter-spacing:.01em;border:none;border-radius:6px;width:100%;padding:.75rem 1rem;font-family:inherit;font-size:1rem;font-weight:600}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{color:#ef4444;text-align:center;font-size:.875rem}.login-message{color:var(--text-primary);font-size:1.25rem;font-weight:600}.login-hint{color:var(--text-secondary);font-size:.875rem}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}
