/* Global */

html, body {
    background-color: #f6f9fc;
    color: #000000;
}

a {
    text-decoration: none;
    color: inherit;
}

.label {
    color: #000000;
}

.secondaryLabel {
    color: #00000099;
}

.tertiaryLabel {
    color: #0000004D;
}

.map {
    background-color: #f6f2e7;
}

.real-time {
    color: #16A34A;
}

.cancelled {
    color: #C52925;
}

@media (prefers-color-scheme: dark) {
    html, body {
        background-color: #222324;
        color: #ffffff;
    }

    .label {
        color: #FFFFFFFF;
    }

    .secondaryLabel {
        color: #FFFFFF99;
    }

    .tertiaryLabel {
        color: #FFFFFF4D;
    }

    .real-time {
        color: #75FB99;
    }

    .cancelled {
        color: #ED7267;
    }
}

/* Nav bar */

.navbar {
    background-color: #eff1f6;
    padding: 12px 8px 12px 8px;
    position: relative;
}

@media (min-width: 768px) {
    .navbar {
        padding: 12px 16px 12px 16px;
    }
}

.navbar .navbar-brand {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    padding: 0;
}

.navbar .navbar-brand .site-title {
    margin-left: 8px;
}

.navbar .navbar-brand .site-title h1 {
    margin: 0;
    padding: 0;
    color: #000000;
    font-size: 1.2rem;
    font-weight: 600;
}

.navbar .navbar-brand .site-title h2 {
    margin: 0;
    padding: 0;
    color: #00000099;
    font-size: 0.7rem;
    font-weight: 400;
}

@media (prefers-color-scheme: dark) {
    .navbar {
        background-color: #191b1e;
    }

    .navbar .navbar-brand .site-title h1 {
        color: #ffffff;
    }

    .navbar .navbar-brand .site-title h2 {
        color: #ffffff99;
    }

}

/* Navbar Search */

.navbar .search-input {
    background-color: #ffffff;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12);
}

.navbar .search-input:focus {
    background-color: #ffffff;
}

@media (prefers-color-scheme: dark) {
    .navbar .search-input {
        background-color: #191b1e;
        border: solid 1px #4e4e4e;
        color: #ffffff;
    }

    .navbar .search-input:hover {
        border-color: #ffffff;
    }

    .navbar .search-input::placeholder {
        color: #949494;
    }

    .navbar .search-input:focus {
        background-color: #191b1e;
        border: solid 1px #ffffff;
        color: #ffffff;
    }
}

/* Search Autocomplete */

.autocomplete-results {
    background: rgba(255, 255, 255, 0.7);
    backdrop-filter: blur(32px);
    -webkit-backdrop-filter: blur(32px);
    border-radius: 12px;
    padding: 0;
}

.autocomplete-results .dropdown-item {
    display: flex;
    justify-content: flex-start;
    align-items: center;
}

.autocomplete-results .place-name-container {
    display: block;

    /* Constrain to parent */
    max-width: 100%;
    box-sizing: border-box;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap; /* optional if you want it all in one line */
}

.autocomplete-results .dropdown-item .title,
.autocomplete-results .dropdown-item .subtitle {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    display: block;
    margin: 0;
    padding: 0;
}

.autocomplete-results .dropdown-item .icon {
    display: inline-block;
    width: 32px;
    height: 32px;
    min-width: 32px;
    max-width: 32px;
    min-height: 32px;
    max-height: 32px;
    margin-right: 8px;
    background-size: 32px 32px;
}

.autocomplete-results .dropdown-item .title {
    font-size: 1rem;
    font-weight: 700;
    color: #000000;
}

.autocomplete-results .dropdown-item .subtitle {
    font-size: 0.8rem;
    font-weight: 400;
    color: #00000099;
}

.autocomplete-results .dropdown-item:hover, .autocomplete-results .dropdown-item:focus {
    background-color: #e0e0e0;
}

.autocomplete-results .dropdown-item .search-icon {
    background-image: url("/images/live-bus-times/autocomplete-search.png");
}

.autocomplete-results .dropdown-item .current-location-icon {
    background-image: url("/images/live-bus-times/autocomplete-user-location.png");
}

@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
    .autocomplete-results .dropdown-item .search-icon {
        background-image: url("/images/live-bus-times/autocomplete-search@2x.png");
    }

    .autocomplete-results .dropdown-item .current-location-icon {
        background-image: url("/images/live-bus-times/autocomplete-user-location@2x.png");
    }
}

@media (-webkit-min-device-pixel-ratio: 3), (min-resolution: 288dpi) {
    .autocomplete-results .dropdown-item .search-icon {
        background-image: url("/images/live-bus-times/autocomplete-search@3x.png");
    }

    .autocomplete-results .dropdown-item .current-location-icon {
        background-image: url("/images/live-bus-times/autocomplete-user-location@3x.png");
    }
}

@media (prefers-color-scheme: dark) {
    .autocomplete-results .dropdown-item .search-icon {
        background-image: url("/images/live-bus-times/autocomplete-search-dark.png");
    }

    @media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
        .autocomplete-results .dropdown-item .search-icon {
            background-image: url("/images/live-bus-times/autocomplete-search-dark@2x.png");
        }
    }

    @media (-webkit-min-device-pixel-ratio: 3), (min-resolution: 288dpi) {
        .autocomplete-results .dropdown-item .search-icon {
            background-image: url("/images/live-bus-times/autocomplete-search-dark@3x.png");
        }
    }
}

@media (prefers-color-scheme: dark) {
    .autocomplete-results {
        background: rgba(39, 39, 39, 0.7);
        border: solid 1px #363636;
        box-shadow: 0 16px 32px rgba(0, 0, 0, 0.5);
    }

    .autocomplete-results .dropdown-item {
        color: #ffffff;
    }

    .autocomplete-results .dropdown-item:hover, .autocomplete-results .dropdown-item:focus {
        background-color: #4e4d4e;
    }

    .autocomplete-results .dropdown-item .title {
        color: #FFFFFF;
    }

    .autocomplete-results .dropdown-item .subtitle {
        color: #FFFFFF99;
    }
}


.autocomplete-results .dropdown-item:not(:last-child) {
    border-bottom: solid 1px #0000001F;
}

@media (prefers-color-scheme: dark) {
    .autocomplete-results .dropdown-item:not(:last-child) {
        border-bottom: solid 1px #FFFFFF1F;
    }
}

.navbar .autocomplete-results {
    overflow-y: auto;
    overflow-x: hidden;
    white-space: normal;
    word-wrap: break-word;
    width: 100%;
    padding: 0;
}

@media (min-width: 768px) {
    .navbar .autocomplete-results {
        width: 320px;
        max-width: 320px;
        right: 0;
        left: auto;
        position: absolute;
        top: calc(100% + 4px);
        z-index: 1080;
    }
}

/* Breadcrumbs */

nav.breadcrumbs {
    padding: 14px 18px 14px 18px;
    margin: 0;
    overflow-x: auto;
    overflow-y: hidden;
    -ms-overflow-style: none;  /* Hide scrollbar IE/Edge */
    scrollbar-width: none;  /* Hide scrollbar Firefox */
    white-space: nowrap;
    border-bottom: solid 1px #e0e0e0;
    font-size: 0.9rem;
}

nav.breadcrumbs::-webkit-scrollbar {
    display: none; /* Hide scrollbar Chrome/Safari/WebKit */
}

nav.breadcrumbs ol {
    margin: 0;
    padding: 0;
}

nav.breadcrumbs li a,
nav.breadcrumbs .breadcrumb-item + .breadcrumb-item::before /* Breadcrumb divider */ {
    color: #00000070;
}

nav.breadcrumbs li.active a {
    color: #000000;
    font-weight: 500;
}

nav.breadcrumbs li a:hover {
    color: #007AFF;
}

@media (prefers-color-scheme: dark) {
    nav.breadcrumbs {
        border-bottom: solid 1px #ffffff20;
    }

    nav.breadcrumbs li a,
    nav.breadcrumbs .breadcrumb-item + .breadcrumb-item::before /* Breadcrumb divider */ {
        color: #ffffff70;
    }

    nav.breadcrumbs li.active a {
        color: #ffffff;
    }

    nav.breadcrumbs li a:hover {
        color: #0A84FF;
    }
}


/* Force single-line, horizontally scrolling breadcrumbs */
nav.breadcrumbs ol,
nav.breadcrumbs .breadcrumb {
    display: flex;
    flex-wrap: nowrap; /* override Bootstrap's wrap */
    align-items: center;
}

nav.breadcrumbs .breadcrumb-item {
    flex: 0 0 auto;       /* don't shrink */
    white-space: nowrap;  /* keep each item on one line */
}

nav.breadcrumbs .breadcrumb-item:last-child {
    padding-right: 18px;
}

nav.breadcrumbs .breadcrumb-item a {
    display: inline-block; /* avoid inline wrapping quirks */
}

/* Ensure the divider never wraps to a new line */
nav.breadcrumbs .breadcrumb-item + .breadcrumb-item::before {
    white-space: nowrap;
}



/* Mobile searchbar behaviour */
@media (max-width: 768px) {
    .navbar { display: flex; align-items: center; gap: .5rem; }
    /* default: short search */
    .navbar .search-form { flex: 0 0 auto; }
    .navbar .search-input { width: 140px; }

    /* when open on mobile: hide brand + let search take all space */
    .navbar.search-open .navbar-brand { display: none; }
    .navbar.search-open .search-form { flex: 1 1 auto; }
    .navbar.search-open .search-input { width: 100%; }

    .navbar .clear-btn {
        display: none;
        position: absolute;
        right: 10px;
        top: 50%;
        transform: translateY(-50%);
        background: none;
        border: none;
        font-size: 1.2rem;
        cursor: pointer;
    }
    .navbar.search-open .clear-btn {
        display: block;
    }
}

@media (min-width: 768px) {
    .navbar .clear-btn {
        display: none;
    }
}

/* Footer */

footer {
    background-color: #00000020;
    border-top: solid 4px #9333ea;
    margin-top: 48px;
}

footer p {
    font-size: 0.8rem;
}

@media (prefers-color-scheme: dark) {
    footer {
        border-top: solid 4px #6b21a8;
    }
}

footer .momego-logo {
    display: block;
    width: 192px;
    height: 37.5px;
    background-image: url("/images/live-bus-times/momego-horizontal.png");
    background-size: 192px 37.5px;
    margin-bottom: 6px;
}

@media (prefers-color-scheme: dark) {
    footer .momego-logo {
        background-image: url("/images/live-bus-times/momego-horizontal-dark.png");
    }
}

footer .app-store-badges a {
    margin-right: 6px;
}

/* Global Content Styles */

.section h2 {
    font-size: 1.2rem;
    font-weight: 500;
    margin: 0 0 16px 0;
}

.section h3 {
    font-size: 1rem;
    font-weight: 500;
    margin: 24px 0 16px 0;
}

.content-panel {
    background-color: #ffffff;
    display: block;
    justify-content: flex-start;
    align-items: baseline;
    width: 100%;
    padding: 14px 18px 12px 18px;
    border-radius: 32px;
    margin-bottom: 16px;
    overflow: hidden;
    border: solid 0.5px #00000015;
    box-shadow: 0 6px 55px rgba(0, 0, 0, 0.08);
}

@media (prefers-color-scheme: dark) {
    .content-panel {
        background-color: #ffffff10;
        border: solid 0.5px #ffffff25;
    }
}

.item-default-padding {
    padding: 14px 18px 14px 18px;
}

.item-bottom-separator:not(:last-child) {
    border-bottom: solid 1px #0000001F;
}

@media (prefers-color-scheme: dark) {
    .item-bottom-separator:not(:last-child) {
        border-bottom: solid 1px #FFFFFF1F;
    }
}

.content-panel-no-padding {
    padding: 0;
}

.highlight-on-hover:hover {
    background-color: #00000011;
}

@media (prefers-color-scheme: dark) {
    .highlight-on-hover:hover {
        background-color: #FFFFFF11;
    }
}

.link:hover {
    color: #007AFF;
}

@media (prefers-color-scheme: dark) {
    .link:hover {
        color: #0A84FF;
    }
}

/* Page Title */

.page-title {
    padding: 32px 24px 32px 24px;
    text-align: center;
}

.page-title h1 {
    margin: 0;
    font-weight: 700;
}

.page-title h2 {
    margin: 2px 0 0 0;
    font-size: 1.4rem;
    font-weight: 500;
}

.page-title p {
    margin: 8px 0 0 0;
    font-size: 0.9rem;
    font-weight: 600;
}

/* Linkable content */

.disclosure-arrow {
    display: inline-block;
    width: 16px;
    height: 16px;
    min-width: 16px;
    max-width: 16px;
    min-height: 16px;
    max-height: 16px;
    background-size: 16px 16px;
    background-image: url("/images/live-bus-times/disclosure-arrow.png");
}

@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
    .disclosure-arrow {
        background-image: url("/images/live-bus-times/disclosure-arrow@2x.png");
    }
}

@media (-webkit-min-device-pixel-ratio: 3), (min-resolution: 288dpi) {
    .disclosure-arrow {
        background-image: url("/images/live-bus-times/disclosure-arrow@3x.png");
    }
}

@media (prefers-color-scheme: dark) {
    .disclosure-arrow {
        background-image: url("/images/live-bus-times/disclosure-arrow-dark.png");
    }

    @media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
        .disclosure-arrow {
            background-image: url("/images/live-bus-times/disclosure-arrow-dark@2x.png");
        }
    }

    @media (-webkit-min-device-pixel-ratio: 3), (min-resolution: 288dpi) {
        .disclosure-arrow {
            background-image: url("/images/live-bus-times/disclosure-arrow-dark@3x.png");
        }
    }
}

/* Map Containers */

.map-container {
    background-color: #f6f2e790;
    border-radius: 32px;
    overflow: hidden;
    border: solid 0.5px #00000025;
    box-shadow: 0 6px 55px rgba(0, 0, 0, 0.08);
}

@media (prefers-color-scheme: dark) {
    .map-container {
        background-color: #34445990;
        border: solid 0.5px #ffffff25;
    }
}

.small-map, .medium-map {
    height: 270px;
}

@media (min-width: 768px) {
    .small-map {
        height: 270px;
    }

    .medium-map {
        height: 500px;
    }
}






