:root {
    --anante-navy: #0d1b2a;
    --anante-navy-light: #1b2838;
    --anante-orange: #e85d04;
    --anante-orange-hover: #dc5803;
    --bs-primary: #e85d04;
    --bs-primary-rgb: 232, 93, 4;
    --bs-btn-bg: #e85d04;
    --bs-btn-border-color: #e85d04;
    --bs-btn-hover-bg: #dc5803;
    --bs-btn-hover-border-color: #dc5803;
    --bs-btn-active-bg: #c44f03;
    --bs-btn-active-border-color: #c44f03;
    --anante-bg: #ffffff;
    --anante-surface: #f4f6f8;
    --anante-lavender: #ffffff;
    --anante-text: #0d1b2a;
    --anante-text-muted: #5c6778;
    --anante-border: #e2e8f0;
    --anante-header-height: 72px;
    --anante-radius: 12px;
    --anante-shadow: 0 4px 24px rgba(13, 27, 42, 0.08);
    --anante-font: "Inter", "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
}

html {
    scroll-behavior: smooth;
}

body {
    font-family: var(--anante-font);
    color: var(--anante-text);
    background-color: var(--anante-bg);
    margin: 0;
}

a {
    color: var(--anante-navy);
    text-decoration: none;
}

a:hover {
    color: var(--anante-orange);
}

.btn-primary,
.home-form-card .btn-primary,
.home-form-card button[type="submit"].btn-primary {
    --bs-btn-color: #fff;
    --bs-btn-bg: var(--anante-orange);
    --bs-btn-border-color: var(--anante-orange);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: var(--anante-orange-hover);
    --bs-btn-hover-border-color: var(--anante-orange-hover);
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #c44f03;
    --bs-btn-active-border-color: #c44f03;
    --bs-btn-focus-shadow-rgb: 232, 93, 4;
    color: #fff;
    background-color: var(--anante-orange);
    border-color: var(--anante-orange);
    border-radius: 6px;
    font-weight: 600;
    padding: 0.6rem 1.5rem;
}

.btn-primary:hover,
.btn-primary:focus-visible,
.btn-primary:active {
    color: #fff;
    background-color: var(--anante-orange-hover);
    border-color: var(--anante-orange-hover);
}

.btn-outline-primary {
    --bs-btn-color: var(--anante-orange);
    --bs-btn-border-color: var(--anante-orange);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: var(--anante-orange);
    --bs-btn-hover-border-color: var(--anante-orange);
}

/* App shell */
.anante-app {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.anante-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: var(--anante-bg);
    border-bottom: 1px solid var(--anante-border);
    box-shadow: 0 1px 0 rgba(13, 27, 42, 0.04);
}

/* Mobile menu backdrop — hidden on desktop; only shown on small screens when menu is open */
.anante-mobile-nav-backdrop {
    display: none;
    appearance: none;
    border: none;
    padding: 0;
    margin: 0;
}

.anante-header-inner {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    min-height: var(--anante-header-height);
    padding: 0.5rem 1.5rem;
    max-width: 1400px;
    margin: 0 auto;
}

.anante-brand {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    flex-shrink: 0;
    text-decoration: none;
    color: var(--anante-navy);
}

.anante-brand:hover {
    color: var(--anante-navy);
}

.anante-brand-logo {
    height: 40px;
    width: auto;
}

.anante-brand-text {
    display: flex;
    flex-direction: column;
    line-height: 1.1;
}

.anante-brand-name {
    font-size: 1.15rem;
    font-weight: 800;
    letter-spacing: 0.06em;
}

.anante-brand-sub {
    font-size: 0.75rem;
    font-weight: 400;
    letter-spacing: 0.2em;
    color: var(--anante-text-muted);
}

.anante-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 1;
    gap: 0.25rem;
    flex-wrap: nowrap;
}

.anante-nav-link {
    position: relative;
    padding: 0.5rem 0.85rem;
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--anante-navy);
    text-decoration: none;
    border-radius: 4px;
    transition: color 0.15s ease;
}

.anante-nav-link:hover {
    color: var(--anante-orange);
}

.anante-nav-link.active {
    color: var(--anante-navy);
    font-weight: 600;
}

.anante-nav-link.active::after {
    content: "";
    position: absolute;
    left: 0.85rem;
    right: 0.85rem;
    bottom: 0;
    height: 3px;
    background: var(--anante-orange);
    border-radius: 2px 2px 0 0;
}

.anante-header-actions {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-shrink: 0;
}

.anante-user-link {
    display: flex;
    color: var(--anante-navy);
}

.anante-user-avatar {
    display: flex;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--anante-surface);
    border: 1px solid var(--anante-border);
    align-items: center;
    justify-content: center;
}

.anante-user-avatar svg {
    width: 22px;
    height: 22px;
}

.anante-logout-form {
    margin: 0;
}

.anante-logout-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    background: none;
    border: none;
    padding: 0.35rem 0.5rem;
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--anante-navy);
    cursor: pointer;
}

.anante-logout-btn:hover {
    color: var(--anante-orange);
}

.anante-chevron {
    width: 12px;
    height: 12px;
}

.anante-btn-register {
    padding: 0.35rem 0.9rem !important;
}

.anante-nav-toggle {
    display: none;
    flex-direction: column;
    gap: 5px;
    background: none;
    border: none;
    padding: 0.5rem;
    margin-left: auto;
}

.anante-nav-toggle span {
    display: block;
    width: 22px;
    height: 2px;
    background: var(--anante-navy);
}

.anante-main {
    flex: 1;
}

/* Home page */
.home-page {
    background: var(--anante-bg);
}

.home-hero {
    padding: 3.5rem 0 4rem;
    background: linear-gradient(180deg, #fff 0%, var(--anante-surface) 100%);
}

.home-hero__title {
    font-size: clamp(2rem, 4vw, 2.75rem);
    font-weight: 800;
    color: var(--anante-navy);
    line-height: 1.15;
    margin-bottom: 0.75rem;
}

.home-hero__subtitle {
    font-size: clamp(1.1rem, 2.5vw, 1.35rem);
    font-weight: 600;
    color: var(--anante-navy-light);
    margin-bottom: 1rem;
}

.home-hero__lead {
    font-size: 1.05rem;
    line-height: 1.65;
    color: var(--anante-text-muted);
    max-width: 32rem;
    margin-bottom: 1.75rem;
}

.home-hero__cta {
    min-width: 10rem;
}

.home-hero__image {
    width: 100%;
    max-width: 560px;
    height: auto;
    display: block;
    margin: 0 auto;
}

.home-contact-zone {
    background: var(--anante-lavender);
    padding-bottom: 4rem;
}

.home-contact-zone__banner {
    line-height: 0;
    margin: 0;
}

.home-contact-zone__image {
    width: 100%;
    height: auto;
    display: block;
    max-height: min(56vh, 540px);
    object-fit: cover;
    object-position: center 55%;
}

.home-contact-zone__cards {
    position: relative;
    z-index: 2;
    margin-top: clamp(-4rem, -7vw, -6rem);
    padding-bottom: 0.5rem;
}

.home-info-card__icon--image {
    width: auto;
    height: auto;
    max-width: 72px;
    margin-bottom: 1.25rem;
}

.home-info-card__icon--image img {
    width: 72px;
    height: 72px;
    object-fit: contain;
    display: block;
    margin: 0 auto;
}

.home-section {
    padding: 3.5rem 0;
}

.home-section--muted {
    background: var(--anante-surface);
}

.home-section--intro {
    background: var(--anante-bg);
    padding: 4rem 0 2.5rem;
}

.home-section--cards {
    background: var(--anante-bg);
    padding-top: 0;
    padding-bottom: 3.5rem;
}

.home-section__intro--lead {
    max-width: 42rem;
    margin-left: auto;
    margin-right: auto;
    font-size: 1.05rem;
    line-height: 1.65;
    color: var(--anante-text);
}

.home-form-card {
    background: var(--anante-bg);
    border-radius: var(--anante-radius);
    box-shadow: var(--anante-shadow);
    padding: 2rem 1.75rem;
    height: 100%;
    border: 1px solid rgba(13, 27, 42, 0.06);
}

.home-form-card__title {
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--anante-navy);
    margin-bottom: 0.65rem;
}

.home-form-card__intro {
    font-size: 0.95rem;
    color: var(--anante-text-muted);
    line-height: 1.55;
    margin-bottom: 1.25rem;
}

.quote-route-estimate {
    font-size: 0.9rem;
    padding: 0.75rem 1rem;
    background: var(--anante-surface-alt, #f8f9fa);
    border-radius: 0.375rem;
    border-left: 3px solid var(--anante-orange, #e85d04);
}

.home-contact-list {
    list-style: none;
    padding: 0;
    margin: 0 0 1.5rem;
}

.home-contact-list li {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    margin-bottom: 0.65rem;
    font-size: 0.95rem;
}

.home-contact-list a {
    color: var(--anante-navy);
    font-weight: 500;
    text-decoration: none;
}

.home-contact-list a:hover {
    color: var(--anante-orange);
}

.home-contact-list__icon {
    display: flex;
    color: var(--anante-orange);
    flex-shrink: 0;
}

.home-contact-list__icon svg {
    width: 20px;
    height: 20px;
}

.home-form-control {
    background-color: #f0f2f5 !important;
    border: 1px solid transparent !important;
    border-radius: 8px !important;
    padding: 0.65rem 0.85rem !important;
    font-size: 0.95rem;
}

.home-form-control:focus {
    background-color: #fff !important;
    border-color: var(--anante-orange) !important;
    box-shadow: 0 0 0 0.2rem rgba(232, 93, 4, 0.15) !important;
}

.home-form-card .form-label {
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--anante-navy);
    margin-bottom: 0.35rem;
}

.home-form-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: center;
    margin-top: 0.5rem;
}

.home-form-actions .btn-primary {
    min-width: 10rem;
    padding: 0.65rem 1.5rem;
}

.home-btn-cancel.btn-primary {
    background-color: var(--anante-orange);
    border-color: var(--anante-orange);
    color: #fff;
    font-weight: 600;
    padding: 0.65rem 1.5rem;
    opacity: 0.92;
}

.home-btn-cancel.btn-primary:hover {
    opacity: 1;
    background-color: var(--anante-orange-hover);
    border-color: var(--anante-orange-hover);
    color: #fff;
}

.home-section__header {
    max-width: 640px;
    margin: 0 auto 2.5rem;
}

.home-section__title {
    font-size: clamp(1.5rem, 3vw, 2rem);
    font-weight: 800;
    color: var(--anante-navy);
    margin-bottom: 0.75rem;
}

.home-section__intro {
    font-size: 1.05rem;
    color: var(--anante-text-muted);
    line-height: 1.6;
    margin: 0;
}

.home-info-card {
    background: var(--anante-bg);
    border-radius: var(--anante-radius);
    box-shadow: var(--anante-shadow);
    padding: 2rem 1.5rem;
    height: 100%;
    text-align: center;
    border: 1px solid var(--anante-border);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.home-info-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 32px rgba(13, 27, 42, 0.12);
}

.home-info-card__icon {
    width: 56px;
    height: 56px;
    margin: 0 auto 1.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.home-info-card__icon svg {
    width: 48px;
    height: 48px;
}

.home-info-card__icon--orange {
    color: var(--anante-orange);
}

.home-info-card__icon--navy {
    color: var(--anante-navy);
}

.home-info-card__title {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--anante-navy);
    margin-bottom: 0.65rem;
}

.home-info-card__text {
    font-size: 0.95rem;
    color: var(--anante-text-muted);
    line-height: 1.55;
    margin: 0;
}

.anante-page-title {
    font-weight: 700;
    color: var(--anante-navy);
}

.anante-card {
    background: var(--anante-bg);
    border: 1px solid var(--anante-border);
    border-radius: var(--anante-radius);
    box-shadow: var(--anante-shadow);
}

.anante-placeholder {
    color: var(--anante-text-muted);
    padding: 2rem;
    border: 1px dashed var(--anante-border);
    background: var(--anante-surface);
    border-radius: var(--anante-radius);
}

@media (max-width: 991.98px) {
    .anante-nav-toggle {
        display: flex;
        z-index: 1032;
    }

    .anante-nav {
        display: none;
        position: fixed;
        top: var(--anante-header-height);
        left: 0;
        right: 0;
        flex-direction: column;
        align-items: stretch;
        background: var(--anante-bg);
        border-bottom: 1px solid var(--anante-border);
        padding: 1rem;
        box-shadow: var(--anante-shadow);
        z-index: 1050;
        max-height: calc(100vh - var(--anante-header-height));
        overflow-y: auto;
    }

    .anante-nav.is-open {
        display: flex;
    }

    .anante-mobile-nav-backdrop {
        display: none;
        position: fixed;
        inset: 0;
        top: var(--anante-header-height);
        border: none;
        padding: 0;
        margin: 0;
        background: rgba(13, 27, 42, 0.35);
        z-index: 1040;
        cursor: pointer;
    }

    .anante-mobile-nav-backdrop.is-visible {
        display: block;
    }

    .anante-header-inner {
        flex-wrap: wrap;
        position: relative;
    }

    .anante-nav-link {
        padding: 0.65rem 0.85rem;
    }

    .anante-nav-link.active::after {
        left: 0;
        right: auto;
        width: 3rem;
    }

    html.anante-mobile-nav-open {
        overflow: hidden;
    }
}

/* Account / auth pages */
.account-page {
    min-height: 100vh;
    background: var(--anante-bg);
    position: relative;
    overflow: hidden;
}

.account-page__watermark {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: min(65vw, 800px);
    max-height: 90vh;
    pointer-events: none;
    z-index: 0;
    opacity: 0.32;
}

.account-page__watermark img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: contain;
    object-position: left center;
}

.account-page__inner {
    position: relative;
    z-index: 1;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 1rem 1.25rem 2rem;
}

.account-page__brand {
    margin-bottom: 0.65rem;
    text-align: center;
}

.account-page__brand-link {
    display: inline-block;
    text-decoration: none;
}

.account-page__logo {
    max-width: min(140px, 36vw);
    height: auto;
    display: block;
}

.account-page__main {
    flex: 1;
    width: 100%;
    max-width: 440px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}

.account-page__main:has(.account-card--wide) {
    max-width: 960px;
}

.account-page__footer {
    margin-top: 2.5rem;
    text-align: center;
}

.account-page__copyright,
.account-page__legal {
    font-size: 0.8rem;
    color: var(--anante-text-muted);
    margin: 0 0 0.35rem;
}

.account-page__legal a {
    color: var(--anante-text-muted);
    text-decoration: none;
}

.account-page__legal a:hover {
    color: var(--anante-navy);
    text-decoration: underline;
}

.account-card {
    width: 100%;
    background: var(--anante-bg);
    border-radius: var(--anante-radius);
    box-shadow: 0 8px 40px rgba(13, 27, 42, 0.1);
    border: 1px solid rgba(13, 27, 42, 0.06);
    padding: 2rem 2rem 1.75rem;
}

.account-card--wide {
    max-width: 920px;
    margin: 0 auto;
}

.account-card__title {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--anante-navy);
    margin: 0 0 1.25rem;
    text-align: left;
}

.account-card__intro,
.account-card__message {
    font-size: 0.95rem;
    color: var(--anante-text-muted);
    line-height: 1.55;
    margin: 0 0 1.25rem;
}

.account-card__message--danger {
    color: #b42318;
}

.account-card__link a,
.account-card__secondary-links a {
    color: var(--anante-navy);
    font-weight: 600;
    font-size: 0.9rem;
    text-decoration: none;
}

.account-card__link a:hover,
.account-card__secondary-links a:hover {
    color: var(--anante-orange);
    text-decoration: underline;
}

.account-card__secondary-links {
    margin-top: 1.25rem;
    padding-top: 1rem;
    border-top: 1px solid var(--anante-border);
}

.account-card__secondary-links p {
    margin: 0 0 0.5rem;
    font-size: 0.9rem;
}

.account-field__label {
    display: block;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--anante-navy);
    margin-bottom: 0.4rem;
}

.account-field__control {
    display: flex;
    align-items: center;
    border: 1px solid #d4dae3;
    border-radius: 8px;
    background: #fff;
    overflow: hidden;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.account-field__control:focus-within {
    border-color: var(--anante-orange);
    box-shadow: 0 0 0 3px rgba(232, 93, 4, 0.15);
}

.account-field__icon {
    flex-shrink: 0;
    width: 2.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #8a94a6;
}

.account-field__icon svg {
    width: 1.15rem;
    height: 1.15rem;
}

.account-field__input {
    border: none !important;
    box-shadow: none !important;
    padding: 0.7rem 0.85rem 0.7rem 0;
    font-size: 0.95rem;
    background: transparent !important;
}

.account-field__input:focus {
    outline: none;
    box-shadow: none !important;
}

.account-field__error,
.account-validation-summary {
    font-size: 0.85rem;
    color: #b42318;
    margin-top: 0.35rem;
}

.account-validation-summary {
    margin-bottom: 1rem;
}

.account-submit-btn {
    width: 100%;
    padding: 0.75rem 1rem;
    font-size: 1rem;
    font-weight: 700;
    border-radius: 8px;
}

.account-remember__label {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.9rem;
    color: var(--anante-text-muted);
    margin: 0;
    cursor: pointer;
}

button.account-passkey-link,
.account-passkey-link {
    background: none !important;
    border: none !important;
    padding: 0 !important;
    color: var(--anante-navy) !important;
    font-weight: 600;
    font-size: 0.9rem;
    text-decoration: none;
    box-shadow: none !important;
}

button.account-passkey-link:hover,
.account-passkey-link:hover {
    color: var(--anante-orange) !important;
    text-decoration: underline;
}

.account-manage {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 2rem;
    align-items: start;
}

.account-manage__content h3 {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--anante-navy);
    margin-bottom: 1rem;
}

.account-manage-nav .nav-link {
    color: var(--anante-text-muted);
    font-weight: 500;
    border-radius: 8px;
    padding: 0.5rem 0.85rem;
    margin-bottom: 0.2rem;
}

.account-manage-nav .nav-link.active,
.account-manage-nav .nav-link:hover {
    background: rgba(232, 93, 4, 0.1);
    color: var(--anante-navy);
}

.account-manage__content .form-floating > .form-control,
.account-manage__content .form-floating > .form-select {
    border-radius: 8px;
    border-color: #d4dae3;
}

.account-manage__content .btn-primary {
    min-width: 10rem;
}

@media (max-width: 767.98px) {
    .account-page__watermark {
        width: 95vw;
        opacity: 0.26;
        top: 40%;
    }

    .account-manage {
        grid-template-columns: 1fr;
    }

    .account-card--wide {
        padding: 1.5rem 1.25rem;
    }
}

/* Fleet */
.fleet-page {
    padding-top: 1.5rem;
    padding-bottom: 3rem;
}

.fleet-page__title {
    font-size: 2rem;
    font-weight: 800;
    color: var(--anante-navy);
    margin: 0 0 0.25rem;
}

.fleet-page__subtitle {
    color: var(--anante-text-muted);
    margin: 0;
    font-size: 1rem;
}

.fleet-diesel-bar {
    background: #fff;
    border: 1px solid #e8ecf2;
    border-radius: 12px;
    padding: 1.25rem 1.35rem;
    box-shadow: 0 2px 8px rgba(26, 35, 50, 0.04);
}

.fleet-diesel-bar__inner {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 2rem 2.5rem;
}

.fleet-diesel-bar__current {
    flex: 1 1 18rem;
    min-width: 0;
}

.fleet-diesel-bar__title {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--anante-navy);
    margin: 0 0 0.35rem;
}

.fleet-diesel-bar__entry {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 0.75rem;
}

.fleet-diesel-bar__history {
    flex: 0 0 auto;
    min-width: 12rem;
    padding-left: 0;
}

.fleet-diesel-bar__history-list {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.fleet-diesel-bar__history .fleet-diesel-history__item {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.15rem;
    min-width: 8.5rem;
}

.fleet-table__diesel-col {
    white-space: nowrap;
}

.fleet-diesel-dashboard {
    max-width: 36rem;
}

.fleet-diesel-card {
    background: #fff;
    border: 1px solid #e8ecf2;
    border-radius: 12px;
    padding: 1.25rem 1.35rem;
    box-shadow: 0 2px 8px rgba(26, 35, 50, 0.04);
}

.fleet-diesel-card__title {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--anante-navy);
    margin: 0 0 0.35rem;
}

.fleet-diesel-card__header {
    margin-bottom: 1rem;
}

.fleet-diesel-price-entry__row {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 0.75rem;
}

.fleet-diesel-price-input {
    flex: 1;
    min-width: 10rem;
    max-width: 14rem;
}

.fleet-diesel-history {
    margin-top: 1.25rem;
    padding-top: 1rem;
    border-top: 1px dashed #e0e6ef;
}

.fleet-diesel-history__list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.fleet-diesel-history__item {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.55rem 0.75rem;
    background: #f7f9fc;
    border-radius: 8px;
    border-left: 3px solid var(--anante-orange);
}

.fleet-diesel-history__amount {
    font-weight: 700;
    color: var(--anante-navy);
}

.fleet-diesel-history__date {
    font-size: 0.8rem;
    color: var(--anante-text-muted);
    white-space: nowrap;
}

.fleet-monthly-diesel-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    align-items: flex-start;
}

.fleet-monthly-diesel-stat__label {
    display: block;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--anante-text-muted);
    margin-bottom: 0.35rem;
}

.fleet-monthly-diesel-stat__value {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--anante-navy);
}

.fleet-monthly-diesel-stat--amount {
    flex: 1;
    min-width: 14rem;
}

.fleet-monthly-diesel-stat__edit {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 0.5rem;
}

.fleet-monthly-diesel-stat__edit .input-group {
    flex: 1;
    min-width: 10rem;
    max-width: 14rem;
}

.fleet-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
    margin: 1.5rem 0 1.25rem;
}

.fleet-toolbar__filters {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    flex: 1;
    min-width: 280px;
}

.fleet-filter__label {
    display: block;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--anante-navy);
    margin-bottom: 0.35rem;
}

.fleet-filter__control {
    min-width: 180px;
    border-radius: 8px;
    border-color: #d4dae3;
}

.fleet-filter--search {
    flex: 1;
    min-width: 220px;
}

.fleet-search {
    position: relative;
}

.fleet-search__icon {
    position: absolute;
    left: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--anante-text-muted);
    pointer-events: none;
}

.fleet-search__input {
    padding-left: 2.25rem;
    border-radius: 8px;
    border-color: #d4dae3;
}

.fleet-toolbar__add {
    white-space: nowrap;
    min-width: 8rem;
}

.fleet-table-wrap {
    background: #fff;
    border: 1px solid #e8ecf1;
    border-radius: 12px;
    overflow-x: auto;
    box-shadow: 0 2px 12px rgba(15, 39, 71, 0.06);
}

.fleet-table {
    margin: 0;
    font-size: 0.9rem;
}

.fleet-table thead th {
    background: #f6f8fb;
    color: var(--anante-navy);
    font-weight: 700;
    border-bottom: 1px solid #e8ecf1;
    white-space: nowrap;
    padding: 0.85rem 1rem;
}

.fleet-table tbody td {
    vertical-align: middle;
    padding: 0.85rem 1rem;
    border-color: #eef1f5;
}

.fleet-table__row--selected {
    background: rgba(232, 93, 4, 0.06);
}

.fleet-table__type {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    font-weight: 600;
    color: var(--anante-navy);
}

.fleet-table__type-icon {
    width: 36px;
    height: 36px;
    object-fit: contain;
}

.fleet-table__diesel {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.fleet-table__diesel-icon {
    font-size: 0.95rem;
}

.fleet-money-badge--expense {
    background-color: rgba(220, 53, 69, 0.12);
    color: #842029;
}

.fleet-money-badge--profit {
    background-color: rgba(25, 135, 84, 0.12);
    color: #0f5132;
}

.fleet-table__totals td {
    border-top: 2px solid var(--anante-navy);
    background-color: #f8f9fa;
    font-weight: 600;
}

.fleet-money-badge {
    display: inline-block;
    background: #d4edda;
    color: #155724;
    font-weight: 700;
    padding: 0.35rem 0.65rem;
    border-radius: 8px;
    white-space: nowrap;
}

.fleet-table__actions-col {
    width: 3rem;
    text-align: right;
}

.fleet-edit-btn {
    border: 1px solid #d4dae3;
    background: #fff;
    color: var(--anante-navy);
    border-radius: 8px;
    padding: 0.35rem 0.5rem;
}

.fleet-edit-btn:hover {
    border-color: var(--anante-orange);
    color: var(--anante-orange);
    background: rgba(232, 93, 4, 0.08);
}

.fleet-editor {
    margin-top: 2rem;
    padding: 1.75rem;
    background: #fff;
    border: 1px solid #e8ecf1;
    border-radius: 12px;
    box-shadow: 0 2px 12px rgba(15, 39, 71, 0.06);
}

.fleet-editor__title {
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--anante-navy);
    margin-bottom: 1.25rem;
}

.fleet-editor__section-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--anante-navy);
    margin: 0 0 0.75rem;
}

.fleet-editor__diesel-panel {
    margin-top: 1.25rem;
    padding: 1rem 1.25rem;
    background: #f8fafc;
    border-radius: 10px;
    border: 1px solid #e8ecf1;
}

.fleet-editor__diesel-calc {
    font-size: 0.9rem;
    color: var(--anante-text-muted);
}

.fleet-editor__financials {
    margin-top: 1rem;
}

.fleet-editor__profit-display {
    padding: 0.65rem 0.85rem;
    background: #f0f7f2;
    border: 1px solid #c3e6cb;
    border-radius: 8px;
    font-size: 0.95rem;
    color: var(--anante-navy);
}

.fleet-editor__actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.75rem;
    margin-top: 1.5rem;
    padding-top: 1rem;
    border-top: 1px solid #eef1f5;
}

.fleet-modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(15, 39, 71, 0.45);
    z-index: 1040;
}

.fleet-modal {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1050;
    width: min(420px, calc(100vw - 2rem));
    background: #fff;
    border-radius: 12px;
    padding: 1.5rem;
    box-shadow: 0 12px 40px rgba(15, 39, 71, 0.2);
}

.fleet-modal__title {
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--anante-navy);
    margin-bottom: 0.75rem;
}

.fleet-modal__text {
    margin-bottom: 0.5rem;
    font-weight: 500;
}

.fleet-modal__actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
    margin-top: 1.25rem;
}

@media (max-width: 767.98px) {
    .fleet-toolbar {
        flex-direction: column;
        align-items: stretch;
    }

    .fleet-toolbar__add {
        width: 100%;
    }
}

/* Drivers */
.drivers-page {
    padding-top: 1.5rem;
    padding-bottom: 3rem;
}

.drivers-page__title {
    font-size: 2rem;
    font-weight: 800;
    color: var(--anante-navy);
    margin: 0 0 0.25rem;
}

.drivers-page__subtitle {
    color: var(--anante-text-muted);
    margin: 0;
}

.drivers-toolbar,
.drivers-detail__toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
    margin: 1.5rem 0 1.25rem;
}

.drivers-toolbar__filters {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    flex: 1;
}

.drivers-filter__label {
    display: block;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--anante-navy);
    margin-bottom: 0.35rem;
}

.drivers-filter__control {
    min-width: 180px;
    border-radius: 8px;
    border-color: #d4dae3;
}

.drivers-filter--search {
    flex: 1;
    min-width: 220px;
}

.drivers-search {
    position: relative;
}

.drivers-search__icon {
    position: absolute;
    left: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--anante-text-muted);
    pointer-events: none;
}

.drivers-search__input {
    padding-left: 2.25rem;
    border-radius: 8px;
    border-color: #d4dae3;
}

.drivers-table-wrap {
    background: #fff;
    border: 1px solid #e8ecf1;
    border-radius: 12px;
    overflow-x: auto;
    box-shadow: 0 2px 12px rgba(15, 39, 71, 0.06);
}

.drivers-table {
    margin: 0;
    font-size: 0.9rem;
}

.drivers-table thead th {
    background: #f6f8fb;
    color: var(--anante-navy);
    font-weight: 700;
    padding: 0.85rem 1rem;
}

.drivers-table tbody td {
    vertical-align: middle;
    padding: 0.85rem 1rem;
}

.drivers-table__row {
    cursor: pointer;
}

.drivers-table__row--selected {
    background: rgba(232, 93, 4, 0.06);
}

.drivers-table__name {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.drivers-table__fullname {
    font-weight: 700;
    color: var(--anante-navy);
}

.drivers-table__meta {
    font-size: 0.85rem;
    color: var(--anante-text-muted);
    display: flex;
    align-items: center;
    gap: 0.35rem;
}

.drivers-avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    object-fit: cover;
    background: #e8ecf1;
}

.drivers-avatar--lg {
    width: 72px;
    height: 72px;
}

.drivers-avatar--xl {
    width: 96px;
    height: 96px;
}

.drivers-truck-badge {
    display: inline-block;
    background: #d6ebff;
    color: #0c4a6e;
    font-weight: 600;
    font-size: 0.8rem;
    padding: 0.25rem 0.55rem;
    border-radius: 6px;
}

.drivers-cut-hint {
    font-weight: 500;
    color: var(--anante-text-muted);
    font-size: 0.85em;
}

.drivers-cut-badge {
    display: inline-block;
    background: #d4edda;
    color: #155724;
    font-weight: 700;
    padding: 0.3rem 0.55rem;
    border-radius: 6px;
}

.drivers-cut-badge--total {
    font-size: 1.05rem;
}

.drivers-earnings-table__total td {
    border-top: 2px solid #dee2e6;
    padding-top: 0.85rem;
    background: #f8fafc;
}

.drivers-row-btn {
    border: 1px solid #d4dae3;
    background: #fff;
    border-radius: 8px;
}

.drivers-pagination {
    display: flex;
    justify-content: center;
    gap: 0.35rem;
    margin: 1.25rem 0 2rem;
}

.drivers-editor,
.drivers-detail {
    margin-top: 2rem;
    padding: 1.75rem;
    background: #fff;
    border: 1px solid #e8ecf1;
    border-radius: 12px;
    box-shadow: 0 2px 12px rgba(15, 39, 71, 0.06);
}

.drivers-editor__profile-upload {
    display: flex;
    align-items: center;
    gap: 1.25rem;
}

.drivers-editor__actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.75rem;
    margin-top: 1.5rem;
    padding-top: 1rem;
    border-top: 1px solid #eef1f5;
}

.drivers-breadcrumb {
    font-size: 0.9rem;
    margin-bottom: 1.25rem;
    color: var(--anante-text-muted);
}

.drivers-breadcrumb__link {
    color: var(--anante-navy);
    font-weight: 600;
    text-decoration: none;
}

.drivers-breadcrumb__sep {
    margin: 0 0.35rem;
}

.drivers-detail__header {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 1.5rem;
    margin-bottom: 1.5rem;
}

.drivers-detail__profile {
    display: flex;
    align-items: center;
    gap: 1.25rem;
}

.drivers-detail__name {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--anante-navy);
    margin: 0 0 0.35rem;
}

.drivers-detail__contact {
    color: var(--anante-text-muted);
    font-size: 0.95rem;
}

.drivers-profit-card {
    background: linear-gradient(135deg, #fff7ed 0%, #ffedd5 100%);
    border: 1px solid #fed7aa;
    border-radius: 12px;
    padding: 1.25rem 1.75rem;
    min-width: 200px;
    text-align: center;
}

.drivers-profit-card__label {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--anante-navy);
    margin: 0 0 0.35rem;
}

.drivers-profit-card__value {
    font-size: 1.75rem;
    font-weight: 800;
    color: var(--anante-orange);
    margin: 0;
}

.drivers-earnings-title {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--anante-navy);
    margin-bottom: 1rem;
}

.drivers-modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(15, 39, 71, 0.45);
    z-index: 1040;
}

.drivers-modal {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1050;
    width: min(420px, calc(100vw - 2rem));
    background: #fff;
    border-radius: 12px;
    padding: 1.5rem;
    box-shadow: 0 12px 40px rgba(15, 39, 71, 0.2);
}

.drivers-modal__title {
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--anante-navy);
}

.drivers-modal__actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
    margin-top: 1.25rem;
}

@media (max-width: 767.98px) {
    .drivers-toolbar__add {
        width: 100%;
    }

    .drivers-detail__header {
        flex-direction: column;
    }
}

/* Route plan */
.routes-page {
    padding-top: 1.5rem;
    padding-bottom: 3rem;
}

.routes-mapbox-usage {
    font-size: 0.875rem;
    margin-bottom: 1rem;
}

.routes-page__title {
    font-size: 2rem;
    font-weight: 800;
    color: var(--anante-navy);
    margin: 0 0 0.25rem;
}

.routes-page__subtitle {
    color: var(--anante-text-muted);
    margin: 0;
}

.routes-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
    margin: 1.5rem 0 1.25rem;
}

.routes-toolbar__filters {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    flex: 1;
}

.routes-filter__label {
    display: block;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--anante-navy);
    margin-bottom: 0.35rem;
}

.routes-filter__control {
    min-width: 160px;
    border-radius: 8px;
}

.routes-filter--search {
    flex: 1;
    min-width: 220px;
}

.routes-search {
    position: relative;
}

.routes-search__icon {
    position: absolute;
    left: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--anante-text-muted);
}

.routes-search__input {
    padding-left: 2.25rem;
    border-radius: 8px;
}

.routes-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.routes-card {
    display: grid;
    grid-template-columns: 1fr 1.5fr auto auto;
    gap: 1rem;
    align-items: center;
    padding: 1rem 1.25rem;
    background: #fff;
    border: 1px solid #e8ecf1;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(15, 39, 71, 0.05);
    cursor: pointer;
}

.routes-card--selected {
    border-color: var(--anante-orange);
    background: rgba(232, 93, 4, 0.04);
}

.routes-card__start,
.routes-card__end {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
}

.routes-card__address {
    font-weight: 600;
    color: var(--anante-navy);
    font-size: 0.9rem;
}

.routes-card__ref {
    font-size: 0.8rem;
    color: var(--anante-text-muted);
}

.routes-card__distance {
    font-weight: 700;
    color: var(--anante-navy);
    white-space: nowrap;
}

.routes-card__icon--start {
    font-size: 1.25rem;
}

.routes-edit-btn {
    border: 1px solid #d4dae3;
    border-radius: 8px;
    background: #fff;
}

.route-map-canvas {
    width: 100%;
    height: 380px;
    border-radius: 12px;
    border: 1px solid #e8ecf1;
    margin-bottom: 1rem;
    overflow: hidden;
}

.routes-editor,
.routes-detail {
    margin-top: 2rem;
    padding: 1.75rem;
    background: #fff;
    border: 1px solid #e8ecf1;
    border-radius: 12px;
}

.routes-stops-title {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--anante-navy);
}

.routes-stop-row {
    margin-bottom: 0.75rem;
}

.routes-stop-row__label {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--anante-navy);
    margin-bottom: 0.25rem;
}

.routes-stop-row__input {
    display: flex;
    gap: 0.5rem;
    align-items: center;
}

.routes-stop-row__input .form-control {
    flex: 1;
}

.routes-calc-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 1rem;
}

.routes-distance-badge {
    font-size: 1rem;
    color: var(--anante-navy);
}

.routes-editor__actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.75rem;
    margin-top: 1.25rem;
    padding-top: 1rem;
    border-top: 1px solid #eef1f5;
}

.routes-modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(15, 39, 71, 0.45);
    z-index: 1040;
}

.routes-modal {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1050;
    background: #fff;
    padding: 1.5rem;
    border-radius: 12px;
    width: min(420px, calc(100vw - 2rem));
}

.routes-modal__actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
    margin-top: 1rem;
}

@media (max-width: 767.98px) {
    .routes-card {
        grid-template-columns: 1fr;
    }

    .routes-toolbar__add {
        width: 100%;
    }
}

/* Loads */
.loads-page {
    padding-top: 1.5rem;
    padding-bottom: 3rem;
}

.loads-page__title {
    font-size: 2rem;
    font-weight: 800;
    color: var(--anante-navy);
    margin-bottom: 0.25rem;
}

.loads-page__subtitle {
    color: var(--anante-text-muted);
    margin: 0;
}

.loads-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.25rem;
}

.loads-toolbar__filters {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    flex: 1;
}

.loads-filter__label {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--anante-navy);
    margin-bottom: 0.35rem;
}

.loads-filter__control,
.loads-search__input {
    min-width: 160px;
}

.loads-filter--search {
    flex: 1;
    min-width: 220px;
}

.loads-search {
    position: relative;
}

.loads-search__icon {
    position: absolute;
    left: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--anante-text-muted);
    pointer-events: none;
}

.loads-search__input {
    padding-left: 2.25rem;
    width: 100%;
}

.loads-table-wrap {
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 1px 4px rgba(15, 39, 71, 0.08);
    overflow: hidden;
}

@media (max-width: 767.98px) {
    .loads-table-wrap {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .loads-toolbar__filters,
    .loads-toolbar__actions,
    .fleet-toolbar,
    .drivers-toolbar,
    .invoices-toolbar,
    .routes-toolbar__filters {
        flex-direction: column;
        align-items: stretch;
    }

    .loads-filter,
    .fleet-filter,
    .drivers-filter,
    .invoices-filter,
    .routes-filter,
    .schedule-filter {
        width: 100%;
    }

    .loads-filter__control,
    .fleet-filter__control,
    .drivers-filter__control,
    .invoices-filter__control,
    .routes-filter__control,
    .schedule-filter__control {
        width: 100%;
    }
}

.loads-table thead th {
    background: var(--anante-navy);
    color: #fff;
    font-weight: 600;
    font-size: 0.85rem;
    border: none;
    padding: 0.85rem 1rem;
}

.loads-table tbody td {
    vertical-align: middle;
    padding: 1rem;
    border-color: #eef1f5;
}

.loads-table__driver {
    display: flex;
    align-items: center;
    gap: 0.65rem;
}

.loads-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
}

.loads-table__customer-name,
.loads-table__load-id,
.loads-table__route {
    font-weight: 600;
    color: var(--anante-navy);
}

.loads-table__meta {
    font-size: 0.85rem;
    color: var(--anante-text-muted);
}

.loads-status-badge {
    display: inline-block;
    font-size: 0.75rem;
    font-weight: 600;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    margin-bottom: 0.35rem;
}

.loads-status-badge--planning,
.loads-status-select--planning {
    background-color: #f3e8ff;
    border-color: #9333ea;
    color: #6b21a8;
}

.loads-status-badge--enroute,
.loads-status-select--enroute {
    background-color: #e8f0fe;
    border-color: #2563eb;
    color: #1d4ed8;
}

.loads-status-badge--complete,
.loads-status-select--complete {
    background-color: #e6f4ea;
    border-color: #137333;
    color: #137333;
}

.loads-status-badge--returned,
.loads-status-select--returned {
    background-color: #fce8e6;
    border-color: #c5221f;
    color: #c5221f;
}

.loads-status-badge--cancelled,
.loads-status-select--cancelled {
    background-color: #fef9c3;
    border-color: #ca8a04;
    color: #854d0e;
}

.loads-status-select {
    font-weight: 600;
    border-width: 1px;
    border-style: solid;
}

.loads-status-select:focus {
    box-shadow: 0 0 0 0.2rem rgba(15, 39, 71, 0.12);
}

.loads-status-select option.loads-status-select__option--planning {
    background-color: #f3e8ff;
    color: #6b21a8;
}

.loads-status-select option.loads-status-select__option--enroute {
    background-color: #e8f0fe;
    color: #1d4ed8;
}

.loads-status-select option.loads-status-select__option--complete {
    background-color: #e6f4ea;
    color: #137333;
}

.loads-status-select option.loads-status-select__option--returned {
    background-color: #fce8e6;
    color: #c5221f;
}

.loads-status-select option.loads-status-select__option--cancelled {
    background-color: #fef9c3;
    color: #854d0e;
}

.loads-delivery-date {
    font-size: 0.85rem;
    color: var(--anante-navy);
    margin-top: 0.35rem;
}

.loads-table__status-cell {
    min-width: 8.5rem;
}

.loads-table__inline-input {
    min-width: 5.5rem;
    max-width: 8rem;
}

.loads-table__inline-input:disabled {
    background-color: #f1f3f5;
    cursor: not-allowed;
}

.loads-table__actions-col {
    white-space: nowrap;
    vertical-align: middle;
}

.loads-table__row--saving {
    opacity: 0.65;
}

.loads-edit-btn {
    font-size: 0.8rem;
    padding: 0.2rem 0.55rem;
}

.loads-operational-panel__title {
    font-size: 0.9rem;
    font-weight: 600;
    margin-bottom: 0.75rem;
    color: var(--anante-navy);
}

.loads-edit-details--locked {
    opacity: 0.85;
}

.loads-pagination {
    display: flex;
    justify-content: center;
    gap: 0.35rem;
    margin-top: 1.5rem;
}

.loads-modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(15, 39, 71, 0.45);
    z-index: 1040;
}

.loads-modal {
    z-index: 1050;
}

.loads-modal__dialog {
    max-width: 720px;
    margin: 1rem auto;
}

.loads-modal__content {
    max-height: calc(100vh - 2rem);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.loads-modal__form {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
    overflow: hidden;
}

.loads-modal__header {
    border-bottom: 1px solid #eef1f5;
}

.loads-modal__body {
    overflow-y: auto;
    flex: 1 1 auto;
    min-height: 0;
    max-height: calc(100vh - 11rem);
}

.loads-modal__footer {
    border-top: 1px solid #eef1f5;
    background: #fff;
}

.loads-weights-section__title {
    font-weight: 600;
    color: var(--anante-navy);
    margin-bottom: 0.25rem;
}

.loads-weights-table-wrap {
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background: #fafbfc;
}

.loads-weights-table {
    margin-bottom: 0;
    font-size: 0.8rem;
}

.loads-weights-table thead th {
    background: var(--anante-navy);
    color: #fff;
    font-weight: 600;
    text-align: center;
    padding: 0.45rem 0.35rem;
    border: none;
    vertical-align: middle;
}

.loads-weights-table tbody td {
    padding: 0.35rem;
    vertical-align: middle;
    border-color: #e8ecf1;
}

.loads-weights-table .form-control {
    min-width: 4.5rem;
    text-align: right;
}

.loads-weights-table__nett {
    background: #f0f4f8;
}

.loads-distance-row {
    padding: 0.75rem;
    background: #f8f9fb;
    border-radius: 8px;
}

/* Schedule */
.schedule-page {
    padding-bottom: 2.5rem;
}

.schedule-page__header {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.schedule-page__title {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--anante-navy);
    margin-bottom: 0.25rem;
}

.schedule-page__subtitle {
    color: var(--anante-text-muted);
    margin: 0;
}

.schedule-page__header-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.schedule-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.25rem;
    padding: 1rem 1.25rem;
    background: #fff;
    border: 1px solid #e8ecf1;
    border-radius: 12px;
}

.schedule-toolbar__filters {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: flex-end;
}

.schedule-filter__label {
    display: block;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--anante-text-muted);
    margin-bottom: 0.25rem;
}

.schedule-filter__control {
    min-width: 10rem;
}

.schedule-view-toggle .btn {
    min-width: 4.5rem;
}

.schedule-toolbar__nav {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.schedule-toolbar__range {
    font-weight: 600;
    color: var(--anante-navy);
    min-width: 10rem;
    text-align: center;
}

.schedule-nav-btn {
    min-width: 2.25rem;
}

.schedule-calendar-menu {
    position: relative;
}

.schedule-calendar-menu__toggle {
    min-width: 9rem;
}

.schedule-calendar-menu__backdrop {
    position: fixed;
    inset: 0;
    z-index: 1040;
    background: transparent;
}

.schedule-calendar-menu__panel {
    display: block;
    position: absolute;
    top: calc(100% + 0.35rem);
    right: 0;
    z-index: 1050;
    min-width: 11rem;
    padding: 0.35rem 0;
    box-shadow: 0 8px 24px rgba(15, 39, 71, 0.12);
}

.schedule-calendar-menu__panel .dropdown-item {
    font-size: 0.9rem;
    padding: 0.5rem 1rem;
}

.schedule-calendar-menu__panel .dropdown-item:disabled {
    opacity: 0.65;
}

.schedule-grid-wrap {
    overflow-x: auto;
    margin-bottom: 2rem;
}

.schedule-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(8.5rem, 1fr));
    gap: 0.5rem;
    min-width: min(100%, 56rem);
}

.schedule-grid--month {
    grid-template-columns: repeat(7, minmax(7rem, 1fr));
}

.schedule-grid__day {
    min-height: 8rem;
    background: #fff;
    border: 1px solid #e8ecf1;
    border-radius: 8px;
    display: flex;
    flex-direction: column;
}

.schedule-grid__day--today {
    border-color: var(--anante-teal, #1a8a7a);
    box-shadow: 0 0 0 1px var(--anante-teal, #1a8a7a);
}

.schedule-grid__day-header {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 0.35rem 0.5rem;
    background: #f4f6f9;
    border-bottom: 1px solid #e8ecf1;
    border-radius: 8px 8px 0 0;
    font-size: 0.75rem;
}

.schedule-grid__weekday {
    font-weight: 600;
    color: var(--anante-text-muted);
    text-transform: uppercase;
}

.schedule-grid__date {
    font-weight: 700;
    color: var(--anante-navy);
}

.schedule-grid__cards {
    flex: 1;
    padding: 0.35rem;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    overflow-y: auto;
    max-height: 14rem;
}

.schedule-card {
    padding: 0.35rem 0.45rem;
    border-radius: 6px;
    border-left: 3px solid #6c757d;
    background: #f8f9fa;
    font-size: 0.7rem;
    line-height: 1.3;
}

.schedule-card__id {
    font-weight: 700;
    color: var(--anante-navy);
}

.schedule-card__dest {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.schedule-card__meta {
    display: flex;
    justify-content: space-between;
    gap: 0.25rem;
    color: var(--anante-text-muted);
    margin-top: 0.15rem;
}

.schedule-card__status {
    font-size: 0.65rem;
}

.schedule-card--status-planning {
    border-left-color: #9333ea;
    background: #f3e8ff;
}

.schedule-card--status-enroute {
    border-left-color: #2563eb;
    background: #e8f0fe;
}

.schedule-card--status-complete {
    border-left-color: #137333;
    background: #e6f4ea;
}

.schedule-card--status-returned {
    border-left-color: #c5221f;
    background: #fce8e6;
}

.schedule-card--status-cancelled {
    border-left-color: #ca8a04;
    background: #fef9c3;
}

.schedule-list__badge--status-planning {
    background: #f3e8ff;
    color: #6b21a8;
}

.schedule-list__badge--status-enroute {
    background: #e8f0fe;
    color: #1d4ed8;
}

.schedule-list__badge--status-complete {
    background: #e6f4ea;
    color: #137333;
}

.schedule-list__badge--status-returned {
    background: #fce8e6;
    color: #c5221f;
}

.schedule-list__badge--status-cancelled {
    background: #fef9c3;
    color: #854d0e;
}

.schedule-list {
    margin-top: 1rem;
}

.schedule-list__title {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--anante-navy);
    margin-bottom: 1rem;
}

.schedule-list__group {
    margin-bottom: 1.5rem;
}

.schedule-list__group-header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.75rem;
    padding-bottom: 0.35rem;
    border-bottom: 1px solid #e8ecf1;
}

.schedule-list__group-header h3 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--anante-navy);
    margin: 0;
}

.schedule-list__km {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--anante-teal, #1a8a7a);
}

.schedule-list__items {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.schedule-list__item {
    display: flex;
    gap: 0.75rem;
    padding: 0.75rem 1rem;
    background: #fff;
    border: 1px solid #e8ecf1;
    border-radius: 10px;
}

.schedule-list__icon {
    width: 2.5rem;
    height: 2.5rem;
    object-fit: contain;
    flex-shrink: 0;
}

.schedule-list__badge {
    display: inline-block;
    font-size: 0.75rem;
    font-weight: 600;
    padding: 0.15rem 0.5rem;
    border-radius: 4px;
    margin-bottom: 0.25rem;
}

.schedule-list__destination {
    font-weight: 600;
    color: var(--anante-navy);
}

@media (max-width: 767.98px) {
    .schedule-grid {
        grid-template-columns: repeat(7, minmax(5.5rem, 1fr));
    }

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

/* Invoices */
.invoices-page {
    padding-bottom: 2.5rem;
}

.invoices-page__title {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--anante-navy);
    margin-bottom: 0.25rem;
}

.invoices-page__subtitle {
    color: var(--anante-text-muted);
    margin: 0;
}

.invoices-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.25rem;
    padding: 1rem 1.25rem;
    background: #fff;
    border: 1px solid #e8ecf1;
    border-radius: 12px;
}

.invoices-toolbar__filters {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: flex-end;
    flex: 1;
}

.invoices-filter__label {
    display: block;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--anante-text-muted);
    margin-bottom: 0.25rem;
}

.invoices-filter__control {
    min-width: 10rem;
}

.invoices-filter--search {
    flex: 1;
    min-width: 14rem;
}

.invoices-search {
    position: relative;
}

.invoices-search__icon {
    position: absolute;
    left: 0.65rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--anante-text-muted);
    pointer-events: none;
}

.invoices-search__input {
    padding-left: 2.25rem;
}

.invoices-table-wrap {
    background: #fff;
    border: 1px solid #e8ecf1;
    border-radius: 12px;
    overflow-x: auto;
}

.invoices-table thead th {
    background: #f4f6f9;
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--anante-navy);
    border-bottom: 1px solid #e8ecf1;
    white-space: nowrap;
}

.invoices-table tbody td {
    vertical-align: middle;
    font-size: 0.9rem;
}

.invoices-status-badge {
    display: inline-block;
    padding: 0.15rem 0.5rem;
    border-radius: 4px;
    font-size: 0.75rem;
    font-weight: 600;
    background: #eef2f7;
    color: var(--anante-navy);
}

.invoices-status-badge--missing {
    background: #fde8e8;
    color: #9b1c1c;
}

.invoices-status-badge--warning {
    background: #fff4e5;
    color: #9a5b00;
}

.invoices-status-badge--onload {
    background: #e8f4fd;
    color: #0d4a7a;
}

.invoices-status-badge--draft {
    background: #eef2f7;
    color: var(--anante-navy);
}

.invoices-status-badge--issued {
    background: #e6f4ea;
    color: #1e6b3a;
}

.invoices-status-badge--paid {
    background: #e6f4ea;
    color: #0d5c2e;
}

.invoices-status-badge--void {
    background: #f0f0f0;
    color: #666;
}

.invoices-status-badge--returned {
    background: #fce8e6;
    color: #c5221f;
}

.invoices-status-cell {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}

.invoices-vat-summary {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.75rem;
    padding: 0.75rem 1rem;
    background: #f7f9fc;
    border-radius: 8px;
    border: 1px solid #e8ecf2;
}

.invoices-vat-summary__label {
    display: block;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--anante-text-muted);
    margin-bottom: 0.15rem;
}

.invoices-vat-summary__value {
    font-weight: 700;
    color: var(--anante-navy);
}

.invoices-pagination {
    display: flex;
    justify-content: center;
    gap: 0.35rem;
    margin-top: 1.25rem;
}

.invoices-modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(15, 39, 71, 0.45);
    z-index: 1040;
}

.invoices-modal .modal-content {
    border: none;
    border-radius: 12px;
    box-shadow: 0 12px 40px rgba(15, 39, 71, 0.18);
}

.invoices-modal__header {
    border-bottom: 1px solid #eef1f5;
}

.invoices-modal__body {
    background: #faf8fc;
}

.invoices-upload-zone {
    border: 2px dashed #c5cad3;
    border-radius: 10px;
    padding: 1.5rem 1rem;
    text-align: center;
    background: #fff;
}

.invoices-upload-zone__icon {
    color: #4a90d9;
    margin-bottom: 0.5rem;
}

.invoices-upload-zone__title {
    font-weight: 600;
    color: var(--anante-navy);
}

.invoices-upload-zone__btn {
    font-weight: 600;
}

.invoices-modal__footer {
    background: #faf8fc;
}

.diesel-entry--compact .diesel-entry__switch--compact {
    margin-bottom: 0.25rem;
    padding-left: 2.25rem;
    min-height: auto;
}

.diesel-entry--compact .diesel-entry__switch--compact .form-check-label {
    font-size: 0.7rem;
}

.loads-table__diesel-cell {
    min-width: 7.5rem;
    vertical-align: middle;
}

/* Global navigation loading overlay (navigation-loading.js) */
.app-navigation-loading {
    position: fixed;
    inset: 0;
    z-index: 2000;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.72);
    backdrop-filter: blur(2px);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.15s ease;
}

.app-navigation-loading.is-active {
    opacity: 1;
    pointer-events: auto;
}

.app-navigation-loading__panel {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.85rem;
    padding: 1.5rem 2rem;
    border-radius: var(--anante-radius);
    background: #fff;
    box-shadow: var(--anante-shadow);
    border: 1px solid var(--anante-border);
}

.app-navigation-loading__spinner {
    display: block;
    width: 2.5rem;
    height: 2.5rem;
    border: 0.2em solid var(--anante-orange);
    border-right-color: transparent;
    border-radius: 50%;
    animation: btn-loading-spin 0.65s linear infinite;
}

.app-navigation-loading__text {
    margin: 0;
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--anante-navy);
}

html.app-is-navigating {
    cursor: progress;
}

/* Admin */
.admin-page {
    padding-top: 1.5rem;
    padding-bottom: 3rem;
}

.admin-page__title {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--anante-navy);
    margin-bottom: 0.25rem;
}

.admin-page__subtitle {
    color: var(--anante-text-muted);
    max-width: 42rem;
}

.admin-card {
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 1px 4px rgba(15, 39, 71, 0.08);
    padding: 1.25rem 1.5rem;
    margin-bottom: 1.25rem;
}

.admin-card__title {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--anante-navy);
    margin-bottom: 1rem;
}

.admin-table thead th {
    background: var(--anante-navy);
    color: #fff;
    font-size: 0.85rem;
    border: none;
}

.admin-status-badge {
    display: inline-block;
    font-size: 0.75rem;
    font-weight: 600;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
}

.admin-status-badge--pending {
    background: #fff7ed;
    color: #c2410c;
}

.admin-status-badge--active {
    background: #e6f4ea;
    color: #137333;
}

.admin-status-badge--revoked {
    background: #fce8e6;
    color: #c5221f;
}

/* App footer (matches login / register account footer) */
.anante-app-footer {
    width: 100%;
    margin-top: 2.5rem;
    padding: 0 1.25rem 2rem;
    text-align: center;
    background: transparent;
}

.anante-app-footer__copyright,
.anante-app-footer__legal {
    font-size: 0.8rem;
    color: var(--anante-text-muted);
    margin: 0 0 0.35rem;
}

.anante-app-footer__legal {
    margin-bottom: 0;
}

.anante-app-footer__legal a {
    color: var(--anante-text-muted);
    text-decoration: none;
}

.anante-app-footer__legal a:hover {
    color: var(--anante-navy);
    text-decoration: underline;
}

.anante-app-footer__powered {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.4rem 0.5rem;
    margin: 1rem 0 0;
    font-size: 0.75rem;
    color: var(--anante-text-muted);
}

.anante-app-footer__powered-label {
    opacity: 0.85;
}

.anante-app-footer__powered-link {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    color: var(--anante-text-muted);
    text-decoration: none;
    font-weight: 600;
    transition: color 0.15s ease;
}

.anante-app-footer__powered-link:hover {
    color: var(--anante-navy);
    text-decoration: none;
}

.anante-app-footer__powered-logo {
    display: block;
    width: 24px;
    height: 24px;
    object-fit: contain;
    flex-shrink: 0;
}

.account-page__inner .anante-app-footer {
    margin-top: 2.5rem;
    padding: 0 0 0;
}

.anante-app {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.anante-main {
    flex: 1 0 auto;
}

.anante-app .anante-app-footer {
    margin-top: auto;
    padding-top: 2.5rem;
    padding-bottom: 2rem;
}

.anante-app:has(.cookie-notice) .anante-app-footer {
    padding-bottom: 5rem;
}

.legal-document {
    padding: 2rem 1rem 3rem;
    max-width: 800px;
}

.legal-document__loading {
    color: var(--anante-text-muted);
}

.legal-document__body {
    font-size: 1rem;
    line-height: 1.65;
    color: var(--anante-text);
}

.legal-document__body h1 {
    font-size: 1.75rem;
    font-weight: 700;
    margin: 0 0 1rem;
    color: var(--anante-navy);
}

.legal-document__body h2 {
    font-size: 1.25rem;
    font-weight: 700;
    margin: 2rem 0 0.75rem;
    color: var(--anante-navy);
}

.legal-document__body h3 {
    font-size: 1.05rem;
    font-weight: 600;
    margin: 1.25rem 0 0.5rem;
}

.legal-document__body p,
.legal-document__body li {
    margin-bottom: 0.75rem;
}

.legal-document__body ul {
    padding-left: 1.25rem;
}

.legal-document__body a {
    color: var(--anante-orange);
}

.legal-document__body blockquote {
    border-left: 4px solid var(--anante-orange);
    margin: 1rem 0;
    padding: 0.5rem 0 0.5rem 1rem;
    background: var(--anante-surface);
    color: var(--anante-text-muted);
}

.form-privacy-notice {
    font-size: 0.8125rem;
    color: var(--anante-text-muted);
    line-height: 1.5;
    margin: 0 0 0.5rem;
}

.form-privacy-notice a {
    color: var(--anante-navy);
    font-weight: 500;
}

.cookie-notice {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 1045;
    background: var(--anante-navy);
    color: #e2e8f0;
    box-shadow: 0 -4px 20px rgba(13, 27, 42, 0.2);
    padding: 0.85rem 0;
}

.cookie-notice__inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem 1rem;
}

.cookie-notice__text {
    margin: 0;
    font-size: 0.875rem;
    flex: 1 1 280px;
}

.cookie-notice__text a {
    color: #fff;
    text-decoration: underline;
}

.cookie-notice__btn {
    flex-shrink: 0;
}
