@import url("./brand-tokens.css");
@import url("./dp-components.css");

:root {
    /* Variables del laboratorio:
       aqui fijamos color, contraste y medidas base sin tocar todavia la home real. */
    --lab-bg: var(--dp-color-ink);
    --lab-text: var(--dp-color-ivory);
    --lab-muted: rgba(245, 241, 232, 0.76);
    --lab-muted-soft: #d8c8a8;
    --lab-border: var(--dp-border-dark);
    --lab-accent: var(--dp-color-gold);
    --lab-accent-soft: var(--dp-color-gold-soft);
    --lab-champagne: var(--dp-color-champagne);
    --lab-cool-highlight: #d9e7f6;
    --lab-cool-fill-soft: rgba(162, 188, 218, 0.1);
    --lab-cool-fill: rgba(151, 178, 209, 0.14);
    --lab-cool-border: rgba(166, 196, 227, 0.34);
    --lab-cool-outline: rgba(177, 208, 239, 0.3);
    --lab-cool-panel-start: rgba(18, 29, 44, 0.48);
    --lab-cool-panel-end: rgba(8, 15, 25, 0.58);
    --lab-cool-glass-top: rgba(245, 250, 255, 0.24);
    --lab-cool-glass-mid: rgba(165, 190, 220, 0.14);
    --lab-cool-glass-bottom: rgba(56, 87, 123, 0.14);
    --lab-cool-lens-edge: rgba(223, 236, 250, 0.26);
    --lab-cool-lens-shadow: rgba(3, 8, 14, 0.34);
    --lab-cool-card-idle: rgba(255, 255, 255, 0.024);
    --lab-cool-card-hover: rgba(162, 188, 218, 0.11);
    --lab-header-offset: var(--dp-header-offset);
    --lab-frame-max: var(--dp-frame-max);
    --lab-frame-gutter: var(--dp-frame-gutter);
    --lab-frame-width: var(--dp-frame-width);
    --lab-font-sans: var(--dp-font-sans);
    --lab-font-display: var(--dp-font-display);
}

/* Home refresh:
   more direct commercial hierarchy, quick-contact utility and a premium mobile menu. */
.home-page .lab-header {
    position: absolute;
    background: linear-gradient(180deg, rgba(4, 4, 6, 0.96) 0%, rgba(4, 4, 6, 0.84) 64%, rgba(4, 4, 6, 0.46) 100%);
    transition: background 220ms ease, backdrop-filter 220ms ease, box-shadow 220ms ease;
}

.home-page .lab-header::after {
    opacity: 0;
    transition: opacity 220ms ease;
}

.home-page .lab-header.is-scrolled {
    background: linear-gradient(180deg, rgba(8, 9, 11, 0.98) 0%, rgba(8, 9, 11, 0.94) 100%);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.22);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
}

.home-page .lab-header.is-scrolled::after {
    opacity: 1;
}

.lab-header__utility {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    margin-left: auto;
}

.lab-header__utility-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border: 1px solid rgba(241, 226, 189, 0.42);
    border-radius: 999px;
    background: rgba(8, 9, 11, 0.78);
    color: #fff1c9;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
    transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
}

.lab-header__utility-link:hover,
.lab-header__utility-link:focus-visible {
    transform: translateY(-1px);
    border-color: rgba(var(--dp-color-gold-rgb), 0.48);
    background: rgba(var(--dp-color-gold-rgb), 0.12);
}

.lab-header__utility-link svg {
    width: 16px;
    height: 16px;
}

.lab-header__utility-link[href*="wa.me"],
.lab-header__utility-link[href*="api.whatsapp.com"] {
    box-shadow: none;
}

.lab-header__utility-link[href*="wa.me"] svg,
.lab-header__utility-link[href*="api.whatsapp.com"] svg,
.lab-header__utility-link[href*="wa.me"] path,
.lab-header__utility-link[href*="api.whatsapp.com"] path {
    filter: none;
    text-shadow: none;
}

.lab-header__utility-link span {
    display: none;
}

.home-page .hero-lab {
    min-height: 100svh;
    background:
        radial-gradient(circle at 68% 22%, rgba(var(--dp-color-gold-rgb), 0.12), rgba(var(--dp-color-gold-rgb), 0) 30%),
        linear-gradient(180deg, #060708 0%, #10100d 42%, #050607 100%);
}

.home-page .hero-lab__video {
    object-position: 72% center;
    opacity: 0.04;
    transform: scale(1.035);
    filter: saturate(0.78) brightness(0.34) contrast(1.02);
}

.home-page .hero-lab__still {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 58% 24%, rgba(var(--dp-color-gold-rgb), 0.08), rgba(var(--dp-color-gold-rgb), 0) 30%),
        linear-gradient(180deg, rgba(6, 7, 8, 0.98) 0%, rgba(14, 14, 12, 0.96) 48%, rgba(5, 6, 7, 0.98) 100%);
    opacity: 1;
    transform: none;
    transition: opacity 1200ms ease;
}

.home-page .hero-lab.is-video-ready .hero-lab__still {
    opacity: 0;
}

html.js .home-page .hero-lab:not(.is-video-ready) .hero-lab__video {
    opacity: 0;
}

.home-page .hero-lab__overlay {
    background:
        linear-gradient(180deg, rgba(3, 4, 6, 0.64) 0%, rgba(3, 4, 6, 0.18) 22%, rgba(3, 4, 6, 0.7) 68%, rgba(3, 4, 6, 0.92) 100%),
        linear-gradient(90deg, rgba(4, 5, 7, 0.9) 0%, rgba(4, 5, 7, 0.78) 22%, rgba(4, 5, 7, 0.28) 58%, rgba(4, 5, 7, 0.38) 100%);
}

.home-page .hero-lab__glow {
    inset: auto 8% 22% auto;
    width: 22rem;
    height: 16rem;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(239, 215, 147, 0.1) 0%, rgba(239, 215, 147, 0.04) 34%, rgba(239, 215, 147, 0) 74%);
    filter: blur(48px);
}

.home-page .hero-lab__watermark {
    display: none;
}

.home-page .hero-lab__watermark img {
    width: 100%;
    height: auto;
    filter: grayscale(1) brightness(1.18);
}

.home-page .hero-lab__shell,
.home-page .hero-lab__shell {
    min-height: 100svh;
    display: block;
    padding-top: 0;
    padding-bottom: 0;
}

.home-page .hero-lab__body {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    width: 100%;
    min-height: 100svh;
    padding: calc(var(--lab-header-offset) - 0.1rem) 0 2.8rem;
}

.home-page .hero-lab__body::after,
.home-page .hero-lab__content-box::after {
    content: none;
}

.home-page .hero-lab__content-box {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: min(100%, 64rem);
    min-height: calc(100svh - var(--lab-header-offset) - 3rem);
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
    gap: 1.55rem;
}

@media (min-width: 1101px) {
    .home-page .hero-lab__content-box {
        transform: translateY(0);
    }
}

.home-page .hero-lab__body-copy {
    display: grid;
    justify-items: center;
    gap: 1.02rem;
    width: min(100%, 48rem);
    max-width: 48rem;
    margin-inline: auto;
    text-align: center;
}

.home-page .hero-lab__eyebrow {
    justify-content: center;
}

.home-page .hero-lab__eyebrow::before,
.home-page .hero-lab__eyebrow::after {
    content: "";
    width: 42px;
    height: 1px;
    background: linear-gradient(90deg, rgba(214, 188, 134, 0), rgba(214, 188, 134, 0.9));
}

.home-page .hero-lab__eyebrow::after {
    background: linear-gradient(90deg, rgba(214, 188, 134, 0.9), rgba(214, 188, 134, 0));
}

.home-page .hero-lab__center-mark {
    width: clamp(4.2rem, 5.4vw, 5.1rem);
    height: auto;
    opacity: 0.92;
    filter:
        sepia(0.36)
        saturate(1.3)
        brightness(1.06)
        drop-shadow(0 14px 28px rgba(0, 0, 0, 0.36))
        drop-shadow(0 0 20px rgba(239, 215, 147, 0.12));
}

.home-page .hero-lab__body-copy h1 {
    width: min(100%, 24ch);
    max-width: 24ch;
    margin: 0;
    font-family: var(--lab-font-display);
    font-size: clamp(3.15rem, 3.4vw, 4rem);
    font-weight: 700;
    line-height: 0.96;
    letter-spacing: 0;
    text-wrap: pretty;
    text-align: center;
}

.home-page .hero-lab__body-copy h1 strong {
    color: inherit;
    font-weight: inherit;
}

.home-page .hero-lab__lead {
    width: min(100%, 34rem);
    max-width: 34rem;
    margin: 0;
    color: rgba(255, 255, 255, 0.84);
    font-size: 1rem;
    line-height: 1.54;
    text-align: center;
}

.home-page .hero-lab__launcher {
    display: grid;
    gap: 1rem;
    margin-top: 0;
    max-width: 36rem;
}

.home-page .hero-lab__launcher h2 {
    margin: 0;
    font-family: var(--lab-font-display);
    font-size: 2.05rem;
    line-height: 1.02;
    letter-spacing: 0;
    font-weight: 600;
}

.home-page .hero-lab__launcher p {
    margin: 0;
    color: rgba(255, 255, 255, 0.78);
    max-width: 32rem;
    font-size: 0.98rem;
    line-height: 1.55;
}

.home-page .hero-lab__actions {
    display: flex;
    flex-wrap: nowrap;
    gap: 1rem;
    align-items: center;
    width: fit-content;
}

.home-page .hero-lab__cta {
    min-width: 0;
    min-height: 55px;
    padding: 0 1.45rem;
    border-radius: 8px;
    font-size: 0.76rem;
    letter-spacing: 0;
}

.home-page .hero-lab__cta--primary {
    width: 374px;
    flex: 0 0 374px;
    border: 1px solid rgba(255, 255, 255, 0.78);
    background: rgba(255, 255, 255, 0.02);
    color: #ffffff;
    box-shadow: none;
}

.home-page .hero-lab__cta--secondary {
    min-width: 100px;
    flex: 0 0 auto;
    min-height: 46px;
    padding: 0 1.2rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 8px;
    background: rgba(12, 13, 16, 0.24);
    color: rgba(255, 255, 255, 0.92);
    box-shadow: none;
    justify-content: center;
}

.hero-floating-actions {
    position: fixed;
    right: 1.1rem;
    bottom: 1.4rem;
    z-index: 95;
    display: grid;
    gap: 0.85rem;
}

.hero-floating-actions__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 62px;
    height: 62px;
    border-radius: 999px;
    color: #fff;
    box-shadow: 0 18px 38px rgba(0, 0, 0, 0.28);
}

.hero-floating-actions__link svg {
    width: 26px;
    height: 26px;
    filter: none;
    text-shadow: none;
}

.hero-floating-actions__link--call {
    background: linear-gradient(135deg, #dcb45d, #efcf84);
    color: #17120d;
}

.hero-floating-actions__link--wa {
    background: #19a83f;
    border: 1px solid rgba(241, 226, 189, 0.58);
    box-shadow: none;
}

.home-page .hero-floating-actions {
    display: none;
}

.home-trust-strip {
    position: relative;
    z-index: 1;
    padding: 0 0 2.2rem;
}

.home-trust-strip__shell {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    width: min(100%, 64rem);
    margin-inline: auto;
    gap: 0.8rem;
}

.home-trust-strip__item {
    display: grid;
    gap: 0.32rem;
    padding: 1rem 1rem 1.02rem;
    border: 1px solid rgba(239, 215, 147, 0.16);
    border-radius: 14px;
    background:
        linear-gradient(180deg, rgba(20, 20, 22, 0.82), rgba(7, 8, 10, 0.92)),
        radial-gradient(circle at 16% 0%, rgba(239, 215, 147, 0.13), rgba(239, 215, 147, 0) 42%);
    box-shadow:
        0 18px 36px rgba(0, 0, 0, 0.24),
        inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.home-trust-strip__item strong {
    color: #fff8d5;
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.home-trust-strip__item span {
    color: rgba(245, 241, 232, 0.74);
    font-size: 0.9rem;
    line-height: 1.45;
}

.home-booking {
    position: relative;
    z-index: 1;
    padding: 1.35rem 0 1.4rem;
}

.home-booking__shell {
    display: grid;
    grid-template-columns: minmax(0, 20rem) minmax(0, 1fr);
    gap: 1rem 1.15rem;
    align-items: end;
    padding: 1.2rem 1.25rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 8px;
    background: linear-gradient(180deg, rgba(13, 14, 17, 0.92), rgba(7, 8, 10, 0.96));
    box-shadow: 0 22px 38px rgba(3, 4, 8, 0.14);
}

.home-booking__intro {
    display: grid;
    gap: 0.55rem;
    padding-right: 0.4rem;
}

.home-booking__eyebrow {
    color: #f1e2bd;
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.home-booking__intro h2 {
    margin: 0;
    font-size: clamp(1.6rem, 2.7vw, 2rem);
    line-height: 1.02;
}

.home-booking__intro p {
    margin: 0;
    color: rgba(245, 241, 232, 0.74);
    line-height: 1.55;
}

.home-booking__form {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr)) auto;
    gap: 0.8rem;
}

.home-booking__field {
    display: grid;
    gap: 0.48rem;
}

.home-booking__field span {
    color: rgba(245, 241, 232, 0.72);
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.home-booking__field input,
.home-booking__field select {
    min-height: 54px;
    padding: 0 0.95rem;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.04);
    color: #fff;
}

.home-booking__submit {
    align-self: end;
    min-width: 182px;
    min-height: 54px;
    padding: 0 1.2rem;
    border: 0;
    border-radius: 8px;
    background: linear-gradient(135deg, #efd793, #ddb75a);
    color: #17120d;
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.home-page .hero-lab .home-booking {
    width: min(100%, 58rem);
    margin-inline: auto;
    padding: 0;
}

.home-page .hero-lab .home-booking__shell {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.95rem;
    align-items: stretch;
    padding: 1rem 1.05rem 1.08rem;
    border-color: rgba(239, 215, 147, 0.24);
    border-radius: 20px;
    background:
        linear-gradient(135deg, rgba(12, 13, 16, 0.78), rgba(5, 6, 8, 0.9)),
        radial-gradient(circle at 88% 12%, rgba(239, 215, 147, 0.18), rgba(239, 215, 147, 0) 34%);
    box-shadow: 0 22px 52px rgba(0, 0, 0, 0.32);
    backdrop-filter: blur(18px);
}

.home-page .hero-lab .home-booking__intro {
    justify-items: center;
    gap: 0.34rem;
    max-width: none;
    padding-right: 0;
    text-align: center;
}

.home-page .hero-lab .home-booking__intro h2 {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip-path: inset(50%);
    white-space: nowrap;
}

.home-page .hero-lab .home-booking__intro p {
    display: none;
}

.home-page .hero-lab .home-booking__form {
    grid-template-columns:
        minmax(10rem, 1.08fr)
        minmax(10rem, 1.08fr)
        minmax(8.6rem, 0.92fr)
        minmax(8.6rem, 0.92fr)
        minmax(14rem, 1.16fr);
    gap: 0.88rem;
}

.home-page .hero-lab .home-booking__field {
    gap: 0.38rem;
    min-width: 0;
    text-align: left;
}

.home-page .hero-lab .home-booking__field span {
    color: rgba(245, 241, 232, 0.7);
    font-size: 0.62rem;
    padding-left: 0.95rem;
    text-align: left;
}

.home-page .hero-lab .home-booking__field input,
.home-page .hero-lab .home-booking__field select {
    width: 100%;
    min-width: 0;
    min-height: 48px;
    border-color: rgba(255, 255, 255, 0.16);
    background: rgba(255, 255, 255, 0.085);
    color: #f8f1df;
    font-family: var(--lab-font-sans);
    font-size: 0.9rem;
    font-weight: 600;
    letter-spacing: 0;
    font-variant-numeric: tabular-nums;
    color-scheme: dark;
    text-align: left;
    text-align-last: left;
}

.home-page .hero-lab .home-booking__field select option,
.hero-lab-overlay__input option {
    background-color: #3a3a3a;
    color: #fffaf1;
    font-family: var(--lab-font-sans);
    font-weight: 600;
}

.home-page .hero-lab .home-booking__field select option:checked,
.hero-lab-overlay__input option:checked {
    background-color: #5a5a5a;
    color: #fffaf1;
}

.home-page .hero-lab .home-booking__field input[type="date"]::-webkit-calendar-picker-indicator {
    opacity: 0.9;
    filter: brightness(0) invert(1) sepia(0.52) saturate(1.65) hue-rotate(350deg);
}

.home-page .hero-lab .home-booking__submit {
    min-width: 0;
    min-height: 48px;
    border-radius: 12px;
    white-space: nowrap;
    box-shadow: 0 16px 34px rgba(221, 183, 90, 0.18);
}

.home-page .fleet-categories {
    padding-top: 0.8rem;
}

.lab-mobile-toggle {
    width: 46px;
    height: 46px;
    border: 1px solid rgba(241, 226, 189, 0.28);
    border-radius: 8px;
    background: rgba(10, 12, 15, 0.22);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.lab-mobile-toggle span {
    width: 19px;
    margin-left: auto;
    margin-right: auto;
    transition: transform 220ms ease, opacity 220ms ease, width 220ms ease;
}

.lab-mobile-toggle span:nth-child(2) {
    width: 15px;
}

.lab-mobile-toggle span:nth-child(3) {
    width: 11px;
}

.lab-mobile-toggle.is-open span:nth-child(1) {
    width: 18px;
    transform: translateY(6px) rotate(45deg);
}

.lab-mobile-toggle.is-open span:nth-child(2) {
    opacity: 0;
}

.lab-mobile-toggle.is-open span:nth-child(3) {
    width: 18px;
    transform: translateY(-6px) rotate(-45deg);
}

.lab-mobile-drawer__actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.65rem;
}

.lab-mobile-drawer__action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    border-radius: 8px;
    font-size: 0.8rem;
    font-weight: 700;
}

.lab-mobile-drawer__action--primary {
    background: linear-gradient(135deg, #efd793, #ddb75a);
    color: #17120d;
}

.lab-mobile-drawer__action--secondary {
    border: 1px solid rgba(255, 255, 255, 0.14);
    background: rgba(255, 255, 255, 0.04);
    color: rgba(245, 241, 232, 0.92);
}

.home-page .lab-mobile-action-bar {
    display: none !important;
}

.home-page.lab-has-mobile-bar {
    padding-bottom: 0 !important;
}

@media (max-width: 1100px) {
    .home-trust-strip__shell {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .home-booking__shell {
        grid-template-columns: 1fr;
    }

    .home-booking__form {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .home-booking__submit {
        min-width: 0;
    }
}

@media (max-height: 980px) and (min-width: 1101px) {
    .home-page .hero-lab__body {
        padding-top: calc(var(--lab-header-offset) + 0.3rem);
        padding-bottom: 2.2rem;
    }

    .home-page .hero-lab__content-box {
        gap: 1.2rem;
    }

    .home-page .hero-lab__body-copy h1 {
        font-size: clamp(2.7rem, 3vw, 3.2rem);
        max-width: 18ch;
    }

    .home-page .hero-lab__lead {
        max-width: 34rem;
        font-size: 0.94rem;
        line-height: 1.5;
    }

    .home-page .hero-lab__launcher {
        gap: 0.9rem;
        margin-top: 3.6rem;
    }

    .home-page .hero-lab__cta {
        min-width: 340px;
        min-height: 48px;
    }

    .home-page .hero-lab .home-booking__shell {
        padding: 0.88rem 0.95rem 0.95rem;
    }

    .home-page .hero-lab .home-booking__field input,
    .home-page .hero-lab .home-booking__field select,
    .home-page .hero-lab .home-booking__submit {
        min-height: 44px;
    }
}

@media (max-height: 820px) and (min-width: 1101px) {
    .home-page .hero-lab__body {
        padding-top: calc(var(--lab-header-offset) + 0.75rem);
        padding-bottom: 2.8rem;
    }

    .home-page .hero-lab__body-copy h1 {
        font-size: clamp(2.45rem, 2.8vw, 2.8rem);
        max-width: 18ch;
    }

    .home-page .hero-lab__lead {
        font-size: 0.9rem;
    }

    .hero-lab__signal-row li {
        font-size: 0.7rem;
        letter-spacing: 0.12em;
    }

    .home-page .hero-lab .home-booking__intro p {
        display: none;
    }
}

@media (max-width: 860px) {
    .home-page .lab-header__inner {
        grid-template-columns: minmax(0, 1fr) auto;
        gap: 0.55rem;
    }

    .lab-header__utility {
        display: none;
    }

    .home-page .hero-lab,
    .home-page .hero-lab__shell {
        min-height: 86svh;
    }

    .home-page .hero-lab__video {
        display: block;
        object-position: 58% 50%;
        opacity: 0.72;
        transform: scale(1.04);
        filter: saturate(1.02) brightness(0.62) contrast(1.08);
    }

    .home-page .hero-lab__still {
        background:
            radial-gradient(circle at 64% 22%, rgba(var(--dp-color-gold-rgb), 0.1), rgba(var(--dp-color-gold-rgb), 0) 34%),
            linear-gradient(180deg, rgba(6, 7, 8, 0.98) 0%, rgba(14, 14, 12, 0.96) 48%, rgba(5, 6, 7, 0.98) 100%);
    }

    .home-page .hero-lab__overlay {
        background:
            linear-gradient(180deg, rgba(5, 6, 8, 0.76) 0%, rgba(6, 7, 9, 0.38) 25%, rgba(6, 7, 9, 0.72) 62%, rgba(5, 6, 8, 0.95) 100%),
            linear-gradient(90deg, rgba(5, 6, 8, 0.92) 0%, rgba(5, 6, 8, 0.68) 38%, rgba(5, 6, 8, 0.32) 100%);
    }

    .home-page .hero-lab__glow {
        inset: auto -10% 24% auto;
        width: 12rem;
        height: 9rem;
        opacity: 0.44;
        filter: blur(34px);
    }

    .home-page .hero-lab__body {
        min-height: 86svh;
        align-items: flex-start;
        padding-top: calc(var(--lab-header-offset) - 1rem);
        padding-bottom: 0.95rem;
    }

    .home-page .hero-lab__content-box {
        width: 100%;
        max-width: 100%;
        min-height: auto;
        justify-content: center;
        gap: 1.05rem;
    }

    .home-page .hero-lab__body-copy {
        gap: 0.55rem;
        max-width: 100%;
    }

    .home-page .hero-lab__eyebrow {
        gap: 0.62rem;
        font-size: 0.65rem;
        letter-spacing: 0.18em;
    }

    .home-page .hero-lab__eyebrow::before {
        width: 32px;
    }

    .home-page .hero-lab__body-copy h1 {
        font-family: var(--lab-font-display);
        font-size: clamp(3rem, 10vw, 3.55rem);
        max-width: 6.1ch;
        line-height: 0.93;
        letter-spacing: 0;
        text-wrap: pretty;
    }

    .home-page .hero-lab__lead {
        max-width: 19rem;
        font-size: 0.93rem;
        line-height: 1.52;
        color: rgba(255, 255, 255, 0.82);
    }

    .home-page .hero-lab__launcher {
        gap: 0.75rem;
        margin-top: 0;
        max-width: 100%;
    }

    .home-page .hero-lab__launcher h2 {
        font-family: var(--lab-font-display);
        font-size: 1.34rem;
        line-height: 1.06;
    }

    .home-page .hero-lab__launcher p {
        max-width: 100%;
        font-size: 0.82rem;
        line-height: 1.52;
    }

    .home-page .hero-lab__actions {
        display: grid;
        grid-template-columns: 1fr;
        gap: 0.85rem;
        width: 100%;
        max-width: 100%;
    }

    .home-page .hero-lab__cta {
        min-width: 0;
        min-height: 55px;
        padding: 0 1rem;
        font-size: 0.8rem;
        letter-spacing: 0;
    }

    .home-page .hero-lab__cta--primary {
        width: 100%;
        min-height: 55px;
        box-shadow: none;
    }

    .home-page .hero-lab__cta--secondary {
        width: 100%;
        min-height: 46px;
        padding: 0 1.2rem;
        border: 1px solid rgba(255, 255, 255, 0.08);
        border-radius: 8px;
        background: rgba(12, 13, 16, 0.26);
        color: rgba(255, 255, 255, 0.9);
        font-size: 0.74rem;
        letter-spacing: 0;
        box-shadow: none;
        justify-content: center;
        justify-self: stretch;
    }

    .home-trust-strip {
        padding-bottom: 1.1rem;
    }

    .home-trust-strip__shell {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.62rem;
    }

    .home-trust-strip__item {
        padding: 0.82rem 0.78rem 0.86rem;
        border-radius: 12px;
    }

    .home-trust-strip__item strong {
        font-size: 0.68rem;
        line-height: 1.22;
    }

    .home-trust-strip__item span {
        font-size: 0.76rem;
        line-height: 1.36;
    }

    .home-booking__shell {
        padding: 1rem;
    }

    .home-booking__form {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 540px) {
    .home-page .hero-lab__body {
        padding-top: calc(var(--lab-header-offset) - 0.9rem);
        padding-bottom: 1.1rem;
    }

    .home-page .hero-lab__content-box {
        width: 100%;
        max-width: 100%;
    }

    .home-page .hero-lab__actions {
        width: 100%;
        max-width: 100%;
    }

    .home-page .hero-lab__body-copy h1 {
        font-size: clamp(2.9rem, 12vw, 3.35rem);
        max-width: 12ch;
    }

    .home-page .hero-lab__lead {
        max-width: 100%;
        font-size: 0.9rem;
    }
}

@media (max-width: 300px) {
    .home-trust-strip__shell {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 860px) {
    .home-page .hero-lab__content-box,
    .home-page .hero-lab__body-copy {
        align-items: center;
        text-align: center;
    }

    .home-page .hero-lab__eyebrow {
        justify-content: center;
        margin-inline: auto;
    }

    .home-page .hero-lab__body-copy h1 {
        margin-inline: auto;
    }

    .home-page .hero-lab__lead {
        margin-inline: auto;
    }

    .home-page .hero-lab .home-booking {
        width: 100%;
    }

    .home-page .hero-lab .home-booking__shell {
        gap: 0.84rem;
        padding: 0.82rem;
        border-radius: 18px;
        text-align: left;
    }

    .home-page .hero-lab .home-booking__intro {
        align-items: center;
        justify-items: center;
        text-align: center;
    }

    .home-page .hero-lab .home-booking__intro h2 {
        font-size: 1.06rem;
        line-height: 1.1;
    }

    .home-page .hero-lab .home-booking__intro p {
        display: none;
    }

    .home-page .hero-lab .home-booking__form {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.74rem 0.68rem;
    }

    .home-page .hero-lab .home-booking__field {
        gap: 0.34rem;
    }

    .home-page .hero-lab .home-booking__field span {
        font-size: 0.55rem;
        letter-spacing: 0.11em;
        padding-left: 0.72rem;
    }

    .home-page .hero-lab .home-booking__field input,
    .home-page .hero-lab .home-booking__field select {
        min-height: 44px;
        padding: 0 0.72rem;
    }

    .home-page .hero-lab .home-booking__submit {
        grid-column: 1 / -1;
        min-height: 48px;
        font-size: 0.7rem;
    }
}

@media (min-width: 340px) and (max-width: 480px) {
    .home-page .hero-lab .home-booking__shell {
        gap: 0.78rem;
        padding: 0.78rem;
    }

    .home-page .hero-lab .home-booking__intro h2 {
        font-size: 1.02rem;
    }

    .home-page .hero-lab .home-booking__form {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.68rem 0.56rem;
    }

    .home-page .hero-lab .home-booking__field:nth-of-type(1),
    .home-page .hero-lab .home-booking__field:nth-of-type(2) {
        grid-column: 1 / -1;
    }

    .home-page .hero-lab .home-booking__field span {
        padding-left: 0.66rem;
        font-size: 0.52rem;
    }

    .home-page .hero-lab .home-booking__field input,
    .home-page .hero-lab .home-booking__field select {
        min-height: 42px;
        padding: 0 0.66rem;
        font-size: 0.88rem;
    }

    .home-page .hero-lab .home-booking__field input[type="date"] {
        display: block;
        inline-size: 100%;
        max-inline-size: 100%;
        min-inline-size: 0;
        box-sizing: border-box;
        padding: 0 0.66rem;
        font-size: 0.88rem;
    }

    @supports (-webkit-touch-callout: none) {
        .home-page .hero-lab .home-booking__field input[type="date"] {
            width: -webkit-fill-available;
        }
    }

    .home-page .hero-lab .home-booking__field input[type="date"]::-webkit-calendar-picker-indicator {
        width: 15px;
        height: 15px;
        margin-left: 0.2rem;
    }

    .home-page .hero-lab .home-booking__submit {
        min-height: 44px;
    }
}

@media (max-width: 540px) and (max-height: 640px) {
    .home-page .lab-floating-contact {
        display: none;
    }

    .home-page .hero-lab,
    .home-page .hero-lab__shell,
    .home-page .hero-lab__body {
        min-height: 100svh;
    }

    .home-page .hero-lab__body {
        padding-top: calc(var(--lab-header-offset) - 0.9rem);
        padding-bottom: 0.5rem;
    }

    .home-page .hero-lab__content-box {
        min-height: auto;
        justify-content: flex-start;
        gap: 0.64rem;
        padding-top: 0.72rem;
    }

    .home-page .hero-lab__body-copy {
        gap: 0.38rem;
    }

    .home-page .hero-lab__center-mark {
        display: none;
    }

    .home-page .hero-lab__eyebrow {
        gap: 0.48rem;
        font-size: 0.56rem;
        letter-spacing: 0.14em;
    }

    .home-page .hero-lab__eyebrow::before {
        width: 24px;
    }

    .home-page .hero-lab__body-copy h1 {
        max-width: 10ch;
        font-size: clamp(2.34rem, 10.6vw, 2.82rem);
        line-height: 0.94;
    }

    .home-page .hero-lab__lead {
        max-width: 17.8rem;
        font-size: 0.875rem;
        line-height: 1.44;
    }

    .home-page .hero-lab .home-booking__shell {
        gap: 0.5rem;
        padding: 0.62rem 0.68rem 0.7rem;
        border-radius: 16px;
    }

    .home-page .hero-lab .home-booking__intro {
        gap: 0.18rem;
    }

    .home-page .hero-lab .home-booking__eyebrow {
        font-size: 0.52rem;
        letter-spacing: 0.13em;
    }

    .home-page .hero-lab .home-booking__intro h2 {
        position: absolute;
        width: 1px;
        height: 1px;
        overflow: hidden;
        clip-path: inset(50%);
        white-space: nowrap;
    }

    .home-page .hero-lab .home-booking__form {
        gap: 0.54rem;
    }

    .home-page .hero-lab .home-booking__field {
        gap: 0.26rem;
    }

    .home-page .hero-lab .home-booking__field span {
        padding-left: 0.58rem;
        font-size: 0.48rem;
        letter-spacing: 0.1em;
    }

    .home-page .hero-lab .home-booking__field input,
    .home-page .hero-lab .home-booking__field select {
        min-height: 44px;
        padding: 0 0.58rem;
        font-size: 0.78rem;
        letter-spacing: -0.03em;
    }

    .home-page .hero-lab .home-booking__field input[type="date"] {
        padding: 0 0.58rem;
        font-size: 0.72rem;
    }

    .home-page .hero-lab .home-booking__field input[type="date"]::-webkit-calendar-picker-indicator {
        width: 14px;
        height: 14px;
        margin-left: 0;
    }

    .home-page .hero-lab .home-booking__submit {
        min-height: 44px;
        border-radius: 10px;
        font-size: 0.64rem;
        letter-spacing: 0.12em;
    }
}

* {
    box-sizing: border-box;
}

html,
body {
    margin: 0;
    min-height: 100%;
    overflow-x: clip;
    background: #050506;
}

@supports not (overflow: clip) {
    html,
    body {
        overflow-x: hidden;
    }
}

body {
    color: var(--lab-text);
    font-family: var(--lab-font-sans);
}

/* La home V2 ya no es solo hero:
   este fondo base ayuda a que los siguientes bloques entren sin corte duro. */
.lab-main {
    background: #050506;
}

body.hero-lab-overlay-open {
    overflow: hidden;
}

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

img {
    display: block;
    max-width: 100%;
}

button,
input,
select {
    font: inherit;
}

.lab-shell {
    /* Marco maestro de la home:
       todas las secciones cuelgan del mismo eje visual. */
    width: var(--lab-frame-width);
    margin: 0 auto;
}

.lab-header .lab-shell,
.hero-lab__shell,
.brand-marquee__shell,
.fleet-categories__shell,
.featured-fleet__shell {
    width: var(--lab-frame-width);
    margin: 0 auto;
}

.brand-marquee__shell,
.fleet-categories__shell,
.featured-fleet__shell,
.service-layer__shell {
    position: relative;
    z-index: 1;
}

.home-trust-strip .home-trust-strip__shell {
    width: min(var(--lab-frame-width), 64rem);
    margin-inline: auto;
}

.lab-header {
    /* Header superpuesto al hero, pero ya no fijo:
       al hacer scroll desaparece con la pagina. */
    position: absolute;
    inset: 0 0 auto;
    z-index: 20;
    line-height: normal;
    background: linear-gradient(180deg, rgba(4, 4, 6, 0.96) 0%, rgba(4, 4, 6, 0.86) 64%, rgba(4, 4, 6, 0.52) 100%);
}

.lab-header::after {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 1px;
    background: linear-gradient(90deg, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0));
}

.lab-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;
    padding: 1.15rem 0;
}

.lab-brand {
    display: inline-flex;
    align-items: center;
    gap: 0.95rem;
    flex: 0 0 auto;
    font-family: var(--lab-font-sans);
}

.lab-brand:focus {
    outline: none;
}

.lab-brand:focus-visible {
    border-radius: 14px;
    outline: 2px solid rgba(239, 215, 147, 0.64);
    outline-offset: 5px;
}

.lab-brand__crest {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 62px;
    aspect-ratio: 1;
    border-radius: 18px;
    border: 1px solid rgba(214, 188, 134, 0.24);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.015));
    overflow: hidden;
}

.lab-brand__crest img {
    width: auto;
    height: 88%;
    object-fit: contain;
    filter: drop-shadow(0 4px 12px rgba(214, 188, 134, 0.18));
}

.lab-brand__copy {
    display: grid;
    gap: 0.2rem;
    min-width: max-content;
}

.lab-brand__copy strong {
    color: #fffaf2;
    font-family: var(--lab-font-sans);
    font-size: 0.9rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    line-height: 1.08;
    text-transform: uppercase;
    text-shadow: 0 1px 10px rgba(0, 0, 0, 0.42);
    white-space: nowrap;
}

.lab-brand__copy span {
    color: var(--lab-muted-soft);
    font-family: var(--lab-font-sans);
    font-size: 0.64rem;
    letter-spacing: 0.18em;
    line-height: 1.25;
    text-transform: uppercase;
    text-shadow: 0 1px 8px rgba(0, 0, 0, 0.35);
    white-space: nowrap;
}

.lab-header__nav {
    display: flex;
    align-items: center;
    gap: 1rem;
    position: relative;
}

.lab-nav {
    /* Navegacion en linea, sin capsula visual detras. */
    display: flex;
    align-items: center;
    gap: clamp(1.2rem, 1.45vw, 2rem);
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.lab-nav > a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.38rem 0;
    border-radius: 0;
    font-family: var(--lab-font-sans);
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #f8f3e8;
    text-shadow: 0 1px 8px rgba(0, 0, 0, 0.38);
}

.lab-nav > a[aria-current="page"] {
    color: var(--lab-champagne);
    background: transparent;
}

.lab-reserve {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 56px;
    padding: 0 1.5rem;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--lab-accent-soft), var(--lab-accent));
    color: var(--dp-color-text);
    font-family: var(--lab-font-sans);
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    box-shadow: 0 14px 34px rgba(216, 180, 95, 0.18);
}

.lab-header__nav {
    position: relative;
}

.lab-nav {
    position: relative;
    isolation: isolate;
}

.lab-nav::before {
    content: none;
}

.lab-nav > a,
.lab-nav__trigger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.16rem 0;
    border-radius: 0;
    border: 0;
    background: transparent;
    font-family: var(--lab-font-sans);
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #f8f3e8;
    cursor: pointer;
    white-space: nowrap;
    position: relative;
    overflow: visible;
    line-height: 1;
    transition:
        color 180ms ease,
        opacity 180ms ease;
}

.lab-nav > a::after,
.lab-nav__trigger::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -0.42rem;
    height: 1px;
    border-radius: 999px;
    background: linear-gradient(90deg, rgba(214, 188, 134, 0), rgba(214, 188, 134, 0.9), rgba(214, 188, 134, 0));
    pointer-events: none;
    opacity: 0;
    transform: scaleX(0.65);
    transform-origin: center;
    transition: opacity 180ms ease, transform 180ms ease;
}

.lab-nav__trigger::before {
    content: none;
}

.lab-nav__item {
    position: relative;
    display: flex;
    align-items: center;
}

.lab-nav__trigger {
    gap: 0.58rem;
    z-index: 1;
}

.lab-nav__chevron {
    width: 0.42rem;
    height: 0.42rem;
    border-right: 1.5px solid currentColor;
    border-bottom: 1.5px solid currentColor;
    transform: rotate(45deg) translateY(-1px);
    transition: transform 180ms ease;
}

.lab-nav__trigger:hover {
    color: var(--lab-cool-highlight);
    background: transparent;
    box-shadow: none;
}

.lab-nav__item.is-open .lab-nav__trigger {
    color: var(--lab-champagne);
    background: transparent;
    box-shadow: none;
}

.lab-nav__trigger:focus-visible {
    color: var(--lab-cool-highlight);
    background: transparent;
    outline: 1px solid var(--lab-cool-outline);
    outline-offset: 4px;
}

.lab-nav > a:hover,
.lab-nav > a:focus-visible {
    color: var(--lab-cool-highlight);
    background: transparent;
    box-shadow: none;
}

.lab-nav > a:hover::after,
.lab-nav > a:focus-visible::after,
.lab-nav > a[aria-current="page"]::after,
.lab-nav__trigger:hover::after,
.lab-nav__item.is-open .lab-nav__trigger::after,
.lab-nav__trigger:focus-visible::after {
    opacity: 1;
    transform: scaleX(1);
}

.lab-nav__item.is-open .lab-nav__chevron {
    transform: rotate(-135deg) translateY(-1px);
}

.lab-nav__trigger:focus-visible .lab-nav__chevron {
    transform: rotate(-135deg) translateY(-1px);
}

.lab-nav__panel {
    --lab-nav-panel-width: 33rem;
    position: absolute;
    top: calc(100% + 0.55rem);
    left: 50%;
    width: min(var(--lab-nav-panel-width), calc(100vw - 4rem));
    padding: 0.98rem 1.05rem 1.02rem;
    border: 1px solid var(--lab-cool-lens-edge);
    border-radius: 1.2rem;
    overflow: hidden;
    background:
        linear-gradient(180deg, var(--lab-cool-panel-start) 0%, var(--lab-cool-panel-end) 100%),
        radial-gradient(circle at 18% -10%, var(--lab-cool-glass-top), rgba(255, 255, 255, 0) 34%),
        radial-gradient(circle at 100% 12%, var(--lab-cool-glass-mid), rgba(255, 255, 255, 0) 30%),
        radial-gradient(circle at 15% 112%, var(--lab-cool-glass-bottom), rgba(255, 255, 255, 0) 42%);
    box-shadow:
        0 26px 64px var(--lab-cool-lens-shadow),
        0 12px 26px rgba(23, 43, 69, 0.16),
        inset 0 1px 0 rgba(255, 255, 255, 0.22),
        inset 0 -1px 0 rgba(156, 182, 212, 0.08);
    backdrop-filter: blur(22px) saturate(150%) brightness(1.04) contrast(1.04);
    -webkit-backdrop-filter: blur(22px) saturate(150%) brightness(1.04) contrast(1.04);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translate(-50%, 0.8rem) scale(0.985);
    transition:
        opacity 180ms ease,
        transform 180ms ease,
        visibility 180ms ease;
    z-index: 30;
}

.lab-nav__panel::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 100%;
    height: 1rem;
}

.lab-nav__panel::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.16), rgba(255, 255, 255, 0.03) 14%, rgba(255, 255, 255, 0) 34%),
        radial-gradient(circle at 24% 0%, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0) 24%);
    opacity: 0.92;
    pointer-events: none;
}

.lab-nav__panel--brands {
    width: max-content;
    max-width: calc(100vw - 4rem);
}

.lab-nav__panel--types {
    --lab-nav-panel-width: 24.8rem;
}

.lab-nav__panel--brands,
.lab-nav__panel--types {
    background:
        linear-gradient(180deg, rgba(18, 29, 44, 0.92) 0%, rgba(8, 15, 25, 0.96) 100%),
        radial-gradient(circle at 18% -10%, var(--lab-cool-glass-top), rgba(255, 255, 255, 0) 34%),
        radial-gradient(circle at 100% 12%, var(--lab-cool-glass-mid), rgba(255, 255, 255, 0) 30%),
        radial-gradient(circle at 15% 112%, var(--lab-cool-glass-bottom), rgba(255, 255, 255, 0) 42%);
}

.lab-nav__panel--brands .lab-nav__card,
.lab-nav__panel--types .lab-nav__card {
    border-color: transparent;
    background: transparent;
    box-shadow: none;
}

.lab-nav__item:focus-within .lab-nav__panel,
.lab-nav__item.is-open .lab-nav__panel {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translate(-50%, 0) scale(1);
}

.lab-nav__panel-grid {
    display: grid;
    align-items: center;
    column-gap: 1.05rem;
    row-gap: 0.72rem;
    justify-content: center;
    justify-items: start;
    position: relative;
    z-index: 1;
    isolation: isolate;
}

.lab-nav__panel-grid::before {
    content: "";
    position: absolute;
    inset: -0.4rem -0.5rem;
    border-radius: 1.05rem;
    background:
        linear-gradient(180deg, rgba(8, 13, 20, 0.22), rgba(8, 13, 20, 0.12)),
        radial-gradient(circle at 50% 0%, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0) 48%);
    backdrop-filter: blur(10px) saturate(125%);
    -webkit-backdrop-filter: blur(10px) saturate(125%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.05),
        inset 0 -1px 0 rgba(156, 182, 212, 0.03);
    z-index: 0;
    pointer-events: none;
}

.lab-nav__panel-grid--types {
    grid-template-columns: repeat(2, minmax(9.6rem, max-content));
    column-gap: 0.95rem;
    row-gap: 0.64rem;
}

.lab-nav__panel-grid--types::before {
    display: none;
}

.lab-nav__panel-grid--brands {
    grid-template-columns: repeat(2, minmax(9.6rem, max-content));
    column-gap: 0.95rem;
    row-gap: 0.64rem;
}

.lab-nav__panel-grid--brands::before {
    display: none;
}

.lab-nav__card {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.9rem;
    min-height: 2.8rem;
    width: 100%;
    padding: 0.72rem 0.84rem;
    border: 1px solid rgba(198, 220, 243, 0.05);
    border-radius: 1rem;
    background: linear-gradient(180deg, var(--lab-cool-card-idle), rgba(255, 255, 255, 0.008));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.04),
        inset 0 -1px 0 rgba(156, 182, 212, 0.035);
    color: var(--lab-text);
    position: relative;
    z-index: 1;
    transition:
        transform 180ms ease,
        color 180ms ease,
        opacity 180ms ease,
        background-color 180ms ease,
        box-shadow 180ms ease,
        border-color 180ms ease;
}

.lab-nav__card:hover,
.lab-nav__card:focus-visible {
    color: var(--lab-cool-highlight);
    opacity: 1;
    transform: translateX(2px);
    border-color: rgba(205, 226, 247, 0.14);
    background: linear-gradient(180deg, var(--lab-cool-card-hover), rgba(82, 106, 137, 0.055));
    box-shadow:
        inset 0 1px 0 rgba(247, 251, 255, 0.1),
        0 10px 18px rgba(4, 10, 18, 0.11);
}

.lab-nav__card:focus-visible {
    outline: none;
}

.lab-nav__card-media {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
}

.lab-nav__card-media--type {
    width: 3.4rem;
    min-width: 3.4rem;
}

.lab-nav__card-media--type img {
    width: 100%;
    height: auto;
    object-fit: contain;
    filter: none;
}

.lab-nav__card-media--brand {
    width: 2.9rem;
    min-width: 2.9rem;
    height: 2rem;
}

.lab-nav__card-media--brand img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    filter: drop-shadow(0 8px 14px rgba(0, 0, 0, 0.18));
}

.lab-nav__card-copy {
    display: grid;
    gap: 0.22rem;
    min-width: 0;
}

.lab-nav__card-copy strong {
    color: currentColor;
    font-family: var(--lab-font-sans);
    font-size: 0.98rem;
    line-height: 1.2;
    font-weight: 600;
    letter-spacing: 0;
    text-transform: none;
}

.lab-nav__card-copy span {
    display: none;
}

.lab-nav__card--brand {
    min-height: auto;
    padding: 0;
    width: 100%;
    border: none;
    border-radius: 0;
    background: none;
    box-shadow: none;
    gap: 0.56rem;
    opacity: 0.94;
}

.lab-nav__card--brand:hover,
.lab-nav__card--brand:focus-visible {
    transform: translateY(-1px);
    border-color: transparent;
    background: none;
    box-shadow: none;
    color: var(--lab-cool-highlight);
    opacity: 1;
}

.lab-nav__card--brand .lab-nav__card-media--brand {
    width: 2.04rem;
    min-width: 2.04rem;
    height: 1.48rem;
}

.lab-nav__card--brand .lab-nav__card-media--brand img {
    filter: drop-shadow(0 10px 14px rgba(0, 0, 0, 0.2));
}

.lab-nav__card--brand .lab-nav__card-copy {
    gap: 0;
}

.lab-nav__card--brand .lab-nav__card-copy strong {
    font-family: var(--lab-font-sans);
    font-size: 0.9rem;
    font-weight: 600;
    line-height: 1.05;
    letter-spacing: -0.01em;
}

.lab-nav__card--type {
    min-height: auto;
    padding: 0;
    border: none;
    border-radius: 0;
    background: none;
    box-shadow: none;
    gap: 0.56rem;
    opacity: 0.94;
}

.lab-nav__card--type:hover,
.lab-nav__card--type:focus-visible {
    transform: translateY(-1px);
    border-color: transparent;
    background: none;
    box-shadow: none;
    color: var(--lab-cool-highlight);
    opacity: 1;
}

.lab-nav__card--type .lab-nav__card-media--type {
    width: 3.9rem;
    min-width: 3.9rem;
    height: 1.8rem;
    overflow: visible;
}

.lab-nav__card--type .lab-nav__card-media--type img {
    transform: scale(1.36);
    transform-origin: center;
    filter: none;
}

.lab-nav__card--type .lab-nav__card-copy {
    gap: 0;
}

.lab-nav__card--type .lab-nav__card-copy strong {
    font-family: var(--lab-font-sans);
    font-size: 0.9rem;
    font-weight: 600;
    line-height: 1.02;
    letter-spacing: -0.01em;
}

.lab-nav a.lab-nav__card {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.9rem;
    width: 100%;
    min-height: 2.8rem;
    padding: 0.72rem 0.84rem;
    border-radius: 1rem;
    color: var(--lab-text);
    font-size: inherit;
    font-weight: inherit;
    letter-spacing: 0;
    text-transform: none;
}

.hero-lab {
    /* Escena principal del hero. Todo lo visual se apila dentro de esta seccion. */
    position: relative;
    min-height: 100svh;
    overflow: clip;
    background: #060708;
    isolation: isolate;
}

.hero-lab::after {
    content: none;
}

.hero-lab__video,
.hero-lab__overlay,
.hero-lab__glow {
    /* Estas capas ocupan todo el hero y se superponen una encima de otra. */
    position: absolute;
    inset: 0;
}

.hero-lab__video {
    /* El video sigue subordinado al copy, pero con suficiente presencia para vender el mood. */
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 58% center;
    opacity: 0.62;
    transform: scale(1.015);
    filter: saturate(1.12) brightness(0.9) contrast(1.05);
    transition:
        opacity 1400ms ease,
        transform 2200ms cubic-bezier(0.19, 1, 0.22, 1),
        filter 1600ms ease;
}

.hero-lab__overlay {
    /* Dos degradados:
       1. oscurecen izquierda y bordes
       2. ayudan a que el texto sea legible sobre el video */
    background:
        linear-gradient(180deg, rgba(4, 4, 6, 0.5) 0%, rgba(4, 4, 6, 0.08) 31%, rgba(4, 4, 6, 0.66) 100%);
    transition: background 1600ms ease, opacity 1000ms ease;
}

.hero-lab__glow {
    /* Halo sutil para evitar que la derecha quede completamente vacia. */
    inset: 9% 5% 10% 40%;
    background:
        radial-gradient(circle at 34% 30%, rgba(214, 188, 134, 0.16), transparent 16%),
        radial-gradient(circle at 52% 40%, rgba(var(--dp-color-gold-rgb), 0.14), transparent 22%),
        radial-gradient(circle at 48% 54%, rgba(255, 255, 255, 0.06), transparent 32%);
    filter: blur(18px);
    opacity: 0.7;
    transition:
        opacity 1600ms ease,
        inset 1800ms cubic-bezier(0.19, 1, 0.22, 1),
        filter 1600ms ease;
}

.js .hero-lab.hero-lab--intro-pending .hero-lab__video,
.hero-lab.is-intro-enabled:not(.is-body-visible) .hero-lab__video {
    opacity: 0.32;
    transform: scale(1.055);
    filter: saturate(0.9) brightness(0.64) contrast(1.03);
}

.js .hero-lab.hero-lab--intro-pending .hero-lab__overlay,
.hero-lab.is-intro-enabled:not(.is-body-visible) .hero-lab__overlay {
    background:
        linear-gradient(180deg, rgba(4, 4, 6, 0.6) 0%, rgba(4, 4, 6, 0.14) 34%, rgba(4, 4, 6, 0.74) 100%);
}

.js .hero-lab.hero-lab--intro-pending .hero-lab__glow,
.hero-lab.is-intro-enabled:not(.is-body-visible) .hero-lab__glow {
    inset: 10% 7% 11% 44%;
    opacity: 0.2;
    filter: blur(22px);
}

.hero-lab.is-intro-enabled.is-body-visible:not(.is-mark-active):not(.is-intro-complete) .hero-lab__video {
    opacity: 0.5;
    transform: scale(1.03);
    filter: saturate(1.02) brightness(0.78) contrast(1.04);
}

.hero-lab.is-intro-enabled.is-body-visible:not(.is-mark-active):not(.is-intro-complete) .hero-lab__overlay {
    background:
        linear-gradient(180deg, rgba(4, 4, 6, 0.56) 0%, rgba(4, 4, 6, 0.1) 32%, rgba(4, 4, 6, 0.72) 100%);
}

.hero-lab.is-intro-enabled.is-mark-active .hero-lab__video {
    opacity: 0.72;
    transform: scale(1.01);
    filter: saturate(1.16) brightness(0.96) contrast(1.05);
}

.hero-lab.is-intro-enabled.is-mark-active .hero-lab__overlay {
    background:
        linear-gradient(180deg, rgba(4, 4, 6, 0.48) 0%, rgba(4, 4, 6, 0.04) 30%, rgba(4, 4, 6, 0.64) 100%);
}

.hero-lab__shell {
    /* Marco interno del hero:
       separa el contenido del header fijo y da altura util a toda la composicion. */
    position: relative;
    z-index: 1;
    min-height: clamp(46rem, 86svh, 56rem);
    padding-top: calc(var(--lab-header-offset) + 2.75rem);
    padding-bottom: 3.5rem;
}

.hero-lab__body {
    /* Caja grande principal alineada a la izquierda.
       No pensamos en dos columnas de texto, sino en un unico bloque editorial. */
    position: relative;
    width: min(100%, 68rem);
    z-index: 1;
}

.hero-lab__body::before {
    content: "";
    position: absolute;
    top: -3rem;
    left: -6rem;
    width: min(44rem, 80vw);
    height: 31rem;
    border-radius: 50%;
    background: radial-gradient(
        ellipse at 42% 38%,
        rgba(5, 7, 10, 0.44) 0%,
        rgba(5, 7, 10, 0.32) 24%,
        rgba(5, 7, 10, 0.16) 48%,
        rgba(5, 7, 10, 0) 74%
    );
    filter: blur(26px);
    opacity: 0.62;
    pointer-events: none;
    z-index: 0;
}

.hero-lab__content-box {
    /* Dentro de esta caja todas las piezas comparten el mismo arranque izquierdo.
       Luego cada una usa su propia anchura para crear jerarquia. */
    width: 100%;
    position: relative;
    z-index: 1;
}

.hero-lab__body-copy {
    position: relative;
    z-index: 1;
    transition:
        opacity 720ms cubic-bezier(0.22, 1, 0.36, 1),
        transform 720ms cubic-bezier(0.22, 1, 0.36, 1),
        filter 720ms ease;
}

@media (min-width: 1081px) {
    .hero-lab__content-box::after {
        content: "";
        position: absolute;
        top: -1.1rem;
        left: 24rem;
        width: min(48rem, calc(100% - 19rem));
        height: 15rem;
        border-radius: 1.8rem;
        background:
            linear-gradient(90deg, rgba(5, 7, 10, 0.44) 0%, rgba(5, 7, 10, 0.22) 55%, rgba(5, 7, 10, 0) 100%),
            radial-gradient(circle at 20% 28%, rgba(5, 7, 10, 0.34), rgba(5, 7, 10, 0) 38%);
        filter: blur(18px);
        opacity: 0;
        pointer-events: none;
        z-index: 2;
        transition: opacity 180ms ease;
    }

    body:has(.js-nav-mega.is-open) .hero-lab__content-box::after {
        opacity: 1;
    }
}

.js .hero-lab.hero-lab--intro-pending .hero-lab__body-copy,
.hero-lab.is-intro-enabled .hero-lab__body-copy {
    opacity: 0;
    transform: translateY(2rem) scale(1.04);
    filter: blur(14px);
}

.hero-lab.is-intro-enabled.is-body-visible .hero-lab__body-copy {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
}

.hero-lab__mark {
    /* Marca fantasma decorativa.
       Sirve para equilibrar visualmente la derecha, no para comunicar contenido. */
    position: absolute;
    left: 50%;
    top: 47%;
    width: 26rem;
    opacity: 0;
    filter: sepia(1) saturate(1.85) hue-rotate(338deg) brightness(0.76) contrast(0.92);
    pointer-events: none;
    transform-origin: center;
    transition:
        opacity 900ms ease,
        transform 1300ms cubic-bezier(0.19, 1, 0.22, 1),
        filter 1000ms ease,
        left 1300ms cubic-bezier(0.19, 1, 0.22, 1),
        top 1300ms cubic-bezier(0.19, 1, 0.22, 1),
        width 1300ms cubic-bezier(0.19, 1, 0.22, 1);
}

.js .hero-lab.hero-lab--intro-pending .hero-lab__mark,
.hero-lab.is-intro-enabled .hero-lab__mark {
    opacity: 0;
    transform: translate3d(-50%, -50%, 0) scale(0.84);
    filter: sepia(1) saturate(2) hue-rotate(338deg) brightness(0.88) contrast(0.9) blur(2px);
}

.hero-lab.is-intro-enabled.is-mark-active .hero-lab__mark {
    left: 71%;
    top: 52%;
    width: 39rem;
    opacity: 0.23;
    transform: translate3d(-50%, -50%, 0) scale(1);
    filter: sepia(1) saturate(2.45) hue-rotate(338deg) brightness(0.96) contrast(0.92) blur(0)
        drop-shadow(0 0 24px rgba(214, 188, 134, 0.14));
}

.hero-lab.is-intro-enabled.is-intro-complete .hero-lab__mark,
.hero-lab.is-intro-enabled.is-launcher-visible:not(.is-mark-active) .hero-lab__mark {
    left: 50%;
    top: 47%;
    width: 26rem;
    opacity: 0;
    transform: translate3d(-50%, -50%, 0) scale(1.06);
    filter: sepia(1) saturate(1.7) hue-rotate(338deg) brightness(0.82) contrast(0.88) blur(10px);
}

.hero-lab__eyebrow {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.9rem;
    width: fit-content;
    margin-inline: auto;
    color: var(--lab-champagne);
    font-family: var(--lab-font-sans);
    font-size: 0.74rem;
    font-weight: 600;
    letter-spacing: 0.22em;
    text-align: center;
    text-transform: uppercase;
}

.hero-lab__eyebrow::before {
    content: "";
    width: 42px;
    height: 1px;
    background: linear-gradient(90deg, rgba(214, 188, 134, 0), rgba(214, 188, 134, 0.9));
}

.hero-lab h1 {
    /* El h1 ocupa la mayor parte de la content box.
       Sigue siendo un bloque controlado, pero ya no parece una columna estrecha. */
    width: min(100%, 45rem);
    margin: 0.95rem 0 1.65rem;
    font-family: var(--lab-font-sans);
    font-size: clamp(2.95rem, 3.2vw, 3.75rem);
    line-height: 0.96;
    letter-spacing: -0.05em;
    font-weight: 700;
    text-wrap: balance;
}

.hero-lab__lead {
    /* El parrafo sigue naciendo desde el mismo borde izquierdo,
       pero con menos ancho que el h1 para que se lea como apoyo. */
    width: min(100%, 35rem);
    margin: 0;
    color: var(--lab-muted);
    font-size: 0.94rem;
    line-height: 1.5;
}

.hero-lab__launcher {
    /* El launcher es el tercer ancho de la misma caja.
       Mas estrecho que el lead para que se lea como activacion, no como continuacion. */
    width: min(100%, 30rem);
    margin-top: 5.2rem;
    padding-bottom: 1rem;
    transition:
        opacity 720ms cubic-bezier(0.22, 1, 0.36, 1),
        transform 720ms cubic-bezier(0.22, 1, 0.36, 1),
        filter 720ms ease;
}

.js .hero-lab.hero-lab--intro-pending .hero-lab__launcher,
.hero-lab.is-intro-enabled .hero-lab__launcher {
    opacity: 0;
    transform: translateY(2.5rem);
    filter: blur(10px);
    pointer-events: none;
}

.hero-lab.is-intro-bypass .hero-lab__video,
.hero-lab.is-intro-bypass .hero-lab__overlay,
.hero-lab.is-intro-bypass .hero-lab__glow,
.hero-lab.is-intro-bypass .hero-lab__body-copy,
.hero-lab.is-intro-bypass .hero-lab__mark,
.hero-lab.is-intro-bypass .hero-lab__launcher {
    transition: none;
}

.hero-lab.is-intro-enabled.is-launcher-visible .hero-lab__launcher {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
    pointer-events: auto;
}

.hero-lab__launcher h2 {
    margin: 0 0 0.82rem;
    font-family: var(--lab-font-sans);
    font-size: 1.95rem;
    line-height: 1.02;
    letter-spacing: -0.035em;
    font-weight: 600;
}

.hero-lab__launcher p {
    margin: 0;
    color: var(--lab-muted);
    width: min(100%, 25rem);
    font-size: 0.92rem;
    line-height: 1.5;
}

.hero-lab__actions {
    /* Los CTAs se colocan en fila porque aqui estamos trabajando desktop first. */
    display: flex;
    align-items: center;
    gap: 0.8rem;
    margin-top: 1.35rem;
    margin-bottom: 1rem;
}

.hero-lab__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 58px;
    padding: 0 1.35rem;
    border: 0;
    border-radius: 0.9rem;
    font-family: var(--lab-font-sans);
    font-size: 0.73rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    cursor: pointer;
}

.hero-lab__cta--primary {
    /* CTA principal: mas ancho y con acento visual fuerte. */
    min-width: 17.5rem;
    background: linear-gradient(135deg, var(--lab-accent-soft), var(--lab-accent));
    color: #111;
}

.hero-lab__cta--secondary {
    min-width: 8.5rem;
    border: 1px solid rgba(255, 255, 255, 0.12);
    color: var(--lab-text);
    background: rgba(255, 255, 255, 0.02);
}

.hero-lab__cta:focus-visible,
.fleet-visual-card__media:focus-visible,
.fleet-visual-card__title-link:focus-visible,
.fleet-visual-card__primary:focus-visible,
.fleet-visual-card__contact-link:focus-visible,
.featured-fleet__footer-button:focus-visible,
.featured-fleet__link:focus-visible,
.fleet-category:focus-visible,
.catalog-card__more:focus-visible,
.fleet-catalog__button:focus-visible,
.fleet-catalog__link:focus-visible,
.guest-reviews__cta:focus-visible,
.site-v2-footer__column a:focus-visible,
.site-v2-footer__legal a:focus-visible,
.site-v2-footer__socials a:focus-visible,
.service-process__button:focus-visible,
.hero-lab-overlay__close:focus-visible,
.hero-lab-overlay__submit:focus-visible,
.hero-lab-overlay__input:focus-visible {
    outline: 2px solid rgba(var(--dp-color-gold-rgb), 0.92);
    outline-offset: 3px;
}

.featured-fleet {
    position: relative;
    margin-top: 0;
    padding: 1.1rem 0 4.6rem;
    color: #171412;
    background: linear-gradient(180deg, #f7f3ee 0%, #fbf9f6 52%, #f4efe8 100%);
}

.featured-fleet::before,
.featured-fleet::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    z-index: 0;
    pointer-events: none;
}

.featured-fleet::before {
    content: none;
}

.featured-fleet::after {
    content: none;
}

.featured-fleet__shell {
    display: grid;
    gap: 1.85rem;
}

.featured-fleet__intro {
    display: grid;
    justify-items: center;
    max-width: 30rem;
    margin: 0 auto;
    text-align: center;
}

.featured-fleet__eyebrow {
    margin-bottom: 0.2rem;
    color: #80613a;
}

.featured-fleet__eyebrow::before {
    background: linear-gradient(90deg, rgba(140, 119, 97, 0), rgba(140, 119, 97, 0.52));
}

.featured-fleet__intro h2 {
    margin: 0.82rem 0 0;
    font-family: var(--lab-font-display);
    font-size: clamp(2.2rem, 2.7vw, 2.8rem);
    line-height: 0.98;
    letter-spacing: -0.04em;
    font-weight: 600;
    text-wrap: balance;
    color: #171412;
}

.featured-fleet__intro p {
    max-width: 30rem;
    margin: 0 auto;
    color: #3f3328;
    font-family: var(--lab-font-display);
    font-size: 1.2rem;
    line-height: 1.36;
    letter-spacing: -0.01em;
}

.mobile-scroll-hint {
    display: none;
}

.fleet-showcase {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 17.2rem), 1fr));
    gap: 1rem;
    align-items: stretch;
}

.fleet-visual-card {
    --fleet-card-accent-rgb: 66, 58, 52;
    --fleet-card-dot: #6d645d;
    --fleet-card-content-pad-x: 1rem;
    position: relative;
    display: grid;
    grid-template-rows: auto 1fr;
    width: 100%;
    height: 100%;
    min-height: 0;
    padding: 0;
    border: 1px solid rgba(152, 126, 96, 0.16);
    border-radius: 1.55rem;
    background: linear-gradient(180deg, #fffdfa 0%, #fbf7f1 100%);
    overflow: hidden;
    text-align: left;
    box-shadow:
        0 22px 52px rgba(35, 25, 16, 0.08),
        0 1px 0 rgba(255, 255, 255, 0.92) inset;
    transition:
        transform 220ms ease,
        box-shadow 220ms ease,
        border-color 220ms ease;
}

.fleet-visual-card::before {
    content: none;
}

.fleet-visual-card:hover,
.fleet-visual-card:focus-within {
    transform: none;
    border-color: rgba(var(--fleet-card-accent-rgb), 0.18);
    box-shadow:
        0 24px 56px rgba(35, 25, 16, 0.1),
        0 1px 0 rgba(255, 255, 255, 0.92) inset;
}

.fleet-visual-card--huracan {
    --fleet-card-accent-rgb: 66, 58, 52;
    --fleet-card-dot: #6d645d;
}

.fleet-visual-card--ferrari {
    --fleet-card-accent-rgb: 66, 58, 52;
    --fleet-card-dot: #6d645d;
}

.fleet-visual-card--urus {
    --fleet-card-accent-rgb: 66, 58, 52;
    --fleet-card-dot: #6d645d;
}

.fleet-visual-card--cullinan {
    --fleet-card-accent-rgb: 66, 58, 52;
    --fleet-card-dot: #6d645d;
}

.fleet-visual-card__media {
    position: relative;
    aspect-ratio: 1.18;
    height: auto;
    margin: 0;
    border-radius: 0;
    overflow: hidden;
    background: #ede5dc;
    box-shadow: none;
}

.fleet-visual-card img,
.fleet-visual-card__shade {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

.fleet-visual-card img {
    object-fit: cover;
    filter: none;
    transition: transform 260ms ease;
}

.fleet-visual-card:hover img,
.fleet-visual-card:focus-within img {
    transform: scale(1.025);
    filter: none;
}

.fleet-visual-card__shade {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.08) 0%, rgba(15, 14, 13, 0.16) 100%);
}

.fleet-visual-card__body {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    gap: 0.72rem;
    min-height: 0;
    padding: 1rem var(--fleet-card-content-pad-x) 1rem;
}

.fleet-visual-card__utility-row {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 0.6rem;
    min-height: 1.75rem;
}

.fleet-visual-card__badge {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 0.66rem;
    border: 1px solid rgba(196, 157, 88, 0.24);
    border-radius: 999px;
    background: rgba(241, 226, 189, 0.42);
    color: #74512d;
    font-family: var(--lab-font-sans);
    font-size: 0.56rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.fleet-visual-card__trust {
    display: inline-flex;
    align-items: center;
    justify-self: end;
    gap: 0.4rem;
    min-width: 0;
    color: #6a523a;
    font-family: var(--lab-font-sans);
    font-size: 0.52rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    overflow: hidden;
    text-align: right;
    text-overflow: ellipsis;
    text-transform: uppercase;
    white-space: nowrap;
}

.fleet-visual-card__trust::before {
    content: "";
    width: 0.42rem;
    height: 0.42rem;
    border-radius: 999px;
    background: #c99e48;
    box-shadow: 0 0 0 3px rgba(214, 188, 134, 0.12);
}

.fleet-visual-card__label {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    padding: 0;
    border: 0;
    color: #74512d;
    font-family: var(--lab-font-sans);
    font-size: 0.56rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.fleet-visual-card h3 {
    margin: 0 0 0.1rem;
    display: flex;
    align-items: flex-start;
    min-height: 2.55rem;
}

.fleet-visual-card__title-link {
    display: inline-block;
    font-family: var(--lab-font-sans);
    font-size: 1.08rem;
    line-height: 1.14;
    letter-spacing: -0.03em;
    font-weight: 700;
    color: #171412;
    text-wrap: pretty;
}

.fleet-visual-card__title-link:hover {
    color: #000;
}

.fleet-visual-card__description {
    margin: 0;
    color: #43362b;
    font-size: 0.88rem;
    line-height: 1.56;
    min-height: calc(0.88rem * 1.56 * 2);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.fleet-visual-card__sales-line {
    margin: 0.04rem 0 0.08rem;
    color: #74512d;
    font-family: var(--lab-font-sans);
    font-size: 0.52rem;
    font-weight: 700;
    line-height: 1.48;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.fleet-visual-card__spec-list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.28rem;
    margin: 0;
    padding-top: 0.12rem;
}

.fleet-visual-card__spec-item {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 0.65rem;
    min-height: 1.55rem;
    padding: 0.1rem 0;
    border: 0;
    border-radius: 0;
    background: none;
    box-shadow: none;
}

.fleet-visual-card__spec-item dt {
    color: #6b5744;
    font-size: 0.58rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.fleet-visual-card__spec-item dd {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.38rem;
    margin: 0;
    color: #201b18;
    font-size: 0.66rem;
    font-weight: 700;
    line-height: 1.2;
    text-align: right;
    white-space: nowrap;
    padding: 0.28rem 0.58rem;
    border-radius: 999px;
    background: rgba(228, 225, 220, 0.8);
}

.fleet-visual-card__color-dot {
    width: 0.72rem;
    height: 0.72rem;
    border-radius: 999px;
    background: var(--fleet-card-dot);
    box-shadow: 0 0 0 2px rgba(32, 27, 24, 0.08);
}

.fleet-visual-card__spec-item:last-child:nth-child(odd) {
    grid-column: auto;
}

.fleet-visual-card__price-box {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.7rem;
    margin-top: 0.22rem;
    min-height: 0;
    padding: 0.78rem 0.84rem;
    border: 1px solid rgba(196, 157, 88, 0.28);
    border-radius: 0.95rem;
    background: #fffaf4;
}

.fleet-visual-card__price-box > div {
    min-width: 0;
    flex: 1 1 auto;
}

.fleet-visual-card__price-kicker {
    display: block;
    margin-bottom: 0.2rem;
    color: #5f4930;
    font-family: var(--lab-font-sans);
    font-size: 0.58rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.fleet-visual-card__price-value {
    display: block;
    color: #171412;
    font-family: var(--lab-font-sans);
    font-size: 1.28rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1;
    text-shadow: 0 1px 8px rgba(0, 0, 0, 0.38);
}

.fleet-visual-card__price-note {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 1.5rem;
    max-width: 7.5rem;
    padding: 0.35rem 0.64rem;
    border: 1px solid rgba(196, 157, 88, 0.22);
    border-radius: 999px;
    background: rgba(241, 226, 189, 0.4);
    color: #74512d;
    font-family: var(--lab-font-sans);
    font-size: 0.56rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    line-height: 1.15;
    text-align: center;
    text-transform: none;
}

.fleet-visual-card__actions {
    display: flex;
    justify-content: center;
    margin-top: auto;
    padding-top: 0.04rem;
}

.fleet-visual-card__primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    width: 100%;
    min-height: 44px;
    padding: 0 1.1rem;
    border: 1px solid rgba(196, 157, 88, 0.28);
    border-radius: 1rem;
    background: linear-gradient(135deg, rgba(220, 183, 104, 0.96), rgba(198, 151, 66, 0.92));
    color: #171412;
    font-family: var(--lab-font-sans);
    font-size: clamp(0.82rem, 0.78rem + 0.16vw, 0.94rem);
    font-weight: 820;
    line-height: 1.12;
    letter-spacing: 0;
    text-align: center;
    text-transform: none;
    box-shadow: 0 12px 26px rgba(198, 151, 66, 0.16);
}

.fleet-visual-card__primary::after {
    content: none;
}

.fleet-visual-card__contact-row {
    display: none !important;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    margin: 0;
    padding: 0;
    overflow: hidden;
    border-top: 1px solid rgba(152, 126, 96, 0.14);
    border-radius: 0;
    background: rgba(93, 75, 52, 0.14);
}

.fleet-visual-card__contact-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    min-height: 3.25rem;
    border: 0;
    border-radius: 0;
    background: #cfad61;
    color: #171412;
    font-family: var(--lab-font-sans);
    font-size: 0.82rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0;
    text-transform: none;
    box-shadow: none;
}

.fleet-visual-card__contact-icon {
    width: 1.08rem;
    height: 1.08rem;
    flex: 0 0 auto;
}

.fleet-visual-card__contact-link--wa {
    background: #23751f;
    color: #fff;
    box-shadow: inset 1px 0 0 rgba(255, 255, 255, 0.12);
}

.fleet-visual-card__primary:hover,
.fleet-visual-card__contact-link:hover {
    transform: none;
    filter: brightness(0.98);
}

.fleet-card--home .fleet-card__content {
    display: grid;
    grid-template-rows: auto auto 1fr;
    gap: 0.66rem;
    min-height: 100%;
    padding: 0.92rem var(--fleet-card-content-pad-x) 0.98rem;
}

.fleet-card--home .fleet-visual-card__media {
    aspect-ratio: 1.62 / 1;
}

.fleet-card--home .fleet-card__heading {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 0.72rem;
    min-height: 1rem;
}

.fleet-card--home .fleet-card__accent {
    justify-self: end;
    min-width: 0;
    color: #5c4732;
    font-family: var(--lab-font-sans);
    font-size: 0.52rem;
    font-weight: 600;
    letter-spacing: 0.15em;
    overflow: hidden;
    text-align: right;
    text-overflow: ellipsis;
    text-transform: uppercase;
    white-space: nowrap;
}

.fleet-card--home .fleet-card__body-grid {
    display: grid;
    grid-template-rows: minmax(0, 1fr) auto;
    gap: 0.72rem;
    min-height: 100%;
}

.fleet-card--home .fleet-card__copy {
    display: grid;
    grid-template-rows: minmax(2.62rem, auto) 2.8rem 1.35rem auto;
    row-gap: 0.18rem;
    align-content: start;
    min-height: 100%;
}

.fleet-card--home .fleet-card__title {
    margin: 0 0 0.45rem;
}

.fleet-card--home .fleet-visual-card__description {
    min-height: 0;
    height: calc(0.84rem * 1.55 * 2);
    font-size: 0.84rem;
    line-height: 1.55;
}

.fleet-card--home .fleet-visual-card__sales-line {
    height: calc(0.52rem * 1.55);
    margin-top: 0.46rem;
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
}

.fleet-card--home .fleet-visual-card__spec-list {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.44rem;
    margin-top: 0.7rem;
    padding-top: 0;
}

.fleet-card--home .fleet-card__spec {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 30px;
    padding: 0.16rem 0.48rem;
    border: 1px solid rgba(139, 118, 93, 0.14);
    border-radius: 0.8rem;
    background: #f4eee5;
    color: #43362b;
    font-family: var(--lab-font-sans);
    font-size: 0.5rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    line-height: 1.2;
    overflow: hidden;
    text-align: center;
    text-overflow: ellipsis;
    text-transform: uppercase;
    white-space: nowrap;
}

.fleet-card--home .fleet-visual-card__booking {
    display: grid;
    gap: 0.7rem;
    align-self: end;
    margin-top: auto;
}

.fleet-card--home .fleet-visual-card__price-box {
    margin-top: 0;
    padding: 0.72rem 0.82rem;
}

.fleet-card--home .fleet-visual-card__actions {
    padding-top: 0;
}

.featured-fleet__footer,
.featured-fleet__footer-button {
    display: inline-flex;
    align-items: center;
}

.featured-fleet__footer {
    justify-content: space-between;
    gap: 1.2rem;
    padding: 1rem 1.1rem;
    border: 1px solid rgba(49, 41, 36, 0.08);
    border-radius: 1rem;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.72) 0%, rgba(244, 240, 235, 0.92) 100%);
    box-shadow: 0 22px 48px rgba(16, 14, 12, 0.1);
}

.featured-fleet__footer p {
    max-width: 35rem;
    margin: 0;
    color: #3f3328;
    font-size: 0.92rem;
    line-height: 1.5;
}

.featured-fleet__footer-actions {
    display: flex;
    align-items: center;
    gap: 0.9rem;
}

.featured-fleet__footer-button {
    justify-content: center;
    width: fit-content;
    min-height: 46px;
    min-width: 14rem;
    padding: 0 1.15rem;
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 0.92rem;
    background: linear-gradient(135deg, var(--lab-accent-soft), var(--lab-accent));
    color: var(--dp-color-text);
    box-shadow: 0 14px 34px rgba(216, 180, 95, 0.16);
    font-family: var(--lab-font-sans);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    cursor: pointer;
}

.featured-fleet__link {
    color: rgba(231, 225, 210, 0.74);
    font-size: 0.88rem;
    text-decoration: none;
}

.featured-fleet__link:hover,
.featured-fleet__link:focus-visible {
    color: rgba(245, 241, 232, 0.96);
}

.fleet-categories {
    position: relative;
    z-index: 3;
    margin-top: 0;
    padding: 1.65rem 0 0.85rem;
    color: #171412;
    background: linear-gradient(180deg, #f7f3ee 0%, #faf8f5 100%);
    overflow: visible;
    border: none;
    box-shadow: none;
}

.fleet-categories::before {
    content: none;
}

.fleet-categories::after {
    content: none;
}

.fleet-categories__shell {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: repeat(4, minmax(10.8rem, 1fr));
    width: min(100%, 62rem);
    margin-inline: auto;
    justify-content: stretch;
    justify-items: center;
    gap: 0.8rem 1.8rem;
    align-items: center;
    padding: 0;
    border-radius: 0;
    background: none;
    border: none;
    box-shadow: none;
}

.fleet-category {
    --fleet-accent-rgb: 214, 188, 134;
    --fleet-image-width: 102%;
    position: relative;
    display: grid;
    justify-items: center;
    align-content: end;
    gap: 0.62rem;
    padding: 0.1rem 0.08rem 0;
    text-align: center;
    transition: transform 220ms ease, opacity 220ms ease;
}

.fleet-category:hover {
    transform: translateY(-3px);
}

.fleet-category__media {
    position: relative;
    display: grid;
    place-items: end center;
    justify-self: center;
    width: 100%;
    min-height: 8.9rem;
    aspect-ratio: 1.68 / 1;
    padding: 0.05rem 0 0.22rem;
    border-radius: 0;
    background: none;
    overflow: visible;
    transition:
        background 260ms ease,
        transform 260ms ease;
}

.fleet-category__media::before,
.fleet-category__media::after {
    content: none;
    position: absolute;
    pointer-events: none;
}

.fleet-category__media::before {
    left: 16%;
    right: 16%;
    bottom: 0.8rem;
    z-index: 1;
    background:
        radial-gradient(ellipse at center, rgba(36, 32, 29, 0.18) 0%, rgba(36, 32, 29, 0.08) 24%, rgba(var(--fleet-accent-rgb), 0.08) 48%, rgba(var(--fleet-accent-rgb), 0) 74%);
    height: 18%;
    border-radius: 50%;
    filter: blur(14px);
    opacity: 0.78;
}

.fleet-category__media::after {
    left: 20%;
    right: 20%;
    bottom: 0.9rem;
    z-index: 1;
    height: 2px;
    border-radius: 999px;
    background: linear-gradient(90deg, rgba(58, 51, 45, 0), rgba(58, 51, 45, 0.34) 18%, rgba(58, 51, 45, 0.34) 82%, rgba(58, 51, 45, 0));
    box-shadow: 0 0 12px rgba(255, 255, 255, 0.22);
    opacity: 0.72;
}

.fleet-category:hover .fleet-category__media {
    background: none;
}

.fleet-category__image {
    position: relative;
    z-index: 2;
    width: min(var(--fleet-image-width), 118%);
    height: clamp(8.15rem, 8.9vw, 9.9rem);
    max-width: 20.5rem;
    object-fit: contain;
    object-position: center bottom;
    justify-self: center;
    filter: none;
    transform: translateY(var(--fleet-image-shift-y, 0));
    transition: transform 260ms ease, filter 260ms ease;
}

.fleet-category:hover .fleet-category__image {
    transform: translateY(calc(var(--fleet-image-shift-y, 0) - 2px));
    filter: none;
}

.fleet-category__copy {
    display: grid;
    gap: 0.08rem;
    justify-items: center;
}

.fleet-category strong {
    color: rgba(40, 34, 29, 0.92);
    font-size: 1.08rem;
    font-weight: 600;
    line-height: 1.1;
    letter-spacing: -0.015em;
    transition: color 220ms ease, transform 220ms ease;
}

.fleet-category__copy span {
    display: none;
}

.fleet-category:hover strong {
    color: rgba(20, 16, 13, 0.98);
    transform: translateY(-1px);
}

.fleet-editorial {
    position: relative;
    padding: 0.6rem 0 4.6rem;
    background: linear-gradient(180deg, #f4efe8 0%, #faf8f5 100%);
}

.fleet-editorial__shell {
    display: grid;
    gap: 1.8rem;
}

.fleet-editorial__intro {
    display: grid;
    justify-items: start;
    max-width: 34rem;
    gap: 0.6rem;
}

.fleet-editorial--service .fleet-editorial__intro {
    max-width: 42rem;
}

.fleet-editorial__eyebrow {
    color: #80613a;
}

.fleet-editorial__eyebrow::before {
    background: linear-gradient(90deg, rgba(140, 119, 97, 0), rgba(140, 119, 97, 0.52));
}

.fleet-editorial__intro h2 {
    margin: 0;
    color: #171412;
    font-family: var(--lab-font-display);
    font-size: clamp(2.15rem, 2.7vw, 2.9rem);
    line-height: 0.98;
    letter-spacing: -0.04em;
    font-weight: 600;
    text-wrap: balance;
}

.fleet-editorial__intro p {
    margin: 0;
    max-width: 31rem;
    color: #3f3328;
    font-size: 0.98rem;
    line-height: 1.58;
}

.fleet-editorial__grid {
    display: grid;
    grid-template-columns: minmax(0, 1.28fr) minmax(0, 0.94fr);
    gap: 1rem;
    align-items: stretch;
}

.fleet-editorial__panel {
    position: relative;
    display: grid;
    overflow: hidden;
    border-radius: 1.6rem;
    border: 1px solid rgba(78, 67, 57, 0.1);
    background: #ffffff;
    box-shadow: 0 18px 38px rgba(29, 22, 16, 0.1);
}

.fleet-editorial__panel--video {
    min-height: 32rem;
}

.fleet-editorial--service .fleet-editorial__panel--video {
    min-height: 33rem;
}

.fleet-editorial__stack {
    display: grid;
    gap: 1rem;
}

.fleet-editorial__panel--photo,
.fleet-editorial__panel--detail {
    min-height: 15.4rem;
}

.fleet-editorial__media,
.fleet-editorial__panel img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.fleet-editorial__media {
    background: #0b0d10;
}

.fleet-editorial__panel::after {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 48%;
    background: linear-gradient(180deg, rgba(8, 9, 11, 0) 0%, rgba(8, 9, 11, 0.72) 100%);
    pointer-events: none;
}

.fleet-editorial__panel-copy {
    position: absolute;
    left: 1.25rem;
    right: 1.25rem;
    bottom: 1.15rem;
    z-index: 1;
    display: grid;
    gap: 0.38rem;
}

.fleet-editorial__panel-copy span {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    color: rgba(241, 234, 223, 0.78);
    font-family: var(--lab-font-sans);
    font-size: 0.58rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.fleet-editorial__panel-copy h3 {
    margin: 0;
    color: #fffaf2;
    font-family: var(--lab-font-display);
    font-size: 2rem;
    line-height: 0.96;
    letter-spacing: -0.035em;
    font-weight: 600;
}

.fleet-editorial__panel-copy p {
    margin: 0;
    max-width: 24rem;
    color: rgba(245, 241, 232, 0.82);
    font-size: 0.92rem;
    line-height: 1.5;
}

.closing-drive {
    position: relative;
    background: #060708;
}

.closing-drive__media {
    position: relative;
    min-height: clamp(20rem, 37vw, 28rem);
    overflow: hidden;
}

.closing-drive__media img,
.closing-drive__shade {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

.closing-drive__media img {
    object-fit: cover;
    object-position: center 42%;
    filter: saturate(0.88) brightness(0.62) contrast(1.05);
}

.closing-drive__shade {
    background:
        linear-gradient(180deg, rgba(7, 8, 10, 0.2) 0%, rgba(7, 8, 10, 0.46) 42%, rgba(7, 8, 10, 0.82) 100%),
        linear-gradient(90deg, rgba(7, 8, 10, 0.4) 0%, rgba(7, 8, 10, 0.08) 40%, rgba(7, 8, 10, 0.46) 100%);
}

.closing-drive__shell {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: flex-end;
    min-height: inherit;
    padding-top: 5rem;
    padding-bottom: 2.2rem;
}

.closing-drive__copy {
    display: grid;
    gap: 0.65rem;
    max-width: 32rem;
}

.closing-drive__eyebrow {
    color: rgba(241, 234, 223, 0.76);
}

.closing-drive__eyebrow::before {
    background: linear-gradient(90deg, rgba(214, 188, 134, 0), rgba(214, 188, 134, 0.62));
}

.closing-drive__copy h2 {
    margin: 0;
    color: rgba(250, 246, 239, 0.98);
    font-family: var(--lab-font-display);
    font-size: clamp(2.15rem, 2.9vw, 3rem);
    line-height: 0.97;
    letter-spacing: -0.04em;
    font-weight: 600;
    text-wrap: balance;
}

.fleet-category--sports {
    --fleet-accent-rgb: 241, 187, 71;
    --fleet-image-width: 111%;
    --fleet-image-shift-y: 0.05rem;
}

.fleet-category--convertible {
    --fleet-accent-rgb: 209, 88, 78;
    --fleet-image-width: 110%;
    --fleet-image-shift-y: 0.02rem;
}

.fleet-category--luxury {
    --fleet-accent-rgb: 214, 188, 134;
    --fleet-image-width: 106%;
    --fleet-image-shift-y: 0;
}

.fleet-category--suv {
    --fleet-accent-rgb: 170, 191, 143;
    --fleet-image-width: 114%;
    --fleet-image-shift-y: -0.02rem;
}

.brand-marquee {
    position: relative;
    z-index: 2;
    padding: 0.65rem 0 0.35rem;
    background:
        radial-gradient(circle at 50% -24%, rgba(255, 255, 255, 0.04), transparent 32%),
        linear-gradient(180deg, rgba(5, 5, 6, 0) 0%, rgba(7, 9, 13, 0.42) 18%, rgba(7, 9, 13, 0.78) 46%, rgba(6, 8, 11, 0.94) 100%);
}

.brand-marquee::before,
.brand-marquee::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    z-index: 0;
    pointer-events: none;
}

.brand-marquee::before {
    top: -4.6rem;
    height: 7.8rem;
    background: linear-gradient(180deg, rgba(5, 6, 8, 0) 0%, rgba(7, 9, 13, 0.72) 100%);
    filter: blur(28px);
}

.brand-marquee::after {
    bottom: -1.4rem;
    height: 4.8rem;
    background: linear-gradient(180deg, rgba(8, 10, 13, 0) 0%, rgba(10, 13, 18, 0.82) 100%);
    filter: blur(22px);
}

.brand-marquee__viewport {
    --brand-marquee-fade: clamp(48px, 8vw, 112px);
    position: relative;
    display: flex;
    align-items: center;
    overflow: hidden;
    min-height: 6.85rem;
    padding: 0.95rem 0 1.05rem;
    border-top: 1px solid rgba(255, 255, 255, 0.025);
    border-bottom: 1px solid rgba(255, 255, 255, 0.025);
    background:
        radial-gradient(circle at 50% 50%, rgba(216, 227, 247, 0.05), transparent 62%),
        linear-gradient(180deg, rgba(14, 17, 22, 0.78) 0%, rgba(8, 10, 13, 0.92) 100%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.012),
        inset 0 -1px 0 rgba(255, 255, 255, 0.012);
    -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 var(--brand-marquee-fade), #000 calc(100% - var(--brand-marquee-fade)), transparent 100%);
    mask-image: linear-gradient(90deg, transparent 0, #000 var(--brand-marquee-fade), #000 calc(100% - var(--brand-marquee-fade)), transparent 100%);
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
}

.brand-marquee__track {
    --brand-marquee-gap: clamp(1.25rem, 2vw, 2rem);
    display: flex;
    align-items: center;
    width: max-content;
    min-height: 100%;
    animation: brand-marquee-scroll 26s linear infinite;
}

.brand-marquee__group {
    display: flex;
    align-items: center;
    gap: var(--brand-marquee-gap);
    padding-right: var(--brand-marquee-gap);
}

.brand-marquee__item {
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    width: clamp(5.85rem, 7vw, 6.65rem);
    height: clamp(3.55rem, 4.2vw, 4rem);
    text-decoration: none;
    line-height: 0;
}

.brand-marquee__item img {
    display: block;
    width: auto;
    height: 100%;
    max-width: 100%;
    object-fit: contain;
    filter: drop-shadow(0 10px 18px rgba(0, 0, 0, 0.34));
    opacity: 0.96;
    transition: transform 180ms ease, opacity 180ms ease, filter 180ms ease;
}

a.brand-marquee__item:hover img,
a.brand-marquee__item:focus-visible img {
    transform: translateY(-0.06rem) scale(1.015);
    opacity: 1;
    filter: drop-shadow(0 12px 22px rgba(0, 0, 0, 0.42));
}

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

    to {
        transform: translateX(-33.333333%);
    }
}

.fleet-catalog {
    position: relative;
    padding: 1.6rem 0 5.4rem;
    background:
        radial-gradient(circle at 18% 16%, rgba(214, 188, 134, 0.08), transparent 20%),
        radial-gradient(circle at 84% 24%, rgba(var(--dp-color-gold-rgb), 0.04), transparent 24%),
        linear-gradient(180deg, #050506 0%, #07090d 44%, #050506 100%);
}

.fleet-catalog__shell {
    display: grid;
    gap: 1.35rem;
}

.fleet-catalog__intro {
    max-width: 46rem;
}

.fleet-editorial__intro,
.fleet-catalog__intro,
.service-layer__intro,
.locations-teaser__copy {
    display: grid;
    justify-items: center;
    margin-inline: auto;
    text-align: center;
}

.fleet-editorial__eyebrow,
.fleet-catalog__eyebrow,
.service-layer__eyebrow,
.locations-teaser__eyebrow {
    justify-self: center;
}

.fleet-editorial__intro p,
.fleet-catalog__intro p,
.service-layer__intro p,
.locations-teaser__copy p {
    margin-inline: auto;
}

.fleet-catalog__eyebrow {
    margin-bottom: 0.18rem;
}

.fleet-catalog__intro h2 {
    margin: 0.95rem 0 0.78rem;
    font-family: var(--lab-font-display);
    font-size: clamp(2.45rem, 3vw, 3.25rem);
    line-height: 0.98;
    letter-spacing: -0.035em;
    font-weight: 600;
}

.fleet-catalog__intro p {
    max-width: 41rem;
    margin: 0;
    color: var(--lab-muted);
    font-size: 0.98rem;
    line-height: 1.58;
}

.fleet-catalog__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.catalog-card {
    display: grid;
    grid-template-rows: auto 1fr auto;
    min-height: 100%;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 1.35rem;
    overflow: hidden;
    background: linear-gradient(180deg, rgba(19, 21, 26, 0.82) 0%, rgba(9, 10, 13, 0.98) 100%);
    box-shadow: 0 22px 54px rgba(0, 0, 0, 0.24);
}

.catalog-card__media {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 14rem;
    padding: 1rem;
    background: linear-gradient(180deg, #f2eee8 0%, #d8d4cc 100%);
}

.catalog-card__media img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.catalog-card__body {
    display: grid;
    align-content: start;
    gap: 1rem;
    padding: 1rem 1rem 1.1rem;
}

.catalog-card__header {
    display: grid;
    gap: 0.42rem;
}

.catalog-card__kicker {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    padding: 0.36rem 0.62rem;
    border-radius: 999px;
    background: rgba(207, 173, 101, 0.14);
    color: var(--lab-champagne);
    font-family: var(--lab-font-sans);
    font-size: 0.62rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.catalog-card__header h3 {
    margin: 0;
    font-family: var(--lab-font-display);
    font-size: 2rem;
    line-height: 0.94;
    letter-spacing: -0.03em;
    font-weight: 600;
}

.catalog-card__header p {
    margin: 0;
    color: var(--lab-muted);
    font-size: 0.9rem;
    line-height: 1.48;
}

.catalog-stats {
    display: grid;
    gap: 0.5rem;
    margin: 0;
}

.catalog-stats div {
    display: grid;
    grid-template-columns: 6.1rem 1fr;
    gap: 0.55rem;
    align-items: center;
}

.catalog-stats dt,
.catalog-stats dd {
    margin: 0;
}

.catalog-stats dt {
    color: rgba(245, 241, 232, 0.7);
    font-size: 0.88rem;
    line-height: 1.2;
}

.catalog-stats dd {
    display: inline-flex;
    align-items: center;
    gap: 0.42rem;
    width: fit-content;
    min-height: 2rem;
    padding: 0.38rem 0.72rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.05);
    color: rgba(245, 241, 232, 0.92);
    font-size: 0.84rem;
    line-height: 1;
}

.catalog-swatch {
    width: 1rem;
    height: 1rem;
    border-radius: 999px;
    border: 2px solid rgba(255, 255, 255, 0.62);
    box-shadow: 0 0 0 0.12rem rgba(255, 255, 255, 0.04);
}

.catalog-swatch--azure {
    background: #0a5f87;
}

.catalog-swatch--rosso {
    background: #cf1b22;
}

.catalog-swatch--giallo {
    background: #d48e12;
}

.catalog-swatch--obsidian {
    background: #050505;
}

.catalog-card__pricebar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.9rem 1rem;
    border: 1px solid rgba(207, 173, 101, 0.8);
    border-radius: 1.05rem;
    background: rgba(255, 255, 255, 0.02);
}

.catalog-card__pricebar div {
    display: flex;
    align-items: baseline;
    gap: 0.38rem;
    flex-wrap: wrap;
}

.catalog-card__pricebar strong {
    color: var(--lab-champagne);
    font-size: 1.26rem;
    font-weight: 700;
}

.catalog-card__pricebar span {
    color: rgba(245, 241, 232, 0.78);
    font-size: 0.88rem;
    line-height: 1.3;
}

.catalog-card__more {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-height: 46px;
    margin-top: auto;
    padding: 0 1.2rem;
    border-radius: 999px;
    background: rgba(207, 173, 101, 0.92);
    color: #fffaf0;
    font-size: 0.88rem;
    font-weight: 700;
}

.catalog-card__contact {
    display: grid;
    grid-template-columns: 1fr 1fr;
}

.catalog-card__contact a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 3.45rem;
    font-size: 0.92rem;
    font-weight: 700;
}

.catalog-card__contact a:first-child {
    background: rgba(207, 173, 101, 0.92);
    color: #fff7ea;
}

.catalog-card__contact a:last-child {
    background: #2d7a2c;
    color: #f6fff5;
}

.fleet-catalog__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.2rem 1.3rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 1.22rem;
    background: linear-gradient(180deg, rgba(19, 21, 26, 0.84) 0%, rgba(9, 10, 13, 0.96) 100%);
    box-shadow: 0 22px 54px rgba(0, 0, 0, 0.22);
}

.fleet-catalog__footer p {
    max-width: 38rem;
    margin: 0;
    color: var(--lab-muted);
    font-size: 0.95rem;
    line-height: 1.52;
}

.fleet-catalog__actions {
    display: flex;
    align-items: center;
    gap: 0.9rem;
}

.fleet-catalog__button {
    min-height: 50px;
    padding: 0 1.25rem;
    border: 0;
    border-radius: 0.96rem;
    background: linear-gradient(135deg, var(--lab-accent-soft), var(--lab-accent));
    color: #121212;
    font-family: var(--lab-font-sans);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    cursor: pointer;
    box-shadow: 0 14px 34px rgba(var(--dp-color-gold-rgb), 0.16);
}

.fleet-catalog__link {
    color: rgba(245, 241, 232, 0.86);
    font-size: 0.9rem;
    font-weight: 600;
}

.guest-reviews {
    position: relative;
    padding: 1.45rem 0 5.1rem;
    background:
        radial-gradient(circle at 12% 18%, rgba(207, 173, 101, 0.18), rgba(207, 173, 101, 0) 22%),
        radial-gradient(circle at 82% 26%, rgba(20, 22, 27, 0.08), rgba(20, 22, 27, 0) 18%),
        linear-gradient(180deg, #050506 0%, #0b0c0f 3.1rem, rgba(220, 210, 196, 0.42) 4.3rem, #ece3d6 6rem, #e8dfd1 100%);
    color: #111214;
}

.guest-reviews__shell {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
    gap: 1.15rem;
    align-items: start;
}

.guest-reviews__summary {
    display: grid;
    gap: 1.1rem;
    padding: 1.6rem;
    border: 1px solid rgba(17, 18, 20, 0.08);
    border-radius: 1.6rem;
    background: rgba(255, 251, 244, 0.72);
    backdrop-filter: blur(18px);
    box-shadow: 0 26px 70px rgba(15, 16, 20, 0.1);
}

.guest-reviews__eyebrow {
    color: #17181b;
}

.guest-reviews__eyebrow::before {
    background: linear-gradient(90deg, rgba(17, 18, 20, 0), rgba(17, 18, 20, 0.7));
}

.guest-reviews__summary h2 {
    margin: 0;
    font-family: var(--lab-font-display);
    font-size: clamp(2.2rem, 2.8vw, 3rem);
    line-height: 0.98;
    letter-spacing: -0.03em;
    font-weight: 600;
}

.guest-reviews__summary p {
    margin: 0;
    color: #30302b;
    font-size: 0.96rem;
    line-height: 1.58;
}

.guest-reviews__rating {
    display: grid;
    gap: 0.34rem;
    padding: 1rem 1.05rem;
    border: 1px solid rgba(17, 18, 20, 0.08);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.5);
}

.guest-reviews__rating strong {
    color: #cfad65;
    font-size: 0.74rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.guest-reviews__rating span {
    color: #30302b;
    font-size: 0.92rem;
    line-height: 1.45;
}

.guest-reviews__signals {
    display: grid;
    gap: 0.7rem;
}

.guest-reviews__signal {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.85rem;
    padding: 0.9rem 0.95rem;
    border: 1px solid rgba(17, 18, 20, 0.08);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.44);
}

.guest-reviews__signal > span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.1rem;
    height: 2.1rem;
    border-radius: 999px;
    background: rgba(207, 173, 101, 0.16);
    color: #17181b;
    font-family: var(--lab-font-sans);
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.08em;
}

.guest-reviews__signal div {
    display: grid;
    gap: 0.28rem;
}

.guest-reviews__signal strong {
    color: #151619;
    font-size: 0.95rem;
    line-height: 1.25;
}

.guest-reviews__signal p {
    margin: 0;
    color: #34312b;
    font-size: 0.84rem;
    line-height: 1.45;
}

.guest-reviews__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-height: 50px;
    padding: 0 1.35rem;
    border-radius: 0.92rem;
    background: #14161b;
    color: #f7f3eb;
    font-family: var(--lab-font-sans);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.guest-reviews__content {
    display: grid;
    gap: 1rem;
}

.guest-reviews__grid {
    display: grid;
    grid-template-columns: minmax(0, 1.18fr) minmax(0, 0.82fr);
    gap: 1rem;
}

.review-card {
    display: grid;
    align-content: start;
    gap: 0.9rem;
    padding: 1.2rem;
    border: 1px solid rgba(17, 18, 20, 0.08);
    border-radius: 1.35rem;
    background: rgba(255, 251, 244, 0.8);
    box-shadow: 0 18px 38px rgba(15, 16, 20, 0.08);
}

.review-card--feature {
    grid-row: 1 / span 2;
    padding: 1.45rem;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.48) 0%, rgba(255, 255, 255, 0.18) 100%),
        rgba(255, 250, 242, 0.88);
}

.review-card__header {
    display: flex;
    align-items: center;
    gap: 0.8rem;
}

.review-card__avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.9rem;
    height: 2.9rem;
    border-radius: 999px;
    background: rgba(207, 173, 101, 0.16);
    color: #151619;
    font-size: 1rem;
    font-weight: 800;
}

.review-card__header strong {
    display: block;
    color: #111214;
    font-size: 1rem;
    font-weight: 700;
}

.review-card__header span {
    color: #5f4930;
    font-size: 0.82rem;
}

.review-card__kicker {
    color: #6f5433;
    font-family: var(--lab-font-sans);
    font-size: 0.62rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.review-card p {
    margin: 0;
    color: #30302b;
    font-size: 0.98rem;
    line-height: 1.62;
}

.review-card__footer {
    color: #6b5436;
    font-size: 0.82rem;
    line-height: 1.45;
}

.guest-reviews__editorial {
    display: grid;
    grid-template-columns: minmax(0, 0.88fr) minmax(0, 1.12fr);
    gap: 1rem;
}

.guest-reviews__visual,
.guest-reviews__faq {
    border: 1px solid rgba(17, 18, 20, 0.08);
    border-radius: 1.45rem;
    overflow: hidden;
    box-shadow: 0 18px 38px rgba(15, 16, 20, 0.08);
}

.guest-reviews__visual {
    display: grid;
    background: #d8cfbf;
}

.guest-reviews__visual img {
    width: 100%;
    aspect-ratio: 1.06 / 1;
    object-fit: cover;
}

.guest-reviews__visual figcaption {
    padding: 1rem 1.1rem 1.15rem;
    color: #34312b;
    font-size: 0.88rem;
    line-height: 1.48;
}

.guest-reviews__faq {
    padding: 1.3rem 1.3rem 1.1rem;
    background: #14161b;
    color: var(--lab-text);
}

.guest-reviews__faq-kicker {
    display: inline-block;
    margin-bottom: 0.55rem;
    color: var(--lab-champagne);
    font-family: var(--lab-font-sans);
    font-size: 0.64rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.guest-reviews__faq h3 {
    margin: 0 0 1rem;
    font-family: var(--lab-font-display);
    font-size: clamp(2rem, 2.45vw, 2.5rem);
    line-height: 0.98;
    letter-spacing: -0.03em;
    font-weight: 600;
    color: var(--lab-text);
}

.guest-faq__item {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.guest-faq__item:last-child {
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.guest-faq__item summary {
    position: relative;
    list-style: none;
    cursor: pointer;
    padding: 1rem 1.6rem 1rem 0;
    color: rgba(245, 241, 232, 0.92);
    font-size: 0.92rem;
    font-weight: 600;
    line-height: 1.45;
}

.guest-faq__item summary::-webkit-details-marker {
    display: none;
}

.guest-faq__item summary::after {
    content: "+";
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    color: rgba(241, 226, 189, 0.8);
    font-size: 1rem;
    font-weight: 600;
}

.guest-faq__item[open] summary::after {
    content: "-";
}

.guest-faq__item p {
    margin: 0;
    padding: 0 1.6rem 1rem 0;
    color: rgba(245, 241, 232, 0.7);
    font-size: 0.86rem;
    line-height: 1.55;
}

.guest-reviews-band {
    position: relative;
    isolation: isolate;
    overflow: clip;
    background:
        linear-gradient(180deg, #f2eadc 0%, #fbf8f1 52%, #efe7da 100%);
}

.guest-reviews {
    position: relative;
    z-index: 1;
    padding: 1rem 0 5rem;
    background: transparent;
    color: #171412;
}

.guest-reviews__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    overflow: hidden;
    background:
        radial-gradient(circle at 18% 16%, rgba(var(--dp-color-gold-rgb), 0.16), transparent 28rem),
        radial-gradient(circle at 82% 12%, rgba(42, 31, 20, 0.08), transparent 26rem),
        repeating-linear-gradient(90deg, rgba(72, 54, 36, 0.045) 0 1px, transparent 1px 88px);
}

.guest-reviews__bg-shade {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

.guest-reviews__bg-shade {
    background:
        radial-gradient(circle at 18% 18%, rgba(255, 255, 255, 0.32), rgba(255, 255, 255, 0) 28%),
        linear-gradient(180deg, rgba(248, 244, 236, 0.92) 0%, rgba(248, 244, 236, 0.68) 42%, rgba(239, 231, 218, 0.92) 100%);
}

.guest-reviews__shell {
    position: relative;
    z-index: 1;
    grid-template-columns: 1fr;
    gap: 1.8rem;
}

.guest-reviews__intro {
    display: grid;
    justify-items: center;
    gap: 0.7rem;
    text-align: center;
}

.guest-reviews__eyebrow {
    color: #3f3328;
}

.guest-reviews__eyebrow::before {
    background: linear-gradient(90deg, rgba(50, 42, 36, 0), rgba(50, 42, 36, 0.56));
}

.guest-reviews__intro h2 {
    max-width: 48rem;
    margin: 0;
    font-family: var(--lab-font-sans);
    font-size: clamp(2.5rem, 4.6vw, 4rem);
    line-height: 0.96;
    letter-spacing: -0.06em;
    font-weight: 500;
    color: #171412;
}

.guest-reviews__body {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
    align-items: stretch;
}

.guest-reviews__summary {
    display: grid;
    box-sizing: border-box;
    width: 100%;
    justify-items: center;
    align-content: center;
    gap: 0.72rem;
    min-height: 100%;
    padding: 1.7rem 1.3rem;
    border: 1px solid rgba(58, 48, 41, 0.12);
    border-radius: 1.35rem;
    background: rgba(255, 251, 245, 0.58);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    box-shadow: 0 18px 34px rgba(33, 24, 16, 0.14);
    text-align: center;
}

.guest-reviews__brand {
    color: #181512;
    font-size: 1.85rem;
    line-height: 1.12;
    font-weight: 700;
}

.guest-reviews__brand--link {
    color: #181512;
    text-decoration: none;
    transition: color 180ms ease;
}

.guest-reviews__brand--link:hover {
    color: #0f0d0b;
}

.guest-reviews__brand--link:focus-visible {
    outline: none;
    color: #0f0d0b;
}

.guest-reviews__rating {
    display: grid;
    box-sizing: border-box;
    gap: 0.34rem;
    justify-items: center;
    width: 100%;
    padding: 0.95rem 1rem;
    border: 1px solid rgba(58, 48, 41, 0.08);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.82);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.guest-reviews__rating .guest-reviews__score {
    color: #171412;
    font-size: 2.6rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.05em;
}

.guest-reviews__rating .guest-reviews__stars {
    color: #cfad65;
    font-size: 1.42rem;
    letter-spacing: 0.14em;
    text-shadow: 0 0 12px rgba(207, 173, 101, 0.12);
}

.guest-reviews__count,
.guest-reviews__powered {
    margin: 0;
    color: #4f4034;
    font-size: 1rem;
    line-height: 1.44;
}

.google-wordmark {
    display: inline-flex;
    gap: 0;
    margin-left: 0.24rem;
    font-weight: 700;
}

.google-wordmark__g1,
.google-wordmark__g2 {
    color: #4285f4;
}

.google-wordmark__o1 {
    color: #ea4335;
}

.google-wordmark__o2 {
    color: #fbbc05;
}

.google-wordmark__l {
    color: #34a853;
}

.google-wordmark__e {
    color: #ea4335;
}

.guest-reviews__actions {
    display: grid;
    justify-items: center;
    gap: 0.7rem;
    width: 100%;
}

.guest-reviews__google-button {
    min-height: 52px;
    padding: 0 1.28rem;
    border-radius: 999px;
    background: linear-gradient(135deg, #245fbd, #184a9f);
    color: #ffffff;
    font-family: var(--lab-font-sans);
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 14px 28px rgba(66, 133, 244, 0.18);
    transition:
        transform 180ms ease,
        box-shadow 180ms ease,
        filter 180ms ease;
}

.guest-reviews__google-button:hover {
    transform: translateY(-1px);
    filter: brightness(1.03);
    box-shadow: 0 18px 34px rgba(66, 133, 244, 0.24);
}

.guest-reviews__google-button:focus-visible {
    outline: none;
    box-shadow:
        0 0 0 3px rgba(66, 133, 244, 0.22),
        0 18px 34px rgba(66, 133, 244, 0.24);
}

.guest-reviews__google-link {
    justify-self: center;
    color: #3f3328;
    font-size: 0.9rem;
    font-weight: 500;
    letter-spacing: 0.02em;
    text-decoration: none;
    border-bottom: 1px solid rgba(67, 57, 49, 0.22);
    transition:
        color 180ms ease,
        border-color 180ms ease;
}

.guest-reviews__google-link:hover {
    color: #171412;
    border-color: rgba(67, 57, 49, 0.36);
}

.guest-reviews__google-link:focus-visible {
    outline: none;
    color: #171412;
    border-color: rgba(67, 57, 49, 0.44);
}

.guest-reviews__grid {
    display: contents;
}

.guest-reviews .review-card {
    display: grid;
    box-sizing: border-box;
    grid-template-rows: auto auto minmax(0, 1fr);
    gap: 0.95rem;
    min-height: 100%;
    height: 100%;
    width: 100%;
    padding: 1.25rem;
    border-radius: 1.2rem;
    border: 1px solid rgba(24, 28, 34, 0.12);
    background: rgba(255, 252, 247, 0.6);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    box-shadow: 0 16px 30px rgba(33, 24, 16, 0.14);
    overflow: hidden;
}

.guest-reviews .review-card__topline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.9rem;
}

.guest-reviews .review-card__header {
    align-items: center;
    flex: 1 1 auto;
    min-width: 0;
}

.guest-reviews .review-card__avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3rem;
    height: 3rem;
    font-size: 0.96rem;
    line-height: 1;
    font-weight: 800;
    flex-shrink: 0;
    flex: 0 0 auto;
    background: rgba(207, 173, 101, 0.16);
    color: #2d2a24;
    overflow: hidden;
}

.guest-reviews .review-card__avatar--google {
    background:
        radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.62), transparent 34%),
        conic-gradient(from 36deg, #4285f4, #34a853, #fbbc05, #ea4335, #4285f4);
    color: #ffffff;
    text-shadow: 0 1px 8px rgba(0, 0, 0, 0.32);
}

.guest-reviews .review-card__header strong {
    color: #1a1d21;
}

.guest-reviews .review-card__header > div span {
    color: #3d4650;
    display: block;
}

.guest-reviews .review-card__header > div {
    min-width: 0;
}

.guest-reviews .review-card__source {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.8rem;
    height: 1.8rem;
    border-radius: 999px;
    background: #ffffff;
    color: #4285f4;
    font-size: 0.78rem;
    font-weight: 800;
    line-height: 1;
    flex: 0 0 auto;
    text-decoration: none;
    transition:
        transform 180ms ease,
        box-shadow 180ms ease,
        filter 180ms ease;
}

.guest-reviews .review-card__source:hover {
    transform: translateY(-1px) scale(1.03);
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.12);
    filter: saturate(1.05);
}

.guest-reviews .review-card__source:focus-visible {
    outline: none;
    box-shadow:
        0 0 0 3px rgba(66, 133, 244, 0.18),
        0 8px 16px rgba(0, 0, 0, 0.14);
}

.guest-reviews .review-card__stars {
    color: #cfad65;
    font-size: 1rem;
    letter-spacing: 0.08em;
}

.guest-reviews .review-card p {
    margin: 0;
    color: #303a47;
    font-size: 0.96rem;
    line-height: 1.7;
    overflow: auto;
    padding-right: 0.28rem;
}

.guest-reviews .review-card p::-webkit-scrollbar {
    width: 4px;
}

.guest-reviews .review-card p::-webkit-scrollbar-thumb {
    border-radius: 999px;
    background: rgba(120, 121, 126, 0.45);
}

.guest-reviews .review-card__kicker,
.guest-reviews .review-card__footer,
.guest-reviews__content,
.guest-reviews__signals,
.guest-reviews__editorial {
    display: none;
}

.site-v2-footer {
    padding: 0 0 2rem;
    background: #f4efe8;
}

.site-v2-footer--over-video {
    position: relative;
    z-index: 1;
    background: transparent;
}

.site-v2-footer__shell {
    display: grid;
    gap: 1.5rem;
    padding: 2rem 2rem 1.35rem;
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 2rem;
    background:
        radial-gradient(circle at 18% 0%, rgba(214, 188, 134, 0.08), transparent 28%),
        linear-gradient(180deg, #121417 0%, #0c0f12 100%);
    box-shadow: 0 24px 54px rgba(10, 10, 12, 0.22);
}

.site-v2-footer--over-video .site-v2-footer__shell {
    border: 1px solid rgba(255, 255, 255, 0.08);
    background:
        radial-gradient(circle at 18% 0%, rgba(214, 188, 134, 0.12), transparent 28%),
        linear-gradient(180deg, rgba(18, 20, 23, 0.76) 0%, rgba(12, 15, 18, 0.9) 100%);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    box-shadow: 0 24px 54px rgba(8, 10, 14, 0.34);
}

.site-v2-footer__top {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) repeat(3, minmax(0, 0.64fr));
    gap: 1.4rem;
}

.site-v2-footer__brand {
    display: grid;
    align-content: start;
    gap: 1rem;
}

.site-v2-footer__crest {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 6.8rem;
    height: 6.8rem;
    border-radius: 1.55rem;
    border: 1px solid rgba(214, 188, 134, 0.16);
    background: rgba(255, 255, 255, 0.03);
}

.site-v2-footer__crest img {
    width: 70%;
    height: 70%;
    object-fit: contain;
}

.site-v2-footer__brand p {
    max-width: 28rem;
    margin: 0;
    color: rgba(233, 227, 216, 0.72);
    font-size: 0.96rem;
    line-height: 1.62;
}

.site-v2-footer__column {
    display: grid;
    align-content: start;
    gap: 0.7rem;
}

.site-v2-footer__column h3 {
    margin: 0;
    color: rgba(250, 246, 239, 0.96);
    font-size: 1.38rem;
    font-weight: 700;
}

.site-v2-footer__column a,
.site-v2-footer__column p {
    margin: 0;
    color: rgba(223, 216, 206, 0.72);
    font-size: 0.94rem;
    line-height: 1.56;
}

.site-v2-footer__middle,
.site-v2-footer__bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.site-v2-footer__middle {
    padding-top: 1.25rem;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.site-v2-footer__service {
    display: inline-flex;
    align-items: center;
    gap: 0.85rem;
}

.site-v2-footer__service strong {
    font-size: 2.65rem;
    font-weight: 800;
    color: #cfad65;
}

.site-v2-footer__service span {
    color: rgba(250, 246, 239, 0.92);
    font-size: 1rem;
    font-weight: 600;
}

.site-v2-footer__payments {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.65rem;
}

.site-v2-footer__payments span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 5rem;
    min-height: 3rem;
    padding: 0 1rem;
    border-radius: 0.9rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: rgba(255, 255, 255, 0.04);
    color: rgba(250, 246, 239, 0.92);
    font-size: 0.92rem;
    font-weight: 700;
}

.site-v2-footer__legal,
.site-v2-footer__socials {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.site-v2-footer__legal a,
.site-v2-footer__bottom p {
    color: rgba(223, 216, 206, 0.66);
    font-size: 0.9rem;
}

.site-v2-footer__bottom p {
    margin: 0;
    text-align: center;
    flex: 1 1 auto;
    color: rgba(223, 216, 206, 0.56);
}

.site-v2-footer__socials a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 3.05rem;
    min-height: 3.05rem;
    padding: 0 0.8rem;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.14);
    background: rgba(255, 255, 255, 0.03);
    color: rgba(247, 242, 234, 0.92);
    font-size: 0.82rem;
    font-weight: 700;
}

.service-layer {
    position: relative;
    padding: 1.85rem 0 5.9rem;
    background:
        radial-gradient(circle at 18% 12%, rgba(214, 188, 134, 0.08), transparent 22%),
        radial-gradient(circle at 84% 26%, rgba(var(--dp-color-gold-rgb), 0.05), transparent 20%),
        linear-gradient(180deg, rgba(6, 7, 8, 0.18) 0%, #07090d 20%, #06080b 48%, #050506 100%);
}

.service-layer::before {
    content: none;
}

.service-layer__shell {
    display: grid;
    gap: 1.25rem;
}

.service-layer__intro {
    max-width: 48rem;
}

.service-layer__eyebrow {
    margin-bottom: 0.18rem;
}

.service-layer__intro h2 {
    margin: 0.95rem 0 0.82rem;
    font-family: var(--lab-font-display);
    font-size: clamp(2.65rem, 3.1vw, 3.55rem);
    line-height: 0.98;
    letter-spacing: -0.035em;
    font-weight: 600;
}

.service-layer__intro p {
    max-width: 43rem;
    margin: 0;
    color: var(--lab-muted);
    font-size: 0.99rem;
    line-height: 1.62;
}

.service-layer__note-label,
.service-feature__label,
.service-process__kicker {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    padding: 0.4rem 0.64rem;
    border-radius: 999px;
    background: rgba(var(--dp-color-gold-rgb), 0.08);
    color: var(--lab-champagne);
    font-family: var(--lab-font-sans);
    font-size: 0.66rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.service-story {
    display: grid;
    grid-template-columns: minmax(0, 1.12fr) minmax(18rem, 0.88fr);
    gap: 1rem;
    align-items: stretch;
}

.service-scene,
.service-promise,
.service-journey {
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 1.3rem;
    background: linear-gradient(180deg, rgba(19, 21, 26, 0.76) 0%, rgba(10, 11, 14, 0.96) 100%);
    box-shadow: 0 24px 64px rgba(0, 0, 0, 0.2);
}

.service-scene {
    position: relative;
    overflow: hidden;
    min-height: 0;
}

.service-scene img,
.service-scene__shade {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

.service-scene img {
    object-fit: cover;
}

.service-scene__shade {
    background:
        linear-gradient(180deg, rgba(10, 11, 14, 0.14) 0%, rgba(10, 11, 14, 0.38) 44%, rgba(10, 11, 14, 0.9) 100%),
        linear-gradient(90deg, rgba(10, 11, 14, 0.18) 0%, rgba(10, 11, 14, 0.46) 100%);
}

.service-scene__content {
    position: absolute;
    inset: auto 0 0;
    z-index: 1;
    display: grid;
    gap: 0.45rem;
    padding: 1.2rem 1.2rem 1.15rem;
}

.service-scene__content h3,
.service-promise h3,
.service-journey__intro h3,
.service-step-card h4 {
    margin: 0.95rem 0 0.65rem;
    font-family: var(--lab-font-display);
    line-height: 0.98;
    letter-spacing: -0.03em;
    font-weight: 600;
}

.service-scene--hero {
    aspect-ratio: auto;
    min-height: 31.5rem;
}

.service-scene--hero .service-scene__content {
    max-width: 27rem;
    padding: 1.35rem 1.35rem 1.35rem;
}

.service-scene--hero h3 {
    font-size: 2.25rem;
}

.service-scene--mini {
    aspect-ratio: 1.5 / 1;
}

.service-scene--mini .service-scene__content {
    gap: 0.25rem;
}

.service-scene--mini p {
    margin: 0;
    color: rgba(245, 241, 232, 0.88);
    font-size: 0.9rem;
    line-height: 1.4;
}

.service-story__stack {
    display: grid;
    grid-template-rows: minmax(0, 1.08fr) minmax(0, 0.78fr);
    gap: 0.95rem;
    align-content: stretch;
    height: 100%;
}

.service-promise {
    display: grid;
    gap: 1rem;
    padding: 1.35rem 1.35rem 1.45rem;
    align-items: start;
    min-height: 0;
}

.service-promise h3 {
    max-width: 30rem;
    font-size: 2.05rem;
}

.service-promise p,
.service-journey__intro p,
.service-step-card p {
    margin: 0;
    color: var(--lab-muted);
    font-size: 0.94rem;
    line-height: 1.58;
}

.service-promise__points {
    display: grid;
    gap: 0.65rem;
    margin: 0.15rem 0 0;
    padding: 0;
    list-style: none;
}

.service-promise__points li {
    position: relative;
    padding-left: 1.1rem;
    color: rgba(245, 241, 232, 0.88);
    font-size: 0.95rem;
    line-height: 1.5;
}

.service-promise__points li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.62rem;
    width: 0.38rem;
    height: 0.38rem;
    border-radius: 999px;
    background: var(--lab-accent);
    box-shadow: 0 0 0 0.22rem rgba(var(--dp-color-gold-rgb), 0.12);
}

.service-snapshots {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.95rem;
    min-height: 0;
    height: 100%;
}

.service-scene--mini {
    min-height: 0;
    height: 100%;
    aspect-ratio: auto;
}

.service-journey {
    display: grid;
    gap: 1.15rem;
    padding: 1.45rem;
}

.service-journey__intro {
    display: grid;
    align-content: start;
    gap: 0.15rem;
}

.service-journey__intro h3 {
    max-width: 38rem;
    font-size: 2.22rem;
}

.service-journey__steps {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.95rem;
}

.service-process__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-height: 50px;
    margin-top: 0.4rem;
    padding: 0 1.2rem;
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 0.92rem;
    background: linear-gradient(135deg, var(--lab-accent-soft), var(--lab-accent));
    color: var(--dp-color-text);
    box-shadow: 0 14px 34px rgba(216, 180, 95, 0.16);
    font-family: var(--lab-font-sans);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    cursor: pointer;
}

.service-step-card {
    display: grid;
    align-content: start;
    gap: 0.2rem;
    min-height: 100%;
    padding: 1rem 1rem 1.1rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 1.12rem;
    background: rgba(255, 255, 255, 0.02);
}

.service-step-card strong {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.9rem;
    height: 2.9rem;
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.04);
    color: var(--lab-champagne);
    font-family: var(--lab-font-sans);
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.12em;
}

.service-step-card h4 {
    font-size: 1.48rem;
}

.locations-teaser {
    position: relative;
    padding: 0.4rem 0 5.6rem;
    background:
        radial-gradient(circle at 18% 18%, rgba(214, 188, 134, 0.06), transparent 24%),
        linear-gradient(180deg, #050506 0%, #07090d 42%, #050506 100%);
}

.locations-teaser__shell {
    display: grid;
    gap: 1.4rem;
}

.locations-teaser__intro {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) auto;
    gap: 1rem;
    align-items: end;
}

.locations-teaser__copy {
    max-width: 43rem;
}

.locations-teaser__eyebrow {
    margin-bottom: 0.2rem;
}

.locations-teaser__copy h2 {
    margin: 0.95rem 0 0.8rem;
    font-family: var(--lab-font-display);
    font-size: clamp(2.4rem, 2.9vw, 3.2rem);
    line-height: 0.98;
    letter-spacing: -0.035em;
    font-weight: 600;
}

.locations-teaser__copy p {
    max-width: 39rem;
    margin: 0 auto;
    color: var(--lab-muted);
    font-size: 0.97rem;
    line-height: 1.58;
    text-align: center;
}

.locations-teaser__actions {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    justify-content: center;
}

.locations-teaser__primary,
.locations-teaser__secondary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 0 1.2rem;
    border-radius: 0.92rem;
    font-family: var(--lab-font-sans);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.locations-teaser__primary {
    background: linear-gradient(135deg, var(--lab-accent-soft), var(--lab-accent));
    color: #111;
    box-shadow: 0 14px 34px rgba(var(--dp-color-gold-rgb), 0.16);
}

.locations-teaser__secondary {
    border: 1px solid rgba(255, 255, 255, 0.14);
    background: rgba(255, 255, 255, 0.02);
    color: var(--lab-text);
    cursor: pointer;
}

.locations-teaser__visual {
    position: relative;
    display: grid;
    overflow: hidden;
    min-height: clamp(16rem, 28vw, 21rem);
    border-radius: 1.45rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.2);
}

.locations-teaser__visual img,
.locations-teaser__visual-shade {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

.locations-teaser__visual img {
    object-fit: cover;
    object-position: center 44%;
    filter: saturate(0.9) brightness(0.7) contrast(1.04);
}

.locations-teaser__visual-shade {
    background:
        linear-gradient(180deg, rgba(7, 8, 10, 0.28) 0%, rgba(7, 8, 10, 0.54) 50%, rgba(7, 8, 10, 0.82) 100%),
        linear-gradient(90deg, rgba(7, 8, 10, 0.38) 0%, rgba(7, 8, 10, 0.08) 40%, rgba(7, 8, 10, 0.36) 100%);
}

.locations-teaser__visual-copy {
    position: relative;
    z-index: 1;
    display: grid;
    align-content: end;
    gap: 0.7rem;
    max-width: 32rem;
    min-height: inherit;
    padding: 1.4rem 1.45rem;
}

.locations-teaser__visual-eyebrow {
    color: rgba(241, 234, 223, 0.76);
}

.locations-teaser__visual-eyebrow::before {
    background: linear-gradient(90deg, rgba(214, 188, 134, 0), rgba(214, 188, 134, 0.62));
}

.locations-teaser__visual-copy h3 {
    margin: 0;
    color: rgba(250, 246, 239, 0.98);
    font-family: var(--lab-font-display);
    font-size: clamp(2rem, 2.5vw, 2.6rem);
    line-height: 0.98;
    letter-spacing: -0.035em;
    font-weight: 600;
    text-wrap: balance;
}

.locations-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.95rem;
}

.location-card {
    position: relative;
    display: grid;
    align-content: start;
    gap: 0.85rem;
    min-height: 100%;
    padding: 1.2rem 1.1rem 1.15rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 1.25rem;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.03) 0%, rgba(11, 12, 16, 0.96) 100%);
    box-shadow: 0 22px 54px rgba(0, 0, 0, 0.2);
    overflow: hidden;
    color: inherit;
    text-decoration: none;
    transition: transform 180ms ease, border-color 180ms ease, background-color 180ms ease, box-shadow 180ms ease;
}

.location-card:hover,
.location-card:focus-visible {
    transform: translateY(-2px);
    border-color: rgba(var(--dp-color-gold-rgb), 0.22);
    box-shadow: 0 24px 58px rgba(0, 0, 0, 0.24);
}

.location-card:focus-visible {
    outline: 2px solid rgba(var(--dp-color-gold-rgb), 0.56);
    outline-offset: 3px;
}

.location-card::before {
    content: "";
    position: absolute;
    inset: auto -12% -18% auto;
    width: 11rem;
    height: 11rem;
    border-radius: 999px;
    filter: blur(18px);
    opacity: 0.24;
    pointer-events: none;
}

.location-card--palm::before {
    background: radial-gradient(circle, rgba(214, 188, 134, 0.36) 0%, rgba(214, 188, 134, 0) 68%);
}

.location-card--marina::before {
    background: radial-gradient(circle, rgba(164, 199, 255, 0.3) 0%, rgba(164, 199, 255, 0) 68%);
}

.location-card--downtown::before {
    background: radial-gradient(circle, rgba(255, 205, 129, 0.28) 0%, rgba(255, 205, 129, 0) 68%);
}

.location-card--airport::before {
    background: radial-gradient(circle, rgba(var(--dp-color-gold-rgb), 0.26) 0%, rgba(var(--dp-color-gold-rgb), 0) 68%);
}

.location-card__chip {
    position: relative;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    width: fit-content;
    padding: 0.38rem 0.62rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.04);
    color: var(--lab-champagne);
    font-family: var(--lab-font-sans);
    font-size: 0.62rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.location-card h3 {
    position: relative;
    z-index: 1;
    margin: 0;
    font-family: var(--lab-font-display);
    font-size: 1.72rem;
    line-height: 0.98;
    letter-spacing: -0.03em;
    font-weight: 600;
}

.location-card p {
    position: relative;
    z-index: 1;
    margin: 0;
    color: var(--lab-muted);
    font-size: 0.9rem;
    line-height: 1.52;
}

.location-card__meta {
    position: relative;
    z-index: 1;
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-top: 0.1rem;
}

.location-card__meta span {
    display: inline-flex;
    align-items: center;
    padding: 0.38rem 0.58rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.04);
    color: rgba(245, 241, 232, 0.82);
    font-size: 0.75rem;
    line-height: 1;
}

.hero-lab-overlay {
    position: fixed;
    inset: 0;
    z-index: 100;
    display: flex;
    align-items: stretch;
    justify-content: flex-end;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 280ms ease, visibility 280ms ease;
}

.hero-lab-overlay.is-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.hero-lab-overlay__scrim {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, rgba(4, 5, 8, 0.78) 0%, rgba(4, 5, 8, 0.9) 100%),
        radial-gradient(circle at 56% 46%, rgba(var(--dp-color-gold-rgb), 0.06), transparent 24%);
}

.hero-lab-overlay__sheet {
    position: relative;
    z-index: 1;
    margin-top: auto;
    width: 100%;
    transform: translateY(100%);
    transition: transform 320ms cubic-bezier(0.22, 1, 0.36, 1);
}

.hero-lab-overlay.is-open .hero-lab-overlay__sheet {
    transform: translateY(0);
}

.hero-lab-overlay__shell {
    width: 100%;
    max-width: none;
    margin: 0;
    padding-left: 3.5rem;
    padding-right: 3.5rem;
    padding-top: 2rem;
    padding-bottom: 2.2rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    background: linear-gradient(180deg, rgba(10, 11, 15, 0.98) 0%, rgba(6, 7, 10, 0.985) 100%);
    box-shadow: 0 -24px 80px rgba(0, 0, 0, 0.34);
}

.hero-lab-overlay__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 2rem;
}

.hero-lab-overlay__intro h2 {
    margin: 0;
    font-family: var(--lab-font-display);
    font-size: 3rem;
    line-height: 0.96;
    letter-spacing: -0.03em;
    font-weight: 600;
}

.hero-lab-overlay__intro p {
    max-width: 30rem;
    margin: 1rem 0 0;
    color: var(--lab-text);
    font-size: 1.18rem;
    line-height: 1.55;
}

.hero-lab-overlay__close {
    min-height: 46px;
    padding: 0 1.1rem;
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.02);
    color: rgba(245, 241, 232, 0.82);
    font-family: var(--lab-font-sans);
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    cursor: pointer;
}

.hero-lab-overlay__form {
    display: grid;
    grid-template-columns: 1fr 1fr auto;
    gap: 1rem;
    align-items: end;
    margin-top: 2rem;
}

.hero-lab-overlay__field-group {
    display: grid;
    gap: 0.78rem;
}

.hero-lab-overlay__label {
    color: #fbf7ef;
    font-family: var(--lab-font-sans);
    font-size: 0.92rem;
    font-weight: 700;
}

.hero-lab-overlay__input-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 7.5rem;
    gap: 0.34rem;
}

.hero-lab-overlay__input {
    min-height: 62px;
    padding: 0 1.05rem;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 0.7rem;
    background: rgba(33, 37, 46, 0.68);
    color: rgba(245, 241, 232, 0.9);
    appearance: none;
}

.hero-lab-overlay__input--time {
    text-align: center;
}

.hero-lab-overlay__submit {
    min-width: 15rem;
    min-height: 62px;
    padding: 0 1.4rem;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 0.7rem;
    background: rgba(255, 255, 255, 0.02);
    color: var(--lab-text);
    font-family: var(--lab-font-sans);
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.hero-lab-overlay__note {
    margin: 1rem 0 0;
    color: var(--lab-muted-soft);
    font-size: 0.95rem;
    line-height: 1.5;
}


@media (max-width: 1200px) {
    .fleet-categories__shell {
        grid-template-columns: repeat(4, minmax(9rem, 1fr));
        width: min(100%, 56rem);
        gap: 0.8rem 1.2rem;
        padding: 0;
    }

    .fleet-category__media {
        min-height: 9.1rem;
    }

    .fleet-category__image {
        height: 7.95rem;
    }

    .brand-marquee__viewport {
        min-height: 5.95rem;
        padding: 0.82rem 0 0.9rem;
    }

    .brand-marquee__item {
        width: 6rem;
        height: 3.65rem;
    }

    .fleet-catalog__grid {
        grid-template-columns: 1fr 1fr;
    }

    .guest-reviews__shell,
    .site-v2-footer__top {
        grid-template-columns: 1fr;
    }

    .guest-reviews__grid,
    .guest-reviews__editorial {
        grid-template-columns: 1fr 1fr;
    }

    .review-card--feature {
        grid-row: auto;
    }

    .service-story,
    .service-journey__steps {
        grid-template-columns: 1fr;
    }

    .locations-teaser__intro {
        grid-template-columns: 1fr;
        align-items: start;
    }

    .locations-grid {
        grid-template-columns: 1fr 1fr;
    }

    .locations-teaser__visual {
        min-height: 17rem;
    }

    .fleet-showcase {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .fleet-editorial__grid {
        grid-template-columns: 1fr;
    }

    .fleet-editorial__panel--video {
        min-height: 27rem;
    }

    .fleet-editorial__stack {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .closing-drive__media {
        min-height: 23rem;
    }

    .featured-fleet__footer {
        flex-direction: column;
        align-items: flex-start;
    }

    .featured-fleet__footer-actions {
        width: 100%;
        justify-content: flex-start;
    }

    .hero-lab-overlay__form {
        grid-template-columns: 1fr 1fr;
    }

    .hero-lab-overlay__submit {
        grid-column: 1 / -1;
        width: 100%;
    }
}

@media (max-height: 860px) {
    .fleet-categories {
        margin-top: 0;
        padding: 1.45rem 0 1.05rem;
    }

    .fleet-category__media {
        min-height: 8.7rem;
    }

    .fleet-category__image {
        height: 7.4rem;
    }

    .fleet-category__copy span {
        font-size: 0.56rem;
    }

    .hero-lab__shell {
        min-height: auto;
        padding-top: calc(var(--lab-header-offset) + 1.7rem);
        padding-bottom: 1.1rem;
    }

    .hero-lab h1 {
        width: min(100%, 46rem);
        margin: 0.72rem 0 1.35rem;
        font-size: clamp(2.45rem, 3vw, 3.05rem);
    }

    .hero-lab__lead {
        width: min(100%, 40rem);
        font-size: 0.82rem;
        line-height: 1.46;
    }

    .hero-lab__launcher {
        width: min(100%, 31rem);
        margin-top: 3.35rem;
        padding-bottom: 0;
    }

    .hero-lab__launcher h2 {
        margin-bottom: 0.55rem;
        font-size: 1.45rem;
    }

    .hero-lab__launcher p {
        width: min(100%, 28rem);
        font-size: 0.82rem;
        line-height: 1.4;
    }

    .hero-lab__actions {
        gap: 0.65rem;
        margin-top: 0.95rem;
        margin-bottom: 0;
    }

    .hero-lab__service-links {
        gap: 0.55rem;
        margin-top: 0.75rem;
    }

    .hero-lab__service-links a {
        min-height: 2.2rem;
        padding: 0 0.8rem;
        font-size: 0.54rem;
    }

    .hero-lab__cta {
        min-height: 46px;
        padding: 0 1rem;
        font-size: 0.66rem;
    }

    .hero-lab__cta--primary {
        min-width: 14rem;
    }

    .hero-lab__cta--secondary {
        min-width: 7.25rem;
    }

    .hero-lab.is-intro-enabled.is-mark-active .hero-lab__mark {
        left: 79%;
        top: 50%;
        width: 31rem;
        opacity: 0.15;
    }

    .featured-fleet {
        padding: 0.1rem 0 4rem;
    }

    .featured-fleet__intro {
        max-width: 28rem;
    }

    .featured-fleet__intro h2 {
        margin: 0.45rem 0 0;
        font-size: clamp(1.95rem, 2.3vw, 2.2rem);
    }

    .featured-fleet__intro p {
        font-size: 0.86rem;
        line-height: 1.45;
    }

    .fleet-visual-card__title-link {
        font-size: 1rem;
    }

    .fleet-visual-card__description,
    .featured-fleet__footer p {
        font-size: 0.76rem;
        line-height: 1.38;
    }

    .fleet-visual-card__spec-item dt,
    .fleet-visual-card__spec-item dd,
    .fleet-visual-card__price-kicker,
    .fleet-visual-card__price-note {
        font-size: 0.66rem;
    }

    .fleet-visual-card__price-value {
        font-size: 0.88rem;
    }

    .fleet-category strong {
        font-size: 0.92rem;
    }

    .fleet-catalog {
        padding: 1.2rem 0 4.4rem;
    }

    .fleet-catalog__intro h2 {
        font-size: 2.15rem;
    }

    .catalog-card__media {
        min-height: 11.5rem;
    }

    .catalog-card__header h3 {
        font-size: 1.72rem;
    }

    .catalog-card__header p,
    .catalog-stats dt,
    .catalog-stats dd,
    .fleet-catalog__footer p,
    .guest-reviews__summary p,
    .review-card p,
    .guest-reviews__signal p,
    .guest-faq__item p {
        font-size: 0.84rem;
        line-height: 1.42;
    }

    .guest-reviews {
        padding: 0.2rem 0 4.4rem;
    }

    .guest-reviews__summary h2 {
        font-size: 2.25rem;
    }

    .guest-reviews__faq h3 {
        font-size: 2.2rem;
    }

    .site-v2-footer__shell {
        padding: 1.6rem 1.5rem 1.2rem;
    }

    .service-layer {
        padding: 0.7rem 0 4.6rem;
    }

    .service-layer__intro h2 {
        font-size: 2.3rem;
    }

    .service-scene--hero h3,
    .service-promise h3,
    .service-journey__intro h3 {
        font-size: 1.95rem;
    }

    .service-step-card h4 {
        font-size: 1.3rem;
    }

    .service-scene--mini p,
    .service-promise p,
    .service-journey__intro p,
    .service-step-card p {
        font-size: 0.86rem;
        line-height: 1.46;
    }

    .locations-teaser {
        padding: 0.2rem 0 4.8rem;
    }

    .locations-teaser__copy h2 {
        font-size: 2.2rem;
    }

    .locations-teaser__copy p,
    .location-card p {
        font-size: 0.86rem;
        line-height: 1.44;
    }

    .location-card h3 {
        font-size: 1.46rem;
    }
}

@media (max-width: 860px) {
    .fleet-categories {
        margin-top: 0;
        padding: 1.35rem 0 0.7rem;
        overflow: hidden;
    }

    .fleet-categories__shell {
        display: flex;
        grid-template-columns: none;
        width: var(--lab-frame-width);
        justify-content: flex-start;
        justify-items: initial;
        gap: 0.85rem;
        padding: 0.1rem 2.1rem 0.7rem 0.05rem;
        border-radius: 0;
        overflow-x: auto;
        overscroll-behavior-x: contain;
        scroll-padding-inline: 0.05rem;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        scrollbar-color: rgba(214, 181, 94, 0.5) rgba(70, 52, 34, 0.08);
        scrollbar-width: thin;
        mask-image: linear-gradient(90deg, #000 0%, #000 calc(100% - 2.55rem), transparent 100%);
    }

    .fleet-categories__shell::-webkit-scrollbar {
        display: block;
        height: 4px;
    }

    .fleet-categories__shell::-webkit-scrollbar-track {
        background: rgba(70, 52, 34, 0.08);
        border-radius: 999px;
    }

    .fleet-categories__shell::-webkit-scrollbar-thumb {
        background: rgba(214, 181, 94, 0.54);
        border-radius: 999px;
    }

    .fleet-category {
        flex: 0 0 clamp(12rem, 33vw, 17rem);
        scroll-snap-align: start;
        scroll-snap-stop: always;
        padding: 0.7rem 0.7rem 0.6rem;
        border: 1px solid rgba(49, 41, 36, 0.08);
        border-radius: 16px;
        background:
            linear-gradient(180deg, rgba(255, 255, 255, 0.94) 0%, rgba(247, 242, 236, 0.94) 100%),
            radial-gradient(circle at 50% 0%, rgba(214, 188, 134, 0.15), rgba(214, 188, 134, 0) 52%);
        box-shadow: 0 16px 34px rgba(38, 28, 18, 0.08);
    }

    .fleet-category__media {
        min-height: 8.75rem;
    }

    .fleet-category__image {
        height: 7rem;
    }

    .fleet-category__copy span {
        font-size: 0.56rem;
    }

    .fleet-category strong {
        font-size: 0.94rem;
    }

    .fleet-editorial {
        padding: 0.2rem 0 3.7rem;
    }

    .fleet-editorial__panel--video,
    .fleet-editorial__panel--photo,
    .fleet-editorial__panel--detail {
        min-height: 15rem;
    }

    .fleet-editorial__stack {
        grid-template-columns: 1fr;
    }

    .fleet-editorial__panel-copy h3 {
        font-size: 1.62rem;
    }

    .fleet-editorial__panel-copy p {
        font-size: 0.86rem;
    }

    .locations-teaser__visual {
        min-height: 13.5rem;
    }

    .locations-teaser__visual-copy {
        padding: 1rem 1rem 1.1rem;
    }

    .locations-teaser__visual-copy h3 {
        font-size: 1.62rem;
    }

    .closing-drive__media {
        min-height: 16rem;
    }

    .closing-drive__shell {
        padding-top: 3.6rem;
        padding-bottom: 1.5rem;
    }

    .closing-drive__copy h2 {
        font-size: 1.72rem;
    }

    .fleet-catalog {
        padding: 1.2rem 0 4rem;
    }

    .fleet-catalog__grid,
    .guest-reviews__grid,
    .guest-reviews__shell,
    .guest-reviews__editorial {
        grid-template-columns: 1fr;
    }

    .guest-reviews__bg {
        inset: 0;
    }

    .catalog-card__media {
        min-height: 12.5rem;
    }

    .fleet-catalog__footer,
    .fleet-catalog__actions,
    .site-v2-footer__middle,
    .site-v2-footer__bottom,
    .site-v2-footer__legal {
        flex-direction: column;
        align-items: flex-start;
    }

    .fleet-catalog__button,
    .guest-reviews__cta {
        width: 100%;
    }

    .guest-reviews {
        padding: 0.6rem 0 4rem;
    }

    .guest-reviews__summary h2 {
        font-size: 2.05rem;
    }

    .guest-reviews__summary,
    .guest-reviews__faq {
        padding: 1.2rem;
    }

    .guest-reviews__signal {
        grid-template-columns: 1fr;
    }

    .guest-reviews__signal > span {
        width: 2rem;
        height: 2rem;
    }

    .review-card--feature {
        grid-row: auto;
    }

    .site-v2-footer {
        padding-bottom: 1.2rem;
    }

    .site-v2-footer__shell {
        padding: 1.45rem 1.2rem 1.1rem;
    }

    .service-layer {
        padding: 0.6rem 0 4rem;
    }

    .service-layer__intro h2 {
        font-size: 2.15rem;
    }

    .service-layer__intro p {
        font-size: 0.94rem;
    }

    .service-story,
    .service-snapshots,
    .service-journey__steps {
        grid-template-columns: 1fr;
    }

    .service-scene--hero {
        min-height: 25rem;
    }

    .service-story__stack {
        grid-template-rows: none;
        height: auto;
    }

    .service-scene--hero h3,
    .service-promise h3,
    .service-journey__intro h3 {
        font-size: 1.95rem;
    }

    .service-process__button {
        width: 100%;
    }

    .locations-teaser {
        padding: 0.8rem 0 4rem;
    }

    .locations-grid {
        grid-template-columns: 1fr;
    }

    .locations-teaser__actions {
        flex-direction: column;
        align-items: stretch;
    }

    .locations-teaser__primary,
    .locations-teaser__secondary {
        width: 100%;
    }

    .featured-fleet {
        padding: 1rem 0 4rem;
    }

    .featured-fleet__intro h2 {
        font-size: 2.2rem;
    }

    .featured-fleet__intro p {
        font-size: 0.94rem;
    }

    .fleet-showcase {
        grid-template-columns: 1fr;
    }

    .fleet-visual-card {
        grid-template-rows: auto 1fr auto;
        min-height: 0;
        padding: 0;
    }

    .fleet-visual-card__media {
        aspect-ratio: 1.18;
        height: auto;
    }

    .fleet-visual-card__spec-list {
        grid-template-columns: 1fr;
    }

    .fleet-visual-card__price-box {
        grid-template-columns: 1fr;
        display: grid;
    }

    .fleet-visual-card__primary {
        min-height: 48px;
        border-radius: 8px;
    }

    .fleet-visual-card__spec-item dd,
    .fleet-visual-card__price-note {
        width: fit-content;
    }

    .fleet-visual-card__contact-row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 1px;
        margin: 0;
        padding: 0;
        overflow: hidden;
        border-top: 1px solid rgba(152, 126, 96, 0.14);
        border-radius: 0;
        background: rgba(93, 75, 52, 0.14);
    }

    .fleet-visual-card__contact-link {
        width: 100%;
        min-height: 3.75rem;
        border-radius: 0;
        font-size: 0.72rem;
    }

    .fleet-visual-card__contact-icon {
        width: 0.98rem;
        height: 0.98rem;
    }

    .featured-fleet__footer-button {
        width: 100%;
    }

    .featured-fleet__footer-actions {
        width: 100%;
        flex-direction: column;
        align-items: stretch;
    }

    .hero-lab__actions,
    .hero-lab-overlay__form,
    .hero-lab-overlay__input-row {
        grid-template-columns: 1fr;
        display: grid;
    }

    .hero-lab__actions {
        gap: 0.9rem;
    }

    .hero-lab__service-links {
        display: grid;
        grid-template-columns: 1fr;
    }

    .hero-lab__service-links a {
        width: 100%;
        justify-content: flex-start;
        padding: 0 1rem;
    }

    .hero-lab__cta--primary,
    .hero-lab__cta--secondary,
    .hero-lab-overlay__submit {
        width: 100%;
        min-width: 0;
    }

    .hero-lab-overlay__header {
        flex-direction: column;
        gap: 1rem;
    }

    .hero-lab-overlay__close {
        align-self: flex-start;
    }

    .hero-lab-overlay__intro h2 {
        font-size: 2.4rem;
    }

    .hero-lab-overlay__shell {
        padding-left: 1.25rem;
        padding-right: 1.25rem;
    }
}

@media (max-width: 560px) {
    .guest-reviews__bg {
        opacity: 0.7;
    }

    .fleet-categories {
        padding: 1.1rem 0 0.6rem;
    }

    .fleet-categories__shell {
        width: var(--lab-frame-width);
        gap: 0.82rem;
        padding-bottom: 0.65rem;
    }

    .fleet-category {
        flex-basis: clamp(12rem, 68vw, 15.5rem);
        --fleet-image-shift-y: 0.12rem;
        align-content: center;
        min-height: 100%;
        gap: 0.42rem;
        padding: 0.52rem 0.58rem 0.5rem;
        border-radius: 16px;
    }

    .fleet-category__media {
        min-height: 5rem;
        aspect-ratio: 2.12 / 1;
        place-items: center;
        padding: 0.08rem 0 0;
    }

    .fleet-category__image {
        width: min(90%, 8.85rem);
        height: auto;
        max-width: 100%;
    }

    .fleet-visual-card__utility-row {
        display: grid;
        grid-template-columns: 1fr;
        gap: 0.45rem;
    }

    .fleet-visual-card__spec-list {
        grid-template-columns: 1fr;
    }

    .fleet-visual-card__contact-row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 1px;
        margin: 0;
        padding: 0;
        overflow: hidden;
        border-top: 1px solid rgba(152, 126, 96, 0.14);
        border-radius: 0;
        background: rgba(93, 75, 52, 0.14);
    }

    .fleet-visual-card__primary,
    .fleet-visual-card__contact-link {
        width: 100%;
    }

    .fleet-visual-card__primary {
        min-height: 3.2rem;
    }

    .fleet-visual-card__contact-link {
        min-height: 3.75rem;
        border-radius: 0;
        font-size: 0.72rem;
    }
}

@media (max-width: 860px) {
    .mobile-scroll-hint {
        display: inline-flex;
        align-items: center;
        gap: 0.52rem;
        width: fit-content;
        margin: -0.25rem auto 0.1rem;
        padding: 0.45rem 0.74rem;
        border: 1px solid rgba(214, 181, 94, 0.24);
        border-radius: 999px;
        background: rgba(255, 252, 247, 0.76);
        color: #604b35;
        font-family: var(--lab-font-sans);
        font-size: 0.68rem;
        font-weight: 800;
        letter-spacing: 0.14em;
        line-height: 1;
        text-transform: uppercase;
        box-shadow: 0 10px 24px rgba(45, 31, 18, 0.08);
    }

    .mobile-scroll-hint::after {
        content: "";
        width: 1.6rem;
        height: 0.56rem;
        border-radius: 999px;
        background:
            radial-gradient(circle at 0.28rem 50%, rgba(96, 75, 53, 0.52) 0 0.12rem, transparent 0.13rem),
            radial-gradient(circle at 0.8rem 50%, rgba(96, 75, 53, 0.34) 0 0.12rem, transparent 0.13rem),
            radial-gradient(circle at 1.32rem 50%, rgba(96, 75, 53, 0.2) 0 0.12rem, transparent 0.13rem);
    }

    .featured-fleet__mobile-hint {
        justify-self: center;
    }

    .fleet-showcase {
        display: flex;
        grid-template-columns: none;
        gap: 1rem;
        width: 100%;
        margin-inline: 0;
        padding: 0.1rem 2.35rem 0.75rem 0.05rem;
        overflow-x: auto;
        overscroll-behavior-x: contain;
        scroll-padding-inline: 0.05rem;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        scrollbar-color: rgba(214, 181, 94, 0.55) rgba(70, 52, 34, 0.08);
        scrollbar-width: thin;
        mask-image: linear-gradient(90deg, #000 0%, #000 calc(100% - 2.9rem), transparent 100%);
    }

    .fleet-showcase::-webkit-scrollbar {
        display: block;
        height: 4px;
    }

    .fleet-showcase::-webkit-scrollbar-track {
        background: rgba(70, 52, 34, 0.08);
        border-radius: 999px;
    }

    .fleet-showcase::-webkit-scrollbar-thumb {
        background: rgba(214, 181, 94, 0.58);
        border-radius: 999px;
    }

    .fleet-showcase .fleet-visual-card {
        flex: 0 0 clamp(16.5rem, 76vw, 21rem);
        scroll-snap-align: start;
        scroll-snap-stop: always;
    }

    .fleet-showcase .fleet-visual-card__media {
        aspect-ratio: 1.46 / 1;
    }

    .fleet-showcase .fleet-visual-card__body {
        gap: 0.5rem;
        padding: 0.82rem var(--fleet-card-content-pad-x) 0.72rem;
    }

    .fleet-showcase .fleet-visual-card__utility-row {
        min-height: 1.45rem;
    }

    .fleet-showcase .fleet-visual-card__trust {
        display: none;
    }

    .fleet-showcase .fleet-visual-card__sales-line,
    .fleet-showcase .fleet-visual-card__spec-list {
        display: none;
    }

    .fleet-showcase .fleet-visual-card__description {
        display: -webkit-box;
        min-height: 2.55rem;
        margin: 0.12rem 0 0;
        overflow: hidden;
        color: rgba(73, 62, 51, 0.82);
        font-size: 0.84rem;
        line-height: 1.34;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
    }

    .fleet-showcase .fleet-visual-card h3 {
        min-height: auto;
        margin-bottom: 0;
    }

    .fleet-showcase .fleet-visual-card__title-link {
        font-size: 1rem;
        line-height: 1.12;
    }

    .fleet-showcase .fleet-visual-card__price-box {
        margin-top: 0;
        padding: 0.62rem 0.76rem;
        border-radius: 0.82rem;
    }

    .fleet-showcase .fleet-visual-card__price-value {
        font-size: 1rem;
    }

    .fleet-showcase .fleet-visual-card__price-note {
        min-height: 1.35rem;
        padding: 0.28rem 0.54rem;
        font-size: 0.52rem;
    }

    .fleet-showcase .fleet-visual-card__primary {
        min-height: 46px;
        border-radius: 10px;
    }

    .fleet-showcase .fleet-visual-card__contact-link {
        min-height: 3.25rem;
    }
}

.guest-reviews .review-card--status {
    grid-column: span 3;
    align-content: center;
}

@media (max-width: 1200px) {
    .guest-reviews__body {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .guest-reviews .review-card--status {
        grid-column: 1 / -1;
    }

    .guest-reviews__summary {
        grid-column: 1 / -1;
        max-width: none;
        margin: 0;
    }
}

@media (max-height: 860px) {
    .guest-reviews {
        padding: 0.2rem 0 4.4rem;
    }

    .guest-reviews__intro h2 {
        font-size: clamp(2.35rem, 4vw, 3.25rem);
    }

    .guest-reviews__brand {
        font-size: 1.6rem;
    }
}

@media (max-width: 860px) {
    .brand-marquee {
        padding: 0.2rem 0 0;
    }

    .brand-marquee__viewport {
        --brand-marquee-fade: clamp(36px, 11vw, 72px);
        min-height: 4.95rem;
        padding: 0.58rem 0 0.7rem;
    }

    .brand-marquee__track {
        --brand-marquee-gap: 0.95rem;
    }

    .brand-marquee__item {
        width: 4.95rem;
        height: 3rem;
    }

    .guest-reviews__body {
        grid-template-columns: 1fr;
        gap: 0.9rem;
    }

    .guest-reviews {
        padding: 0.65rem 0 3.7rem;
    }

    .guest-reviews__shell {
        gap: 1.15rem;
    }

    .guest-reviews__intro h2 {
        max-width: 21rem;
        font-size: 2.15rem;
        line-height: 1.02;
        letter-spacing: 0;
    }

    .guest-reviews__summary {
        max-width: none;
        gap: 0.62rem;
        padding: 1.05rem 0.92rem 1rem;
        border-radius: 1.15rem;
        background: rgba(255, 251, 245, 0.74);
        box-shadow: 0 14px 28px rgba(33, 24, 16, 0.12);
    }

    .guest-reviews__brand {
        font-size: 1.38rem;
        line-height: 1.1;
    }

    .guest-reviews__rating {
        padding: 0.82rem 0.88rem;
        border-radius: 0.9rem;
    }

    .guest-reviews__rating .guest-reviews__score {
        font-size: 2.05rem;
        letter-spacing: 0;
    }

    .guest-reviews__rating .guest-reviews__stars {
        font-size: 1.1rem;
        letter-spacing: 0.12em;
    }

    .guest-reviews__count,
    .guest-reviews__powered {
        max-width: 18.5rem;
        font-size: 0.88rem;
        line-height: 1.4;
    }

    .guest-reviews__actions {
        gap: 0.45rem;
    }

    .guest-reviews .review-card {
        min-height: 0;
        height: auto;
    }

    .guest-reviews__google-button {
        width: 100%;
        max-width: 19rem;
        min-height: 46px;
        padding: 0 1.1rem;
        border: 1px solid rgba(207, 173, 101, 0.42);
        background: linear-gradient(135deg, #181512, #2a241d);
        color: #fffaf0;
        font-size: 0.7rem;
        letter-spacing: 0.06em;
        box-shadow: 0 12px 24px rgba(33, 24, 16, 0.18);
    }

    .guest-reviews__google-link {
        font-size: 0.86rem;
    }
}

@media (max-width: 1540px) {
    .lab-brand__copy span {
        display: none;
    }

    .lab-header__inner {
        gap: 1.25rem;
    }

    .lab-header__nav {
        gap: 0.75rem;
    }

    .lab-nav {
        gap: 1rem;
        padding: 0;
    }

    .lab-nav > a,
    .lab-nav__trigger {
        padding: 0.16rem 0;
        font-size: 0.67rem;
        letter-spacing: 0.13em;
    }

    .lab-nav__panel--brands {
        --lab-nav-panel-width: 29.4rem;
    }

    .lab-nav__card-copy strong {
        font-size: 0.94rem;
    }

    .lab-nav__card-copy span {
        font-size: 0.72rem;
    }

    .lab-reserve {
        min-height: 52px;
        padding: 0 1.28rem;
        font-size: 0.7rem;
        letter-spacing: 0.14em;
    }
}

@media (min-width: 1081px) and (max-width: 1320px) {
    .lab-header__utility {
        display: none;
    }
}

@media (min-width: 861px) and (max-width: 1540px) {
    .lab-brand {
        gap: 0.78rem;
    }

    .lab-brand__crest {
        flex: 0 0 48px;
        width: 48px;
        border-radius: 14px;
    }
}

@media (max-width: 1080px) {
:root {
        --lab-header-offset: 132px;
    }

    .lab-header__inner {
        flex-wrap: wrap;
        justify-content: center;
        gap: 0.85rem;
    }

    .lab-brand {
        width: 100%;
        justify-content: center;
    }

    .lab-header__nav {
        width: 100%;
        justify-content: center;
        flex-wrap: wrap;
    }

    .lab-nav {
        flex-wrap: wrap;
        justify-content: center;
        gap: 0.6rem 1.05rem;
        padding: 0;
        border-radius: 0;
    }

    .lab-nav__item {
        position: static;
    }

    .lab-nav__panel {
        left: 0;
        width: 100%;
        transform: translateY(0.8rem) scale(0.985);
    }

    .lab-nav__item:focus-within .lab-nav__panel,
    .lab-nav__item.is-open .lab-nav__panel {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        transform: translateY(0) scale(1);
    }

    .lab-nav__panel-grid--brands {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 860px) {
    :root {
        --lab-header-offset: 166px;
    }

    .lab-header__inner {
        padding: 0.95rem 0;
    }

    .lab-nav {
        width: 100%;
        gap: 0.45rem 0.85rem;
        padding: 0;
    }

    .lab-nav > a,
    .lab-nav__trigger {
        flex: 1 1 calc(50% - 0.5rem);
        width: calc(50% - 0.5rem);
        justify-content: flex-start;
        padding: 0.22rem 0;
    }

    .lab-nav__panel-grid--types,
    .lab-nav__panel-grid--brands {
        grid-template-columns: 1fr;
        row-gap: 1rem;
    }

    .lab-nav__card {
        min-height: 2.75rem;
    }

    .lab-reserve {
        width: 100%;
    }
}

@media (max-width: 720px) {
    .hero-lab__launcher {
        margin-top: 2.6rem;
    }

    .hero-lab__launcher h2 {
        max-width: 100%;
        font-size: 1.5rem;
    }

    .hero-lab__launcher p {
        width: 100%;
    }
}

@media (prefers-reduced-motion: reduce) {
    .brand-marquee__track {
        animation: none;
    }
}

.hero-lab__trust {
    display: none;
    margin: 0.9rem 0 0;
    color: rgba(245, 241, 232, 0.78);
    font-size: 0.84rem;
    line-height: 1.5;
}

.lab-mobile-toggle,
.lab-mobile-drawer,
.lab-mobile-action-bar {
    display: none;
}

.lab-mobile-toggle {
    position: relative;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.3rem;
    width: 46px;
    height: 46px;
    padding: 0;
    border: 1px solid rgba(224, 198, 148, 0.24);
    border-radius: 8px;
    background:
        linear-gradient(180deg, rgba(17, 20, 24, 0.72) 0%, rgba(8, 10, 12, 0.94) 100%);
    color: rgba(255, 250, 242, 0.94);
    box-shadow:
        0 14px 28px rgba(0, 0, 0, 0.18),
        inset 0 1px 0 rgba(255, 255, 255, 0.06);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    transition:
        transform 180ms ease,
        border-color 180ms ease,
        background 180ms ease,
        box-shadow 180ms ease;
}

.lab-mobile-toggle:hover,
.lab-mobile-toggle:focus-visible {
    border-color: rgba(238, 216, 169, 0.42);
    background:
        linear-gradient(180deg, rgba(20, 23, 28, 0.82) 0%, rgba(10, 12, 15, 0.98) 100%);
    box-shadow:
        0 18px 34px rgba(0, 0, 0, 0.24),
        inset 0 1px 0 rgba(255, 255, 255, 0.08);
    transform: translateY(-1px);
}

.lab-mobile-toggle:focus-visible {
    outline: none;
}

.lab-mobile-toggle__line {
    display: block;
    width: 18px;
    height: 2px;
    border-radius: 999px;
    background: currentColor;
    transition:
        transform 220ms ease,
        width 220ms ease,
        opacity 180ms ease,
        background-color 180ms ease;
    transform-origin: center;
}

.lab-mobile-toggle__line:nth-child(2) {
    width: 12px;
    background: rgba(230, 196, 111, 0.94);
}

.lab-mobile-toggle.is-open {
    border-color: rgba(238, 216, 169, 0.36);
    background:
        linear-gradient(180deg, rgba(18, 21, 26, 0.88) 0%, rgba(9, 11, 14, 0.98) 100%);
}

.lab-mobile-toggle.is-open .lab-mobile-toggle__line:nth-child(1) {
    transform: translateY(5px) rotate(45deg);
}

.lab-mobile-toggle.is-open .lab-mobile-toggle__line:nth-child(2) {
    opacity: 0;
    transform: scaleX(0.45);
}

.lab-mobile-toggle.is-open .lab-mobile-toggle__line:nth-child(3) {
    transform: translateY(-5px) rotate(-45deg);
}

.lab-mobile-drawer {
    position: fixed;
    inset: 0;
    z-index: 1000;
    width: 100%;
    overflow: hidden;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 220ms ease, visibility 220ms ease;
}

.lab-mobile-drawer.is-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.lab-mobile-drawer:not(.is-open) .lab-mobile-drawer__panel {
    display: none;
}

.lab-mobile-drawer__scrim {
    position: absolute;
    inset: 0;
    background: rgba(4, 5, 8, 0.72);
}

.lab-mobile-drawer__panel {
    position: relative;
    z-index: 1;
    display: grid;
    align-content: start;
    gap: 1.15rem;
    width: min(100%, 28rem);
    height: 100%;
    max-height: 100dvh;
    margin-left: auto;
    padding: 1.15rem 1rem calc(1.15rem + env(safe-area-inset-bottom));
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    background:
        radial-gradient(circle at 18% 6%, rgba(214, 188, 134, 0.1), transparent 20%),
        linear-gradient(180deg, rgba(9, 11, 14, 0.985), rgba(4, 6, 9, 0.99));
    box-shadow: -24px 0 80px rgba(0, 0, 0, 0.32);
    transform: translateX(100%);
    transition: transform 260ms cubic-bezier(0.22, 1, 0.36, 1);
}

.lab-mobile-drawer.is-open .lab-mobile-drawer__panel {
    transform: translateX(0);
}

.lab-mobile-drawer__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.lab-mobile-drawer__brand {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    min-width: 0;
}

.lab-mobile-drawer__crest {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    aspect-ratio: 1;
    border-radius: 8px;
    border: 1px solid rgba(214, 188, 134, 0.2);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.015));
    overflow: hidden;
    flex: 0 0 auto;
}

.lab-mobile-drawer__crest img {
    width: auto;
    height: 88%;
    object-fit: contain;
}

.lab-mobile-drawer__brand-copy {
    display: grid;
    gap: 0.16rem;
    min-width: 0;
}

.lab-mobile-drawer__brand-copy strong {
    font-family: var(--lab-font-sans);
    font-size: 0.84rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.lab-mobile-drawer__brand-copy span {
    font-family: var(--lab-font-sans);
    color: rgba(245, 241, 232, 0.52);
    font-size: 0.62rem;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.lab-mobile-drawer__close,
.hero-lab-overlay__close {
    position: relative;
    z-index: 2;
    display: inline-grid;
    place-items: center;
    flex: 0 0 auto;
    width: 46px;
    min-width: 46px;
    height: 46px;
    min-height: 46px;
    padding: 0;
    overflow: hidden;
    border: 1px solid rgba(224, 198, 148, 0.24);
    border-radius: 8px;
    background: linear-gradient(180deg, rgba(17, 20, 24, 0.72) 0%, rgba(8, 10, 12, 0.94) 100%);
    color: rgba(255, 250, 242, 0.94);
    font-size: 0;
    line-height: 0;
    box-shadow:
        0 14px 28px rgba(0, 0, 0, 0.18),
        inset 0 1px 0 rgba(255, 255, 255, 0.06);
    cursor: pointer;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    transition:
        transform 180ms ease,
        border-color 180ms ease,
        background 180ms ease,
        box-shadow 180ms ease;
}

.lab-mobile-drawer__close::before,
.lab-mobile-drawer__close::after,
.hero-lab-overlay__close::before,
.hero-lab-overlay__close::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 18px;
    height: 2px;
    border-radius: 999px;
    background: currentColor;
    transform-origin: center;
}

.lab-mobile-drawer__close::before,
.hero-lab-overlay__close::before {
    transform: translate(-50%, -50%) rotate(45deg);
}

.lab-mobile-drawer__close::after,
.hero-lab-overlay__close::after {
    transform: translate(-50%, -50%) rotate(-45deg);
}

.lab-mobile-drawer__close:hover,
.lab-mobile-drawer__close:focus-visible,
.hero-lab-overlay__close:hover,
.hero-lab-overlay__close:focus-visible {
    border-color: rgba(238, 216, 169, 0.42);
    background: linear-gradient(180deg, rgba(20, 23, 28, 0.82) 0%, rgba(10, 12, 15, 0.98) 100%);
    box-shadow:
        0 18px 34px rgba(0, 0, 0, 0.24),
        inset 0 1px 0 rgba(255, 255, 255, 0.08);
    outline: none;
    transform: translateY(-1px);
}

.lab-mobile-drawer__intro {
    display: grid;
    gap: 0.8rem;
    padding: 0.15rem 0 0.1rem;
}

.lab-mobile-drawer__intro p {
    margin: 0;
    color: rgba(245, 241, 232, 0.68);
    font-size: 0.92rem;
    line-height: 1.5;
}

.lab-mobile-drawer__quick {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.55rem;
}

.lab-mobile-drawer__quick-link {
    position: relative;
    isolation: isolate;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.34rem;
    min-height: 58px;
    padding: 0.46rem 0.42rem 0.42rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 8px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(11, 12, 16, 0.96));
    color: rgba(245, 241, 232, 0.92);
    font-size: 0.73rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    line-height: 1;
    text-transform: uppercase;
    overflow: hidden;
    transition: transform 180ms ease, border-color 180ms ease, background-color 180ms ease, color 180ms ease;
}

.lab-mobile-drawer__quick-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.62rem;
    height: 1.62rem;
    border: 1px solid rgba(245, 241, 232, 0.1);
    border-radius: 8px;
    background: rgba(245, 241, 232, 0.06);
    color: #f8fbd4;
}

.lab-mobile-drawer__quick-icon svg {
    width: 1rem;
    height: 1rem;
    display: block;
}

.lab-mobile-drawer__quick-text {
    display: block;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.lab-mobile-drawer__quick-link--wa .lab-mobile-drawer__quick-icon {
    background: rgba(76, 143, 47, 0.24);
    color: #dff6d2;
}

.lab-mobile-drawer__quick-link--call .lab-mobile-drawer__quick-icon {
    background: rgba(214, 188, 134, 0.14);
    color: #f6df9e;
}

.lab-mobile-drawer__quick-link:hover,
.lab-mobile-drawer__quick-link:focus-visible {
    transform: translateY(-1px);
    border-color: rgba(var(--dp-color-gold-rgb), 0.24);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.075), rgba(11, 12, 16, 0.92));
    color: #ffffff;
}

.lab-mobile-drawer__section {
    display: grid;
    gap: 0.7rem;
}

.lab-mobile-drawer__label {
    color: rgba(245, 241, 232, 0.5);
    font-size: 0.66rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.lab-mobile-drawer__section--disclosure {
    display: block;
}

.lab-mobile-drawer__summary {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    align-items: center;
    gap: 0.7rem;
    min-height: 46px;
    padding: 0 0.82rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 8px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(11, 12, 16, 0.96));
    color: rgba(245, 241, 232, 0.92);
    cursor: pointer;
    list-style: none;
}

.lab-mobile-drawer__summary::-webkit-details-marker {
    display: none;
}

.lab-mobile-drawer__summary .lab-mobile-drawer__label {
    color: rgba(245, 241, 232, 0.82);
}

.lab-mobile-drawer__summary-meta {
    color: rgba(245, 241, 232, 0.5);
    font-size: 0.66rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    white-space: nowrap;
}

.lab-mobile-drawer__summary-icon {
    width: 0.54rem;
    height: 0.54rem;
    border-right: 2px solid rgba(245, 241, 232, 0.74);
    border-bottom: 2px solid rgba(245, 241, 232, 0.74);
    transform: rotate(45deg) translateY(-2px);
    transition: transform 180ms ease;
}

.lab-mobile-drawer__section--disclosure[open] .lab-mobile-drawer__summary-icon {
    transform: rotate(225deg) translate(-2px, -1px);
}

.lab-mobile-drawer__section--disclosure[open] .lab-mobile-drawer__links {
    margin-top: 0.55rem;
}

.lab-mobile-drawer__links {
    display: grid;
    gap: 0.55rem;
}

.lab-mobile-drawer__links--nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.lab-mobile-drawer__links a {
    display: flex;
    align-items: center;
    min-height: 52px;
    padding: 0 0.95rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 8px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(11, 12, 16, 0.96));
    color: rgba(245, 241, 232, 0.92);
    font-size: 0.88rem;
    font-weight: 600;
    line-height: 1.25;
    transition: transform 180ms ease, border-color 180ms ease, background-color 180ms ease;
}

.lab-mobile-drawer__links a[aria-current="page"] {
    border-color: rgba(var(--dp-color-gold-rgb), 0.34);
    background: rgba(var(--dp-color-gold-rgb), 0.08);
    color: #f8fbd4;
}

.lab-mobile-drawer__links--compact a {
    min-height: 46px;
    font-size: 0.82rem;
    color: rgba(245, 241, 232, 0.84);
}

.lab-mobile-action-bar {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 90;
    align-items: center;
    gap: 0.7rem;
    padding: 0.8rem 1rem calc(0.8rem + env(safe-area-inset-bottom));
    background: linear-gradient(180deg, rgba(9, 11, 14, 0.92), rgba(5, 6, 8, 0.98));
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 -16px 40px rgba(0, 0, 0, 0.24);
}

.lab-mobile-action-bar__primary,
.lab-mobile-action-bar__secondary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 50px;
    border-radius: 8px;
    font-size: 0.82rem;
    font-weight: 700;
    line-height: 1;
}

.lab-mobile-action-bar__primary {
    flex: 1 1 auto;
    border: 0;
    background: linear-gradient(135deg, var(--lab-accent-soft), var(--lab-accent));
    color: var(--dp-color-text);
}

.lab-mobile-action-bar__secondary {
    flex: 0 0 118px;
    border: 1px solid rgba(255, 255, 255, 0.14);
    background: rgba(255, 255, 255, 0.04);
    color: rgba(245, 241, 232, 0.92);
}

.lab-floating-back {
    position: fixed;
    left: max(1rem, env(safe-area-inset-left));
    top: calc(var(--lab-header-offset) + 1rem);
    z-index: 96;
    display: inline-grid;
    place-items: center;
    width: 48px;
    height: 48px;
    border: 1px solid rgba(241, 226, 189, 0.34);
    border-radius: 999px;
    background:
        linear-gradient(180deg, rgba(23, 24, 27, 0.68), rgba(7, 8, 10, 0.58));
    color: rgba(248, 238, 214, 0.96);
    box-shadow:
        0 18px 44px rgba(0, 0, 0, 0.24),
        inset 0 1px 0 rgba(255, 255, 255, 0.08);
    opacity: 0;
    pointer-events: none;
    transform: translate3d(-8px, 8px, 0) scale(0.96);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    transition: opacity 180ms ease, transform 180ms ease, border-color 180ms ease, background 180ms ease, box-shadow 180ms ease, color 180ms ease;
}

.lab-floating-back.is-visible {
    opacity: 0.92;
    pointer-events: auto;
    transform: translate3d(0, 0, 0) scale(1);
}

.lab-floating-back.is-visible.is-over-important-content {
    opacity: 0.78;
    border-color: rgba(241, 226, 189, 0.18);
    background:
        linear-gradient(180deg, rgba(23, 24, 27, 0.62), rgba(7, 8, 10, 0.52));
    color: rgba(248, 238, 214, 0.92);
    box-shadow:
        0 10px 24px rgba(0, 0, 0, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.home-page .lab-floating-back,
.hero-lab-overlay-open .lab-floating-back,
.lab-mobile-nav-open .lab-floating-back,
.fleet-filter-sheet-open .lab-floating-back {
    opacity: 0 !important;
    pointer-events: none !important;
    transform: translate3d(-8px, 8px, 0) scale(0.96);
}

.lab-floating-back:hover,
.lab-floating-back:focus-visible {
    opacity: 0.96;
    border-color: rgba(var(--dp-color-gold-rgb), 0.46);
    background:
        linear-gradient(180deg, rgba(31, 33, 38, 0.82), rgba(8, 9, 11, 0.76));
    color: rgba(248, 238, 214, 0.98);
    outline: none;
    transform: translateY(-2px);
}

.lab-floating-back.is-visible.is-over-important-content:hover,
.lab-floating-back.is-visible.is-over-important-content:focus-visible {
    opacity: 0.96;
    border-color: rgba(var(--dp-color-gold-rgb), 0.46);
    background:
        linear-gradient(180deg, rgba(31, 33, 38, 0.82), rgba(8, 9, 11, 0.76));
    color: rgba(248, 238, 214, 0.98);
    box-shadow:
        0 18px 44px rgba(0, 0, 0, 0.24),
        inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.lab-floating-back svg {
    width: 21px;
    height: 21px;
}

.lab-floating-back span {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.lab-floating-contact {
    position: fixed;
    right: max(1.15rem, env(safe-area-inset-right));
    bottom: calc(1.25rem + env(safe-area-inset-bottom));
    z-index: 95;
    display: grid;
    gap: 0.78rem;
    opacity: 0;
    pointer-events: none;
    transform: translate3d(8px, 10px, 0) scale(0.96);
    transition: opacity 180ms ease, transform 180ms ease;
}

.lab-floating-contact.is-visible {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
}

.lab-floating-contact.is-visible.is-over-card-actions {
    opacity: 0.82;
    pointer-events: auto;
    transform: translate3d(0, 0, 0) scale(0.98);
}

.lab-floating-contact__button {
    position: relative;
    display: inline-grid;
    place-items: center;
    width: 58px;
    height: 58px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 999px;
    color: #fff;
    pointer-events: auto;
    text-decoration: none;
    box-shadow:
        0 18px 38px rgba(0, 0, 0, 0.3),
        inset 0 1px 0 rgba(255, 255, 255, 0.16);
    transition: transform 180ms ease, box-shadow 180ms ease, filter 180ms ease;
}

.lab-floating-contact__button:hover,
.lab-floating-contact__button:focus-visible {
    outline: none;
    transform: translateY(-2px) scale(1.03);
    box-shadow:
        0 22px 46px rgba(0, 0, 0, 0.36),
        inset 0 1px 0 rgba(255, 255, 255, 0.2);
    filter: saturate(1.05);
}

.lab-floating-contact__button--call {
    background: linear-gradient(135deg, #d4ad5b, #f0ce83);
    color: #17120d;
}

.lab-floating-contact__button--wa {
    background: #19a83f;
    border-color: rgba(241, 226, 189, 0.58);
    color: #fff;
    box-shadow: none;
}

.lab-floating-contact__button--wa:hover,
.lab-floating-contact__button--wa:focus-visible {
    border-color: rgba(241, 226, 189, 0.78);
    box-shadow: none;
}

.lab-floating-contact__button svg {
    width: 25px;
    height: 25px;
    filter: none;
    text-shadow: none;
}

.lab-floating-contact__button--wa svg,
.hero-floating-actions__link--wa svg {
    transform: none;
    filter: none;
}

.lab-floating-contact__button--wa path,
.hero-floating-actions__link--wa path {
    filter: none;
}

.lab-floating-contact__button span {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.hero-lab-overlay-open .lab-floating-contact,
.lab-mobile-nav-open .lab-floating-contact,
.fleet-filter-sheet-open .lab-floating-contact,
.vehicle-media-lightbox-open .lab-floating-contact {
    opacity: 0 !important;
    pointer-events: none !important;
    transform: translate3d(8px, 10px, 0) scale(0.96);
}

body.vehicle-media-lightbox-open {
    overflow: hidden;
}

.vehicle-pdp-gallery-top__stage.is-lightbox-trigger,
.vehicle-pdp-gallery-top__thumb--media.is-lightbox-trigger,
.vehicle-pdp-gallery-panel__item.is-lightbox-trigger,
.vehicle-pdp-gallery-card__media.is-lightbox-trigger {
    cursor: zoom-in;
}

.vehicle-pdp-gallery-top__stage.is-lightbox-trigger:focus-visible,
.vehicle-pdp-gallery-top__thumb--media.is-lightbox-trigger:focus-visible,
.vehicle-pdp-gallery-panel__item.is-lightbox-trigger:focus-visible,
.vehicle-pdp-gallery-card__media.is-lightbox-trigger:focus-visible {
    outline: 2px solid rgba(var(--dp-color-gold-rgb), 0.86);
    outline-offset: 4px;
}

.vehicle-media-lightbox {
    position: fixed;
    inset: 0;
    z-index: 360;
    display: grid;
    place-items: center;
    padding: max(1rem, env(safe-area-inset-top)) max(1rem, env(safe-area-inset-right)) max(1rem, env(safe-area-inset-bottom)) max(1rem, env(safe-area-inset-left));
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 180ms ease, visibility 180ms ease;
}

.vehicle-media-lightbox.is-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.vehicle-media-lightbox__scrim {
    position: absolute;
    inset: 0;
    border: 0;
    background:
        radial-gradient(circle at 50% 18%, rgba(214, 188, 134, 0.18), rgba(214, 188, 134, 0) 34%),
        rgba(5, 5, 6, 0.86);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    cursor: zoom-out;
}

.vehicle-media-lightbox__panel {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: clamp(0.75rem, 2vw, 1.35rem);
    width: min(1120px, 100%);
    max-height: min(86vh, 820px);
    padding: clamp(0.8rem, 1.8vw, 1.1rem);
    border: 1px solid rgba(241, 226, 189, 0.22);
    border-radius: clamp(18px, 2vw, 30px);
    background:
        linear-gradient(180deg, rgba(18, 18, 19, 0.92), rgba(7, 7, 8, 0.96));
    box-shadow:
        0 34px 90px rgba(0, 0, 0, 0.52),
        inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.vehicle-media-lightbox__figure {
    position: relative;
    display: grid;
    gap: 0.78rem;
    min-width: 0;
    margin: 0;
}

.vehicle-media-lightbox__image {
    display: block;
    width: 100%;
    max-height: min(70vh, 680px);
    object-fit: contain;
    border-radius: clamp(14px, 1.4vw, 22px);
    background: #090909;
}

.vehicle-media-lightbox__caption,
.vehicle-media-lightbox__counter {
    color: rgba(248, 238, 214, 0.9);
    font-family: var(--lab-font-sans);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.13em;
    text-transform: uppercase;
}

.vehicle-media-lightbox__counter {
    position: absolute;
    top: 0.85rem;
    left: 0.85rem;
    z-index: 2;
    padding: 0.46rem 0.62rem;
    border-radius: 999px;
    background: rgba(5, 5, 6, 0.62);
    box-shadow: inset 0 0 0 1px rgba(241, 226, 189, 0.16);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.vehicle-media-lightbox__close,
.vehicle-media-lightbox__nav {
    display: inline-grid;
    place-items: center;
    border: 1px solid rgba(241, 226, 189, 0.24);
    background: rgba(14, 14, 15, 0.82);
    color: rgba(248, 238, 214, 0.96);
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.24);
    cursor: pointer;
    transition: transform 160ms ease, border-color 160ms ease, background 160ms ease;
}

.vehicle-media-lightbox__close:hover,
.vehicle-media-lightbox__close:focus-visible,
.vehicle-media-lightbox__nav:hover,
.vehicle-media-lightbox__nav:focus-visible {
    border-color: rgba(var(--dp-color-gold-rgb), 0.55);
    background: rgba(29, 30, 31, 0.94);
    outline: none;
    transform: translateY(-1px);
}

.vehicle-media-lightbox__close {
    position: absolute;
    top: 0.85rem;
    right: 0.85rem;
    z-index: 3;
    width: 46px;
    height: 46px;
    border-radius: 8px;
    background: linear-gradient(180deg, rgba(17, 20, 24, 0.72) 0%, rgba(8, 10, 12, 0.94) 100%);
    color: rgba(255, 250, 242, 0.94);
    font-size: 0;
    line-height: 0;
    overflow: hidden;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

.vehicle-media-lightbox__close::before,
.vehicle-media-lightbox__close::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 18px;
    height: 2px;
    border-radius: 999px;
    background: currentColor;
    transform-origin: center;
}

.vehicle-media-lightbox__close::before {
    transform: translate(-50%, -50%) rotate(45deg);
}

.vehicle-media-lightbox__close::after {
    transform: translate(-50%, -50%) rotate(-45deg);
}

.vehicle-media-lightbox__nav {
    width: clamp(42px, 4.6vw, 56px);
    height: clamp(54px, 6vw, 70px);
    border-radius: 999px;
    font-size: clamp(2rem, 4vw, 3rem);
    line-height: 1;
}

@media (max-width: 720px) {
    .vehicle-media-lightbox {
        align-items: center;
        padding: 0.46rem 0.46rem max(0.46rem, env(safe-area-inset-bottom));
    }

    .vehicle-media-lightbox__panel {
        grid-template-columns: 1fr 1fr;
        gap: 0.52rem;
        width: 100%;
        max-height: 92vh;
        padding: 0.46rem;
        border-radius: 20px;
    }

    .vehicle-media-lightbox__figure {
        grid-column: 1 / -1;
        grid-row: 1;
        gap: 0.58rem;
    }

    .vehicle-media-lightbox__image {
        height: clamp(17rem, 74vw, 24rem);
        max-height: 66vh;
        object-fit: cover;
        object-position: center center;
        border-radius: 15px;
    }

    .vehicle-media-lightbox__caption {
        font-size: 0.72rem;
        letter-spacing: 0.1em;
        line-height: 1.35;
    }

    .vehicle-media-lightbox__nav {
        width: 100%;
        height: 3rem;
        border-radius: 14px;
        font-size: 2rem;
    }

    .vehicle-media-lightbox__nav--prev {
        grid-column: 1;
        grid-row: 2;
    }

    .vehicle-media-lightbox__nav--next {
        grid-column: 2;
        grid-row: 2;
    }

    .vehicle-media-lightbox__close {
        width: 46px;
        min-width: 46px;
        height: 46px;
        min-height: 46px;
        top: 1rem;
        right: 1rem;
    }
}

body.lab-has-mobile-bar {
    padding-bottom: 5.9rem;
}

body.lab-mobile-nav-open {
    overflow: hidden;
}

@media (max-width: 860px) {
    :root {
        --lab-header-offset: 92px;
    }

    .lab-header {
        position: fixed;
        background: linear-gradient(180deg, rgba(4, 4, 6, 0.94) 0%, rgba(4, 4, 6, 0.76) 70%, rgba(4, 4, 6, 0.18) 100%);
        backdrop-filter: blur(10px);
        -webkit-backdrop-filter: blur(10px);
    }

    .lab-floating-back {
        left: max(0.85rem, env(safe-area-inset-left));
        top: calc(var(--lab-header-offset) + 0.65rem);
        width: 44px;
        height: 44px;
    }

    .lab-floating-contact {
        right: max(0.65rem, env(safe-area-inset-right));
        bottom: calc(0.65rem + env(safe-area-inset-bottom));
        gap: 0.55rem;
    }

    body.lab-has-mobile-bar .lab-floating-contact {
        bottom: calc(6.55rem + env(safe-area-inset-bottom));
    }

    .lab-floating-contact__button {
        width: 48px;
        height: 48px;
    }

    .lab-floating-contact__button svg {
        width: 22px;
        height: 22px;
    }

    .lab-header__inner {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: center;
        gap: 0.75rem;
        padding: 0.82rem 0;
    }

    .lab-brand {
        width: auto;
        min-width: 0;
        justify-content: flex-start;
    }

    .home-page .lab-brand__crest {
        display: none;
    }

    .lab-brand__crest {
        width: 50px;
        border-radius: 8px;
    }

    .lab-brand__copy {
        min-width: 0;
    }

    .lab-brand__copy strong {
        font-size: 0.78rem;
        letter-spacing: 0.12em;
    }

    .lab-brand__copy span {
        display: none;
    }

    .lab-header__nav {
        display: none;
    }

    .lab-mobile-toggle,
    .lab-mobile-drawer,
    .lab-mobile-action-bar,
    .hero-lab__trust {
        display: flex;
    }

    .lab-mobile-drawer__panel {
        gap: 0.82rem;
        padding: 0.85rem 1rem calc(0.85rem + env(safe-area-inset-bottom));
    }

    .lab-mobile-drawer__intro {
        gap: 0.62rem;
        padding: 0;
    }

    .lab-mobile-drawer__intro p {
        font-size: 0.88rem;
        line-height: 1.42;
    }

    .lab-mobile-drawer__section {
        gap: 0.52rem;
    }

    .lab-mobile-drawer__quick,
    .lab-mobile-drawer__links {
        display: grid;
        align-items: stretch;
        gap: 0.5rem;
    }

    .lab-mobile-drawer__quick,
    .lab-mobile-drawer__links--nav {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .lab-mobile-drawer__links--compact {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .lab-mobile-drawer__links a {
        justify-content: center;
        min-width: 0;
        min-height: 40px;
        padding: 0 0.58rem;
        text-align: center;
        line-height: 1.12;
    }

    .lab-mobile-drawer__quick-link {
        min-width: 0;
        min-height: 54px;
        padding: 0.42rem 0.38rem 0.38rem;
        text-align: center;
    }

    .lab-mobile-drawer__quick-icon {
        width: 1.46rem;
        height: 1.46rem;
    }

    .lab-mobile-drawer__quick-icon svg {
        width: 0.92rem;
        height: 0.92rem;
    }

    .lab-mobile-drawer__links--compact a {
        min-height: 40px;
    }

    .lab-mobile-drawer__actions {
        gap: 0;
    }

    .lab-mobile-drawer__action--secondary {
        display: none;
    }

    .hero-lab {
        min-height: 100svh;
        background:
            radial-gradient(circle at 62% 20%, rgba(var(--dp-color-gold-rgb), 0.12), rgba(var(--dp-color-gold-rgb), 0) 32%),
            linear-gradient(180deg, #060708 0%, #10100d 42%, #050607 100%);
    }

    .hero-lab__video {
        display: none;
    }

    .home-page .hero-lab__video {
        display: block;
        object-position: 58% 50%;
        opacity: 0.72;
        transform: scale(1.04);
        filter: saturate(1.02) brightness(0.62) contrast(1.08);
    }

    .home-page .hero-lab__still {
        opacity: 1;
    }

    .hero-lab__body {
        padding-bottom: 4.2rem;
    }

    .hero-lab__body::after {
        content: "Browse the fleet below";
        display: inline-flex;
        align-items: center;
        gap: 0.45rem;
        margin-top: 1.1rem;
        color: rgba(245, 241, 232, 0.62);
        font-size: 0.74rem;
        font-weight: 600;
        line-height: 1.2;
    }

    .hero-lab__body-copy h1 {
        font-size: clamp(2.5rem, 12vw, 3.5rem);
        line-height: 0.96;
    }

    .hero-lab__lead {
        max-width: 22rem;
        font-size: 0.98rem;
        line-height: 1.48;
    }

    .hero-lab__launcher {
        margin-top: 1.4rem;
    }

    .hero-lab__launcher h2,
    .hero-lab__launcher p {
        display: none;
    }

    .hero-lab__actions {
        display: grid;
        gap: 0.7rem;
    }

    .hero-lab__cta {
        width: 100%;
        min-height: 52px;
        border-radius: 8px;
    }

    .hero-lab-overlay__shell {
        padding: 1.2rem 1rem calc(1rem + env(safe-area-inset-bottom));
        border-radius: 18px 18px 0 0;
    }

    .hero-lab-overlay__header {
        gap: 1rem;
    }

    .hero-lab-overlay__intro h2 {
        font-size: 1.9rem;
    }

    .hero-lab-overlay__intro p {
        margin-top: 0.55rem;
        font-size: 0.92rem;
        line-height: 1.48;
    }

    .hero-lab-overlay__close,
    .hero-lab-overlay__input,
    .hero-lab-overlay__submit {
        border-radius: 8px;
    }

    .hero-lab-overlay__form,
    .hero-lab-overlay__input-row {
        grid-template-columns: 1fr;
    }

    .hero-lab-overlay__submit {
        width: 100%;
        min-width: 0;
    }
}

/* Home hero motion boost:
   stronger motion presence on desktop and a clearer moving image on mobile
   without letting the background overpower the copy. */
.home-page .hero-lab__video {
    object-position: 62% center;
    opacity: 0.82;
    transform: scale(1.02);
    filter: saturate(1.05) brightness(0.76) contrast(1.04);
}

.home-page .hero-lab__overlay {
    background:
        linear-gradient(180deg, rgba(5, 6, 8, 0.68) 0%, rgba(5, 6, 8, 0.22) 26%, rgba(5, 6, 8, 0.66) 66%, rgba(5, 6, 8, 0.9) 100%),
        linear-gradient(90deg, rgba(5, 6, 8, 0.9) 0%, rgba(5, 6, 8, 0.62) 36%, rgba(5, 6, 8, 0.22) 100%);
}

@media (max-width: 860px) {
    .home-page .hero-lab__video {
        object-position: 66% center;
        opacity: 0.78;
        transform: scale(1.04);
        filter: saturate(1.08) brightness(0.72) contrast(1.04);
    }
}


/* Shared compact mobile footer. */
@media (max-width: 860px) {
    .lab-floating-contact {
        display: none;
    }

    .fleet-page .lab-floating-contact {
        display: grid;
    }

    .site-v2-footer {
        padding-top: 0;
        padding-bottom: 0.85rem;
    }

    .site-v2-footer__shell {
        box-sizing: border-box;
        width: min(342px, calc(100vw - 48px));
        margin-inline: auto;
        gap: 1rem;
        padding: 1.05rem 1rem 1rem;
        border: 1px solid rgba(214, 188, 134, 0.18);
        border-radius: 22px;
        background:
            radial-gradient(circle at 50% 0%, rgba(214, 188, 134, 0.1), rgba(214, 188, 134, 0) 30%),
            linear-gradient(180deg, #10100f 0%, #080808 100%);
        box-shadow: 0 22px 48px rgba(8, 7, 6, 0.32);
    }

    .site-v2-footer--over-video .site-v2-footer__shell {
        border-color: rgba(214, 188, 134, 0.2);
        background:
            radial-gradient(circle at 50% 0%, rgba(214, 188, 134, 0.11), rgba(214, 188, 134, 0) 30%),
            linear-gradient(180deg, rgba(16, 16, 15, 0.98) 0%, rgba(8, 8, 8, 0.99) 100%);
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
    }

    .site-v2-footer__top {
        grid-template-columns: 1fr;
        justify-items: center;
        gap: 0.9rem;
        text-align: center;
    }

    .site-v2-footer__crest {
        width: 4.55rem;
        height: 4.55rem;
        border-radius: 16px;
        border-color: rgba(214, 188, 134, 0.26);
        background:
            radial-gradient(circle at 50% 18%, rgba(214, 188, 134, 0.11), rgba(255, 255, 255, 0.03) 54%),
            rgba(255, 255, 255, 0.025);
        box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.035);
    }

    .site-v2-footer__brand {
        justify-items: center;
        gap: 0.62rem;
        padding-bottom: 0.2rem;
        text-align: center;
    }

    .site-v2-footer__brand p {
        max-width: 18.5rem;
        font-size: 0.82rem;
        line-height: 1.42;
        color: rgba(239, 233, 222, 0.74);
    }

    .site-v2-footer__column {
        justify-items: center;
        gap: 0.48rem;
        text-align: center;
    }

    .site-v2-footer__column--guides {
        display: none;
    }

    .site-v2-footer__column h3 {
        font-size: 1.05rem;
        color: rgba(250, 246, 239, 0.96);
    }

    .site-v2-footer__column a,
    .site-v2-footer__column p {
        font-size: 0.82rem;
        line-height: 1.36;
        color: rgba(229, 222, 211, 0.72);
    }

    .site-v2-footer__column--links {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        column-gap: 1.1rem;
        width: min(100%, 16.5rem);
    }

    .site-v2-footer__column--links h3 {
        grid-column: 1 / -1;
    }

    .site-v2-footer__column--links a,
    .site-v2-footer__column--contact a,
    .site-v2-footer__column--contact p {
        justify-self: center;
        text-align: center;
    }

    .site-v2-footer__column--contact {
        width: min(100%, 18.5rem);
    }

    .site-v2-footer__middle {
        display: none;
    }

    .site-v2-footer__bottom {
        display: grid;
        width: 100%;
        justify-content: center;
        justify-items: center;
        gap: 0.7rem;
        padding-top: 0.9rem;
        border-top: 1px solid rgba(255, 255, 255, 0.075);
        text-align: center;
    }

    .site-v2-footer__legal {
        width: 100%;
        flex-direction: row;
        flex-wrap: wrap;
        justify-content: center;
        justify-self: center;
        gap: 0.75rem;
    }

    .site-v2-footer__bottom p {
        width: 100%;
        justify-self: center;
        font-size: 0.76rem;
        text-align: center;
        color: rgba(223, 216, 206, 0.52);
    }

    .site-v2-footer__socials {
        width: 100%;
        justify-self: center;
        justify-content: center;
    }

    .site-v2-footer__socials a {
        min-width: 2.5rem;
        min-height: 2.5rem;
        border-color: rgba(214, 188, 134, 0.18);
        background: rgba(255, 255, 255, 0.035);
        font-size: 0.72rem;
    }
}
