/* Source stylesheet for the inline block embedded in static/index.html. Keep in sync when editing. */
:root {
    color-scheme: light dark;
    --primary-color: #2f6dff;
    --secondary-color: #6aa8ff;
    --accent-color: #1f56d6;
    --on-primary-color: #ffffff;
    --surface-color: #ecf3ff;
    --surface-container-high: rgba(255, 255, 255, 0.84);
    --surface-elevated: rgba(240, 247, 255, 0.72);
    --surface-solid: #ffffff;
    --on-surface-color: #10213d;
    --on-surface-variant-color: #4b638a;
    --text-primary: var(--on-surface-color);
    --outline-color: rgba(112, 145, 197, 0.45);
    --outline-strong: rgba(79, 122, 189, 0.62);
    --shadow-color: rgba(24, 53, 102, 0.2);
    --ripple-color: rgba(47, 109, 255, 0.14);
    --warning-bg: rgba(242, 173, 54, 0.16);
    --warning-border: rgba(242, 173, 54, 0.42);
    --warning-text-color: #7f4a00;
    --success-color: #0e9964;
    --warning-color-medium: #f2ad36;
    --warning-color-high: #e4553f;
    --link-color: var(--primary-color);
    --leaflet-tile-filter: none;
    --backdrop-blur: blur(22px);
    --glass-outline: rgba(255, 255, 255, 0.45);
    --liquid-shadow: rgba(39, 83, 160, 0.22);
    --command-center-bottom-gap: calc(env(safe-area-inset-bottom, 0px) + clamp(16px, 4vh, 32px));
    --command-center-fab-size: 64px;
    --command-center-panel-spacing: 18px;
    --command-center-fab-gap: 16px;
    --command-center-fab-stack-height: calc(var(--command-center-fab-size) * 3 + var(--command-center-fab-gap) * 2);

    /* v8 Aurora Popup Design Variables - Light Mode */
    --popup-bg-primary: #ffffff;
    --popup-bg-secondary: #f2f7ff;
    --popup-bg-tertiary: #eaf2ff;
    --popup-text-primary: #10213d;
    --popup-text-secondary: #4b638a;
    --popup-text-tertiary: #6f83a9;
    --popup-border: #d8e5ff;
    --popup-border-strong: #bfcff1;
    --popup-accent-primary: #2f6dff;
    --popup-accent-secondary: #6aa8ff;
    --popup-success: #0e9964;
    --popup-warning: #f2ad36;
    --popup-error: #e4553f;
    --popup-info: #2f6dff;
    --popup-shadow: rgba(0, 0, 0, 0.08);
    --popup-overlay: rgba(0, 0, 0, 0.4);
    --popup-glow: rgba(47, 109, 255, 0.2);
    --popup-chip-bg: rgba(47, 109, 255, 0.14);
    --popup-chip-border: rgba(47, 109, 255, 0.32);
    --popup-chip-muted-bg: rgba(120, 148, 194, 0.16);
    --popup-chip-text: #10213d;
    --popup-chip-muted-text: #4b638a;
}

body[data-theme="dark"] {
    --primary-color: #8ab4ff;
    --secondary-color: #6aa8ff;
    --accent-color: #aac7ff;
    --on-primary-color: #081427;
    --surface-color: #081327;
    --surface-container-high: rgba(10, 24, 48, 0.86);
    --surface-elevated: rgba(14, 30, 56, 0.8);
    --surface-solid: #0d1d38;
    --on-surface-color: #e8f1ff;
    --on-surface-variant-color: #9ab1d4;
    --text-primary: var(--on-surface-color);
    --outline-color: rgba(87, 120, 173, 0.48);
    --outline-strong: rgba(120, 157, 214, 0.66);
    --shadow-color: rgba(3, 10, 26, 0.7);
    --ripple-color: rgba(138, 180, 255, 0.18);
    --warning-bg: rgba(242, 173, 54, 0.22);
    --warning-border: rgba(242, 173, 54, 0.58);
    --warning-text-color: #ffd38b;
    --success-color: #7bd9ae;
    --warning-color-medium: #ffd38b;
    --warning-color-high: #ff9f8f;
    --link-color: #9bc0ff;
    --leaflet-tile-filter: brightness(0.72) contrast(1.05) saturate(0.92);
    --backdrop-blur: blur(26px);
    --glass-outline: rgba(138, 180, 255, 0.22);
    --liquid-shadow: rgba(4, 13, 30, 0.62);

    /* v8 Aurora Popup Design Variables - Dark Mode */
    --popup-bg-primary: #0d1d38;
    --popup-bg-secondary: #122646;
    --popup-bg-tertiary: #173053;
    --popup-text-primary: #e8f1ff;
    --popup-text-secondary: #bfd1ee;
    --popup-text-tertiary: #95aed4;
    --popup-border: #2a4268;
    --popup-border-strong: #355683;
    --popup-accent-primary: #8ab4ff;
    --popup-accent-secondary: #6aa8ff;
    --popup-success: #7bd9ae;
    --popup-warning: #ffd38b;
    --popup-error: #ff9f8f;
    --popup-info: #7eaeff;
    --popup-shadow: rgba(0, 0, 0, 0.5);
    --popup-overlay: rgba(0, 0, 0, 0.7);
    --popup-glow: rgba(138, 180, 255, 0.2);
    --popup-chip-bg: rgba(138, 180, 255, 0.18);
    --popup-chip-border: rgba(138, 180, 255, 0.3);
    --popup-chip-muted-bg: rgba(84, 112, 154, 0.2);
    --popup-chip-text: #e8f1ff;
    --popup-chip-muted-text: #bfd1ee;
}

* {
    box-sizing: border-box;
}

.visually-hidden {
    position: absolute !important;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

html, body {
    margin: 0;
    padding: 0;
    height: 100%;
    width: 100vw;
    font-family: 'SF Pro Text', 'SF Pro Display', -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Helvetica Neue', Arial, sans-serif;
    line-height: 1.55;
    background: var(--surface-color);
    color: var(--on-surface-color);
    -webkit-tap-highlight-color: transparent;
    transition: background-color 0.3s ease, color 0.3s ease, filter 0.3s ease;
    touch-action: manipulation;
    overflow: hidden;
    overscroll-behavior: none;
    position: relative;
    -webkit-font-smoothing: antialiased;
}

body::before {
    content: '';
    position: fixed;
    inset: -12% -22% -12% -22%;
    pointer-events: none;
    background:
        radial-gradient(120% 120% at 14% 22%, rgba(79, 132, 255, 0.22), transparent 68%),
        radial-gradient(140% 140% at 86% 10%, rgba(56, 108, 226, 0.18), transparent 62%),
        radial-gradient(120% 120% at 44% 90%, rgba(122, 168, 255, 0.16), transparent 68%);
    z-index: -2;
    transition: opacity 0.5s ease;
}

body[data-theme="dark"]::before {
    background:
        radial-gradient(130% 130% at 12% 18%, rgba(138, 180, 255, 0.24), transparent 68%),
        radial-gradient(140% 140% at 84% 12%, rgba(78, 128, 232, 0.26), transparent 62%),
        radial-gradient(140% 140% at 52% 96%, rgba(102, 148, 244, 0.2), transparent 72%),
        linear-gradient(180deg, rgba(8, 19, 39, 0.97) 0%, rgba(6, 14, 30, 0.97) 100%);
    opacity: 0.86;
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}

body[data-theme="dark"] .leaflet-control-attribution {
    background: var(--surface-elevated);
    border-radius: 16px;
    color: var(--on-surface-variant-color);
}

#map {
    width: 100vw;
    height: 100dvh;
    background: var(--surface-color);
    touch-action: none;
}

.route-line {
    shape-rendering: geometricPrecision;
    filter: none;
}

.leaflet-tile-pane {
    filter: var(--leaflet-tile-filter);
    transition: filter 0.3s ease;
}

.material-symbols-outlined {
    font-size: 20px;
    user-select: none;
}

body:not(.ios) .leaflet-tile-pane {
    will-change: filter;
}

.overlay-panel-inner,
.leaflet-popup-content-wrapper,
.leaflet-tooltip {
    background: var(--surface-container-high) !important;
    color: var(--on-surface-color) !important;
    border-radius: 16px !important;
    border: 1px solid var(--outline-color) !important;
    box-shadow: 0 16px 40px -24px var(--shadow-color) !important;
}

body:not(.ios) .overlay-panel-inner,
body:not(.ios) .leaflet-popup-content-wrapper {
    backdrop-filter: var(--backdrop-blur);
}

@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
    .timestamp-info span,
    .overlay-panel-inner,
    .leaflet-popup-content-wrapper,
    .leaflet-tooltip,
    .command-center__panel {
        background: var(--surface-solid) !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
    }

    .timestamp-info span {
        border-color: var(--outline-strong) !important;
        box-shadow: 0 16px 32px -28px var(--shadow-color) !important;
    }

    #timestamp .countdown {
        border-color: var(--outline-strong) !important;
    }
}

.leaflet-popup-tip {
    background: var(--surface-container-high) !important;
    box-shadow: none !important;
}

.leaflet-popup-content-wrapper {
    background: linear-gradient(160deg, var(--popup-bg-secondary), var(--popup-bg-primary)) !important;
    border: 1px solid var(--popup-border) !important;
    box-shadow:
        0 22px 48px -38px var(--popup-shadow),
        0 0 0 1px var(--popup-glow) !important;
    border-radius: 20px !important;
}

.leaflet-popup-content {
    margin: 0 !important;
    padding: 0 !important;
    word-break: break-word;
}

body[data-theme="dark"] .leaflet-popup-close-button {
    color: var(--on-surface-variant-color);
}

#header {
    display: none;
}

#timestamp {
    position: fixed;
    top: calc(env(safe-area-inset-top, 0px) + 12px);
    left: 50%;
    transform: translateX(-50%);
    z-index: 1001;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 10px;
    padding: 0;
    background: transparent;
    border: none;
    box-shadow: none;
    border-radius: 0;
    font-weight: 500;
    font-size: clamp(0.75rem, 0.72rem + 0.15vw, 0.85rem);
    line-height: 1.4;
    pointer-events: none;
    color: var(--on-surface-color);
    transition: opacity 0.2s ease, transform 0.2s ease, color 0.4s ease;
    min-width: auto;
}

body[data-theme="dark"] #timestamp {
    color: var(--on-surface-color);
}

.timestamp-header {
    order: 2;
    display: flex;
    align-items: center;
    gap: 10px;
    width: auto;
    padding: 0;
    margin-left: auto;
    pointer-events: none;
}

.timestamp-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px;
    border-radius: 999px;
    background: rgba(58, 109, 240, 0.12);
    color: var(--primary-color);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.timestamp-chip .material-symbols-outlined {
    font-size: 18px;
}

body[data-theme="dark"] .timestamp-chip {
    background: rgba(144, 194, 255, 0.16);
    color: var(--on-surface-color);
}

.timestamp-info {
    order: 1;
    display: flex;
    align-items: stretch;
    justify-content: center;
    gap: 10px;
    flex-wrap: wrap;
    width: auto;
    pointer-events: none;
}

.timestamp-info span {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 8px 16px;
    border-radius: 18px;
    gap: 6px;
    font-weight: 600;
    letter-spacing: 0.01em;
    white-space: nowrap;
    background: linear-gradient(140deg, rgba(255, 255, 255, 0.58), rgba(244, 248, 255, 0.22));
    border: 1px solid var(--glass-outline);
    color: var(--on-surface-color);
    box-shadow: 0 18px 36px -28px var(--liquid-shadow);
    backdrop-filter: var(--backdrop-blur);
    -webkit-backdrop-filter: var(--backdrop-blur);
    isolation: isolate;
    pointer-events: none;
}

body[data-theme="dark"] .timestamp-info span {
    background: linear-gradient(140deg, rgba(20, 31, 54, 0.72), rgba(12, 21, 42, 0.48));
    border-color: var(--glass-outline);
}

#lastUpdateText {
    font-variant-numeric: tabular-nums;
}

#timestamp .countdown {
    font-variant-numeric: tabular-nums;
    background: linear-gradient(145deg, rgba(58, 109, 240, 0.32), rgba(123, 93, 249, 0.22));
    border-color: rgba(58, 109, 240, 0.38);
}

body[data-theme="dark"] #timestamp .countdown {
    background: linear-gradient(145deg, rgba(58, 109, 240, 0.32), rgba(144, 194, 255, 0.22));
    border-color: rgba(144, 194, 255, 0.38);
}

.status-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    border: 1px solid var(--glass-outline);
    background: rgba(255, 255, 255, 0.24);
    color: var(--on-surface-color);
    transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

body[data-theme="dark"] .status-badge {
    background: rgba(12, 21, 42, 0.5);
}

.status-badge[hidden] {
    display: none;
}

.status-badge--ok {
    background: rgba(30, 142, 62, 0.32);
    color: var(--on-primary-color);
    border-color: rgba(30, 142, 62, 0.42);
}

.status-badge--warning {
    background: rgba(255, 185, 80, 0.32);
    color: var(--on-primary-color);
    border-color: rgba(255, 185, 80, 0.45);
}

.status-badge--error {
    background: rgba(217, 48, 37, 0.36);
    color: var(--on-primary-color);
    border-color: rgba(217, 48, 37, 0.42);
}

.overlay-panel {
    position: fixed;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    z-index: 1003;
    display: none;
    padding: 24px 12px;
    pointer-events: none;
    align-items: center;
    justify-content: center;
}

.overlay-panel[aria-hidden="false"],
.overlay-panel.is-visible {
    display: flex;
}

.overlay-panel-inner {
    pointer-events: auto;
    margin: 0 auto;
    max-width: 880px;
    width: 100%;
    max-height: calc(100vh - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px) - 96px);
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
}

#searchBar,
#infoBar {
    border-bottom: 1px solid var(--outline-color);
    padding: 12px 18px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    background: var(--surface-elevated);
}

#searchBar {
    flex-wrap: wrap;
}

#searchInput {
    flex: 1 1 220px;
    font-size: 16px;
    padding: 12px 16px;
    border-radius: 24px;
    border: 1px solid var(--outline-color);
    background: var(--surface-color);
    color: var(--on-surface-color);
    transition: border-color 0.2s ease, background-color 0.2s ease;
}

#searchInput:focus {
    border-color: var(--primary-color);
    outline: none;
    background: var(--surface-container-high);
}

#searchInput::placeholder {
    color: var(--on-surface-variant-color);
}

.sp-btn {
    background: transparent;
    border: none;
    color: var(--primary-color);
    cursor: pointer;
    font-weight: 500;
    padding: 8px 14px;
    border-radius: 99px;
    transition: background-color 0.2s ease, color 0.2s ease;
}

.sp-btn:hover,
.sp-btn:focus-visible {
    background: var(--ripple-color);
    outline: none;
}

#searchInfo {
    padding: 6px 18px 12px;
    font-size: 14px;
    color: var(--on-surface-variant-color);
}

#resultsWrap {
    max-height: min(48vh, 560px);
    overflow: auto;
    padding: 0 8px 18px 8px;
    scroll-behavior: smooth;
}

#resultsList {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 10px;
}

.resultItem {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 6px 10px;
    align-items: center;
    padding: 12px 14px;
    border-radius: 16px;
    color: var(--on-surface-color);
    cursor: pointer;
    transition: background-color 0.2s ease, transform 0.2s ease;
    background: var(--surface-elevated);
    border: 1px solid transparent;
}

.resultItem:hover,
.resultItem:focus-visible {
    background-color: rgba(26, 115, 232, 0.08);
    border-color: var(--outline-color);
    transform: translateY(-1px);
    outline: none;
}

.resultItem:active {
    transform: translateY(0);
}

.ri-title {
    font-weight: 600;
    font-size: 15px;
}

.ri-sub {
    grid-column: 1 / -1;
    font-size: 13px;
    color: var(--on-surface-variant-color);
}

.ri-badge,
.ri-type-badge {
    font-size: 12px;
    font-weight: 600;
    padding: 4px 8px;
    border-radius: 999px;
    background: rgba(26, 115, 232, 0.1);
    color: var(--primary-color);
}

.ri-type-badge {
    background: rgba(17, 24, 39, 0.06);
    color: var(--on-surface-variant-color);
}

.popup-card {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 16px 18px 18px;
    min-width: 240px;
}

.popup-card--tooltip {
    padding: 10px 14px 12px;
}

.popup-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10px;
}

.popup-header__titles {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 0;
}

.popup-title {
    font-size: clamp(0.95rem, 0.9rem + 0.5vw, 1.1rem);
    line-height: 1.3;
    letter-spacing: -0.015em;
}

.popup-subtitle {
    font-size: 13px;
    color: var(--popup-text-secondary);
    line-height: 1.4;
    letter-spacing: 0;
}

.popup-actions {
    display: flex;
    align-items: center;
    gap: 8px;
}

.popup-info-btn {
    border: 1px solid var(--popup-chip-border);
    background: var(--popup-chip-bg);
    color: var(--popup-accent-primary);
    border-radius: 999px;
    font-weight: 600;
    width: 36px;
    height: 36px;
    font-size: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.popup-info-btn:hover,
.popup-info-btn:focus-visible {
    background: rgba(26, 115, 232, 0.16);
    outline: none;
    box-shadow: 0 10px 24px -16px var(--shadow-color);
    transform: translateY(-1px);
}

.popup-metrics {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.popup-chip {
    border-radius: 999px;
    padding: 5px 12px;
    font-size: 12px;
    font-weight: 600;
    background: var(--popup-chip-bg);
    border: 1px solid var(--popup-chip-border);
    color: var(--popup-chip-text);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.popup-chip--muted {
    background: var(--popup-chip-muted-bg);
    color: var(--popup-chip-muted-text);
    border-color: transparent;
}

.popup-chip--ml {
    background: rgba(139, 92, 246, 0.15);
    color: #8b5cf6;
    border: 1px solid rgba(139, 92, 246, 0.3);
}

body[data-theme="dark"] .popup-chip--ml {
    background: rgba(167, 139, 250, 0.18);
    color: #a78bfa;
    border-color: rgba(167, 139, 250, 0.35);
}

.popup-chip--delay {
    color: var(--popup-text-primary);
}

/* New popup title row with inline delay badge */
.popup-title-row {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.popup-delay-badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    white-space: nowrap;
}

.popup-delay-badge--ontime {
    background: rgba(16, 185, 129, 0.15);
    color: var(--popup-success);
    border: 1px solid rgba(16, 185, 129, 0.3);
}

.popup-delay-badge--late-5 {
    background: rgba(245, 158, 11, 0.15);
    color: var(--popup-warning);
    border: 1px solid rgba(245, 158, 11, 0.3);
}

.popup-delay-badge--late-15 {
    background: rgba(239, 68, 68, 0.15);
    color: var(--popup-error);
    border: 1px solid rgba(239, 68, 68, 0.3);
}

.popup-delay-badge--early {
    background: rgba(14, 165, 233, 0.15);
    color: var(--popup-info);
    border: 1px solid rgba(14, 165, 233, 0.3);
}

.popup-route-arrow {
    color: var(--popup-accent-primary);
    margin-right: 4px;
}

/* GPS stale warning - red UI */
.popup-gps-stale {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    border-radius: 10px;
    background: rgba(239, 68, 68, 0.12);
    border: 1px solid rgba(239, 68, 68, 0.25);
    color: var(--popup-error);
    font-size: 11px;
    font-weight: 500;
    margin: 6px 0;
}

.popup-gps-stale .material-symbols-outlined {
    font-size: 16px;
}

/* "Menetrend és csatlakozások" button */
.popup-schedule-btn {
    width: 100%;
    padding: 10px 14px;
    margin-top: 8px;
    border-radius: 12px;
    border: 1px solid var(--popup-border);
    background: linear-gradient(135deg, var(--popup-chip-bg) 0%, var(--popup-bg-tertiary) 100%);
    color: var(--popup-text-primary);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: transform 0.15s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.popup-schedule-btn:hover,
.popup-schedule-btn:focus-visible {
    transform: translateY(-1px);
    box-shadow: 0 6px 16px -8px var(--popup-shadow);
    background: linear-gradient(135deg, var(--popup-accent-primary) 0%, var(--popup-accent-secondary) 100%);
    color: #fff;
    border-color: transparent;
    outline: none;
}

.popup-alert {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    border-radius: 12px;
    background: var(--warning-bg);
    border: 1px solid var(--warning-border);
    color: var(--warning-text-color);
    font-size: 12px;
    font-weight: 600;
    line-height: 1.4;
}

.popup-alert__icon {
    font-size: 13px;
}

.popup-next-stop {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
    font-size: 12px;
    color: var(--popup-text-secondary);
    padding: 10px 12px;
    border-radius: 10px;
    background: var(--popup-chip-muted-bg);
    border: 1px solid var(--popup-border);
}

.popup-next-stop__label {
    text-transform: uppercase;
    font-size: 10px;
    letter-spacing: 0.08em;
    font-weight: 700;
    color: var(--popup-text-tertiary);
}

.popup-next-stop__value {
    font-weight: 600;
    color: var(--popup-text-primary);
}

.popup-meta {
    font-size: 11px;
    color: var(--popup-text-tertiary);
    padding-top: 2px;
    line-height: 1.4;
}

.gps-freshness-warning {
    color: var(--warning-color-high, #d93025);
}

.popup-overlay {
    margin-top: 4px;
}

.infoTitle {
    font-weight: 600;
    font-size: 16px;
}

.infoContent {
    padding: 18px 18px 24px;
    font-size: 14px;
    line-height: 1.6;
    color: var(--on-surface-color);
}

.infoContent h3 {
    margin-top: 0;
}

.infoContent a {
    color: var(--link-color);
}

#resultsWrap ul,
#station-board-list,
#schedule-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

#schedulePanel .overlay-panel-inner {
    padding-bottom: 12px;
}

#schedulePanel #infoBar {
    position: sticky;
    top: 0;
    z-index: 2;
    background: linear-gradient(180deg, rgba(26, 115, 232, 0.08), rgba(26, 115, 232, 0.02));
    backdrop-filter: var(--backdrop-blur);
    border-bottom-color: rgba(26, 115, 232, 0.22);
}

#schedulePanel #resultsWrap {
    background: linear-gradient(180deg, rgba(123, 93, 249, 0.04), rgba(58, 109, 240, 0.02));
    border: 1px solid var(--outline-color);
    border-radius: 18px;
    padding: 10px;
    max-height: calc(100vh - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px) - 240px);
    box-shadow: 0 18px 32px -24px var(--shadow-color);
}

.schedule-panel {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.schedule-shell {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 14px 14px 18px;
}

.schedule-hero {
    background: linear-gradient(135deg, rgba(58, 109, 240, 0.12) 0%, rgba(123, 93, 249, 0.14) 100%);
    border: 1px solid var(--outline-strong);
    border-radius: 18px;
    padding: 16px;
    box-shadow: 0 18px 34px -24px var(--shadow-color);
    display: flex;
    flex-direction: column;
    gap: 12px;
}

body[data-theme="dark"] .schedule-hero {
    background: linear-gradient(135deg, rgba(58, 109, 240, 0.18) 0%, rgba(123, 93, 249, 0.16) 100%);
    box-shadow: 0 22px 42px -28px var(--shadow-color);
}

.schedule-hero__title {
    font-size: clamp(1.15rem, 1.05rem + 0.6vw, 1.35rem);
    font-weight: 700;
    letter-spacing: -0.01em;
    margin: 0;
}

.schedule-hero__header {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: flex-start;
    flex-wrap: wrap;
}

.schedule-hero__subtitle {
    margin: 2px 0 0;
    color: var(--on-surface-variant-color);
    font-size: 14px;
}

.schedule-hero__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

.pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 7px 12px;
    border-radius: 999px;
    border: 1px solid var(--outline-color);
    background: var(--surface-solid);
    color: var(--on-surface-color);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.01em;
    box-shadow: 0 10px 24px -18px var(--shadow-color);
}

.pill--muted {
    background: rgba(17, 24, 39, 0.04);
    color: var(--on-surface-variant-color);
}

.pill--success {
    background: rgba(15, 157, 88, 0.12);
    color: var(--success-color);
    border-color: rgba(15, 157, 88, 0.42);
}

.pill--warning {
    background: rgba(251, 188, 5, 0.16);
    color: var(--warning-text-color);
    border-color: rgba(251, 188, 5, 0.42);
}

.pill--danger {
    background: rgba(234, 67, 53, 0.14);
    color: var(--warning-color-high);
    border-color: rgba(234, 67, 53, 0.46);
}

.schedule-stat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 12px;
}

.schedule-stat {
    padding: 14px 16px;
    border-radius: 14px;
    border: 1px solid var(--outline-color);
    background: var(--surface-elevated);
    display: grid;
    gap: 4px;
}

.schedule-stat .stat-label {
    font-size: 12px;
    color: var(--on-surface-variant-color);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.schedule-stat .stat-value {
    font-size: 18px;
    font-weight: 700;
}

.schedule-stat .stat-hint {
    font-size: 12px;
    color: var(--on-surface-variant-color);
}

#schedule-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.schedule-item {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 12px;
    align-items: stretch;
    padding: 14px;
    background: var(--surface-elevated);
    border-radius: 16px;
    border: 1px solid var(--outline-color);
    box-shadow: 0 18px 32px -26px var(--shadow-color);
}

.schedule-item.is-past {
    opacity: 0.82;
}

.schedule-timeline {
    position: relative;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding-top: 2px;
    min-width: 18px;
}

.schedule-rail {
    position: absolute;
    top: 14px;
    bottom: 0;
    width: 2px;
    border-radius: 999px;
    background: var(--outline-color);
}

.schedule-rail.is-last {
    display: none;
}

.schedule-node {
    position: relative;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--primary-color);
    border: 2px solid var(--surface-solid);
    box-shadow: 0 6px 18px -10px var(--shadow-color);
    z-index: 1;
}

.schedule-node.is-past {
    background: var(--outline-strong);
}

.schedule-card {
    display: grid;
    gap: 12px;
}

.schedule-card__header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
    flex-wrap: wrap;
}

.schedule-card__title {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.schedule-stop-name {
    font-weight: 700;
    font-size: 16px;
}

.schedule-platform-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    border-radius: 10px;
    background: rgba(26, 115, 232, 0.08);
    color: var(--primary-color);
    font-size: 12px;
    border: 1px dashed rgba(26, 115, 232, 0.35);
}

.schedule-delay-badge {
    align-self: flex-start;
    padding: 6px 10px;
    border-radius: 10px;
    font-weight: 700;
    font-size: 12px;
    border: 1px solid transparent;
    background: rgba(17, 24, 39, 0.04);
    color: var(--on-surface-color);
}

.schedule-delay-badge.ontime {
    background: rgba(15, 157, 88, 0.12);
    color: var(--success-color);
    border-color: rgba(15, 157, 88, 0.36);
}

.schedule-delay-badge.late-5 {
    background: rgba(251, 188, 5, 0.14);
    color: var(--warning-text-color);
    border-color: rgba(251, 188, 5, 0.4);
}

.schedule-delay-badge.late-15 {
    background: rgba(234, 67, 53, 0.14);
    color: var(--warning-color-high);
    border-color: rgba(234, 67, 53, 0.44);
}

.schedule-delay-badge.early {
    background: rgba(26, 115, 232, 0.12);
    color: var(--primary-color);
    border-color: rgba(26, 115, 232, 0.36);
}

.schedule-times-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px;
}

.time-block {
    padding: 12px 14px;
    border-radius: 12px;
    border: 1px dashed var(--outline-color);
    background: var(--surface-color);
    display: grid;
    gap: 8px;
}

.time-label {
    font-size: 11px;
    color: var(--on-surface-variant-color);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    font-weight: 600;
}

.time-values {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 15px;
    font-weight: 600;
}

.time-planned {
    color: var(--on-surface-variant-color);
}

.time-planned.is-offset {
    text-decoration: line-through;
}

.time-actual {
    color: var(--on-surface-color);
    font-weight: 700;
}

.schedule-state {
    font-size: 12px;
    color: var(--on-surface-variant-color);
}

.schedule-connection {
    display: grid;
    gap: 10px;
    padding: 12px;
    border-radius: 14px;
    border: 1px dashed var(--outline-color);
    background: var(--surface-color);
}

.schedule-connection-toggle {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    width: 100%;
    padding: 0;
    border: none;
    background: transparent;
    color: var(--on-surface-color);
    text-align: left;
    cursor: pointer;
}

.schedule-connection-toggle .toggle-label {
    font-weight: 700;
    font-size: 13px;
}

.schedule-connection-toggle .toggle-meta {
    font-size: 12px;
    color: var(--on-surface-variant-color);
}

.schedule-connection-toggle .toggle-arrow {
    font-size: 18px;
    transition: transform 0.2s ease;
}

.schedule-connection-toggle[aria-expanded="true"] .toggle-arrow {
    transform: rotate(180deg);
}

.schedule-connection-panel {
    display: grid;
    gap: 10px;
}

.schedule-connection-summary {
    font-size: 12px;
    color: var(--on-surface-variant-color);
}

.schedule-connection-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 8px;
}

.schedule-connection-item {
    display: grid;
    gap: 6px;
    padding: 10px 12px;
    border-radius: 12px;
    border: 1px solid var(--outline-color);
    background: var(--surface-solid);
}

.connection-main {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
    flex-wrap: wrap;
}

.connection-title {
    font-weight: 600;
    font-size: 13px;
}

.connection-probability {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.probability-pill {
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    border: 1px solid rgba(26, 115, 232, 0.32);
    background: rgba(26, 115, 232, 0.12);
    color: var(--primary-color);
}

.probability-pill.is-high {
    border-color: rgba(15, 157, 88, 0.36);
    background: rgba(15, 157, 88, 0.12);
    color: var(--success-color);
}

.probability-pill.is-medium {
    border-color: rgba(251, 188, 5, 0.4);
    background: rgba(251, 188, 5, 0.14);
    color: var(--warning-text-color);
}

.probability-pill.is-low {
    border-color: rgba(234, 67, 53, 0.44);
    background: rgba(234, 67, 53, 0.14);
    color: var(--warning-color-high);
}

.connection-meta {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    font-size: 12px;
    color: var(--on-surface-variant-color);
}

.connection-note {
    font-size: 12px;
    color: var(--on-surface-variant-color);
}

.connection-history {
    font-size: 11px;
    color: var(--on-surface-variant-color);
}

.schedule-connection-empty {
    padding: 10px 12px;
    border-radius: 12px;
    border: 1px dashed var(--outline-color);
    background: rgba(26, 115, 232, 0.06);
    font-size: 12px;
    color: var(--on-surface-variant-color);
}

.schedule-alert-info {
    padding: 12px 14px;
    margin: 10px 14px 0;
    border-radius: 14px;
    border: 1px solid var(--warning-border);
    background: var(--warning-bg);
    box-shadow: 0 14px 24px -18px rgba(255, 185, 80, 0.3);
}

.schedule-info-services {
    margin: 10px 16px 16px;
    padding: 10px 12px;
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.1) 0%, rgba(14, 165, 233, 0.08) 100%);
    border: 1px solid rgba(99, 102, 241, 0.2);
    color: var(--on-surface-color);
    font-size: 12px;
    display: grid;
    gap: 8px;
    box-shadow: 0 12px 24px -20px var(--shadow-color);
}

.schedule-info-services__title {
    font-weight: 700;
    font-size: 12px;
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--on-surface-color);
}

.schedule-info-services__list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 6px;
}

.schedule-info-services__item {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 6px 8px;
    border-radius: 10px;
    background: var(--surface-solid);
    border: 1px solid var(--outline-color);
    box-shadow: 0 8px 16px -16px var(--shadow-color);
    font-size: 12px;
}

.schedule-info-services__icon {
    font-size: 14px;
    line-height: 1.2;
}

body[data-theme="dark"] .schedule-info-services__item {
    background: rgba(24, 24, 27, 0.6);
}

.schedule-ml-toggle {
    width: 100%;
    padding: 12px 14px;
    margin: 2px 0 0;
    border-radius: 14px;
    border: 1px solid var(--outline-color);
    background: linear-gradient(135deg, rgba(58, 109, 240, 0.12) 0%, rgba(123, 93, 249, 0.12) 100%);
    color: var(--text-primary);
    font-size: 14px;
    font-weight: 700;
    text-align: left;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 10px;
    transition: transform 0.15s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.schedule-ml-toggle:hover,
.schedule-ml-toggle:focus-visible {
    transform: translateY(-1px);
    box-shadow: 0 12px 26px -20px var(--shadow-color);
    outline: none;
}

.schedule-ml-toggle[aria-expanded="true"] {
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--accent-color) 100%);
    color: var(--on-primary-color);
    border-color: transparent;
}

.ml-toggle-icon {
    font-size: 20px;
}

.ml-toggle-text {
    flex: 1;
    font-size: 14px;
}

.ml-toggle-arrow {
    font-size: 16px;
    font-weight: 700;
}

.schedule-ml-card {
    padding: 14px;
    border-radius: 14px;
    border: 1px solid var(--outline-color);
    background: var(--surface-elevated);
    box-shadow: 0 18px 32px -26px var(--shadow-color);
    max-height: 60vh;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
}

@media (max-width: 720px) {
    #schedulePanel #resultsWrap {
        max-height: none;
    }

    .schedule-item {
        grid-template-columns: 1fr;
    }

    .schedule-timeline {
        display: none;
    }

    .schedule-card__header {
        flex-direction: column;
    }
}

.station-board-item {
    display: grid;
    grid-template-columns: minmax(64px, 80px) minmax(160px, 1fr) minmax(160px, 200px) minmax(70px, 90px) minmax(64px, 80px);
    gap: 14px;
    align-items: center;
    padding: 14px 18px;
    border-radius: 18px;
    border: 1px solid var(--outline-color);
    background: linear-gradient(135deg, var(--surface-elevated) 0%, var(--surface-color) 100%);
    box-shadow: 0 14px 30px -24px var(--shadow-color);
}

.station-board-time {
    font-weight: 700;
    font-size: 16px;
}

.station-board-headsign {
    font-weight: 600;
    font-size: 14px;
}

.station-board-details {
    font-size: 12px;
    color: var(--on-surface-variant-color);
}

.station-board-platform {
    display: grid;
    gap: 2px;
    text-align: center;
    font-size: 12px;
    color: var(--on-surface-variant-color);
}

@media (max-width: 480px) {
    .station-board-item {
        grid-template-columns: 1fr;
    }

    .station-board-platform {
        text-align: left;
        margin-top: 4px;
    }
}

.vehicle-marker {
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: auto;
    transform: translateZ(0);
}

.marker-icon-wrapper {
    position: relative;
    width: 22px;
    height: 22px;
}

.marker-icon-wrapper .body {
    position: absolute;
    top: 3px;
    left: 3px;
    width: 16px;
    height: 16px;
    background-color: var(--color);
    border: 2px solid #000;
    border-radius: 50%;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.24);
    z-index: 2;
}

.marker-icon-wrapper .heading-wrapper {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transform: rotate(var(--heading));
    transform-origin: 50% 50%;
    will-change: transform;
    transition: transform 0.2s linear;
}

.marker-icon-wrapper .triangle {
    position: absolute;
    top: -6px;
    left: 50%;
    width: 0;
    height: 0;
    transform: translateX(-50%);
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-bottom: 12px solid #000;
    z-index: 1;
}

.marker-icon-wrapper .triangle::before,
.marker-icon-wrapper .triangle::after {
    content: none;
}

.warning-banner {
    background: var(--warning-bg);
    border: 1px solid var(--warning-border);
    color: var(--warning-text-color);
    border-radius: 12px;
    padding: 12px 16px;
}

.schedule-alert-info {
    margin: 12px 18px;
    padding: 12px 16px;
    border-radius: 16px;
    background: var(--warning-bg);
    border: 1px solid var(--warning-border);
    color: var(--warning-text-color);
    font-size: 14px;
}

body[data-theme="dark"] .bmc-button {
    border-color: var(--on-surface-variant-color) !important;
}

.support-modal {
    position: fixed;
    inset: 0;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding: clamp(12px, 4vw, 28px);
    z-index: 1400;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.25s ease;
}

.support-modal.is-visible {
    opacity: 1;
    pointer-events: auto;
}

.support-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.35);
    backdrop-filter: blur(10px);
}

.support-modal__card {
    position: relative;
    width: min(520px, 100%);
    background: var(--surface-container-high);
    color: var(--on-surface-color);
    border: 1px solid var(--outline-color);
    border-radius: 22px;
    box-shadow: 0 26px 70px -32px var(--shadow-color);
    padding: clamp(18px, 4vw, 26px);
    transform: translateY(18px) scale(0.985);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    backdrop-filter: var(--backdrop-blur);
}

.support-modal.is-visible .support-modal__card {
    transform: translateY(0) scale(1);
    box-shadow: 0 30px 80px -36px var(--shadow-color);
}

.support-modal__icon-close {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 1px solid var(--outline-color);
    background: var(--surface-color);
    color: var(--on-surface-color);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.support-modal__icon-close:hover,
.support-modal__icon-close:focus-visible {
    transform: translateY(-1px);
    box-shadow: 0 10px 30px -16px var(--shadow-color);
    outline: none;
}

.support-modal__badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 7px 12px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
    color: var(--on-primary-color);
    font-weight: 700;
    font-size: 11px;
    letter-spacing: 0.01em;
    box-shadow: 0 10px 28px -18px var(--shadow-color);
}

.support-modal__title {
    margin: 14px 0 8px;
    font-size: clamp(20px, 4vw, 24px);
    line-height: 1.3;
}

.support-modal__copy {
    margin: 0;
    font-size: 15px;
    color: var(--on-surface-variant-color);
}

.support-modal__cta {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin: 16px 0 10px;
}

.support-modal__bmc {
    min-height: 54px;
    display: inline-flex;
    align-items: center;
}

.support-modal__bmc-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 16px;
    border-radius: 14px;
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
    color: var(--on-primary-color);
    font-weight: 700;
    font-size: 15px;
    text-decoration: none;
    box-shadow: 0 18px 32px -22px var(--shadow-color);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.support-modal__bmc-btn:hover,
.support-modal__bmc-btn:focus-visible {
    transform: translateY(-1px);
    box-shadow: 0 20px 40px -24px var(--shadow-color);
    outline: none;
}

.support-modal__bmc-btn.is-hidden {
    display: none;
}

.support-modal__meta {
    margin: 0;
    font-size: 13px;
    color: var(--on-surface-variant-color);
}

.support-modal__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: 6px;
}

.support-modal__primary {
    border: none;
    border-radius: 14px;
    padding: 12px 18px;
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
    color: var(--on-primary-color);
    font-weight: 700;
    font-size: 14px;
    cursor: pointer;
    box-shadow: 0 18px 32px -22px var(--shadow-color);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.support-modal__primary:hover,
.support-modal__primary:focus-visible {
    transform: translateY(-1px);
    box-shadow: 0 20px 40px -24px var(--shadow-color);
    outline: none;
}

.support-modal__dismiss {
    background: transparent;
    border: none;
    padding: 6px 8px;
    color: var(--on-surface-variant-color);
    font-size: 12px;
    text-decoration: underline;
    cursor: pointer;
    text-transform: lowercase;
}

.support-modal__dismiss:hover,
.support-modal__dismiss:focus-visible {
    color: var(--on-surface-color);
    outline: none;
}

.beta-modal {
    position: fixed;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: clamp(12px, 4vw, 28px);
    z-index: 1500;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.25s ease;
}

.beta-modal.is-visible {
    opacity: 1;
    pointer-events: auto;
}

.beta-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(2, 10, 30, 0.45);
    backdrop-filter: blur(12px);
}

.beta-modal__card {
    position: relative;
    width: min(560px, 100%);
    background: var(--surface-container-high);
    color: var(--on-surface-color);
    border: 1px solid var(--outline-color);
    border-radius: 24px;
    box-shadow: 0 30px 80px -36px var(--shadow-color);
    padding: clamp(20px, 4vw, 28px);
    transform: translateY(18px) scale(0.985);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    backdrop-filter: var(--backdrop-blur);
}

.beta-modal.is-visible .beta-modal__card {
    transform: translateY(0) scale(1);
}

.beta-modal__badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 7px 12px;
    border-radius: 999px;
    background: linear-gradient(135deg, #6c87ff, #45c2ff);
    color: var(--on-primary-color);
    font-weight: 700;
    font-size: 11px;
    letter-spacing: 0.01em;
    box-shadow: 0 10px 28px -18px var(--shadow-color);
}

.beta-modal__title {
    margin: 14px 0 8px;
    font-size: clamp(20px, 4vw, 26px);
    line-height: 1.25;
}

.beta-modal__copy {
    margin: 0 0 16px;
    font-size: 15px;
    color: var(--on-surface-variant-color);
}

.beta-modal__form {
    display: grid;
    gap: 14px;
    margin: 0 0 12px;
}

.beta-modal__field {
    display: grid;
    gap: 8px;
}

.beta-modal__label {
    font-size: 13px;
    font-weight: 600;
    color: var(--on-surface-color);
}

.beta-modal__input {
    width: 100%;
    padding: 12px 14px;
    border-radius: 14px;
    border: 1px solid var(--outline-color);
    background: var(--surface-color);
    color: var(--on-surface-color);
    font-size: 14px;
}

.beta-modal__input:focus {
    outline: 2px solid rgba(90, 126, 255, 0.4);
    border-color: rgba(90, 126, 255, 0.8);
}

.beta-modal__options {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.beta-modal__option {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border-radius: 14px;
    border: 1px solid var(--outline-color);
    background: var(--surface-color);
    cursor: pointer;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.beta-modal__option input {
    accent-color: var(--primary-color);
}

.beta-modal__option:hover {
    border-color: rgba(90, 126, 255, 0.6);
    box-shadow: 0 10px 24px -18px var(--shadow-color);
}

.beta-modal__legal {
    margin: 0;
    font-size: 12px;
    color: var(--on-surface-variant-color);
}

.beta-modal__actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: 4px;
}

.beta-modal__submit {
    border: none;
    border-radius: 14px;
    padding: 12px 18px;
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
    color: var(--on-primary-color);
    font-weight: 700;
    font-size: 14px;
    cursor: pointer;
    box-shadow: 0 18px 32px -22px var(--shadow-color);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.beta-modal__submit:hover,
.beta-modal__submit:focus-visible {
    transform: translateY(-1px);
    box-shadow: 0 20px 40px -24px var(--shadow-color);
    outline: none;
}

.beta-modal__dismiss {
    background: transparent;
    border: none;
    padding: 6px 8px;
    color: var(--on-surface-variant-color);
    font-size: 12px;
    text-decoration: underline;
    cursor: pointer;
    text-transform: lowercase;
}

.beta-modal__dismiss:hover,
.beta-modal__dismiss:focus-visible {
    color: var(--on-surface-color);
    outline: none;
}


@media (min-width: 720px) {
    .support-modal {
        align-items: center;
    }

    .support-modal__card {
        padding: 22px 26px;
    }

    .support-modal__footer {
        justify-content: flex-end;
    }
}

@supports (padding: max(0px)) {
    .overlay-panel-inner {
        border-radius: 24px;
    }
}

/* Train Panel - Flightradar-style side panel (desktop) / bottom sheet (mobile) */
.train-panel {
    position: fixed;
    inset: 0;
    z-index: 1100;
    pointer-events: none;
    display: flex;
    visibility: hidden;
}

.train-panel.is-open {
    visibility: visible;
    pointer-events: auto;
}

.train-panel__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.3);
    opacity: 0;
    transition: opacity 0.24s ease;
}

.train-panel.is-open .train-panel__backdrop {
    opacity: 1;
}

.train-panel__sheet {
    position: absolute;
    top: 0;
    right: 0;
    width: min(420px, 92vw);
    height: 100%;
    background: linear-gradient(160deg, var(--popup-bg-secondary), var(--popup-bg-primary));
    border-left: 1px solid var(--popup-border);
    box-shadow: -8px 0 32px -12px var(--popup-shadow);
    transform: translateX(110%);
    transition: transform 0.28s cubic-bezier(0.22, 0.61, 0.36, 1);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    pointer-events: auto;
}

.train-panel.is-open .train-panel__sheet {
    transform: translateX(0);
}

.train-panel__handle {
    display: none;
}

.train-panel__close {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1px solid var(--popup-border);
    background: var(--popup-bg-tertiary);
    color: var(--popup-text-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 10;
    transition: transform 0.2s ease, background-color 0.2s ease;
}

.train-panel__close:hover,
.train-panel__close:focus-visible {
    transform: scale(1.05);
    background: var(--popup-chip-bg);
    outline: none;
}

.train-panel__content {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 24px;
    padding-top: 68px;
    -webkit-overflow-scrolling: touch;
}

/* Train Panel Header */
.train-panel__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
}

.train-panel__title-row {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.train-panel__name {
    font-size: clamp(1.1rem, 1rem + 0.5vw, 1.35rem);
    font-weight: 700;
    color: var(--popup-text-primary);
    margin: 0;
}

.train-panel__delay-badge {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 700;
    white-space: nowrap;
}

.train-panel__delay-badge--ontime {
    background: rgba(16, 185, 129, 0.15);
    color: var(--popup-success);
    border: 1px solid rgba(16, 185, 129, 0.3);
}

.train-panel__delay-badge--late-5 {
    background: rgba(245, 158, 11, 0.15);
    color: var(--popup-warning);
    border: 1px solid rgba(245, 158, 11, 0.3);
}

.train-panel__delay-badge--late-15 {
    background: rgba(239, 68, 68, 0.15);
    color: var(--popup-error);
    border: 1px solid rgba(239, 68, 68, 0.3);
}

.train-panel__route {
    font-size: 14px;
    color: var(--popup-text-secondary);
    margin: 8px 0 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.train-panel__route-arrow {
    color: var(--popup-accent-primary);
}

/* Train Panel Stats Grid */
.train-panel__stats {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    margin-bottom: 16px;
}

.train-panel__stat {
    padding: 14px;
    border-radius: 12px;
    background: var(--popup-chip-muted-bg);
    border: 1px solid transparent;
}

.train-panel__stat-label {
    font-size: 11px;
    color: var(--popup-text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 4px;
}

.train-panel__stat-value {
    font-size: 16px;
    font-weight: 600;
    color: var(--popup-text-primary);
}

/* Train Panel Action Button */
.train-panel__action-btn {
    width: 100%;
    padding: 14px 18px;
    border-radius: 14px;
    border: 1px solid var(--popup-border);
    background: linear-gradient(135deg, var(--popup-chip-bg) 0%, var(--popup-bg-tertiary) 100%);
    color: var(--popup-text-primary);
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    transition: transform 0.15s ease, box-shadow 0.2s ease;
    margin-bottom: 12px;
}

.train-panel__action-btn:hover,
.train-panel__action-btn:focus-visible {
    transform: translateY(-1px);
    box-shadow: 0 8px 20px -12px var(--popup-shadow);
    outline: none;
}

.train-panel__action-btn .material-symbols-outlined {
    font-size: 20px;
    color: var(--popup-accent-primary);
}

/* GPS Stale Warning */
.train-panel__gps-stale {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    border-radius: 12px;
    background: rgba(239, 68, 68, 0.12);
    border: 1px solid rgba(239, 68, 68, 0.25);
    color: var(--popup-error);
    font-size: 13px;
    font-weight: 500;
    margin-bottom: 12px;
}

.train-panel__gps-stale .material-symbols-outlined {
    font-size: 18px;
}

/* Next Stop Section */
.train-panel__next-stop {
    padding: 16px;
    border-radius: 14px;
    background: var(--popup-bg-tertiary);
    border: 1px dashed var(--popup-border);
    margin-bottom: 12px;
}

.train-panel__next-stop-label {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--popup-text-tertiary);
    margin-bottom: 8px;
}

.train-panel__next-stop-name {
    font-size: 15px;
    font-weight: 600;
    color: var(--popup-text-primary);
}

.train-panel__next-stop-time {
    font-size: 13px;
    color: var(--popup-text-secondary);
    margin-top: 4px;
}

/* Mobile Bottom Sheet */
@media (max-width: 768px) {
    .train-panel__sheet {
        top: auto;
        bottom: 0;
        left: 0;
        right: 0;
        width: 100%;
        height: auto;
        max-height: min(75vh, 560px);
        border-left: none;
        border-top: 1px solid var(--popup-border);
        border-radius: 20px 20px 0 0;
        box-shadow: 0 -8px 32px -12px var(--popup-shadow);
        transform: translateY(110%);
    }

    .train-panel.is-open .train-panel__sheet {
        transform: translateY(0);
    }

    .train-panel__handle {
        display: block;
        width: 40px;
        height: 4px;
        background: var(--popup-border-strong);
        border-radius: 999px;
        margin: 10px auto 6px;
    }

    .train-panel__close {
        top: 12px;
        right: 12px;
        width: 36px;
        height: 36px;
    }

    .train-panel__content {
        padding: 20px;
        padding-top: 48px;
        padding-bottom: calc(20px + env(safe-area-inset-bottom, 0px));
    }
}

/* ═══════════════════════════════════════════════════════════════════════
   SCHEDULE PANEL MODERN
   Desktop: Right side panel | Mobile: Bottom sheet
   ═══════════════════════════════════════════════════════════════════════ */
.schedule-panel-modern {
    position: fixed;
    inset: 0;
    z-index: 1200;
    pointer-events: none;
    display: flex;
    visibility: hidden;
}

.schedule-panel-modern.is-open {
    visibility: visible;
    pointer-events: auto;
}

.schedule-panel-modern__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.25);
    opacity: 0;
    transition: opacity 0.3s ease;
}

.schedule-panel-modern.is-open .schedule-panel-modern__backdrop {
    opacity: 1;
}

.schedule-panel-modern__sheet {
    position: absolute;
    top: 0;
    right: 0;
    width: min(520px, 95vw);
    height: 100%;
    background: linear-gradient(180deg, var(--popup-bg-secondary) 0%, var(--popup-bg-primary) 100%);
    border-left: 1px solid var(--popup-border);
    box-shadow: -12px 0 48px -16px rgba(0, 0, 0, 0.35);
    transform: translateX(105%);
    transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    pointer-events: auto;
}

.schedule-panel-modern.is-open .schedule-panel-modern__sheet {
    transform: translateX(0);
}

.schedule-panel-modern__handle {
    display: none;
}

.schedule-panel-modern__close {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 1px solid var(--popup-border);
    background: var(--popup-bg-tertiary);
    color: var(--popup-text-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 10;
    transition: all 0.2s ease;
    box-shadow: 0 4px 12px -4px rgba(0, 0, 0, 0.15);
}

.schedule-panel-modern__close:hover,
.schedule-panel-modern__close:focus-visible {
    transform: scale(1.08);
    background: var(--popup-error);
    color: #fff;
    border-color: transparent;
    outline: none;
}

.schedule-panel-modern__content {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 28px;
    padding-top: 24px;
    -webkit-overflow-scrolling: touch;
}

/* Hero Section - Train Info */
.schedule-panel-modern__hero {
    background: linear-gradient(135deg, var(--popup-chip-bg) 0%, var(--popup-bg-tertiary) 100%);
    border: 1px solid var(--popup-border);
    border-radius: 20px;
    padding: 24px;
    margin-bottom: 20px;
    box-shadow: 0 8px 32px -16px rgba(0, 0, 0, 0.12);
}

.schedule-panel-modern__hero-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    flex-direction: column;
    gap: 14px;
    margin-bottom: 20px;
}

.schedule-panel-modern__hero-title {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.schedule-panel-modern__train-row {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.schedule-panel-modern__train-name {
    font-size: clamp(1.25rem, 1.1rem + 0.8vw, 1.5rem);
    font-weight: 800;
    color: var(--popup-text-primary);
    margin: 0;
    letter-spacing: -0.02em;
}

.schedule-panel-modern__delay-badge {
    display: inline-flex;
    align-items: center;
    padding: 6px 14px;
    border-radius: 999px;
    font-size: 14px;
    font-weight: 700;
    white-space: nowrap;
    box-shadow: 0 2px 8px -2px rgba(0, 0, 0, 0.15);
}

.schedule-panel-modern__delay-badge--ontime {
    background: linear-gradient(135deg, rgba(16, 185, 129, 0.2) 0%, rgba(16, 185, 129, 0.1) 100%);
    color: var(--popup-success);
    border: 1px solid rgba(16, 185, 129, 0.35);
}

.schedule-panel-modern__delay-badge--late-5 {
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.2) 0%, rgba(245, 158, 11, 0.1) 100%);
    color: var(--popup-warning);
    border: 1px solid rgba(245, 158, 11, 0.35);
}

.schedule-panel-modern__delay-badge--late-15 {
    background: linear-gradient(135deg, rgba(239, 68, 68, 0.2) 0%, rgba(239, 68, 68, 0.1) 100%);
    color: var(--popup-error);
    border: 1px solid rgba(239, 68, 68, 0.35);
}

.schedule-panel-modern__delay-badge--early {
    background: linear-gradient(135deg, rgba(14, 165, 233, 0.2) 0%, rgba(14, 165, 233, 0.1) 100%);
    color: var(--popup-info);
    border: 1px solid rgba(14, 165, 233, 0.35);
}

.schedule-panel-modern__route {
    font-size: 15px;
    color: var(--popup-text-secondary);
    display: flex;
    align-items: center;
    gap: 8px;
}

.schedule-panel-modern__route-arrow {
    color: var(--popup-accent-primary);
    font-weight: 600;
}

/* Stats Grid */
.schedule-panel-modern__stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}

.schedule-panel-modern__stat {
    padding: 14px;
    border-radius: 14px;
    background: var(--popup-bg-primary);
    border: 1px solid var(--popup-border);
    text-align: center;
}

.schedule-panel-modern__stat-label {
    font-size: 11px;
    color: var(--popup-text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 6px;
}

.schedule-panel-modern__stat-value {
    font-size: 16px;
    font-weight: 700;
    color: var(--popup-text-primary);
}

/* Action Buttons */
.schedule-panel-modern__actions {
    display: flex;
    gap: 12px;
    margin-bottom: 20px;
}

.schedule-panel-modern__action-btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 18px;
    border-radius: 14px;
    border: 1px solid var(--popup-border);
    background: var(--popup-bg-tertiary);
    color: var(--popup-text-primary);
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
    min-height: 48px;
}

.schedule-panel-modern__action-btn:hover,
.schedule-panel-modern__action-btn:focus-visible {
    background: var(--popup-chip-bg);
    border-color: var(--popup-accent-primary);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px -4px rgba(0, 0, 0, 0.15);
    outline: none;
}

.schedule-panel-modern__action-btn .material-symbols-outlined {
    font-size: 18px;
    color: var(--popup-accent-primary);
}

/* Stops List */
.schedule-panel-modern__stops {
    border-radius: 16px;
    overflow: hidden;
}

.schedule-panel-modern__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

/* Individual Stop Items - Enhanced */
.schedule-panel-modern .schedule-item {
    background: var(--popup-bg-tertiary);
    border: 1px solid var(--popup-border);
    border-radius: 16px;
    padding: 16px;
    transition: all 0.2s ease;
}

.schedule-panel-modern .schedule-item:hover {
    border-color: var(--popup-accent-primary);
    box-shadow: 0 4px 16px -8px rgba(0, 0, 0, 0.15);
}

.schedule-panel-modern .schedule-item.is-past {
    opacity: 0.6;
}

.schedule-panel-modern .schedule-stop-name {
    font-size: 16px;
    font-weight: 700;
    color: var(--popup-text-primary);
}

.schedule-panel-modern .schedule-delay-badge {
    padding: 4px 10px;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 700;
}

.schedule-panel-modern .schedule-times-grid {
    margin-top: 10px;
}

.schedule-panel-modern .time-block {
    background: var(--popup-bg-primary);
    border: 1px dashed var(--popup-border);
    border-radius: 10px;
    padding: 10px;
}

.schedule-panel-modern .schedule-connection {
    margin-top: 10px;
    background: var(--popup-bg-primary);
    border: 1px solid var(--popup-border);
    border-radius: 12px;
}

.schedule-panel-modern .schedule-connection-toggle {
    padding: 12px;
    font-size: 13px;
}

/* Alert Info Box */
.schedule-panel-modern .schedule-alert-info {
    margin: 0 0 16px 0;
    padding: 14px 16px;
    border-radius: 14px;
    background: linear-gradient(135deg, var(--warning-bg) 0%, rgba(245, 158, 11, 0.08) 100%);
    border: 1px solid var(--warning-border);
    color: var(--warning-text-color);
    font-size: 13px;
    line-height: 1.5;
}

/* Info Services Box */
.schedule-panel-modern .schedule-info-services {
    margin: 0 0 12px 0;
    padding: 10px 12px;
    border-radius: 12px;
    background: var(--popup-bg-tertiary);
    border: 1px solid var(--popup-border);
}

/* ML Toggle Button */
.schedule-panel-modern .schedule-ml-toggle {
    margin: 0 0 12px 0;
    border-radius: 14px;
    padding: 14px 16px;
}

.schedule-panel-modern .schedule-ml-card {
    border-radius: 14px;
    margin-bottom: 12px;
}

/* Mobile Bottom Sheet for Schedule Panel */
@media (max-width: 768px) {
    .schedule-panel-modern__sheet {
        top: auto;
        bottom: 0;
        left: 0;
        right: 0;
        width: 100%;
        height: auto;
        max-height: min(90vh, 720px);
        border-left: none;
        border-top: 1px solid var(--popup-border);
        border-radius: 24px 24px 0 0;
        box-shadow: 0 -12px 48px -16px rgba(0, 0, 0, 0.4);
        transform: translateY(105%);
    }

    .schedule-panel-modern.is-open .schedule-panel-modern__sheet {
        transform: translateY(0);
    }

    .schedule-panel-modern__handle {
        display: block;
        width: 48px;
        height: 5px;
        background: var(--popup-border-strong);
        border-radius: 999px;
        margin: 12px auto 8px;
    }

    .schedule-panel-modern__close {
        top: 14px;
        right: 14px;
        width: 40px;
        height: 40px;
    }

    .schedule-panel-modern__content {
        padding: 20px;
        padding-top: 16px;
        padding-bottom: calc(28px + env(safe-area-inset-bottom, 0px));
    }

    .schedule-panel-modern__hero {
        padding: 20px;
        border-radius: 16px;
    }

    .schedule-panel-modern__stats {
        grid-template-columns: repeat(2, 1fr);
    }

    .schedule-panel-modern__actions {
        flex-direction: column;
    }

    .schedule-panel-modern__action-btn {
        min-height: 48px;
    }

    .journey-progress__action-btn {
        width: 44px;
        height: 44px;
    }

    .schedule-connection-toggle {
        min-height: 44px;
    }
}

/* ═══════════════════════════════════════════════════════════════════════════════
   JOURNEY PROGRESS CARD - Modern Train Journey Visualization
   Apple-inspired design with visual progress and highlighted next stop
   ═══════════════════════════════════════════════════════════════════════════════ */

.journey-progress {
    background: linear-gradient(135deg, var(--popup-bg-secondary) 0%, var(--popup-bg-primary) 100%);
    border: 1px solid var(--popup-border);
    border-radius: 20px;
    padding: 24px;
    margin-bottom: 20px;
    box-shadow: 0 8px 32px -12px rgba(0, 0, 0, 0.12);
}

.journey-progress__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 20px;
}

.journey-progress__title-section {
    flex: 1;
    min-width: 0;
}

.journey-progress__train-name {
    font-size: clamp(1.2rem, 1rem + 0.8vw, 1.5rem);
    font-weight: 800;
    color: var(--popup-text-primary);
    margin: 0 0 4px 0;
    letter-spacing: -0.02em;
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.journey-progress__route {
    font-size: 14px;
    color: var(--popup-text-secondary);
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 4px;
}

.journey-progress__route-arrow {
    color: var(--popup-accent-primary);
    font-weight: 600;
}

.journey-progress__actions {
    display: flex;
    gap: 8px;
}

.journey-progress__action-btn {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1px solid var(--popup-border);
    background: var(--popup-bg-tertiary);
    color: var(--popup-text-secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s ease;
}

.journey-progress__action-btn:hover,
.journey-progress__action-btn:focus-visible {
    background: var(--popup-chip-bg);
    color: var(--popup-accent-primary);
    border-color: var(--popup-accent-primary);
    transform: scale(1.05);
    outline: none;
}

.journey-progress__action-btn.is-active {
    background: var(--popup-accent-primary);
    color: #fff;
    border-color: transparent;
}

/* Progress Bar */
.journey-progress__bar-container {
    margin-bottom: 24px;
}

.journey-progress__bar-labels {
    display: flex;
    justify-content: space-between;
    margin-bottom: 8px;
    font-size: 11px;
    color: var(--popup-text-tertiary);
}

.journey-progress__bar {
    position: relative;
    height: 10px;
    background: var(--popup-bg-tertiary);
    border-radius: 5px;
    overflow: visible;
}

.journey-progress__bar-fill {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    background: linear-gradient(90deg, var(--popup-accent-primary), var(--popup-accent-secondary));
    border-radius: 5px;
    transition: width 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.journey-progress__bar-marker {
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 16px;
    height: 16px;
    background: var(--popup-accent-primary);
    border: 3px solid var(--popup-bg-primary);
    border-radius: 50%;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
    z-index: 2;
}

.journey-progress__bar-percent {
    position: absolute;
    right: 0;
    top: -24px;
    font-size: 12px;
    font-weight: 700;
    color: var(--popup-accent-primary);
}

/* Next Stop Highlight Card */
.journey-progress__next-stop {
    background: linear-gradient(135deg, var(--popup-chip-bg) 0%, rgba(102, 126, 234, 0.08) 100%);
    border: 1px solid rgba(102, 126, 234, 0.25);
    border-radius: 16px;
    padding: 20px;
    margin-bottom: 20px;
}

.journey-progress__next-stop-label {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--popup-accent-primary);
    margin-bottom: 10px;
}

.journey-progress__next-stop-content {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
    flex-wrap: wrap;
}

.journey-progress__next-stop-info {
    flex: 1;
    min-width: 140px;
}

.journey-progress__next-stop-name {
    font-size: 20px;
    font-weight: 700;
    color: var(--popup-text-primary);
    margin-bottom: 6px;
}

.journey-progress__next-stop-time {
    font-size: 13px;
    color: var(--popup-text-secondary);
    display: flex;
    align-items: center;
    gap: 8px;
}

.journey-progress__next-stop-platform {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    background: var(--popup-accent-primary);
    color: #fff;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 700;
}

.journey-progress__next-stop-eta {
    text-align: right;
}

.journey-progress__eta-value {
    font-size: 24px;
    font-weight: 800;
    color: var(--popup-text-primary);
    line-height: 1;
}

.journey-progress__eta-label {
    font-size: 11px;
    color: var(--popup-text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* Remaining Stops Carousel */
.journey-progress__remaining {
    margin-top: 8px;
}

.journey-progress__remaining-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.journey-progress__remaining-title {
    font-size: 12px;
    font-weight: 700;
    color: var(--popup-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.journey-progress__remaining-toggle {
    font-size: 12px;
    color: var(--popup-accent-primary);
    background: none;
    border: none;
    cursor: pointer;
    font-weight: 600;
    padding: 4px 8px;
    border-radius: 6px;
    transition: background 0.2s ease;
}

.journey-progress__remaining-toggle:hover {
    background: var(--popup-chip-bg);
}

.journey-progress__stops-carousel {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 8px;
    margin: 0 -4px;
    padding: 4px;
}

.journey-progress__stops-carousel::-webkit-scrollbar {
    height: 4px;
}

.journey-progress__stops-carousel::-webkit-scrollbar-track {
    background: var(--popup-bg-tertiary);
    border-radius: 2px;
}

.journey-progress__stops-carousel::-webkit-scrollbar-thumb {
    background: var(--popup-border-strong);
    border-radius: 2px;
}

.journey-progress__stop-chip {
    flex-shrink: 0;
    scroll-snap-align: start;
    background: var(--popup-bg-tertiary);
    border: 1px solid var(--popup-border);
    border-radius: 12px;
    padding: 12px 16px;
    min-width: 110px;
    max-width: 140px;
    transition: all 0.2s ease;
}

.journey-progress__stop-chip:hover {
    border-color: var(--popup-accent-primary);
    box-shadow: 0 4px 12px -4px rgba(0, 0, 0, 0.1);
}

.journey-progress__stop-chip-name {
    font-size: 12px;
    font-weight: 600;
    color: var(--popup-text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-bottom: 4px;
}

.journey-progress__stop-chip-time {
    font-size: 11px;
    color: var(--popup-text-secondary);
    display: flex;
    align-items: center;
    gap: 6px;
}

/* Delay Indicator Pills */
.delay-pill {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 8px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
}

.delay-pill--ontime {
    background: rgba(16, 185, 129, 0.15);
    color: var(--popup-success);
}

.delay-pill--minor {
    background: rgba(245, 158, 11, 0.15);
    color: var(--popup-warning);
}

.delay-pill--major {
    background: rgba(239, 68, 68, 0.15);
    color: var(--popup-error);
}

.delay-pill--early {
    background: rgba(14, 165, 233, 0.15);
    color: var(--popup-info);
}

/* ═══════════════════════════════════════════════════════════════════════════════
   SMART CONNECTION ADVISOR - Intelligent Transfer Recommendations
   Color-coded cards with probability visualization and alternatives
   ═══════════════════════════════════════════════════════════════════════════════ */

.connection-advisor {
    margin-top: 16px;
}

.connection-advisor__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
    padding: 0 4px;
}

.connection-advisor__title {
    font-size: 14px;
    font-weight: 700;
    color: var(--popup-text-primary);
    display: flex;
    align-items: center;
    gap: 8px;
}

.connection-advisor__title-icon {
    font-size: 18px;
}

.connection-advisor__badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    background: var(--popup-chip-bg);
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
    color: var(--popup-accent-primary);
}

/* Connection Cards */
.connection-card {
    position: relative;
    border-radius: 16px;
    padding: 20px;
    margin-bottom: 14px;
    border-left: 4px solid;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.connection-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px -8px rgba(0, 0, 0, 0.15);
}

.connection-card:last-child {
    margin-bottom: 0;
}

/* Connection Status Variants */
.connection-card--safe {
    background: linear-gradient(135deg, rgba(16, 185, 129, 0.08) 0%, rgba(16, 185, 129, 0.03) 100%);
    border-left-color: #10B981;
}

.connection-card--tight {
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.08) 0%, rgba(245, 158, 11, 0.03) 100%);
    border-left-color: #F59E0B;
}

.connection-card--risky {
    background: linear-gradient(135deg, rgba(239, 68, 68, 0.08) 0%, rgba(239, 68, 68, 0.03) 100%);
    border-left-color: #EF4444;
}

.connection-card__status-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 12px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 12px;
}

.connection-card--safe .connection-card__status-badge {
    background: rgba(16, 185, 129, 0.15);
    color: #059669;
}

.connection-card--tight .connection-card__status-badge {
    background: rgba(245, 158, 11, 0.15);
    color: #D97706;
}

.connection-card--risky .connection-card__status-badge {
    background: rgba(239, 68, 68, 0.15);
    color: #DC2626;
}

body[data-theme="dark"] .connection-card--safe .connection-card__status-badge {
    color: #34D399;
}

body[data-theme="dark"] .connection-card--tight .connection-card__status-badge {
    color: #FBBF24;
}

body[data-theme="dark"] .connection-card--risky .connection-card__status-badge {
    color: #F87171;
}

.connection-card__train-info {
    margin-bottom: 12px;
}

.connection-card__train-name {
    font-size: 15px;
    font-weight: 700;
    color: var(--popup-text-primary);
    margin-bottom: 2px;
}

.connection-card__destination {
    font-size: 13px;
    color: var(--popup-text-secondary);
    display: flex;
    align-items: center;
    gap: 6px;
}

.connection-card__destination-arrow {
    color: var(--popup-accent-primary);
}

/* Timing Grid */
.connection-card__timing {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    margin-bottom: 12px;
}

.connection-card__timing-item {
    text-align: center;
    padding: 12px 10px;
    background: var(--popup-bg-primary);
    border: 1px solid var(--popup-border);
    border-radius: 10px;
}

.connection-card__timing-label {
    font-size: 10px;
    color: var(--popup-text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 4px;
}

.connection-card__timing-value {
    font-size: 14px;
    font-weight: 700;
    color: var(--popup-text-primary);
}

/* Probability Bar */
.connection-card__probability {
    margin-bottom: 12px;
}

.connection-card__probability-bar {
    position: relative;
    height: 28px;
    background: var(--popup-bg-tertiary);
    border-radius: 14px;
    overflow: hidden;
}

.connection-card__probability-fill {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    border-radius: 14px;
    transition: width 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.connection-card--safe .connection-card__probability-fill {
    background: linear-gradient(90deg, #10B981, #34D399);
}

.connection-card--tight .connection-card__probability-fill {
    background: linear-gradient(90deg, #F59E0B, #FBBF24);
}

.connection-card--risky .connection-card__probability-fill {
    background: linear-gradient(90deg, #EF4444, #F87171);
}

.connection-card__probability-text {
    position: absolute;
    top: 50%;
    left: 12px;
    transform: translateY(-50%);
    font-size: 12px;
    font-weight: 700;
    color: #fff;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
    z-index: 1;
}

.connection-card__probability-percent {
    position: absolute;
    top: 50%;
    right: 12px;
    transform: translateY(-50%);
    font-size: 14px;
    font-weight: 800;
    color: var(--popup-text-primary);
}

/* Advice Section */
.connection-card__advice {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 10px 12px;
    background: var(--popup-bg-tertiary);
    border-radius: 10px;
    font-size: 12px;
    color: var(--popup-text-secondary);
    line-height: 1.4;
}

.connection-card__advice-icon {
    flex-shrink: 0;
    font-size: 16px;
}

/* Alternative Suggestion */
.connection-card__alternative {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 10px;
    padding: 10px 12px;
    background: linear-gradient(135deg, var(--popup-chip-bg) 0%, var(--popup-bg-tertiary) 100%);
    border: 1px dashed var(--popup-border);
    border-radius: 10px;
    font-size: 12px;
    color: var(--popup-text-primary);
    cursor: pointer;
    transition: all 0.2s ease;
}

.connection-card__alternative:hover {
    border-color: var(--popup-accent-primary);
    background: var(--popup-chip-bg);
}

.connection-card__alternative-icon {
    font-size: 16px;
    color: var(--popup-accent-primary);
}

.connection-card__alternative-text {
    flex: 1;
}

.connection-card__alternative-badge {
    padding: 3px 8px;
    background: rgba(16, 185, 129, 0.15);
    color: var(--popup-success);
    border-radius: 999px;
    font-size: 10px;
    font-weight: 700;
}

/* Empty State */
.connection-advisor__empty {
    text-align: center;
    padding: 32px 16px;
    background: var(--popup-bg-tertiary);
    border-radius: 16px;
    border: 1px dashed var(--popup-border);
}

.connection-advisor__empty-icon {
    font-size: 48px;
    margin-bottom: 12px;
    opacity: 0.5;
}

.connection-advisor__empty-text {
    font-size: 14px;
    color: var(--popup-text-secondary);
    margin-bottom: 4px;
}

.connection-advisor__empty-hint {
    font-size: 12px;
    color: var(--popup-text-tertiary);
}

/* ML Insight Box */
.connection-card__ml-insight {
    margin-top: 10px;
    padding: 10px 12px;
    background: linear-gradient(135deg, rgba(139, 92, 246, 0.08) 0%, rgba(139, 92, 246, 0.03) 100%);
    border: 1px solid rgba(139, 92, 246, 0.2);
    border-radius: 10px;
}

.connection-card__ml-insight-header {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #8B5CF6;
    margin-bottom: 6px;
}

body[data-theme="dark"] .connection-card__ml-insight-header {
    color: #A78BFA;
}

.connection-card__ml-insight-text {
    font-size: 12px;
    color: var(--popup-text-secondary);
    line-height: 1.4;
}

/* Station Map Link */
.connection-advisor__map-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    margin-top: 16px;
    background: var(--popup-bg-tertiary);
    border: 1px solid var(--popup-border);
    border-radius: 14px;
    cursor: pointer;
    transition: all 0.2s ease;
}

.connection-advisor__map-link:hover {
    border-color: var(--popup-accent-primary);
    background: var(--popup-chip-bg);
}

.connection-advisor__map-link-content {
    display: flex;
    align-items: center;
    gap: 10px;
}

.connection-advisor__map-link-icon {
    font-size: 20px;
    color: var(--popup-accent-primary);
}

.connection-advisor__map-link-text {
    font-size: 13px;
    font-weight: 600;
    color: var(--popup-text-primary);
}

.connection-advisor__map-link-arrow {
    font-size: 18px;
    color: var(--popup-text-tertiary);
}

/* Responsive Adjustments */
@media (max-width: 480px) {
    .connection-card__timing {
        grid-template-columns: 1fr;
        gap: 8px;
    }

    .connection-card__timing-item {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 8px 12px;
    }

    .connection-card__timing-label {
        margin-bottom: 0;
    }

    .journey-progress__next-stop-content {
        flex-direction: column;
    }

    .journey-progress__next-stop-eta {
        text-align: left;
        display: flex;
        align-items: baseline;
        gap: 8px;
    }
}

/* ==========================================================================
   2026 UI Redesign v3: Schedule Panel (high-specificity override)
   ========================================================================== */

#schedulePanel.schedule-panel-modern .schedule-panel-modern__backdrop {
    background: rgba(4, 10, 22, 0.58);
    backdrop-filter: blur(6px);
}

#schedulePanel.schedule-panel-modern .schedule-panel-modern__sheet {
    width: min(620px, 96vw);
    background:
        radial-gradient(120% 90% at 98% 0%, rgba(47, 109, 255, 0.14), transparent 62%),
        linear-gradient(180deg, var(--popup-bg-secondary) 0%, var(--popup-bg-primary) 100%);
    border-left: 1px solid var(--popup-border);
    box-shadow: -20px 0 70px -34px rgba(0, 0, 0, 0.55);
}

#schedulePanel .schedule-panel-modern__content {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 12px;
    padding-top: 10px;
    padding-bottom: calc(16px + env(safe-area-inset-bottom, 0px));
}

#schedulePanel .schedule-panel-modern__hero {
    position: sticky;
    top: 0;
    z-index: 6;
    margin: 0;
    padding: 12px;
    border-radius: 14px;
    border: 1px solid var(--popup-border);
    background: linear-gradient(160deg, var(--popup-bg-primary), var(--popup-bg-tertiary));
    box-shadow: 0 10px 24px -18px rgba(0, 0, 0, 0.4);
}

#schedulePanel .schedule-v2-hero-top {
    gap: 8px;
    margin-bottom: 8px;
}

#schedulePanel .schedule-panel-modern__hero-header {
    gap: 6px;
}

#schedulePanel .schedule-panel-modern__train-name {
    font-size: clamp(1.05rem, 0.96rem + 0.5vw, 1.25rem);
    letter-spacing: -0.015em;
}

#schedulePanel .schedule-panel-modern__delay-badge {
    padding: 5px 10px;
    font-size: 12px;
    border-radius: 999px;
}

#schedulePanel .schedule-panel-modern__route {
    font-size: 12px;
    line-height: 1.35;
}

#schedulePanel .schedule-v2-meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

#schedulePanel .schedule-v2-meta-chip {
    width: auto;
    max-width: 100%;
    padding: 4px 8px;
    font-size: 10px;
}

#schedulePanel .schedule-v2-meta-chip .material-symbols-outlined {
    font-size: 13px;
}

#schedulePanel .schedule-v2-stats {
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: 6px;
}

#schedulePanel .schedule-panel-modern__stat {
    padding: 8px 9px;
    border-radius: 10px;
}

#schedulePanel .schedule-panel-modern__stat-label {
    font-size: 9px;
    margin-bottom: 2px;
}

#schedulePanel .schedule-panel-modern__stat-value {
    font-size: 12px;
    line-height: 1.25;
}

#schedulePanel .schedule-panel-modern__actions {
    margin: 0;
    gap: 6px;
    grid-template-columns: 1fr 1fr;
}

#schedulePanel .schedule-panel-modern__action-btn {
    min-height: 38px;
    padding: 8px 10px;
    border-radius: 10px;
    font-size: 11px;
    font-weight: 700;
}

#schedulePanel .schedule-panel-modern__action-btn .material-symbols-outlined {
    font-size: 16px;
}

#schedulePanel #resultsWrap {
    max-height: none;
    overflow: visible;
    padding: 0;
    background: transparent;
    border: none;
    box-shadow: none;
}

#schedulePanel .schedule-panel-modern__stops {
    border-radius: 0;
}

#schedulePanel .schedule-panel-modern__list {
    gap: 12px;
}

#schedulePanel .schedule-item {
    grid-template-columns: 14px 1fr;
    gap: 8px;
    padding: 8px;
    border-radius: 12px;
    border: 1px solid var(--popup-border);
    background: linear-gradient(160deg, var(--popup-bg-primary), var(--popup-bg-tertiary));
    box-shadow: 0 6px 16px -14px rgba(0, 0, 0, 0.34);
}

#schedulePanel .schedule-item.is-past {
    opacity: 0.7;
}

#schedulePanel .schedule-item--next {
    border-color: rgba(47, 109, 255, 0.45);
    box-shadow: 0 10px 20px -14px rgba(47, 109, 255, 0.38);
}

#schedulePanel .schedule-timeline {
    min-width: 14px;
}

#schedulePanel .schedule-rail {
    top: 10px;
    width: 2px;
}

#schedulePanel .schedule-node {
    width: 10px;
    height: 10px;
    border-width: 2px;
}

#schedulePanel .schedule-card {
    gap: 8px;
    padding: 6px;
    border-radius: 10px;
}

#schedulePanel .schedule-card__header {
    gap: 8px;
    align-items: center;
}

#schedulePanel .schedule-card__title {
    gap: 4px;
}

#schedulePanel .schedule-stop-name {
    font-size: 13px;
    font-weight: 700;
    line-height: 1.3;
}

#schedulePanel .schedule-platform-chip {
    padding: 3px 7px;
    border-radius: 999px;
    font-size: 10px;
}

#schedulePanel .schedule-delay-badge {
    padding: 4px 8px;
    border-radius: 999px;
    font-size: 10px;
}

#schedulePanel .schedule-times-grid {
    grid-template-columns: 1fr;
    gap: 6px;
    margin-top: 0;
}

#schedulePanel .time-block {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 7px 8px;
    border-radius: 9px;
    border-style: solid;
}

#schedulePanel .time-label {
    font-size: 9px;
    letter-spacing: 0.07em;
    min-width: 44px;
}

#schedulePanel .time-values {
    margin-left: auto;
    gap: 5px;
    font-size: 12px;
    font-weight: 600;
}

#schedulePanel .schedule-state {
    font-size: 10px;
    margin-top: -1px;
}

#schedulePanel .schedule-connection {
    margin-top: 0;
    gap: 8px;
    padding: 8px;
    border-radius: 10px;
    border-style: solid;
    background: var(--popup-bg-primary);
}

#schedulePanel .schedule-connection-toggle {
    min-height: 34px;
    align-items: flex-start;
}

#schedulePanel .schedule-connection-toggle .toggle-label {
    font-size: 12px;
}

#schedulePanel .schedule-connection-toggle .toggle-meta {
    font-size: 10px;
    line-height: 1.3;
}

#schedulePanel .schedule-connection-summary,
#schedulePanel .connection-meta {
    font-size: 10px;
}

#schedulePanel .connection-title {
    font-size: 12px;
}

#schedulePanel .probability-pill {
    font-size: 10px;
    padding: 3px 7px;
}

#schedulePanel .schedule-alert-info,
#schedulePanel .schedule-info-services,
#schedulePanel .schedule-ml-toggle,
#schedulePanel .schedule-ml-card {
    margin: 0;
    border-radius: 11px;
}

#schedulePanel .schedule-alert-info {
    padding: 10px 12px;
    font-size: 11px;
}

#schedulePanel .schedule-info-services {
    padding: 9px 10px;
}

#schedulePanel .schedule-info-services__title {
    font-size: 11px;
    margin-bottom: 6px;
    display: flex;
    align-items: center;
    gap: 6px;
}

#schedulePanel .schedule-info-services__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 5px;
}

#schedulePanel .schedule-info-services__item {
    font-size: 11px;
    display: flex;
    align-items: center;
    gap: 7px;
}

#schedulePanel .schedule-ml-toggle {
    min-height: 36px;
    padding: 9px 10px;
    font-size: 11px;
}

#schedulePanel .schedule-ml-card {
    padding: 9px;
}

@media (max-width: 768px) {
    #schedulePanel.schedule-panel-modern .schedule-panel-modern__sheet {
        top: auto;
        bottom: 0;
        left: 0;
        right: 0;
        width: 100%;
        max-height: min(92dvh, 760px);
        border-left: none;
        border-top: 1px solid var(--popup-border);
        border-radius: 18px 18px 0 0;
        transform: translateY(105%);
    }

    #schedulePanel .schedule-panel-modern__content {
        padding: 10px;
        padding-top: 8px;
        padding-bottom: calc(14px + env(safe-area-inset-bottom, 0px));
    }

    #schedulePanel .schedule-panel-modern__actions {
        grid-template-columns: 1fr;
    }

    #schedulePanel .schedule-v2-stats {
        grid-template-columns: 1fr 1fr;
    }
}

/* ==========================================================================
   2026 UI Redesign: Popup + Schedule Panel (data-preserving visual overhaul)
   ========================================================================== */

.leaflet-popup-content-wrapper {
    border-radius: 20px !important;
    overflow: hidden;
}

.leaflet-popup-content {
    margin: 0 !important;
    min-width: 250px;
}

.leaflet-popup .popup-card {
    display: grid;
    gap: 12px;
    padding: 14px;
    min-width: 250px;
    background: linear-gradient(165deg, var(--popup-bg-primary) 0%, var(--popup-bg-secondary) 100%);
}

.leaflet-popup .popup-card--tooltip {
    padding: 10px 12px;
    min-width: 200px;
}

.popup-headline {
    padding: 12px;
    border-radius: 14px;
    border: 1px solid var(--popup-border);
    background: linear-gradient(145deg, var(--popup-bg-primary) 0%, var(--popup-bg-tertiary) 100%);
}

.popup-header__titles {
    gap: 8px;
}

.popup-title-row {
    align-items: baseline;
    gap: 8px;
}

.popup-title {
    font-size: clamp(1rem, 0.95rem + 0.35vw, 1.15rem);
    letter-spacing: -0.02em;
}

.popup-subtitle {
    font-size: 12px;
    line-height: 1.45;
}

.popup-kpi-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.popup-kpi {
    display: grid;
    gap: 4px;
    padding: 9px 10px;
    border-radius: 12px;
    border: 1px solid var(--popup-border);
    background: var(--popup-bg-primary);
}

.popup-kpi--muted {
    background: var(--popup-chip-muted-bg);
}

.popup-kpi--ml {
    grid-column: 1 / -1;
    background: linear-gradient(150deg, var(--popup-chip-bg), var(--popup-bg-tertiary));
    border-color: var(--popup-chip-border);
}

.popup-kpi__label {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--popup-text-tertiary);
}

.popup-kpi__value {
    font-size: 13px;
    font-weight: 700;
    color: var(--popup-text-primary);
    line-height: 1.25;
}

.popup-gps-stale {
    border-radius: 12px;
    padding: 10px 12px;
    font-size: 12px;
    margin: 0;
}

.popup-next-stop {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border-radius: 12px;
    background: var(--popup-bg-tertiary);
    border: 1px solid var(--popup-border);
}

.popup-next-stop__content {
    min-width: 0;
    display: grid;
    gap: 2px;
}

.popup-next-stop__icon {
    width: 30px;
    height: 30px;
    border-radius: 10px;
    font-size: 17px;
}

.popup-next-stop__value {
    font-size: 12px;
    line-height: 1.35;
}

.popup-schedule-btn {
    margin-top: 2px;
    border-radius: 12px;
    min-height: 42px;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.01em;
}

.popup-card--tooltip .popup-kpi-grid {
    grid-template-columns: 1fr;
}

.popup-card--tooltip .popup-kpi--ml,
.popup-card--tooltip .popup-schedule-btn,
.popup-card--tooltip .popup-gps-stale,
.popup-card--tooltip .popup-next-stop {
    display: none;
}

.schedule-panel-modern__backdrop {
    background: rgba(5, 13, 28, 0.46);
    backdrop-filter: blur(4px);
}

.schedule-panel-modern__sheet {
    width: min(560px, 96vw);
    background:
        radial-gradient(120% 85% at 100% 0%, rgba(79, 132, 255, 0.13), transparent 62%),
        linear-gradient(180deg, var(--popup-bg-secondary) 0%, var(--popup-bg-primary) 100%);
    border-left: 1px solid var(--popup-border);
    box-shadow: -24px 0 80px -34px rgba(0, 0, 0, 0.5);
}

.schedule-panel-modern__content {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 18px;
    padding-top: 16px;
    padding-bottom: calc(22px + env(safe-area-inset-bottom, 0px));
}

.schedule-panel-modern__hero {
    position: sticky;
    top: 0;
    z-index: 5;
    margin: 0;
    padding: 14px;
    border-radius: 16px;
    border: 1px solid var(--popup-border);
    background: linear-gradient(160deg, var(--popup-bg-primary), var(--popup-bg-tertiary));
    box-shadow: 0 14px 34px -26px rgba(0, 0, 0, 0.45);
}

.schedule-v2-hero-top {
    display: grid;
    gap: 10px;
    margin-bottom: 10px;
}

.schedule-panel-modern__hero-header {
    display: grid;
    gap: 8px;
    margin: 0;
}

.schedule-panel-modern__train-row {
    gap: 10px;
}

.schedule-panel-modern__train-name {
    font-size: clamp(1.15rem, 1.02rem + 0.6vw, 1.4rem);
}

.schedule-panel-modern__route {
    font-size: 13px;
    color: var(--popup-text-secondary);
}

.schedule-v2-meta-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 6px;
}

.schedule-v2-meta-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    width: fit-content;
    max-width: 100%;
    padding: 5px 10px;
    border-radius: 999px;
    border: 1px solid var(--popup-chip-border);
    background: var(--popup-chip-bg);
    color: var(--popup-text-primary);
    font-size: 11px;
    font-weight: 600;
    line-height: 1.3;
}

.schedule-v2-meta-chip .material-symbols-outlined {
    font-size: 15px;
    color: var(--popup-accent-primary);
}

.schedule-v2-meta-chip--muted {
    background: var(--popup-chip-muted-bg);
    border-color: transparent;
    color: var(--popup-text-secondary);
}

.schedule-v2-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.schedule-panel-modern__stat {
    padding: 10px 11px;
    border-radius: 12px;
    border: 1px solid var(--popup-border);
    background: var(--popup-bg-primary);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.22);
}

.schedule-panel-modern__stat-label {
    font-size: 10px;
    margin-bottom: 3px;
}

.schedule-panel-modern__stat-value {
    font-size: 13px;
}

.schedule-panel-modern__actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    margin: 0;
}

.schedule-panel-modern__action-btn {
    min-height: 42px;
    padding: 10px 12px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 700;
}

#schedulePanel #resultsWrap {
    max-height: none;
    overflow: visible;
    padding: 0;
    background: transparent;
    border: none;
    box-shadow: none;
}

.schedule-panel-modern__stops {
    border-radius: 0;
}

.schedule-panel-modern__list {
    gap: 8px;
}

.schedule-panel-modern .schedule-item {
    border-radius: 14px;
    padding: 10px;
    border: 1px solid var(--popup-border);
    background: linear-gradient(160deg, var(--popup-bg-primary), var(--popup-bg-tertiary));
    box-shadow: 0 10px 24px -20px rgba(0, 0, 0, 0.3);
}

.schedule-panel-modern .schedule-item:hover {
    transform: translateY(-1px);
    box-shadow: 0 16px 28px -22px rgba(0, 0, 0, 0.38);
}

.schedule-panel-modern .schedule-item--next .schedule-card {
    border-color: rgba(47, 109, 255, 0.36);
    background: linear-gradient(160deg, rgba(47, 109, 255, 0.08), rgba(106, 168, 255, 0.06));
}

.schedule-panel-modern .schedule-node {
    width: 12px;
    height: 12px;
    border-width: 2px;
}

.schedule-panel-modern .schedule-rail {
    top: 12px;
}

.schedule-panel-modern .schedule-card {
    gap: 10px;
    border: 1px solid transparent;
    border-radius: 12px;
    padding: 8px;
}

.schedule-panel-modern .schedule-card__header {
    gap: 8px;
}

.schedule-panel-modern .schedule-stop-name {
    font-size: 14px;
    letter-spacing: -0.01em;
}

.schedule-panel-modern .schedule-delay-badge {
    padding: 5px 9px;
    border-radius: 999px;
    font-size: 11px;
}

.schedule-panel-modern .schedule-times-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin-top: 0;
}

.schedule-panel-modern .time-block {
    border-radius: 10px;
    padding: 9px 10px;
    border-style: solid;
    background: var(--popup-bg-primary);
}

.schedule-panel-modern .time-label {
    font-size: 9px;
}

.schedule-panel-modern .time-values {
    font-size: 13px;
}

.schedule-panel-modern .schedule-state {
    font-size: 11px;
}

.schedule-panel-modern .schedule-connection {
    margin-top: 2px;
    padding: 10px;
    border-radius: 11px;
    border-style: solid;
    background: var(--popup-bg-primary);
}

.schedule-panel-modern .schedule-connection-toggle {
    min-height: 42px;
}

.schedule-panel-modern .schedule-alert-info,
.schedule-panel-modern .schedule-info-services,
.schedule-panel-modern .schedule-ml-toggle,
.schedule-panel-modern .schedule-ml-card {
    margin: 0;
    border-radius: 12px;
}

.schedule-panel-modern .schedule-alert-info {
    padding: 12px 14px;
    font-size: 12px;
}

.schedule-panel-modern .schedule-info-services {
    padding: 10px 12px;
}

.schedule-panel-modern .schedule-info-services__title {
    font-size: 12px;
    font-weight: 700;
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    gap: 6px;
}

.schedule-panel-modern .schedule-info-services__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 6px;
}

.schedule-panel-modern .schedule-info-services__item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
}

.schedule-panel-modern .schedule-info-services__icon {
    font-size: 14px;
}

.schedule-panel-modern .schedule-ml-toggle {
    min-height: 42px;
    padding: 10px 12px;
    font-size: 12px;
}

.schedule-panel-modern .schedule-ml-card {
    padding: 10px;
}

@media (max-width: 768px) {
    .leaflet-popup .popup-card {
        min-width: 228px;
        padding: 12px;
        gap: 10px;
    }

    .popup-kpi-grid {
        grid-template-columns: 1fr;
    }

    .schedule-panel-modern__sheet {
        top: auto;
        bottom: 0;
        left: 0;
        right: 0;
        width: 100%;
        max-height: min(92dvh, 760px);
        border-left: none;
        border-top: 1px solid var(--popup-border);
        border-radius: 22px 22px 0 0;
        transform: translateY(105%);
    }

    .schedule-panel-modern__content {
        padding: 20px;
        padding-top: 16px;
        padding-bottom: calc(20px + env(safe-area-inset-bottom, 0px));
    }

    .schedule-panel-modern__hero {
        top: 0;
    }

    .schedule-panel-modern__actions,
    .schedule-v2-stats {
        grid-template-columns: 1fr;
    }
}

/* ==========================================================================
   2026 Schedule Panel Redesign v6
   Dedicated light/dark theme just for the detailed timetable panel
   ========================================================================== */

#schedulePanel.schedule-panel-modern--v4 {
    --schedule-backdrop: rgba(16, 22, 36, 0.34);
    --schedule-sheet-bg: linear-gradient(180deg, rgba(250, 252, 255, 0.94), rgba(241, 245, 251, 0.98));
    --schedule-surface-1: rgba(255, 255, 255, 0.92);
    --schedule-surface-2: rgba(248, 250, 254, 0.88);
    --schedule-surface-3: rgba(237, 242, 250, 0.88);
    --schedule-border: rgba(91, 109, 142, 0.18);
    --schedule-border-strong: rgba(91, 109, 142, 0.28);
    --schedule-text: #182033;
    --schedule-text-soft: rgba(24, 32, 51, 0.72);
    --schedule-text-faint: rgba(24, 32, 51, 0.46);
    --schedule-accent: #1473e6;
    --schedule-accent-strong: #0059c7;
    --schedule-shadow: rgba(10, 18, 35, 0.18);
    --schedule-success-bg: rgba(16, 185, 129, 0.14);
    --schedule-success-text: #047857;
    --schedule-warning-bg: rgba(245, 158, 11, 0.14);
    --schedule-warning-text: #b45309;
    --schedule-danger-bg: rgba(239, 68, 68, 0.14);
    --schedule-danger-text: #b91c1c;
    --schedule-early-bg: rgba(14, 165, 233, 0.14);
    --schedule-early-text: #0369a1;
    --popup-bg-primary: var(--schedule-surface-1);
    --popup-bg-secondary: var(--schedule-surface-2);
    --popup-bg-tertiary: var(--schedule-surface-3);
    --popup-chip-bg: rgba(20, 115, 230, 0.1);
    --popup-chip-muted-bg: rgba(24, 32, 51, 0.06);
    --popup-border: var(--schedule-border);
    --popup-border-strong: var(--schedule-border-strong);
    --popup-text-primary: var(--schedule-text);
    --popup-text-secondary: var(--schedule-text-soft);
    --popup-text-tertiary: var(--schedule-text-faint);
    --popup-accent-primary: var(--schedule-accent);
    --popup-accent-secondary: #63b3ff;
    --popup-shadow: var(--schedule-shadow);
    --popup-success: var(--schedule-success-text);
    --popup-warning: var(--schedule-warning-text);
    --popup-error: var(--schedule-danger-text);
    --popup-info: var(--schedule-early-text);
}

body[data-theme="dark"] #schedulePanel.schedule-panel-modern--v4 {
    --schedule-backdrop: rgba(3, 7, 14, 0.56);
    --schedule-sheet-bg: linear-gradient(180deg, rgba(11, 13, 19, 0.96), rgba(17, 20, 28, 0.985));
    --schedule-surface-1: rgba(20, 23, 31, 0.92);
    --schedule-surface-2: rgba(24, 28, 38, 0.9);
    --schedule-surface-3: rgba(30, 34, 46, 0.88);
    --schedule-border: rgba(255, 255, 255, 0.12);
    --schedule-border-strong: rgba(255, 255, 255, 0.22);
    --schedule-text: #f5f7fb;
    --schedule-text-soft: rgba(245, 247, 251, 0.74);
    --schedule-text-faint: rgba(245, 247, 251, 0.46);
    --schedule-accent: #0a84ff;
    --schedule-accent-strong: #3ea6ff;
    --schedule-shadow: rgba(0, 0, 0, 0.56);
    --schedule-success-bg: rgba(52, 211, 153, 0.16);
    --schedule-success-text: #6ee7b7;
    --schedule-warning-bg: rgba(251, 191, 36, 0.16);
    --schedule-warning-text: #fcd34d;
    --schedule-danger-bg: rgba(248, 113, 113, 0.16);
    --schedule-danger-text: #fca5a5;
    --schedule-early-bg: rgba(96, 165, 250, 0.16);
    --schedule-early-text: #93c5fd;
    --popup-chip-bg: rgba(10, 132, 255, 0.14);
    --popup-chip-muted-bg: rgba(255, 255, 255, 0.06);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__backdrop {
    background: var(--schedule-backdrop);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__sheet {
    top: auto;
    right: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    height: auto;
    max-height: min(93dvh, 820px);
    border-left: none;
    border-top: 1px solid var(--schedule-border);
    border-radius: 28px 28px 0 0;
    transform: translateY(105%);
    background: var(--schedule-sheet-bg);
    backdrop-filter: blur(14px) saturate(125%);
    box-shadow: 0 -18px 56px -34px var(--schedule-shadow);
    color: var(--schedule-text);
}

#schedulePanel.schedule-panel-modern--v4.is-open .schedule-panel-modern__sheet {
    transform: translateY(0);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__handle {
    display: block;
    width: 84px;
    height: 6px;
    border-radius: 999px;
    margin: 12px auto 4px;
    background: var(--schedule-border-strong);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__close {
    position: absolute;
    top: 18px;
    right: 18px;
    width: 48px;
    height: 48px;
    border-radius: 16px;
    border: 1px solid var(--schedule-border);
    background: var(--schedule-surface-2);
    color: var(--schedule-text);
    box-shadow: 0 8px 20px -18px var(--schedule-shadow);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__close:hover,
#schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__close:focus-visible {
    background: var(--schedule-surface-3);
    color: var(--schedule-accent);
    border-color: var(--schedule-border-strong);
    transform: none;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__content {
    display: grid;
    grid-auto-rows: max-content;
    row-gap: 10px;
    padding: 14px;
    padding-top: 10px;
    padding-bottom: calc(16px + env(safe-area-inset-bottom, 0px));
}

#schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__content > * {
    margin: 0 !important;
    min-width: 0;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__hero {
    position: static !important;
    top: auto !important;
    z-index: auto !important;
    margin: 0;
    padding: 0;
    border: none;
    background: transparent;
    box-shadow: none;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__actions {
    order: -1;
    justify-self: end;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid var(--schedule-border);
    box-shadow: 0 10px 24px -24px var(--schedule-shadow);
    backdrop-filter: none;
}

body:not([data-theme="dark"]) #schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__actions {
    background: rgba(255, 255, 255, 0.72);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__action-btn {
    width: 46px;
    height: 46px;
    min-height: 46px;
    padding: 0;
    border-radius: 18px;
    border: none;
    background: transparent;
    color: var(--schedule-text-soft);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background-color 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__action-btn:hover,
#schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__action-btn:focus-visible {
    background: var(--popup-chip-bg);
    color: var(--schedule-accent);
    transform: none;
    outline: none;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__action-btn[disabled] {
    opacity: 0.45;
    cursor: not-allowed;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__action-btn .material-symbols-outlined {
    font-size: 25px;
    line-height: 1;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__action-btn.is-active {
    color: #f59e0b;
    background: rgba(245, 158, 11, 0.14);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-hero {
    padding: 15px 14px 14px;
    border-radius: 22px;
    border: 1px solid var(--schedule-border);
    background:
        radial-gradient(120% 140% at 50% -20%, rgba(20, 115, 230, 0.16), transparent 55%),
        linear-gradient(180deg, var(--schedule-surface-2), var(--schedule-surface-1));
    box-shadow: 0 16px 34px -30px var(--schedule-shadow);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-eyebrow {
    margin-bottom: 9px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--schedule-text-faint);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-title {
    margin: 0;
    font-size: clamp(1.34rem, 1.08rem + 0.72vw, 1.82rem);
    line-height: 1.06;
    font-weight: 800;
    letter-spacing: -0.04em;
    color: var(--schedule-text);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-route {
    margin-top: 8px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: var(--schedule-text-soft);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-route__arrow {
    color: var(--schedule-accent);
    font-weight: 700;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-summary {
    margin-top: 12px;
    display: grid;
    gap: 8px;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-summary__item {
    display: flex;
    align-items: center;
    gap: 6px;
    min-width: 0;
    padding: 6px 9px;
    border-radius: 12px;
    border: 1px solid var(--schedule-border);
    background: rgba(255, 255, 255, 0.025);
}

body:not([data-theme="dark"]) #schedulePanel.schedule-panel-modern--v4 .schedule-v5-summary__item {
    background: rgba(255, 255, 255, 0.42);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-summary__icon,
#schedulePanel.schedule-panel-modern--v4 .schedule-v5-stat__icon {
    color: var(--schedule-accent);
    flex-shrink: 0;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-summary__icon {
    font-size: 16px;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-summary__text {
    min-width: 0;
    font-size: 12px;
    font-weight: 550;
    color: var(--schedule-text);
    line-height: 1.35;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-stats {
    margin-top: 12px;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-stat {
    padding: 8px 8px;
    border-radius: 14px;
    border: 1px solid var(--schedule-border);
    background: color-mix(in srgb, var(--schedule-surface-1) 78%, transparent);
    display: grid;
    gap: 4px;
    justify-items: start;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-stat__icon {
    font-size: 17px;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-stat__label {
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--schedule-text-faint);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-stat__value {
    font-size: 12px;
    font-weight: 800;
    line-height: 1.2;
    color: var(--schedule-text);
    min-width: 0;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-stat__value--status {
    display: inline-flex;
    align-items: center;
    padding: 3px 7px;
    border-radius: 999px;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-meta {
    margin-top: 10px;
    display: grid;
    gap: 7px;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-meta__item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding-top: 8px;
    border-top: 1px solid var(--schedule-border);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-meta__label {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--schedule-text-faint);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-meta__value {
    text-align: right;
    font-size: 12px;
    font-weight: 600;
    color: var(--schedule-text-soft);
    min-width: 0;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-note {
    margin-top: 10px;
    font-size: 12px;
    line-height: 1.45;
    color: var(--schedule-text-soft);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-tone--ontime {
    background: var(--schedule-success-bg);
    color: var(--schedule-success-text);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-tone--minor {
    background: var(--schedule-warning-bg);
    color: var(--schedule-warning-text);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-tone--major {
    background: var(--schedule-danger-bg);
    color: var(--schedule-danger-text);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-tone--early {
    background: var(--schedule-early-bg);
    color: var(--schedule-early-text);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-alert-info,
#schedulePanel.schedule-panel-modern--v4 .schedule-info-services,
#schedulePanel.schedule-panel-modern--v4 .schedule-ml-card,
#schedulePanel.schedule-panel-modern--v4 #resultsWrap {
    clear: both;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-alert-info,
#schedulePanel.schedule-panel-modern--v4 .schedule-info-services,
#schedulePanel.schedule-panel-modern--v4 .schedule-ml-card {
    padding: 12px 14px;
    border-radius: 18px;
    border: 1px solid var(--schedule-border);
    background: var(--schedule-surface-1);
    box-shadow: 0 16px 36px -34px var(--schedule-shadow);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-alert-info {
    background:
        linear-gradient(180deg, rgba(245, 158, 11, 0.12), transparent 85%),
        var(--schedule-surface-1);
    color: var(--schedule-text);
    line-height: 1.55;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-info-services__title {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
    font-size: 13px;
    font-weight: 700;
    color: var(--schedule-text);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-info-services__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 6px;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-info-services__item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: var(--schedule-text-soft);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-ml-toggle {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    border-radius: 18px;
    border: 1px solid var(--schedule-border);
    background: var(--schedule-surface-1);
    color: var(--schedule-text);
    text-align: left;
    box-shadow: 0 14px 30px -30px var(--schedule-shadow);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-ml-toggle .ml-toggle-icon {
    font-size: 20px;
    color: var(--schedule-accent);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-ml-toggle .ml-toggle-copy {
    flex: 1;
    min-width: 0;
    display: grid;
    gap: 2px;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-ml-toggle .ml-toggle-label {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--schedule-text-faint);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-ml-toggle .ml-toggle-text {
    font-size: 13px;
    font-weight: 700;
    color: var(--schedule-text);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-ml-toggle .ml-toggle-arrow {
    font-size: 22px;
    color: var(--schedule-text-soft);
}

#schedulePanel.schedule-panel-modern--v4 #resultsWrap {
    max-height: none;
    overflow: visible;
    padding: 0;
    border: none;
    background: transparent;
    box-shadow: none;
}

#schedulePanel.schedule-panel-modern--v4 #resultsWrap::before {
    content: attr(data-title);
    display: block;
    margin: 0 0 9px;
    font-size: clamp(1.02rem, 0.98rem + 0.22vw, 1.18rem);
    font-weight: 800;
    letter-spacing: -0.02em;
    color: var(--schedule-text);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

#schedulePanel.schedule-panel-modern--v4 .js-schedule-stop-row {
    display: block;
}

#schedulePanel.schedule-panel-modern--v4 .js-schedule-stop-row.is-past .js-schedule-stop-toggle {
    opacity: 0.82;
}

#schedulePanel.schedule-panel-modern--v4 .js-schedule-stop-toggle {
    position: relative;
    width: 100%;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto 16px;
    align-items: start;
    gap: 10px;
    padding: 10px 11px;
    border-radius: 15px;
    border: 1px solid var(--schedule-border);
    background: var(--schedule-surface-1);
    text-align: left;
    color: inherit;
    box-shadow: 0 10px 22px -28px var(--schedule-shadow);
}

#schedulePanel.schedule-panel-modern--v4 .js-schedule-stop-toggle:hover,
#schedulePanel.schedule-panel-modern--v4 .js-schedule-stop-toggle:focus-visible {
    border-color: var(--schedule-border-strong);
    outline: none;
}

#schedulePanel.schedule-panel-modern--v4 .js-schedule-stop-row.is-current .js-schedule-stop-toggle {
    border-color: rgba(20, 115, 230, 0.38);
    box-shadow: 0 0 0 1px rgba(20, 115, 230, 0.18), 0 18px 38px -34px var(--schedule-shadow);
}

#schedulePanel.schedule-panel-modern--v4 .js-schedule-stop-row.is-expanded .js-schedule-stop-toggle {
    border-bottom-left-radius: 16px;
    border-bottom-right-radius: 16px;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-stop__station {
    min-width: 0;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-stop__name {
    display: block;
    font-size: clamp(0.92rem, 0.88rem + 0.18vw, 1.02rem);
    line-height: 1.08;
    font-weight: 720;
    letter-spacing: -0.025em;
    color: var(--schedule-text);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-stop__platform {
    display: inline-flex;
    align-items: center;
    margin-top: 5px;
    padding: 2px 6px;
    border-radius: 8px;
    border: 1px solid rgba(20, 115, 230, 0.2);
    background: rgba(20, 115, 230, 0.04);
    font-size: 10px;
    font-weight: 680;
    letter-spacing: 0.01em;
    color: var(--schedule-accent);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-stop__times {
    min-width: 92px;
    display: grid;
    gap: 5px;
    text-align: right;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-stop__time-group {
    display: grid;
    gap: 1px;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-stop__time-label {
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.11em;
    text-transform: uppercase;
    color: var(--schedule-text-faint);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-stop__time-value {
    font-size: 14px;
    font-weight: 780;
    line-height: 1.08;
    color: var(--schedule-text);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-stop__time-value.is-scheduled-delayed {
    font-size: 10px;
    font-weight: 620;
    color: var(--schedule-text-faint);
    text-decoration: line-through;
    text-decoration-thickness: 1px;
    text-decoration-color: color-mix(in srgb, var(--schedule-text-faint) 68%, transparent);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-stop__time-real {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 11px;
    font-weight: 720;
    color: var(--schedule-text-soft);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-stop__time-arrow {
    font-size: 9px;
    line-height: 1;
    font-weight: 500;
    color: var(--schedule-text-faint);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-stop__time-actual {
    font-weight: 760;
    color: var(--schedule-text-soft);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-stop__status {
    justify-self: end;
    padding: 2px 6px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 760;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-stop__chevron {
    align-self: center;
    font-size: 16px;
    color: var(--schedule-text-faint);
    transition: transform 0.2s ease;
}

#schedulePanel.schedule-panel-modern--v4 .js-schedule-stop-toggle[aria-expanded="true"] .schedule-v5-stop__chevron {
    transform: rotate(180deg);
}

#schedulePanel.schedule-panel-modern--v4 .js-schedule-stop-details {
    margin-top: 6px;
    padding: 10px 11px 0;
    border-radius: 0 0 15px 15px;
    border-left: 1px solid var(--schedule-border);
    border-right: 1px solid var(--schedule-border);
    border-bottom: 1px solid var(--schedule-border);
    background: var(--schedule-surface-2);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-v5-stop__note {
    font-size: 11px;
    line-height: 1.45;
    color: var(--schedule-text-soft);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-connection {
    margin-top: 2px;
    padding: 10px;
    border-radius: 15px;
    border: 1px solid var(--schedule-border);
    background: var(--schedule-surface-1);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-connection-toggle {
    width: 100%;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
    background: transparent;
    border: none;
    color: inherit;
    padding: 0;
    text-align: left;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-connection-toggle .toggle-label {
    font-size: 12px;
    font-weight: 800;
    color: var(--schedule-text);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-connection-toggle .toggle-meta,
#schedulePanel.schedule-panel-modern--v4 .schedule-connection-summary,
#schedulePanel.schedule-panel-modern--v4 .connection-meta,
#schedulePanel.schedule-panel-modern--v4 .connection-note,
#schedulePanel.schedule-panel-modern--v4 .connection-history {
    font-size: 11px;
    line-height: 1.5;
    color: var(--schedule-text-soft);
}

#schedulePanel.schedule-panel-modern--v4 .schedule-connection-panel {
    display: grid;
    gap: 8px;
    padding-top: 10px;
}

#schedulePanel.schedule-panel-modern--v4 .schedule-connection-item {
    padding: 10px;
    border-radius: 14px;
    border: 1px solid var(--schedule-border);
    background: var(--schedule-surface-2);
}

#schedulePanel.schedule-panel-modern--v4 .connection-title {
    font-size: 13px;
    font-weight: 700;
    color: var(--schedule-text);
}

#schedulePanel.schedule-panel-modern--v4 .connection-probability {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

#schedulePanel.schedule-panel-modern--v4 .probability-pill {
    padding: 3px 7px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 800;
}

#schedulePanel.schedule-panel-modern--v4 .probability-pill.is-high {
    background: var(--schedule-success-bg);
    color: var(--schedule-success-text);
}

#schedulePanel.schedule-panel-modern--v4 .probability-pill.is-medium {
    background: var(--schedule-warning-bg);
    color: var(--schedule-warning-text);
}

#schedulePanel.schedule-panel-modern--v4 .probability-pill.is-low {
    background: var(--schedule-danger-bg);
    color: var(--schedule-danger-text);
}

@media (max-width: 640px) {
    #schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__actions {
        justify-self: stretch;
        width: auto;
        max-width: calc(100% - 56px);
        flex-wrap: nowrap;
        justify-content: flex-end;
        gap: 6px;
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__action-btn {
        width: 38px;
        height: 38px;
        min-height: 38px;
        border-radius: 14px;
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__action-btn .material-symbols-outlined {
        font-size: 21px;
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__sheet {
        max-height: min(92dvh, 860px);
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__close {
        top: 16px;
        right: 16px;
        width: 44px;
        height: 44px;
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-v5-stats {
        gap: 5px;
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-v5-stat {
        padding: 7px 7px;
        border-radius: 12px;
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-v5-stat__icon {
        font-size: 16px;
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-v5-stat__label {
        font-size: 9px;
        letter-spacing: 0.1em;
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-v5-stat__value {
        font-size: 11px;
        line-height: 1.15;
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-v5-stat__value--status {
        padding: 3px 6px;
        font-size: 10px;
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-v5-meta {
        gap: 6px;
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-v5-meta__item {
        padding: 8px 8px;
        border-radius: 14px;
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-v5-meta__label {
        font-size: 9px;
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-v5-meta__value {
        font-size: 11px;
    }

    #schedulePanel.schedule-panel-modern--v4 .js-schedule-stop-toggle {
        grid-template-columns: minmax(0, 1fr);
        gap: 8px;
        padding: 9px 10px;
        border-radius: 14px;
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-v5-stop__times {
        min-width: 0;
        text-align: left;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        align-items: start;
        gap: 5px;
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-v5-stop__status {
        justify-self: start;
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-v5-stop__time-value {
        font-size: 12px;
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-v5-stop__time-value.is-scheduled-delayed {
        font-size: 10px;
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-v5-stop__time-real {
        font-size: 10px;
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-v5-stop__name {
        font-size: 0.92rem;
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-v5-stop__platform {
        margin-top: 6px;
        padding: 2px 6px;
        font-size: 9px;
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-v5-stop__status {
        padding: 3px 7px;
        font-size: 9px;
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-v5-stop__chevron {
        position: absolute;
        top: 11px;
        right: 11px;
    }
}

@media (min-width: 900px) and (hover: hover) and (pointer: fine) {
    #schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__sheet {
        top: 0;
        bottom: 0;
        left: auto;
        width: min(460px, 92vw);
        height: 100%;
        max-height: none;
        border-top: none;
        border-left: 1px solid var(--schedule-border);
        border-radius: 0;
        transform: translateX(105%);
        box-shadow: -18px 0 44px -32px var(--schedule-shadow);
    }

    #schedulePanel.schedule-panel-modern--v4.is-open .schedule-panel-modern__sheet {
        transform: translateX(0);
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__handle {
        display: none;
    }

    #schedulePanel.schedule-panel-modern--v4 .schedule-panel-modern__content {
        padding: 16px;
        padding-top: 14px;
    }
}
