:root {
    --monitor-bg: #05193f;
    --monitor-bg-top: #0a2b66;
    --monitor-panel: rgba(255, 255, 255, 0.045);
    --monitor-line: rgba(203, 223, 255, 0.16);
    --monitor-line-strong: rgba(233, 242, 255, 0.28);
    --monitor-text: #f6f9ff;
    --monitor-muted: #aec2e6;
    --monitor-alert: #ffdb5c;
    --monitor-danger: #ff6f7d;
    --monitor-danger-soft: rgba(255, 111, 125, 0.16);
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

html,
body {
    min-height: 100%;
}

body {
    margin: 0;
    font-family: "Bahnschrift", "DIN 1451 Std", "Segoe UI", sans-serif;
    color: var(--monitor-text);
    background:
        radial-gradient(circle at top left, rgba(183, 210, 255, 0.1), transparent 24%),
        linear-gradient(180deg, var(--monitor-bg-top) 0%, var(--monitor-bg) 68%, #020d24 100%);
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    background:
        linear-gradient(rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.008)),
        repeating-linear-gradient(
            180deg,
            transparent 0,
            transparent 5px,
            rgba(255, 255, 255, 0.012) 6px,
            transparent 7px
        );
    pointer-events: none;
}

.monitor {
    width: 100%;
    display: grid;
    gap: 0.6rem;
    padding: 0.75rem;
}

.monitor__header,
.board {
    background: var(--monitor-panel);
    border: 1px solid var(--monitor-line);
}

.monitor__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.55rem 0.9rem 0.5rem;
}

.monitor__station-block {
    min-width: 0;
}

.monitor__station {
    margin: 0;
    font-size: clamp(1.2rem, 1.8vw, 1.8rem);
    line-height: 1.05;
    font-weight: 700;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.monitor__subline,
.board__col,
.departure__route {
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.monitor__subline {
    margin: 0.3rem 0 0;
    color: var(--monitor-muted);
    font-size: clamp(0.62rem, 0.82vw, 0.78rem);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.board {
    position: relative;
    display: grid;
    gap: 0;
    padding: 0.75rem 0.9rem;
}

.board__head {
    display: grid;
    grid-template-columns: 5rem 5.5rem 1fr 4rem;
    gap: 0.7rem;
    padding: 0 0 0.45rem;
    border-bottom: 1px solid var(--monitor-line-strong);
}

.board__col {
    color: var(--monitor-muted);
    font-size: 0.68rem;
}

.board__rows {
    display: grid;
}

.board--all .board__rows {
    grid-auto-rows: minmax(0, auto);
}

.board__rows[data-rows="2"] {
    grid-template-rows: repeat(2, minmax(0, 1fr));
}

.board__rows[data-rows="3"] {
    grid-template-rows: repeat(3, minmax(0, 1fr));
}

.departure {
    display: grid;
    grid-template-columns: 5rem minmax(0, 1fr) 4rem;
    gap: 0.7rem;
    align-items: center;
    padding: 0.62rem 0;
    border-bottom: 1px solid var(--monitor-line);
}

.departure:last-child {
    border-bottom: none;
}

.departure__line {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 3.4rem;
    padding: 0.35rem 0.55rem;
    border: 1px solid rgba(255, 255, 255, 0.18);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02));
    font-size: clamp(1.05rem, 1.6vw, 1.45rem);
    font-weight: 700;
    letter-spacing: 0.02em;
    text-align: center;
    border-radius: 1rem;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.departure__line.line-s1 {
    background: #0aa636;
    border-color: #0aa636;
    color: #ffffff;
}

.departure__line.line-s2 {
    background: #b81c43;
    border-color: #b81c43;
    color: #ffffff;
}

.departure__line.line-s3 {
    background: #652282;
    border-color: #652282;
    color: #ffffff;
}

.departure__line.line-s5 {
    background: #008abd;
    border-color: #008abd;
    color: #ffffff;
}

.departure__line.line-s7 {
    background: #cf7821;
    border-color: #cf7821;
    color: #ffffff;
}

.departure__line.line-a1,
.departure__line.line-a3 {
    background: #f29100;
    border-color: #f29100;
    color: #ffffff;
}

.departure__main {
    min-width: 0;
    display: grid;
    grid-template-columns: 6.2rem minmax(0, 1fr);
    grid-template-areas:
        "time destination"
        "time route";
    column-gap: 0.75rem;
    row-gap: 0.18rem;
    align-items: center;
}

.departure__main--no-route {
    grid-template-areas: "time destination";
    row-gap: 0;
}

.departure__time {
    grid-area: time;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    gap: 0.12rem;
    font-variant-numeric: tabular-nums;
}

.departure__time-current {
    font-size: clamp(1.2rem, 2vw, 1.9rem);
    font-weight: 700;
    line-height: 0.95;
}

.departure__time-meta {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    min-height: 0.9rem;
}

.departure__time-planned {
    color: #f56a6a;
    font-size: 0.66rem;
    line-height: 1;
    text-decoration: line-through;
}

.departure__time-delay {
    padding: 0.12rem 0.34rem;
    border-radius: 999px;
    background: rgba(245, 106, 106, 0.16);
    color: #ff9e9e;
    font-size: 0.62rem;
    line-height: 1;
    font-weight: 700;
}

.departure__time--delayed .departure__time-current {
    color: #ffffff;
}

.departure__destination {
    grid-area: destination;
    min-width: 0;
    font-size: clamp(1.08rem, 1.8vw, 1.55rem);
    line-height: 1;
    font-weight: 700;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.departure__route {
    grid-area: route;
    min-width: 0;
    color: var(--monitor-muted);
    font-size: 0.62rem;
    overflow: hidden;
    white-space: nowrap;
}

.departure__route-track {
    display: inline-flex;
    align-items: center;
    min-width: max-content;
    white-space: nowrap;
    gap: 0;
}

.departure__route--marquee .departure__route-track,
.departure__route-track--marquee {
    animation: route-marquee var(--marquee-duration, 20s) linear infinite;
}

.departure__route-text {
    display: inline-block;
    white-space: nowrap;
}

.departure__route-text--clone {
    display: inline-block;
    white-space: nowrap;
    padding-left: 3rem;
}

@keyframes route-marquee {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(calc(-1 * var(--marquee-distance, 100%)));
    }
}

.departure__platform {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 3.4rem;
    border-left: 1px solid var(--monitor-line);
    border-radius: 0.85rem;
    font-size: clamp(1.2rem, 2vw, 1.85rem);
    font-weight: 700;
    font-variant-numeric: tabular-nums;
    line-height: 1;
    background: rgba(255, 255, 255, 0.03);
}

.departure--placeholder,
.departure--muted {
    opacity: 0.72;
}

.departure--cancelled {
    background: linear-gradient(90deg, rgba(255, 111, 125, 0.08), rgba(255, 111, 125, 0.02));
}

.departure__time--cancelled .departure__time-current {
    color: #ffffff;
}

.departure__time-status {
    padding: 0.12rem 0.38rem;
    border-radius: 999px;
    background: var(--monitor-danger-soft);
    color: var(--monitor-danger);
    font-size: 0.62rem;
    line-height: 1;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.departure__destination-status {
    display: inline-flex;
    align-items: center;
    margin-left: 0.45rem;
    padding: 0.14rem 0.42rem;
    border-radius: 999px;
    background: var(--monitor-danger-soft);
    color: var(--monitor-danger);
    font-size: 0.58rem;
    line-height: 1;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    vertical-align: middle;
}

.monitor--all {
    gap: 0.45rem;
}

.board--all {
    padding-top: 0.6rem;
}

.board--all .departure {
    padding: 0.46rem 0;
}

.board--all .departure__line,
.board--all .departure__platform {
    min-height: 2.8rem;
}

.board--all .departure__destination {
    font-size: clamp(0.98rem, 1.45vw, 1.2rem);
}

.board--all .departure__time-current {
    font-size: clamp(1rem, 1.55vw, 1.3rem);
}

.board--all .departure__route {
    font-size: 0.56rem;
}

.board__fallback {
    position: absolute;
    inset: 2.4rem 0.9rem 0.75rem;
    display: grid;
    place-items: center;
    background: linear-gradient(180deg, rgba(3, 17, 48, 0.88), rgba(2, 10, 28, 0.94));
}

.board__fallback-box {
    max-width: 30rem;
    padding: 0.9rem 1rem;
    border: 1px solid rgba(255, 255, 255, 0.16);
    text-align: center;
}

.board__fallback-title {
    margin: 0 0 0.35rem;
    color: var(--monitor-alert);
    font-size: 0.92rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.board__fallback-text {
    margin: 0;
    color: var(--monitor-text);
    font-size: 0.82rem;
}

.noscript-hint {
    margin: 0.75rem;
    padding: 0.7rem 0.85rem;
    border: 1px solid rgba(255, 219, 92, 0.45);
    background: rgba(4, 16, 44, 0.96);
    color: var(--monitor-alert);
    font-family: "Bahnschrift", "DIN 1451 Std", "Segoe UI", sans-serif;
    font-size: 0.8rem;
}

.is-hidden {
    display: none;
}

@media (max-width: 900px) {
    .monitor {
        padding: 0.55rem;
        gap: 0.5rem;
    }

    .monitor__header {
        padding: 0.48rem 0.72rem 0.44rem;
    }

    .monitor__station {
        font-size: clamp(1rem, 2.1vw, 1.35rem);
    }

    .monitor__subline {
        margin-top: 0.22rem;
        font-size: 0.62rem;
    }

    .board {
        padding: 0.6rem 0.72rem;
    }

    .board__head {
        grid-template-columns: 4.3rem 4.9rem 1fr 3.4rem;
        gap: 0.55rem;
        padding-bottom: 0.38rem;
    }

    .board__col {
        font-size: 0.6rem;
    }

    .departure {
        grid-template-columns: 4.3rem minmax(0, 1fr) 3.4rem;
        gap: 0.55rem;
        padding: 0.52rem 0;
    }

    .departure__line {
        min-height: 2.95rem;
        padding: 0.28rem 0.42rem;
        border-radius: 0.9rem;
        font-size: clamp(0.95rem, 1.9vw, 1.2rem);
    }

    .departure__main {
        grid-template-columns: 5.2rem minmax(0, 1fr);
        column-gap: 0.55rem;
    }

    .departure__time-current {
        font-size: clamp(1.05rem, 2.2vw, 1.45rem);
    }

    .departure__time-planned,
    .departure__time-delay {
        font-size: 0.58rem;
    }

    .departure__destination {
        font-size: clamp(0.95rem, 1.8vw, 1.2rem);
    }

    .departure__route {
        font-size: 0.56rem;
    }

    .departure__route-track {
        max-width: 100%;
    }

    .departure__platform {
        min-height: 2.95rem;
        border-radius: 0.75rem;
        font-size: clamp(1rem, 2vw, 1.35rem);
    }

    .board__fallback {
        inset: 2.05rem 0.72rem 0.6rem;
    }

    .board--all .departure__line,
    .board--all .departure__platform {
        min-height: 2.55rem;
    }
}

@media (max-width: 600px) {
    .monitor {
        padding: 0.42rem;
        gap: 0.42rem;
    }

    .monitor__header {
        padding: 0.42rem 0.6rem 0.38rem;
    }

    .monitor__station {
        font-size: clamp(0.92rem, 4vw, 1.08rem);
    }

    .monitor__subline {
        font-size: 0.56rem;
    }

    .board {
        padding: 0.5rem 0.6rem;
    }

    .board__head {
        display: none;
    }

    .departure {
        grid-template-columns: 3.6rem minmax(0, 1fr) 2.9rem;
        gap: 0.45rem;
        align-items: stretch;
        padding: 0.46rem 0;
    }

    .departure__line,
    .departure__platform {
        min-height: 2.45rem;
    }

    .departure__line {
        padding: 0.22rem 0.35rem;
        border-radius: 0.82rem;
        font-size: 0.88rem;
    }

    .departure__main {
        grid-template-columns: 4.7rem minmax(0, 1fr);
        grid-template-areas:
            "time destination";
        align-items: center;
        row-gap: 0;
    }

    .departure__time {
        gap: 0.08rem;
    }

    .departure__time-current {
        font-size: 1rem;
    }

    .departure__time-meta {
        min-height: 0.72rem;
        gap: 0.25rem;
    }

    .departure__time-planned,
    .departure__time-delay {
        font-size: 0.54rem;
    }

    .departure__destination {
        align-self: center;
        font-size: 0.95rem;
        line-height: 1.05;
    }

    .departure__route {
        display: none;
    }

    .departure__destination-status {
        display: inline-flex;
        margin-left: 0.3rem;
        font-size: 0.5rem;
    }

    .departure__platform {
        min-height: 2.45rem;
        border-radius: 0.72rem;
        font-size: 0.95rem;
    }

    .board__fallback {
        inset: 0.5rem 0.6rem;
    }

    .board__fallback-box {
        padding: 0.72rem 0.78rem;
    }

    .board__fallback-title {
        font-size: 0.78rem;
    }

    .board__fallback-text {
        font-size: 0.72rem;
    }
}

@media (max-width: 420px) {
    .monitor {
        padding: 0.35rem;
    }

    .monitor__header,
    .board {
        border-width: 1px;
    }

    .departure {
        grid-template-columns: 3.2rem minmax(0, 1fr) 2.55rem;
        gap: 0.38rem;
    }

    .departure__line {
        font-size: 0.8rem;
    }

    .departure__main {
        grid-template-columns: 4.1rem minmax(0, 1fr);
        column-gap: 0.4rem;
    }

    .departure__time-current {
        font-size: 0.92rem;
    }

    .departure__destination {
        font-size: 0.86rem;
    }

    .departure__platform {
        font-size: 0.86rem;
    }

    .departure__time-status,
    .departure__time-delay,
    .departure__time-planned,
    .departure__destination-status {
        font-size: 0.48rem;
    }
}
