#map {
    position: fixed;
    width: 100%;
    height: 100%;
}

.leaflet-container {
    will-change: transform;
    transform: translateZ(0);
}

[data-bs-theme=dark] #map {
    background-color: #343a40;
}

[data-bs-theme=dark] .leaflet-tile-pane, [data-bs-theme=dark] .leaflet-overlay-pane canvas {
    filter: invert(1) hue-rotate(180deg) contrast(80%) brightness(80%);
}

/* [data-bs-theme=dark] .leaflet-overlay-pane canvas {
    filter: brightness(80%);
} */

/* [data-bs-theme=dark] .leaflet-marker-pane, [data-bs-theme=dark] .leaflet-overlay-pane svg {
    filter: brightness(90%);
} */

.leaflet-control {
    font-weight: 500;
    user-select: none;
    -webkit-user-select: none;
}

.leaflet-right .leaflet-control {
    margin-right: 16px !important;
}

.leaflet-top .leaflet-control {
    margin-top: 16px !important;
}

.leaflet-control-zoom {
    border: none !important;
    border-radius: 12px;
    box-shadow: var(--shadow-6) !important;
}

.leaflet-bar a {
    background-color: var(--button-bg) !important;
    color: var(--bs-body-color) !important;
    border: none !important;
    font-size: 25px !important;
    width: 40px !important;
    height: 40px !important;
    line-height: 40px !important;
    transition: background-color 0.3s;
    -webkit-tap-highlight-color: transparent !important;
}

.leaflet-bar a:first-child {
    border-top-left-radius: 12px !important;
    border-top-right-radius: 12px !important;
}

.leaflet-bar a:last-child {
    border-bottom-left-radius: 12px !important;
    border-bottom-right-radius: 12px !important;
}

@media (hover: hover) and (pointer: fine) {
    .leaflet-bar a:hover {
        background-color: var(--button-hover) !important;
    }
}

.leaflet-bar a:active {
    background-color: var(--button-active) !important;
}

.leaflet-tooltip {
    font-weight: 600;
    font-size: 13px;
    border-radius: 12px;
    padding: 10px 20px 10px 20px;
}

.leaflet-popup {
    cursor: default;
    pointer-events: none;
    user-select: none;
    -webkit-user-select: none;

    .leaflet-popup-tip {
        pointer-events: none;
    }
}

.leaflet-popup-content-wrapper, .leaflet-popup-tip {
    background-color: var(--bs-body-bg);
}

.leaflet-popup-content {
    color: var(--bs-body-color);
}

.leaflet-tooltip {
    background-color: var(--bs-body-bg);
    border-color: var(--bs-body-bg);
    color: var(--bs-body-color);
}

.leaflet-tooltip::before {
    border-top-color: var(--bs-body-bg);
}

.icon, .modal-button {
    background-color: var(--bs-body-color);
}

.popup-row {
    font-weight: 600;
}

.popup-row p {
    margin: 0;
}

.stop-popup .popup-row {
    margin-bottom: 5px;
}

.vehicle-popup .popup-row {
    margin-bottom: 3px;
}

.vehicle-popup .vehicle-popup-header {
    /* min-height: 37.5px; */
    background-repeat: no-repeat;
    background-position: left center;
    background-size: contain;
    /* padding-left: 50px; */
    /* padding-left: 65px; */
    margin-bottom: 5px;
}

.vehicle-popup .last-updated {
    font-style: italic;
    color: var(--bs-secondary-color);
}

/* .vehicle-popup .vehicle-popup-header.bus {
    background-image: url(../images/bus_circle.png);
}

.vehicle-popup .vehicle-popup-header.night {
    background-image: url(../images/night_bus_circle.png);
}

.vehicle-popup .vehicle-popup-header.tram {
    background-image: url(../images/tram_circle.png);
}

.vehicle-popup .vehicle-popup-header.trolley {
    background-image: url(../images/trolley_circle.png);
} */

.popup-row .title {
    font-weight: bold;
    font-size: 15px;
}

.popup-row .description {
    white-space: pre-wrap;
}

.popup-row .info {
    user-select: none;
    -webkit-user-select: none;
}

.popup-row .icon {
    display: inline-block;
    background-size: contain;
    background-repeat: no-repeat;
    vertical-align: middle;
    width: 16px;
    height: 16px;
    margin-left: 3px;
}

.popup-row .icon:first-child {
    margin-left: 0;
}

.popup-row .icon.copy {
    mask-image: url(../images/copy_icon.svg);
    mask-size: contain;
}

.popup-row .icon.speedometer {
    mask-image: url(../images/speedometer_icon.svg);
    width: 18px;
    height: 18px;
}

.popup-row .icon.external {
    mask-image: url(../images/external_link_icon.svg);
    /* width: 18px;
    height: 18px; */
}

.popup-row .vehicle-model {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 3px;
}

.popup-row .vehicle-model .feature-icon {
    display: inline-block;
    background-color: var(--bs-body-color);
    background-size: contain;
    background-repeat: no-repeat;
    vertical-align: middle;
    width: 13px;
    height: 13px;
}

.popup-row .vehicle-model .feature-icon.low-floor, .search-results .category .results .result .vehicle-model .feature-icon.low-floor {
    mask-image: url(../images/low_floor_icon.svg);
}

.popup-row .vehicle-model .feature-icon.ac, .search-results .category .results .result .vehicle-model .feature-icon.ac {
    mask-image: url(../images/ac_icon.svg);
}

.popup-row .info .speed {
    border-left: none;
    padding-left: 0;
}

.stop-popup .arrivals {
    display: grid;
    grid-template-columns: max-content /*max-content*/ auto;
    gap: 5px;
}

.popup-row.route {
    display: contents;
}

.popup-row .line-number {
    display: inline-block;
    color: white;
    padding-left: 5px;
    padding-right: 5px;
    text-align: center;
}

.popup-row .line-number.bus {
    background-color: var(--bus);
}

.popup-row .line-number.trolley {
    background-color: var(--trolley);
}

.leaflet-tooltip .line-number.bus {
    color: var(--bus);
}

.leaflet-tooltip .line-number.trolley {
    color: var(--trolley);
}

.popup-row.view-more {
    text-align: center;
    user-select: none;
    -webkit-user-select: none;
}

.loading-screen, .page-notice {
	position: fixed;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 10000;
	overflow: hidden;
}

.page-notice {
    margin: 20px;
}

.leaflet-vehicle-icon {
    background: none;
    border: none;
    transition: opacity 0.3s linear;
    /* transition: all 0.3s linear; */
    /* transition: transform 5s ease-in-out; */
    /* box-shadow: 0 1px 10px #0000001f, 0 2px 4px -1px #0003; */
}

.vehicle-marker-simple {
    border-radius: 50%;
    background-color: var(--bus);
}

.vehicle-marker {
    height: 26px;
    width: 26px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 50%;
    font-size: 13.4px;
    font-weight: 700;
    color: white;
    /* outline: 2px solid white; */
    box-shadow: 0px 1px 10px 0px #0000001f, 0px 0px 4px 4px #0003;
}

.vehicle-marker.direction {
    border-radius: 0 100% 100% 100%;
}

.vehicle-marker.bus {
    background-color: var(--bus) !important;
    outline: 2.5px solid var(--bus-dark);
}

.vehicle-marker.trolley {
    background-color: var(--trolley) !important;
    outline: 2px solid var(--trolley-dark);
}

.buttons {
    display: flex;
    flex-direction: row;
    gap: 10px;
    position: absolute;
}

.buttons.top-left {
    top: 16px;
    left: 16px;
}

.buttons.bottom-right {
    bottom: 16px;
    right: 16px;
}

.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background-color: var(--button-bg);
    /* color: black; */
    border: none;
    border-radius: 12px;
    box-shadow: var(--shadow-6);
    cursor: pointer;
    user-select: none;
    -webkit-user-select: none;
    transition: background-color 0.3s;
    /* background-image: url(../images/three_lines.svg);
    background-size: contain;
    background-repeat: no-repeat; */
}

@media (hover: hover) and (pointer: fine) {
    .button:hover {
        background-color: var(--button-hover);
    }
}

.button:active {
    background-color: var(--button-active);
}

.button.big {
    width: 56px;
    height: 56px;
}

.button .icon {
    width: 25px;
    height: 25px;
}

.button .icon.menu {
    mask-image: url(../images/menu_icon.svg);
}

.button .icon.search {
    mask-image: url(../images/search_icon.svg);
}

.button .icon.filter {
    mask-image: url(../images/filter_icon.svg);
}

.button .icon.location {
    mask-image: url(../images/location_off_icon.svg);
}

.button .icon.location.on {
    mask-image: url(../images/location_on_icon.svg);
}

.button svg {
    width: 1em;
    height: 1em;
    fill: currentColor;
    font-size: 1.5rem;
}

.button.menu-button {
    z-index: 999;
}

.backdrop {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    transition: opacity 225ms cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 999;
}

.hidden {
    opacity: 0;
    pointer-events: none;
}

.sidebar {
    position: absolute;
    width: 240px;
    height: 100%;
    top: 0;
    left: 0;
    transform: none;
    border-radius: 0px 16px 16px 0px;
    box-shadow: var(--shadow-16);
    background-color: var(--bs-body-bg);
    transition: transform 225ms cubic-bezier(0, 0, 0.2, 1);
    user-select: none;
    -webkit-user-select: none;
    z-index: 1000;
}

.sidebar.closed {
    transform: translateX(-240px);
    box-shadow: none;
}

.sidebar-header {
    display: flex;
    align-items: center;
    padding: 10px;
}

.sidebar-header .logo {
    display: inline-block;
    width: 60px;
    height: 60px;
    margin-right: 10px;
}

.sidebar-header .title {
    font-size: 20px;
    font-weight: 700;
}

.sidebar-header .title-container {
    display: flex;
    flex-direction: column;
}

.sidebar-header .title-container .city-selector {
    display: flex;
    align-items: center;
    gap: 2px;
    cursor: pointer;
}

.sidebar-header .title-container .city-selector .icon {
    display: inline-block;
    background-color: var(--bs-body-color);
    background-size: contain;
    background-repeat: no-repeat;
    vertical-align: middle;
    width: 25px;
    height: 25px;
    mask-image: url(../images/arrow_down.svg);
}

.sidebar-list {
    display: flex;
    flex-direction: column;
    padding: 10px;
    gap: 8px;
}

.sidebar-button {
    display: flex;
    align-items: center;
    padding: 10px;
    border-radius: 24px;
    cursor: pointer;
    transition: background-color 0.3s;
}

.sidebar-button.active {
    pointer-events: none;
    background-color: var(--bs-secondary-bg);
}

@media (hover: hover) and (pointer: fine) {
    .sidebar-button:hover {
        background-color: var(--button-hover);
    }
}

.sidebar-button:active {
    background-color: var(--button-active);
}

.sidebar-button .icon {
    width: 25px;
    height: 25px;
    margin-right: 10px;
}

.sidebar-button .icon.map {
    mask-image: url(../images/map_icon.svg);
}

.sidebar-button.active .icon.map {
    mask-image: url(../images/map_icon_active.svg);
}

.sidebar-button .icon.settings {
    mask-image: url(../images/settings_icon.svg);
}

.sidebar-button.active .icon.settings {
    mask-image: url(../images/settings_icon_active.svg);
}

.sidebar-button .icon.info {
    mask-image: url(../images/info_icon.svg);
}

.sidebar-button.active .icon.info {
    mask-image: url(../images/info_icon_active.svg);
}

.sidebar-button .text {
    font-size: 16px;
    font-weight: 600;
}

.sidebar-footer {
    position: absolute;
    bottom: 0;
    padding: 10px;
}

.sidebar-footer .site-notice {
    margin-bottom: 10px;
}

.sidebar-footer .credits {
    font-style: italic;
}

.sidebar-footer .links {
    display: flex;
    justify-content: flex-start;
    margin-bottom: 5px;
    gap: 5px;
}

.sidebar-footer .links .icon {
    width: 30px;
    height: 30px;
}

.sidebar-footer .links .icon.forum {
    mask-image: url(../images/forum_icon.svg);
}

.sidebar-footer .links .icon.github {
    mask-image: url(../images/github_icon.svg);
}

.sidebar-footer .links .icon.email {
    mask-image: url(../images/email_icon.svg);
}

.sidebar-footer .attribution {
    font-size: 13px;
}

div.menu {
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--bs-body-bg);
    transition: opacity 225ms cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 998;
}

.menu-header {
    padding: 16px;
    padding-left: 72px;
    display: flex;
    font-size: 25px;
    font-weight: 700;
}

.menu-content {
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    padding: 24px;
    padding-top: 0;
    gap: 10px;
}

.menu-content .category {
    display: flex;
    flex-direction: column;
    padding: 16px;
    border-radius: 16px;
    background-color: var(--bs-secondary-bg);
}

.menu-content .category .title {
    font-size: 25px;
    font-weight: 600;
    margin-bottom: 10px;
}

div.menu .setting {
    display: inline-flex;
    align-items: center;
    cursor: pointer;
}

div.menu .setting + .setting {
    margin-top: 10px;
}

div.menu .setting input[type="checkbox"], .setting input[type="radio"] {
    display: grid;
    place-content: center;
    font-size: 25px;
    color: var(--bs-body-color);
    width: 25px;
    height: 25px;
    padding: 5px;
    margin: 5px;
    border: 3px solid var(--bs-body-color);
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
}

.setting input[type="checkbox"] {
    border-radius: 5px;
}

.setting input[type="radio"] {
    border-radius: 50%;
}

.setting input[type="checkbox"]::before, .setting input[type="radio"]::before {
    content: "";
    width: 0.6em;
    height: 0.6em;
    opacity: 0;
    background-color: var(--bs-body-color);
    transition: 0.2s opacity;
    clip-path: polygon(14% 44%, 0 65%, 50% 100%, 100% 16%, 80% 0%, 43% 62%);
}

.setting input[type="checkbox"]::before {
    clip-path: polygon(14% 44%, 0 65%, 50% 100%, 100% 16%, 80% 0%, 43% 62%);
}

.setting input[type="radio"]::before {
    clip-path: circle();
}

.setting input[type="checkbox"]:checked::before, .setting input[type="radio"]:checked::before {
    opacity: 1;
}

.modal-container {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transition: opacity 225ms cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 1000;
    user-select: none;
    -webkit-user-select: none;
    overflow-y: auto;
}

.modal-backdrop {
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    z-index: -1;
}

.modal-base {
    display: flex;
    flex-direction: column;
    width: calc(100% - 64px);
    height: 70%;
    max-width: 600px;
    max-height: calc(100% - 64px);
    background-color: var(--bs-body-bg);
    border-radius: 16px;
    /* padding: 8px; */
}

.notice-modal {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    width: calc(100% - 64px);
    max-width: 400px;
    /* max-height: calc(100% - 64px); */
    margin: 32px 0;
    background-color: var(--bs-body-bg);
    border-radius: 16px;
    padding: 16px;
    gap: 16px;
}

@media (max-width: 600px) {
    .modal-base {
        width: 100%;
        height: 100%;
        max-width: calc(100% - 64px);
        max-height: calc(100% - 64px);
    }

    .modal-base.fullscreen {
        max-width: 100%;
        max-height: 100%;
        border-radius: 0;
    }
}

.modal-header {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 4px;
    margin-bottom: 8px;
    padding: 8px 8px 0px 8px;
}

.modal-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    flex: 0 0 auto;
    width: 40px;
    height: 40px;
    padding: 8px;
    background-color: var(--bs-body-bg);
    border-radius: 50%;
    cursor: pointer;
    user-select: none;
    -webkit-user-select: none;
    transition: background-color 0.3s;
}

.modal-button::before {
    content: "";
    position: absolute;
    inset: 8px;
    background-color: var(--bs-body-color);
}

.modal-button.modal-back::before {
    mask-image: url(../images/arrow_left.svg);
}

.modal-button.modal-close::before {
    mask-image: url(../images/close_icon.svg);
}

.modal-button.more-info::before {
    mask-image: url(../images/three_dots.svg);
}

.modal-title {
    font-size: 20px;
    font-weight: 700;
}

.modal-buttons {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-left: auto;
}

.stop-modal .modal-button, .vehicle-modal .modal-button {
    width: 35px;
    height: 35px;
    padding: 6px;
    background-color: var(--bs-secondary-bg);
}

.stop-modal .modal-button::before, .vehicle-modal .modal-button::before {
    content: "";
    position: absolute;
    inset: 6px;
    background-color: var(--bs-body-color);
}

@media (hover: hover) and (pointer: fine) {
    .modal-button:hover, .custom-dropdown-item:hover {
        background-color: var(--button-hover);
    }
}

.modal-button:active, .custom-dropdown-item:active {
    background-color: var(--button-active);
}

.search-bar {
    display: inline-flex;
    align-items: center;
    width: 100%;
    border-radius: 20px;
    background-color: var(--bs-secondary-bg);
    font-size: 1rem;
}

.search-bar input {
    width: 100%;
    margin: 0;
    padding: 8px 8px 8px 14px;
    background: none;
    border: none;
}

.search-bar input:focus {
    outline: none;
}

.search-bar input::-webkit-search-cancel-button {
    appearance: none;
    height: 1.25em;
    width: 1.25em;
    background: url(../images/close_circle_icon.svg) no-repeat 50% 50%;
    background-size: contain;
    opacity: 1;
}

[data-bs-theme=dark] .search-bar input::-webkit-search-cancel-button {
    background: url(../images/close_circle_icon_dark_mode.svg) no-repeat 50% 50%;
}

.search-results, .filter-list, .search-info {
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    gap: 8px;
    padding: 0 8px 8px 8px;
}

.filter-list {
    align-items: flex-start;
}

.search-info {
    text-align: center;
    gap: 4px;
}

.search-info > .title {
    font-size: 1.5rem;
    font-weight: 600;
}

.search-info .category {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    padding: 8px 16px;
    border-radius: 5px;
    background-color: var(--bs-secondary-bg);
}

.search-info .category .title {
    font-size: 1rem;
    font-weight: 700;
}

.search-info .category:first-of-type:last-of-type {
    border-radius: 16px;
}

.search-info .category:first-of-type {
    border-radius: 16px 16px 5px 5px;
}

.search-info .category:last-of-type {
    border-radius: 5px 5px 16px 16px;
}

.search-results .category .title {
    font-size: 1rem;
    font-weight: 600;
    padding-left: 16px;
}

.search-results .category .results {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.search-results .category .results .result {
    display: flex;
    flex-wrap: nowrap;
    flex-direction: column;
    overflow-x: auto;
    padding: 8px 16px;
    border-radius: 5px;
    background-color: var(--bs-secondary-bg);
    cursor: pointer;
    transition: background-color 0.3s;
}

.search-results .category .results .result:active {
    background-color: var(--button-active);
}

.search-results .category .results .result:first-of-type:last-of-type, .cities-list .city:first-of-type:last-of-type {
    border-radius: 16px;
}

.search-results .category .results .result:first-of-type, .cities-list .city:first-of-type {
    border-radius: 16px 16px 5px 5px;
}

.search-results .category .results .result:last-of-type, .cities-list .city:last-of-type {
    border-radius: 5px 5px 16px 16px;
}

.search-results .category .results .result .line-info, .search-results .category .results .result .vehicle-info {
    display: flex;
    align-items: center;
}

.search-results .category .results .result .line, .stop-modal .arrivals .arrival .line,
.line-info .line {
    display: inline-flex;
    height: 1.5rem;

    .number {
        width: 3rem;
    }

    .icon {
        width: 1.5rem;
    }
}

.search-results .category .results .result .line .icon, .stop-modal .arrivals .arrival .line .icon,
.line-info .line .icon {
    display: inline-block;
    color: white;
    margin-right: 5px;
    text-align: center;
    /* aspect-ratio: 1 / 1; */
    /* height: 1.5rem; */
    border-radius: 50%;
    background-size: contain;
}

.search-results .category .results .result .line.bus .icon, .stop-modal .arrivals .arrival .line.bus .icon,
.line-info .line.bus .icon {
    background-image: url(../images/bus_icon_white.png);
}

.search-results .category .results .result .line.night .icon, .stop-modal .arrivals .arrival .line.night .icon,
.line-info .line.night .icon {
    background-image: url(../images/bus_icon_white.png);
}

.search-results .category .results .result .line.tram .icon, .stop-modal .arrivals .arrival .line.tram .icon,
.line-info .line.tram .icon {
    background-image: url(../images/tram_icon_white.png);
}

.search-results .category .results .result .line.trolley .icon, .stop-modal .arrivals .arrival .line.trolley .icon,
.line-info .line.trolley .icon {
    background-image: url(../images/trolley_icon_white.png);
}

.search-results .category .results .result .line .number, .stop-modal .arrivals .arrival .line .number,
.line-info .line .number {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    color: white;
    margin-right: 5px;
    /* text-align: center; */
    font-weight: 700;
    /* aspect-ratio: 2 / 1; */
    /* width: 3rem; */
    /* border-radius: 0.375rem; */
    border-radius: 12.5% / 25%;
}

.search-results .category .results .result .line.bus .number, .stop-modal .arrivals .arrival .line.bus .number,
.line-info .line.bus .number {
    background-color: var(--bus);
}

.search-results .category .results .result .line.night .number, .stop-modal .arrivals .arrival .line.night .number,
.line-info .line.night .number {
    background-color: var(--night);
}

.search-results .category .results .result .line.tram .number, .stop-modal .arrivals .arrival .line.tram .number,
.line-info .line.tram .number {
    background-color: var(--tram);
}

.search-results .category .results .result .line.trolley .number, .stop-modal .arrivals .arrival .line.trolley .number,
.line-info .line.trolley .number {
    background-color: var(--trolley);
}

.search-results .category .results .result .route, .stop-modal .arrivals .arrival .route {
    /* white-space: nowrap; */
    overflow-x: auto;
}

.search-results .category .results .result .vehicle {
    white-space: nowrap;
}

.search-results .category .results .result .vehicle-model {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 3px;
    font-size: 14px;
    /* white-space: nowrap; */
}

.search-results .category .results .result .vehicle-model .feature-icon {
    display: inline-block;
    text-align: center;
    background-color: var(--bs-body-color);
    background-size: contain;
    background-repeat: no-repeat;
    vertical-align: middle;
    height: 18px;
    width: 18px;
}

/* .stop-modal-container {
    position: absolute;
    width: 100%;
    height: 100%;
    bottom: 0;
    transform: none;
    border-radius: 0px 16px 16px 0px;
    box-shadow: var(--shadow-16);
    background-color: white;
    transition: transform 225ms cubic-bezier(0, 0, 0.2, 1);
    user-select: none;
    z-index: 1000;
} */

.stop-modal, .vehicle-modal {
    display: flex;
    flex-direction: column;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    margin-left: auto;
    margin-right: auto;
    width: calc(100% - 64px);
    height: var(--modal-start-height);
    max-width: 600px;
    box-shadow: var(--shadow-16);
    background-color: var(--bs-body-bg);
    border-radius: 16px 16px 0 0;
    user-select: none;
    -webkit-user-select: none;
    touch-action: none;
    transition: transform 225ms cubic-bezier(0, 0, 0.2, 1), height 225ms cubic-bezier(0, 0, 0.2, 1);
}

.stop-modal.resizing, .vehicle-modal.resizing {
    transition: transform 225ms cubic-bezier(0, 0, 0.2, 1);
}

.stop-modal.closed, .vehicle-modal.closed {
    transform: translateY(100%);
    box-shadow: none;
}

@media (max-width: 600px) {
    .stop-modal, .vehicle-modal {
        width: 100%;
        max-width: 100%;
    }
}

.stop-modal .spinner-border, .vehicle-modal .spinner-border, .brigade-modal .spinner-border {
    width: 3rem;
    height: 3rem;
    position: absolute;
    top: calc(50% - 1.5rem);
    left: calc(50% - 1.5rem);
}

.stop-modal .notice, .vehicle-modal .notice {
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    font-size: 18px;
    font-weight: 700;
    color: var(--bs-warning);
    z-index: -1;
}

.stop-modal .stop-header, .vehicle-header {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 8px;
    /* padding: 16px 16px 8px 16px; */
    padding: 12px 12px 8px 12px;
    cursor: ns-resize;
}

.stop-modal .stop-header::before, .vehicle-header::before {
    position: absolute;
    content: "";
    display: block;
    width: 36px;
    height: 4px;
    top: calc(8px);
    left: 50%;
    transform: translate(-50%);
    border-radius: 2px;
    background-color: var(--bs-secondary-color);
}

.stop-modal .stop-header .stop-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    background-color: var(--bs-secondary-bg);
    flex: 0 0 auto;
    width: 35px;
    height: 35px;
    padding: 6px;
    border-radius: 10px;
    user-select: none;
    -webkit-user-select: none;
}

.stop-modal .stop-header .stop-icon::before {
    content: "";
    position: absolute;
    inset: 6px;
    background-color: var(--bs-body-color);
    mask-image: url(../images/stop_icon.svg);
}

.stop-modal .stop-header .stop-name {
    font-weight: 700;
    user-select: none;
    -webkit-user-select: none;
}

.stop-modal .arrivals, .vehicle-modal .route {
    display: flex;
    flex-direction: column;
    overflow-y: auto;
}

.stop-modal .arrivals .arrival, .vehicle-modal .route .stop {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 16px;
    border-radius: 16px;
    user-select: none;
    -webkit-user-select: none;
    transition: background-color 0.3s;
    cursor: pointer;
}

.stop-modal .arrivals .arrival:active, .vehicle-modal .route .stop:active {
    background-color: var(--button-active);
}

.stop-modal .arrivals .arrival .arrival-header, .vehicle-modal .stop .stop-details {
    display: flex;
    flex-direction: column;
}

.stop-modal .arrivals .arrival .arrival-header .line-info, .line-info {
    display: flex;
}

.stop-modal .arrivals .arrival .line.metro .icon, .line-info .line.metro .icon {
    background-image: url(../images/metro_icon.svg);
}

.stop-modal .arrivals .arrival .line.metro .number, .line-info .line.metro .number {
    border-radius: 50%;
    width: 24px;
}

.stop-modal .arrivals .arrival .line.M1 .number, .line-info .line.M1 .number {
    background-color: var(--M1);
}

.stop-modal .arrivals .arrival .line.M2 .number, .line-info .line.M2 .number {
    background-color: var(--M2);
}

.stop-modal .arrivals .arrival .line.M3 .number, .line-info .line.M3 .number {
    background-color: var(--M3);
}

.stop-modal .arrivals .arrival .line.M4 .number, .line-info .line.M4 .number {
    background-color: var(--M4);
    color: #000;
}

.stop-modal .arrivals .arrival .destination, .line-info .destination {
    white-space: nowrap;
    overflow-x: hidden;
    text-overflow: ellipsis;
}

/* .stop-modal .arrivals .arrival .times {
    margin-left: auto;
    padding-left: 5px;
    white-space: nowrap;
} */

.stop-modal .arrivals .arrival .arrival-details, .vehicle-modal .stop .arrival-details {
    display: flex;
    gap: 4px;
}

.stop-modal .arrivals .arrival .arrival-details, .vehicle-modal .stop .arrival-details, .arrival-time .unit {
    /* display: flex;
    justify-content: space-between; */
    font-size: 14px;
    color: var(--bs-secondary-color);
}

.stop-modal .arrivals .arrival .arrival-time, .vehicle-modal .stop .arrival-time {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}

.stop-modal .arrivals .arrival .arrival-details .gps {
    display: inline-block;
    text-align: center;
    background-color: var(--bs-secondary-color);
    background-size: contain;
    background-repeat: no-repeat;
    vertical-align: middle;
    height: 20px;
    width: 20px;
}

.stop-modal .arrivals .arrival .arrival-details .gps-on {
    mask-image: url(../images/location_gps_icon.svg);
}

.stop-modal .arrivals .arrival .arrival-details .gps-off {
    mask-image: url(../images/location_off_icon.svg);
}

.stop-modal .arrivals .arrival .arrival-details .delay, .vehicle-modal .stop .arrival-details .delay {
    font-weight: 700;
}

.stop-modal .arrivals .arrival .arrival-details .delay.delay-none, .vehicle-modal .stop .arrival-details .delay.delay-none {
    color: var(--delay-none);

    .gps {
        background-color: var(--delay-none);
    }
}
.stop-modal .arrivals .arrival .arrival-details .delay.delay-early, .vehicle-modal .stop .arrival-details .delay.delay-early {
    color: var(--delay-early);

    .gps {
        background-color: var(--delay-early);
    }
}

.stop-modal .arrivals .arrival .arrival-details .delay.delay-delayed, .vehicle-modal .stop .arrival-details .delay.delay-delayed {
    color: var(--delay-delayed);

    .gps {
        background-color: var(--delay-delayed);
    }
}

.vehicle-modal .line-info.big {
    cursor: pointer;
    overflow-x: hidden;
    user-select: none;
    -webkit-user-select: none;
}

.line-info.big {
    font-size: 1.125rem;
}

.line-info.big .line {
    height: 1.75rem;
}

.line-info.big .line .icon {
    width: 1.75rem !important;
    height: 1.75rem !important;
}

.line-info.big .line .number {
    width: 3.5rem !important;
}

.line-info.big .line .number.big {
    width: 4.5rem !important;
    border-radius: 0.4375rem !important;
}

.line-info.big .line .number.big .brigade-number {
    font-size: 14px;
}

.vehicle-modal .route .stop.departed {
    opacity: 0.5;
}

.filter-modal .filter-list .filter {
    display: inline-flex;
    align-items: center;
    min-width: 50%;
    height: 40px;
    border-radius: 20px;
    background-color: var(--bs-secondary-bg);
    font-size: 1rem;
    padding-right: 14px;
}

.filter-modal .filter-list .filter input {
    width: 100%;
    margin: 0;
    padding: 8px 8px 8px 0px;
    background: none;
    border: none;
}

.filter-modal .filter-list .filter select {
    width: 100%;
    margin: 0px 0px 0px 14px;
    padding: 8px 0px;
    background-color: var(--bs-secondary-bg);
    border: none;
}

.filter-modal .filter-list .filter input:focus, .filter-modal .filter-list .filter select:focus {
    outline: none;
}

.filter-modal .filter-list .filter input::-webkit-search-cancel-button {
    appearance: none;
    height: 1.5em;
    width: 1.5em;
    background: url(../images/close_circle_icon.svg) no-repeat 50% 50%;
    background-size: contain;
    opacity: 1;
}

.custom-dropdown-menu {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: 60px;
    right: 60px;
    background: var(--bs-secondary-bg);
    box-shadow: var(--shadow-8);
    border-radius: 12px;
    padding: 0;
    overflow: hidden;
    user-select: none;
    -webkit-user-select: none;
    transition: opacity 225ms cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 100;
}

.custom-dropdown-menu .custom-dropdown-item {
    padding: 10px;
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    transition: background-color 0.3s;
}

.custom-dropdown-menu .custom-dropdown-item.disabled {
    color: #999;
    cursor: not-allowed;
}

.dropdown-item-icon {
    display: inline-block;
    background-color: var(--bs-body-color);
    background-size: contain;
    background-repeat: no-repeat;
    vertical-align: middle;
    width: 20px;
    height: 20px;
}

.dropdown-item-icon.share {
    mask-image: url(../images/share_icon.svg);
}

.dropdown-item-icon.brigade {
    mask-image: url(../images/brigade_icon.svg);
}

.dropdown-item-icon.info {
    mask-image: url(../images/info_icon.svg);
}

.cities-modal .cities-header {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 4px;
    padding: 24px 24px 0px 24px;
    text-align: center;
}

.cities-list {
    display: flex;
    flex-direction: column;
    align-items: center;
    overflow-y: auto;
    gap: 4px;
    padding: 8px;
}

.cities-list .city {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    padding: 10px 20px;
    border-radius: 5px;
    background-color: var(--bs-secondary-bg);
    cursor: pointer;
    transition: background-color 0.3s, font-weight 0.1s;
}

@media (hover: hover) and (pointer: fine) {
    .cities-list .city:hover {
        background-color: var(--button-hover);
    }
}

.cities-list .city:active {
    background-color: var(--button-active);
}

.cities-list .city .city-info {
    display: flex;
    flex-direction: column;
}

.cities-list .city-info .name {
    font-size: 18px;
}

.cities-list .city-info .details {
    color: var(--bs-secondary-color);
}

.cities-list .city .arrow {
    display: inline-block;
    flex-shrink: 0;
    background-color: var(--bs-body-color);
    width: 25px;
    height: 25px;
    mask-image: url(../images/arrow_right.svg);
    mask-size: contain;
    mask-repeat: no-repeat;
}

.logo {
    background-color: var(--bs-body-color);
    width: 128px;
    height: 128px;
    mask-image: url(../images/logo.svg);
    mask-size: contain;
    mask-repeat: no-repeat;
}

.brigade-modal .line-info {
    margin-left: 24px;
    margin-bottom: 8px;
}

.brigade-modal .trip-list {
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    padding: 0 8px 8px 8px;
}

.brigade-modal .trip .inner {
    display: flex;
    flex-wrap: nowrap;
    flex-direction: column;
    overflow-x: auto;
    padding: 8px 16px;
    border-radius: 16px;
    background-color: var(--bs-secondary-bg);
    cursor: pointer;
    transition: background-color 0.3s;
}

.brigade-modal .trip .trip-stop {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 4px;
}

.brigade-modal .trip .trip-stop .time {
    font-size: 14px;
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.05em;
}

.brigade-modal .trip .trip-stop .name {
    font-weight: 700;
    white-space: nowrap;
    overflow-x: hidden;
    text-overflow: ellipsis;
}

.brigade-modal .trip .trip-details {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 14px;
    color: var(--bs-secondary-color);
    /* margin-left: 52px; */
}

.brigade-modal .trip .trip-details .arrow {
    display: inline-block;
    flex-shrink: 0;
    background-color: var(--bs-body-color);
    width: 35px;
    height: 20px;
    margin-right: 8px;
    mask-image: url(../images/arrow_down.svg);
    mask-size: contain;
    mask-position: center;
    mask-repeat: no-repeat;
}

.brigade-modal .trip-list .trip .break-time {
    font-size: 14px;
    color: var(--bs-secondary-color);
    margin-left: 16px;
}

:root {
    --bus: #519dd5;
    --bus-dark: #2870a6;
    --tram: var(--bus);
    --tram-dark: var(--bus-dark);
    --trolley: var(--bus);
    --trolley-dark: var(--bus-dark);
    --night: var(--bus);
    --night-dark: var(--bus-dark);
    --trolley: var(--bus);
    --trolley-dark: var(--bus-dark);
    --cgm-light: #2d54a4;
    --cgm-light-hover: #1f3b73;
    --cgm-dark: #0b265e;

    --text-primary: #e2e3dd;
    --text-secondary: rgba(255, 255, 255, 0.7);

    --button-bg: var(--bs-body-bg); /* #f8f9fa */
    --button-hover: #ced4db;
    --button-active: #b2bdc7;

    --delay-none: #1ea566;
    --delay-early: #ff9500;
    --delay-delayed: #dc3545;

    --shadow-6: 0px 3px 5px -1px rgba(0, 0, 0, 0.2), 0px 6px 10px 0px rgba(0, 0, 0, 0.14), 0px 1px 18px 0px rgba(0, 0, 0, 0.12);
    --shadow-8: 0px 5px 5px -3px rgba(0,0,0,0.2),0px 8px 10px 1px rgba(0,0,0,0.14),0px 3px 14px 2px rgba(0,0,0,0.12);
    --shadow-16: 0px 8px 10px -5px rgba(0, 0, 0, 0.2), 0px 16px 24px 2px rgba(0, 0, 0, 0.14), 0px 6px 30px 5px rgba(0, 0, 0, 0.12);
}

[data-bs-theme=dark] {
    color-scheme: dark;

    --button-bg: var(--bs-secondary-bg);
    /* --button-hover: #2b3035; */
    --button-hover: #464e56;
    --button-active: #57616b;

    --delay-none: #24c279;
    --delay-early: #ffc107;
    --delay-delayed: #ff6966;
}

[data-bs-theme=dark][data-bs-theme-amoled] {
    --bs-body-bg: #000;
    --bs-secondary-bg: #1a1a1a;
    
    --button-hover: #313131;
    --button-active: #484848;

    .bg-dark {
        background-color: var(--bs-body-bg) !important;
    }
}