/* Import Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,200;12..96,300;12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=Manrope:wght@200;300;400;500;600;700;800&display=swap');

:root {
    /* Layouts & Breakpoint Variables */
    --container-wide-desktop: 1320px;
    --container-desktop: 1140px;
    --container-tablet: 960px;
    --container-mobile: 720px;
    --container-xsmall-mobile: 92vw;

    /* Typography Variables */
    /* Font Families */
    --font-headline: 'Bricolage Grotesque', serif;
    --font-body: 'Manrope', sans-serif;
    /* Font Weights */
    --font-weight-light: 200;
    --font-weight-regular: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --font-weight-extrabold: 800;
    /* Font Sizes */
    --font-size-xsmall: 12px;
    --font-size-small: 14px;
    --font-size-medium: 18px;
    --font-size-large: 24px;
    --font-size-xlarge: 32px;
    --font-size-xxlarge: 40px;
    --font-size-xxxlarge: 48px;
    /* line Heights */
    --line-height-small: 1.2;
    --line-height-medium: 1.5;
    --line-height-large: 1.6;
    --line-height-xlarge: 1.8;
    --line-height-xxlarge: 2;

    /* Colors Variables*/
    /* Neutral Colors */
    --color-white: #FFFFFF;
    --color-black: #000000;
    /* Blue Charcoal */
    --color-blue-charcoal-lightestest: #F5F6F7;
    --color-blue-charcoal-lightest: #E5E7E8;
    --color-blue-charcoal-lighter: #8C979F;
    --color-blue-charcoal-light: #4D595E;
    --color-blue-charcoal: #011219;
    --color-blue-charcoal-dark: #000E14;
    --color-blue-charcoal-darker: #00070A;
    --color-blue-charcoal-darkest: #000507;
    /* Web Orange */
    --color-web-orange-lightestest: #FFFBF2;
    --color-web-orange-lightest: #FFF6E5;
    --color-web-orange-lighter: #FFEDCC;
    --color-web-orange-light: #FFC04C;
    --color-web-orange: #FFA500;
    --color-web-orange-dark: #CC8400;
    --color-web-orange-darker: #664200;
    --color-web-orange-darkest: #4C3100;
    /* Apple Green */
    --color-apple-green-lightest: #EAFAEA;
    --color-apple-green-lighter: #D6F5D6;
    --color-apple-green-light: #6FDC6F;
    --color-apple-green: #32CD32;
    --color-apple-green-dark: #28A428;
    --color-apple-green-darker: #145214;
    --color-apple-green-darkest: #0F3D0F;
    /* Rose */
    --color-rose-pink-lightest: #FFE5EF;
    --color-rose-pink-lighter: #FFCCDF;
    --color-rose-pink-light: #FF4C91;
    --color-rose-pink: #FF0062;
    --color-rose-pink-dark: ##CC004E;
    --color-rose-pink-darker: #660027;
    --color-rose-pink-darkest: #4C001D;
    /* Fuchsia Pink */
    --color-fuchsia-pink-lightest: #FAECFA;
    --color-fuchsia-pink-lighter: #F5DAF5;
    --color-fuchsia-pink-light: #DE7DDC;
    --color-fuchsia-pink: #D046CE;
    --color-fuchsia-pink-dark: #A638A4;
    --color-fuchsia-pink-darker: #531C52;
    --color-fuchsia-pink-darkest: #3E153D;

    /* Spacing & Feelings */
    --spacing-xxxsmall: 4px;
    --spacing-xxsmall: 6px;
    --spacing-xsmall: 12px;
    --spacing-small: 16px;
    --spacing-medium: 24px;
    --spacing-large: 32px;
    --spacing-xlarge: 48px;
    --spacing-xxlarge: 64px;
    --spacing-xxxlarge: 80px;
    --spacing-xxxxlarge: 96px;

    /* Border Radius */
    --border-radius-none: 0;
    --border-radius-xsmall: 2px;
    --border-radius-small: 4px;
    --border-radius-medium: 8px;
    --border-radius-large: 12px;
    --border-radius-xlarge: 16px;

    /* Animations & Transitions */
}


/* Global Styles */
*,
*::before,
*::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html,
body {
    font-family: var(--font-body);
    font-size: var(--font-size-medium);
    line-height: var(--line-height-medium);
    color: var(--color-blue-charcoal);
}

body {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

main {
    flex: 1 0 auto;
}

section {
    width: 100%;
}


.container {
    width: var(--container-wide-desktop);
    margin: 0 auto;
}

.content {
    width: 100%;
    height: 100%;
}

.terms-content {
    max-width: 1200px;
    margin: 0 auto;
}

.terms-content h1,
.terms-content h2,
.terms-content h3,
p {
    margin: var(--spacing-xxsmall) 0;
    line-height: var(--line-height-large);
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: var(--font-headline);
    font-weight: var(--font-weight-bold);
    color: var(--color-blue-charcoal);
}

h1 {
    font-size: var(--font-size-xxxlarge);
    line-height: var(--line-height-small);
}

ul li {
    list-style: none;
    display: inline-block;
}

button {
    display: inline-block;
    background-color: var(--color-apple-green);
    color: var(--color-white);
    font-size: var(--font-size-medium);
    font-weight: var(--font-weight-medium);
    padding: var(--spacing-small) var(--spacing-medium);
    border-radius: var(--border-radius-medium);
    text-decoration: none;
    border: none;
}

hr {
    border: none;
    border-top: 1px solid var(--color-web-orange-lighter);
}

.cta-button-primary {
    display: inline-block;
    background-color: var(--color-apple-green);
    color: var(--color-white);
    font-weight: var(--font-weight-medium);
    padding: var(--spacing-small) var(--spacing-medium);
    border-radius: var(--border-radius-medium);
    text-decoration: none;
}

.cta-button-primary:hover {
    background-color: var(--color-apple-green-dark);
    position: relative;
}

.cta-button-full-width {
    width: 100%;
    text-align: center;
}

/* Content Grids */
.grid-2col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-large);
}

.grid-2col-equal {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-large);
}

.grid-2col-car-page {
    display: grid;
    grid-template-columns: 1.5fr 1fr;
    grid-template-rows: auto;
    gap: var(--spacing-large);
    align-items: start;
}

.grid-2col-auto {
    display: grid;
    grid-template-columns: auto auto;
    gap: var(--spacing-large);
}

.grid-3col {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: var(--spacing-large);
}

.grid-3col-cars {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: var(--spacing-large);
}

.grid-3col-auto {
    display: grid;
    grid-template-columns: auto auto auto;
    gap: var(--spacing-large);
}

.grid-3col-header {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: var(--spacing-large);
}

.align-items-center {
    align-items: center;
}

.justify-content-start {
    justify-content: start;
}

.justify-content-end {
    justify-content: end;
}

.section-spacing {
    padding: var(--spacing-xxxxlarge) 0;
}

.title {
    width: 60%;
    margin-bottom: var(--spacing-xlarge);
}

.title .subtitle {
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-semibold);
    color: var(--color-blue-charcoal-light);
}

.title h2 {
    margin: var(--spacing-small) 0;
}

.icon {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    display: flex !important;
    align-items: center;
    justify-content: center;
    color: var(--color-white);
}

.icon-small {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    display: flex !important;
    align-items: center;
    justify-content: center;
    color: var(--color-white);
}

.icon-apple-green {
    background-color: var(--color-apple-green);
}

.icon-web-orange {
    background-color: var(--color-web-orange);
}

.icon-rose-pink {
    background-color: var(--color-rose-pink);
}

.icon-fuchsia-pink {
    background-color: var(--color-fuchsia-pink);
}

.icon-charcoal-light {
    background-color: var(--color-blue-charcoal-lighter);
}

/* Cards */

.card-top-green {
    border-top: 8px solid var(--color-apple-green-light) !important;
}

.card-top-orange {
    border-top: 8px solid var(--color-web-orange-light) !important;
}

.card-top-pink {
    border-top: 8px solid var(--color-rose-pink-light) !important;
}

.card-top-fuchsia {
    border-top: 8px solid var(--color-fuchsia-pink-light) !important;
}

/* Review Card */

.review-card {
    background-color: var(--color-web-orange-lightestest);
    border-radius: var(--border-radius-large);
    border: 1px solid var(--color-web-orange-lighter);
    padding: var(--spacing-large);
}

.review-card .review-stars {
    color: var(--color-web-orange);
    font-variation-settings:
        'FILL' 1,
        'wght' 700,
        'GRAD' 0,
        'opsz' 24;
}

.review-card p {
    font-size: var(--font-size-medium);
    line-height: var(--line-height-large);
    margin: var(--spacing-medium) 0;
}

.review-card .author {
    display: block;
    font-weight: var(--font-weight-semibold);
    font-size: var(--font-size-medium);
}

.review-card .author-status {
    display: inline-block;
    font-size: var(--font-size-small);
    color: var(--color-blue-charcoal-light);
}

/* Car Forms */

/* Fleet Form */
.form-group {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xsmall);
}

.form-group label {
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-semibold);
    color: var(--color-blue-charcoal);
    margin-bottom: var(--spacing-xxsmall);
}

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="date"],
input[type="time"],
input[type="number"],
select,
textarea {
    padding: var(--spacing-small) var(--spacing-medium);
    border: 1px solid var(--color-blue-charcoal-lightest);
    border-radius: var(--border-radius-medium);
    font-size: var(--font-size-medium);
    font-family: var(--font-body);
    color: var(--color-blue-charcoal);
    background-color: var(--color-white);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    width: 100%;
    box-sizing: border-box;
    height: 59px;
    -webkit-appearance: none;
    appearance: none;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="date"]:focus,
input[type="time"]:focus,
input[type="number"]:focus,
select:focus,
textarea:focus {
    outline: none;
    border: 3px solid;
    border-color: var(--color-web-orange);
}

input[type="text"]:hover,
input[type="email"]:hover,
input[type="tel"]:hover,
input[type="date"]:hover,
input[type="time"]:hover,
input[type="number"]:hover,
select:hover,
textarea:hover {
    border: 3px solid;
    border-color: var(--color-web-orange);
}

/* Select Dropdown Styling */
select {
    appearance: none;
    background-position: right var(--spacing-small) center;
    background-repeat: no-repeat;
    background-size: 16px;
    padding-right: var(--spacing-xlarge);
}

select option {
    padding: var(--spacing-small);
    font-size: var(--font-size-medium);
}

/* Textarea Specific */
textarea {
    min-height: 120px;
    resize: vertical;
}

/* Form Button Alignment */
.form-group-button {
    justify-content: flex-end;
}

.form-group-button .cta-button-primary {
    white-space: nowrap;
}

/* Checkbox Form Group */
.form-group-checkbox {
    flex-direction: row;
    align-items: start;
    gap: 10px;
    margin-top: 15px;
}

.form-group-checkbox input[type="checkbox"] {
    width: auto;
    height: 20px;
    margin-top: 2px;
}

.form-group-checkbox label {
    margin-bottom: 0;
    font-weight: normal;
    font-size: var(--font-size-medium);
    line-height: 1.4;
}

/* Validation Styling */
.form-group label span.required {
    color: var(--color-rose-pink);
}

.error-message {
    color: var(--color-rose-pink);
    font-size: var(--font-size-small);
    margin-top: 4px;
    display: none;
}

.form-group.error input {
    border-color: var(--color-rose-pink) !important;
}

.form-group.error .error-message {
    display: block;
}


/* Car Cards */

.car-card {
    background: var(--color-web-orange-lightestest);
    background: radial-gradient(circle at center 65%, var(--color-white) 10%, var(--color-web-orange-lightestest) 100%);
    border-radius: var(--border-radius-large);
    border: 1px solid var(--color-web-orange-lighter);
    padding: var(--spacing-medium);
}

.car-card:hover {
    background: var(--color-web-orange-lightest);
    background: radial-gradient(circle at center 65%, var(--color-white) 10%, var(--color-web-orange-lightest) 60%, var(--color-web-orange-lighter) 100%);
    border: 1px solid var(--color-web-orange-light);
}

.car-card .badges {
    margin-bottom: var(--spacing-xsmall);
}

.car-card .badges .badge {
    color: var(--color-white);
    padding: var(--spacing-xxsmall) var(--spacing-xsmall);
    border-radius: var(--border-radius-medium);
    font-size: var(--font-size-xsmall);
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
}

.car-card .badges .badge-orange {
    background-color: var(--color-web-orange);
}

.car-card .badges .badge-green {
    background-color: var(--color-apple-green);
}

.car-card .badges .badge-pink {
    background-color: var(--color-rose-pink);
}

.car-card .badges .badge-fuchsia {
    background-color: var(--color-fuchsia-pink);
}

.car-card .car-header h4 {
    font-size: var(--font-size-large);
    font-weight: var(--font-weight-semibold);
}

.car-card .car-header h4 .car-year {
    color: var(--color-blue-charcoal-light);
    font-weight: var(--font-weight-light);
}

.car-card .car-header .car-description {
    font-size: var(--font-size-small);
}

.car-card .car-specs {
    display: flex;
    gap: var(--spacing-xxsmall);
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-semibold);
    margin: var(--spacing-xxsmall) 0;
}

.car-card .car-specs .spec-item {
    background: #E5E7E899;
    backdrop-filter: blur(10px);
    border: 1px solid var(--color-blue-charcoal-lightest);
    border-radius: 20px;
    padding: var(--spacing-xxsmall) var(--spacing-xsmall);
}

.car-card .car-specs .spec-item .car-spec-icon {
    font-size: var(--font-size-small);
    position: relative;
    top: 2px;
    font-variation-settings:
        'FILL' 1,
        'wght' 700,
        'GRAD' 0,
        'opsz' 24;
}

.car-card .car-image {
    margin: var(--spacing-medium) 0;
}

.car-card .car-image img {
    width: 100%;
}

.car-card .car-benefits {
    display: flex;
    gap: var(--spacing-xsmall);
    font-size: var(--font-size-small);
}

.car-card .car-benefits .car-benefit .car-benefit-icon {
    font-size: var(--font-size-small);
    color: var(--color-apple-green);
    position: relative;
    top: 2px;
    font-variation-settings:
        'FILL' 0,
        'wght' 700,
        'GRAD' 0,
        'opsz' 12;
}

.car-card .car-footer {
    margin-top: var(--spacing-small);
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--spacing-xsmall);
    align-items: center;
    justify-content: space-between;
}

.car-card .car-footer .car-price .daily-price {
    font-size: var(--font-size-medium);
    font-weight: var(--font-weight-bold);
}

.car-card .car-footer .car-price .daily-price-digits {
    font-size: var(--font-size-xlarge);
}

.car-card .car-footer .car-price .total-price {
    font-size: var(--font-size-small);
    color: var(--color-blue-charcoal-light);
    font-weight: var(--font-weight-regular);
}

/* Components */

header {
    background-color: var(--color-white);
    padding: 0px;
    width: 100%;
    height: 80px;
    position: fixed;
    box-shadow: 0 0 4px 0 rgba(0, 0, 0, 0.05);
    z-index: 1000;
    display: flex;
    align-items: center;
}

header .content {
    height: 80px;
}

header .header-content {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-large);
}

header .logo {
    height: 40px;
}

header .logo img {
    height: 32px;
    position: relative;
    top: 4px;
    object-fit: contain;
}

header nav {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    margin-left: auto;
}

header nav ul {
    display: flex;
    align-items: center;
    gap: var(--spacing-medium);
}

header nav li {
    font-weight: var(--font-weight-medium);
}

nav li a {
    text-decoration: none;
    color: var(--color-blue-charcoal);
}

nav li a:hover {
    color: var(--color-blue-charcoal-light);
}

main {
    padding-top: 80px;
}

.hero {
    background-color: var(--color-web-orange-lighter);
    padding: var(--spacing-xxxlarge) 0;
}

.hero .hero-content-top {
    padding: var(--spacing-large) 0;
}

.hero .hero-content-top .hero-content-right p {
    margin-bottom: var(--spacing-large);
}

.hero .hero-content-bottom {
    width: 100%;
    margin: var(--spacing-large) 0;
    border-radius: var(--border-radius-small);
    overflow: hidden;
}

.hero .hero-content-bottom img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: var(--border-radius-small);
}

.benefits .items .item {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-column-gap: var(--spacing-small);
    grid-row-gap: var(--spacing-xxsmall);
}

.benefits .items .item .icon {
    grid-row-start: 1;
    grid-row-end: 3;
}

.stats {
    background: var(--color-web-orange-lightestest);
}

.stats .items .item {
    border-radius: var(--border-radius-medium);
    background: var(--color-white);
    padding: var(--spacing-medium);
}

.stats .items .item h3 {
    font-size: var(--font-size-xxlarge);
}

footer {
    background-color: var(--color-blue-charcoal);
    color: var(--color-blue-charcoal-lighter);
}

footer a {
    color: var(--color-blue-charcoal-lighter);
    text-decoration: none;
}

footer a:hover {
    color: var(--color-white);
}

footer .footer-top {
    justify-content: space-between;
    gap: var(--spacing-large);
    align-items: flex-start;
}

footer .footer-top .logo img {
    height: 32px;
    filter: brightness(0) invert(80%);
    margin-bottom: var(--spacing-medium);
}

footer .footer-top .links {
    display: flex;
    justify-content: center;
}

footer .footer-top .links ul {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-xsmall);
    justify-content: center;
}

footer .footer-top .links a {
    margin: var(--spacing-xsmall);
    ;
}

footer .footer-top .social {
    display: flex;
    justify-content: flex-end;
    gap: var(--spacing-medium);
}

footer .footer-top .social ul {
    display: flex;
    align-items: center;
    gap: var(--spacing-medium);
}

footer .footer-top .social a {
    margin-left: var(--spacing-medium);
    opacity: 0.8;
}

footer .footer-top .social a:hover {
    opacity: 1;
}

footer .footer-bottom {
    border-top: 1px solid #ffffff22;
    padding-top: var(--spacing-medium);
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: var(--font-size-small);
}

footer .footer-bottom ul {
    display: flex;
    gap: var(--spacing-small);
}

footer .footer-bottom a {
    margin-left: var(--spacing-medium);
}

/* Fleet Hero Section */

.fleet-hero {
    background-color: var(--color-web-orange-lightest);
}

.fleet-search-form {
    background: var(--color-white);
    border-radius: var(--border-radius-large);
    padding: var(--spacing-large);
    box-shadow: 0 20px 50px rgba(1, 18, 25, 0.04);
}

.fleet-form-fields {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr auto;
    gap: var(--spacing-medium);
    align-items: end;
}

.fleet-form .form-group label {
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-medium);
    color: var(--color-blue-charcoal-light);
    margin-bottom: var(--spacing-xsmall);
    display: inline-block;
}

.fleet-form .form-group select,
.fleet-form .form-group input {
    width: 100%;
    padding: var(--spacing-small);
    border-radius: var(--border-radius-medium);
    border: 1px solid var(--color-blue-charcoal-lightest);
    font-size: var(--font-size-medium);
    background-color: var(--color-blue-charcoal-lightestest);
}

.fleet-form .form-group select:focus,
.fleet-form .form-group input:focus {
    outline: none;
    border-color: var(--color-apple-green);
    box-shadow: 0 0 0 3px rgba(50, 205, 50, 0.15);
}

.fleet-form .form-group-button {
    align-self: stretch;
    display: flex;
    justify-content: flex-end;
    align-items: flex-end;
}

.fleet-form .form-group-button .cta-button-primary {
    width: 100%;
    text-align: center;
}

.car-details-page {
    background-color: var(--color-web-orange-lightestest);
    padding-bottom: var(--spacing-xxxxlarge);
}

.breadcrumb {
    margin: var(--spacing-medium) 0;
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-bold);
}

.breadcrumb a {
    color: var(--color-blue-charcoal-light);
}

.breadcrumb a:hover {
    color: var(--color-blue-charcoal);
}

.car-details .car-title {
    margin-bottom: var(--spacing-medium);
}

.car-details .car-title .car-year {
    color: var(--color-blue-charcoal-light);
    font-weight: var(--font-weight-regular);
}

.car-details .car-gallery {
    border-radius: var(--border-radius-large);
    height: auto;
    overflow: hidden;
}

.car-details .car-gallery .main-image,
.car-details .car-gallery .main-image img {
    width: 100%;
    border-radius: var(--border-radius-large);
}

.car-details .booking-info {
    grid-column: 2;
    grid-row: 1 / span 2;
    background-color: var(--color-white);
    border-radius: var(--border-radius-large);
    border: 1px solid var(--color-web-orange-lighter);
    overflow: hidden;
}

.car-details .booking-info .booking-padding {
    padding: var(--spacing-medium);
}

.car-details .booking-info .booking-price {
    display: flex;
    flex-direction: column;
}

.car-details .booking-info .booking-price .total-price {
    font-size: var(--font-size-xlarge);
    font-weight: var(--font-weight-bold);
}

.car-details .booking-info .booking-price .daily-price {
    font-size: var(--font-size-medium);
    font-weight: var(--font-weight-regular);
}

.car-details .booking-info .booking-price .booking-badges {
    display: flex;
    gap: var(--spacing-xxsmall);
    margin-top: var(--spacing-xsmall);
}

.car-details .booking-info .booking-price .booking-badges .badge {
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-regular);
    padding: var(--spacing-xxxsmall) var(--spacing-xsmall);
    border-radius: var(--border-radius-medium);
}

.car-details .booking-info .booking-price .booking-badges .badge-orange {
    background-color: var(--color-web-orange-lighter);
}

.car-details .booking-info .booking-price .booking-badges .badge-green {
    background-color: var(--color-apple-green-lighter);
}

.car-details .booking-info .booking-price .booking-badges .badge-pink {
    background-color: var(--color-rose-pink-lighter);
}

.car-details .booking-info .booking-details .booking-details-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.car-details .booking-info .booking-details .booking-details-form {
    margin: var(--spacing-xsmall) 0;
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-semibold);

}

.car-details .booking-info .booking-details .form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    margin-bottom: var(--spacing-small);
    gap: var(--spacing-xsmall);
}

.car-details .booking-info .booking-details .reservation-button {
    margin-top: var(--spacing-xsmall);
}

.information-card p {
    font-size: var(--font-size-small);
    margin-bottom: var(--spacing-small);
}

.car-details .booking-info .payment-options {
    display: flex;
    font-size: var(--font-size-small);
    background-color: var(--color-web-orange-lightest);
    align-items: center;
    justify-content: center;
    gap: var(--spacing-medium);
}

.car-details .booking-info .payment-options .payment-option {
    height: 22px;
}

.car-details .booking-info .payment-options .payment-option img {
    height: 100%;
}

.car-details .car-description {
    background-color: var(--color-white);
    border-radius: var(--border-radius-large);
    padding: var(--spacing-medium);
}

.car-details .car-description .car-specifications {
    margin-bottom: var(--spacing-medium);
}

.car-details .car-description .car-features .car-features-list {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: var(--spacing-medium);
    margin-top: var(--spacing-medium);
}

.car-details .car-description .car-features .car-features-list .feature-item {
    display: grid;
    grid-template-columns: 32px auto;
    align-items: center;
    justify-content: start;
    gap: var(--spacing-xsmall);
}

.car-details .car-description .car-features .car-features-list .feature-item .feature-icon {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.car-details .car-description .car-features .car-features-list .feature-item .feature-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.car-details .car-description .car-features .car-features-list .feature-item .feature-details .feature-label {
    display: block;
    margin-bottom: -6px;
    font-size: var(--font-size-xsmall);
    color: var(--color-blue-charcoal-light);
    font-weight: var(--font-weight-medium);
    text-transform: uppercase;
}

.car-details .car-description .car-features .car-features-list .feature-item .feature-details .feature-text {
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-medium);
}

/* Booking Page */
.car-booking-page {
    background-color: var(--color-web-orange-lightestest);
}

.car-booking-page .car-booking-form .form-group {
    margin-bottom: 16px;
}

.car-booking-page .car-booking-form .form-group label {
    margin-bottom: -8px !important;
}

.car-booking-page .booking-info {
    background-color: var(--color-white);
    border-radius: var(--border-radius-large);
    border: 1px solid var(--color-web-orange-lighter);
    overflow: hidden;
    padding: var(--spacing-medium);
}

.car-booking-page .booking-info .car-info {
    display: grid;
    grid-template-columns: 140px 1fr;
    grid-column-gap: 24px;
}

.car-booking-page .booking-info .car-info .car-image-small {
    width: 100%;
    align-self: center;
    display: flex;
    align-items: center;
    justify-content: center;
}

.car-booking-page .booking-info .car-info .car-image-small img {
    width: 100%;
}

.car-booking-page .booking-info .car-info .car-booking-name {
    align-self: center;
}

.car-booking-page .booking-info .car-info .car-booking-name h3 {
    font-size: var(--font-size-large);
}

.car-booking-page .booking-info .car-info .car-booking-name p {
    margin: 0;
}

.car-booking-page .booking-info .booking-details {
    display: grid;
    grid-template-columns: 48px auto;
    row-gap: 16px;
    column-gap: 24px;
    padding: 16px 0px;
}

.car-booking-page .booking-info .booking-details p {
    padding: 0px;
    margin: 0px;
}

.car-booking-page .booking-info .booking-details .pickup-icon,
.car-booking-page .booking-info .booking-details .dropoff-icon {
    align-self: center;
}

.car-booking-page .booking-info .booking-checklist {
    padding: 12px 0px;
}

.car-booking-page .booking-info .booking-checklist .checklist-item {
    display: grid;
    grid-template-columns: 22px auto;
    column-gap: 8px;
}

.car-booking-page .booking-info .booking-checklist .checklist-item p {
    color: var(--color-blue-charcoal-light);
}

.car-booking-page .booking-info .booking-checklist .checklist-item img {
    position: relative;
    top: 10px;
}

/* Success Page */
.success-page {
    background-color: var(--color-web-orange-lightestest);
}


/* Responsive Design */

/* Extra small devices & mobile phones */
@media only screen and (max-width: 767px) {
    
    /* Update Variables for Mobile */
    :root {
         /* Font Sizes */
        --font-size-xsmall: 12px;
        --font-size-small: 14px;
        --font-size-medium: 16px;
        --font-size-large: 20px;
        --font-size-xlarge: 24px;
        --font-size-xxlarge: 28px;
        --font-size-xxxlarge: 32px;
        
        /* Spacing & Feelings */
        --spacing-xxxsmall: 4px;
        --spacing-xxsmall: 6px;
        --spacing-xsmall: 12px;
        --spacing-small: 16px;
        --spacing-medium: 20px;
        --spacing-large: 22px;
        --spacing-xlarge: 24px;
        --spacing-xxlarge: 28px;
        --spacing-xxxlarge: 32px;
        --spacing-xxxxlarge: 64px;

        /* Border Radius */
        --border-radius-none: 0;
        --border-radius-xsmall: 2px;
        --border-radius-small: 4px;
        --border-radius-medium: 8px;
        --border-radius-large: 12px;
        --border-radius-xlarge: 16px;
    }

    .desktop-only {
        display: none !important;
    }
    
    .mobile-only {
        display: block;
        background: var(--color-white);
    }

    .mobile-col-header {
        display: grid;
        grid-template-columns: 1fr auto;
    }

    .container {
        width: var(--container-xsmall-mobile);
    }

    .title {
        width: 100%;
        margin-bottom: var(--spacing-xlarge);
    }

    .mobile-menu {
        display: none;
        background: var(--color-white);
        position: fixed;
        top: 80px;
        left: 0;
        width: 100vw;
        height: calc(100vh - 80px);
        z-index: 999;
        overflow-y: auto;
    }

    .mobile-menu nav {
        display: block;
        padding: 0px 24px;
        text-align: center;
    }

    .mobile-menu nav ul {
        display: block;
    }

    .mobile-menu nav ul li {
        display: list-item;
        margin: var(--spacing-xlarge) 0px;
    }

    .mobile-menu nav ul li a {
        font-size: var(--font-size-large);
    }

    .grid-2col, .grid-2col-equal, .grid-2col-car-page, .grid-2col-auto, .grid-3col, .grid-3col-cars, .grid-3col-auto, .fleet-form-fields {
        display: grid;
        grid-template-columns: 1fr;
    }

    .grid-2col-car-page .car-booking-summary {
        order: -1;
        margin-bottom: var(--spacing-medium);
    }

    /* Force hide on mobile */
    .car-booking-page .booking-info .booking-details,
    .car-booking-page .booking-info .booking-checklist {
        display: none !important;
    }

    .car-details .car-description .car-features .car-features-list {
        display: grid;
        grid-template-columns: 1fr;
        gap: var(--spacing-medium);
        margin-top: var(--spacing-medium);
    }

    .car-details .booking-info {
        grid-column: auto;
        grid-row: auto;
        background-color: var(--color-white);
        border-radius: var(--border-radius-large);
        border: 1px solid var(--color-web-orange-lighter);
        overflow: hidden;
    }

    .car-details .booking-info .booking-details .form-row {
        display: grid;
        grid-template-columns: 1fr;
        margin-bottom: var(--spacing-small);
        gap: var(--spacing-xsmall);
    }

    footer .footer-top {
        justify-content: space-between;
        gap: var(--spacing-large);
        text-align: center;
    }

    footer .footer-top .logo {
        text-align: center;
    }
    
    footer .footer-top .logo img {
        height: 32px;
        filter: brightness(0) invert(80%);
        margin-bottom: var(--spacing-medium);;
    }
    
    footer .footer-top .links {
        display: flex;
        justify-content: center;
    }
    
    footer .footer-top .links ul {
        display: flex;
        flex-wrap: wrap;
        gap: var(--spacing-xsmall);
        justify-content: center;
    }

    
    footer .footer-top .links a {
        margin: var(--spacing-xsmall);
        ;
    }
    
    footer .footer-top .social {
        display: flex;
        justify-content: center;
        gap: var(--spacing-medium);
        margin-bottom: var(--spacing-medium);
    }
    
    footer .footer-top .social ul {
        display: flex;
        align-items: center;
        gap: var(--spacing-medium);
    }
    
    footer .footer-top .social a {
        margin-left: var(--spacing-medium);
        opacity: 0.8;
    }
    
    footer .footer-top .social a:hover {
        opacity: 1;
    }
    
    footer .footer-bottom {
        border-top: 1px solid #ffffff22;
        padding-top: var(--spacing-large);
        display: grid;
        grid-template-columns: 1fr;
        text-align: center;
        font-size: var(--font-size-small);
    }

    footer .footer-bottom p {
        order: 1;
    }
    
    footer .footer-bottom ul {
        display: grid;
        grid-template-columns: 1fr;
        gap: var(--spacing-small);
    }
    
    footer .footer-bottom a {
        margin-left: var(--spacing-medium);
    }
}

/* Large Mobiles + Tablets */
@media only screen and (min-width: 768px) and (max-width: 991px) {
   
    /* Update Variables for Mobile */
    :root {
        /* Font Sizes */
        --font-size-xsmall: 12px;
        --font-size-small: 14px;
        --font-size-medium: 16px;
        --font-size-large: 20px;
        --font-size-xlarge: 26px;
        --font-size-xxlarge: 32px;
        --font-size-xxxlarge: 36px;
       
        /* Spacing & Feelings */
        --spacing-xxxsmall: 6px;
        --spacing-xxsmall: 8px;
        --spacing-xsmall: 12px;
        --spacing-small: 16px;
        --spacing-medium: 20px;
        --spacing-large: 22px;
        --spacing-xlarge: 24px;
        --spacing-xxlarge: 28px;
        --spacing-xxxlarge: 32px;
        --spacing-xxxxlarge: 64px;

        /* Border Radius */
        --border-radius-none: 0;
        --border-radius-xsmall: 2px;
        --border-radius-small: 4px;
        --border-radius-medium: 8px;
        --border-radius-large: 12px;
        --border-radius-xlarge: 16px;
    }

    .desktop-only {
        display: none;
    }
    
    .mobile-only {
        display: block;
        background: var(--color-white);
    }

    .mobile-col-header {
        display: grid;
        grid-template-columns: 1fr auto;
    }

    .container {
        width: var(--container-xsmall-mobile);
    }

    .title {
        width: 100%;
        margin-bottom: var(--spacing-xlarge);
    }

    .mobile-menu {
        display: none;
        background: var(--color-white);
        position: fixed;
        top: 80px;
        left: 0;
        width: 100vw;
        height: calc(100vh - 80px);
        z-index: 999;
        overflow-y: auto;
    }

    .mobile-menu nav {
        display: block;
        padding: 0px 24px;
        text-align: center;
    }

    .mobile-menu nav ul {
        display: block;
    }

    .mobile-menu nav ul li {
        display: list-item;
        margin: var(--spacing-xlarge) 0px;
    }

    .mobile-menu nav ul li a {
        font-size: var(--font-size-large);
    }

    .grid-2col, .grid-2col-equal, .grid-2col-car-page, .grid-2col-auto, .grid-3col, .grid-3col-auto {
        display: grid;
        grid-template-columns: 1fr;
    }

    .grid-2col-car-page .car-booking-summary {
        order: -1;
        margin-bottom: 0;
    }

    /* Force hide on tablet */
    .car-booking-page .booking-info .booking-details,
    .car-booking-page .booking-info .booking-checklist {
        display: none !important;
    }

    .grid-3col-cars, .fleet-form-fields {
        display: grid;
        grid-template-columns: 1fr 1fr;
    }

    .benefits .items .item {
        display: grid;
        grid-template-columns: auto 1fr;
        grid-column-gap: var(--spacing-small);
        grid-row-gap: var(--spacing-xxsmall);
    }

    .benefits .items .item p {
        margin: 0px;
    }

    .stats .items {
        display: grid;
        grid-template-columns: 1fr 1fr 1fr;
    }

    .form-group-button {
        grid-column: span 2;
    }

    .car-details .car-description .car-features .car-features-list {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: var(--spacing-medium);
        margin-top: var(--spacing-medium);
    }

    .car-details .booking-info {
        grid-column: auto;
        grid-row: auto;
        background-color: var(--color-white);
        border-radius: var(--border-radius-large);
        border: 1px solid var(--color-web-orange-lighter);
        overflow: hidden;
    }

    footer .footer-top {
        justify-content: space-between;
        gap: var(--spacing-large);
        text-align: center;
    }

    footer .footer-top .logo {
        text-align: center;
    }
    
    footer .footer-top .logo img {
        height: 32px;
        filter: brightness(0) invert(80%);
        margin-bottom: var(--spacing-medium);;
    }
    
    footer .footer-top .links {
        display: flex;
        justify-content: center;
    }
    
    footer .footer-top .links ul {
        display: flex;
        flex-wrap: wrap;
        gap: var(--spacing-xsmall);
        justify-content: center;
    }

    
    footer .footer-top .links a {
        margin: var(--spacing-xsmall);
        ;
    }
    
    footer .footer-top .social {
        display: flex;
        justify-content: center;
        gap: var(--spacing-medium);
        margin-bottom: var(--spacing-medium);
    }
    
    footer .footer-top .social ul {
        display: flex;
        align-items: center;
        gap: var(--spacing-medium);
    }
    
    footer .footer-top .social a {
        margin-left: var(--spacing-medium);
        opacity: 0.8;
    }
    
    footer .footer-top .social a:hover {
        opacity: 1;
    }
    
    footer .footer-bottom {
        border-top: 1px solid #ffffff22;
        padding-top: var(--spacing-large);
        display: grid;
        grid-template-columns: 1fr;
        text-align: center;
        font-size: var(--font-size-small);
    }

    footer .footer-bottom p {
        order: 1;
    }
    
    footer .footer-bottom ul {
        display: grid;
        grid-template-columns: 1fr;
        gap: var(--spacing-small);
    }
    
    footer .footer-bottom a {
        margin-left: var(--spacing-medium);
    }
}

/* Large Tablets & Laptops (992px - 1199px) */
@media only screen and (min-width: 992px) and (max-width: 1199px) {

    /* Update Variables for Laptops */
    :root {
        /* Font Sizes - Slightly smaller than large desktop, larger than tablet */
        --font-size-xsmall: 12px;
        --font-size-small: 14px;
        --font-size-medium: 16px;
        --font-size-large: 20px;
        --font-size-xlarge: 24px;
        --font-size-xxlarge: 32px;
        --font-size-xxxlarge: 40px;
       
        /* Spacing & Feelings */
        --spacing-xxxsmall: 4px;
        --spacing-xxsmall: 8px;
        --spacing-xsmall: 12px;
        --spacing-small: 16px;
        --spacing-medium: 24px;
        --spacing-large: 32px;
        --spacing-xlarge: 40px;
        --spacing-xxlarge: 56px;
        --spacing-xxxlarge: 72px;
        --spacing-xxxxlarge: 80px;

        /* Border Radius */
        --border-radius-none: 0;
        --border-radius-xsmall: 2px;
        --border-radius-small: 4px;
        --border-radius-medium: 8px;
        --border-radius-large: 12px;
        --border-radius-xlarge: 16px;
    }

    .desktop-only {
        display: block;
    }
    
    .mobile-only {
        display: none;
    }

    .container {
        width: var(--container-tablet); /* 960px */
    }

    .title {
        width: 100%;
        margin-bottom: var(--spacing-xlarge);
    }

    .mobile-menu {
        display: none !important;
    }
    
    /* Ensure Grids reset to multi-column if needed */
    .grid-2col, .grid-2col-equal, .grid-2col-car-page, .grid-2col-auto {
        grid-template-columns: repeat(2, 1fr);
    }

    .grid-2col-car-page .car-booking-summary {
        order: unset;
        margin-bottom: 0;
    }
    
    .grid-3col, .grid-3col-auto {
        grid-template-columns: repeat(3, 1fr);
    }

    .grid-3col-cars {
        grid-template-columns: repeat(2, 1fr);
    }

    .benefits .items .item {
        display: grid;
        grid-template-columns: auto 1fr;
        grid-column-gap: var(--spacing-small);
        grid-row-gap: var(--spacing-xxsmall);
    }

    .benefits .items .item p {
        margin: 0px;
    }

    .stats .items {
        display: grid;
        grid-template-columns: 1fr 1fr 1fr;
    }

    .form-group-button {
        grid-column: span 4;
    }

    .car-details .car-description .car-features .car-features-list {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: var(--spacing-medium);
        margin-top: var(--spacing-medium);
    }
}

/* Large Laptops & Desktops (1200px+) */
@media only screen and (min-width: 1200px) {
    
    /* Restore Variables for Desktop */
    :root {
        /* Font Sizes - Restoring to Default/Root values */
        --font-size-xsmall: 12px;
        --font-size-small: 14px;
        --font-size-medium: 18px; /* Back to 18px */
        --font-size-large: 24px;
        --font-size-xlarge: 32px;
        --font-size-xxlarge: 40px;
        --font-size-xxxlarge: 48px;
       
        /* Spacing & Feelings */
        --spacing-xxxsmall: 4px;
        --spacing-xxsmall: 6px;
        --spacing-xsmall: 12px;
        --spacing-small: 16px;
        --spacing-medium: 24px;
        --spacing-large: 32px;
        --spacing-xlarge: 48px;
        --spacing-xxlarge: 64px;
        --spacing-xxxlarge: 80px;
        --spacing-xxxxlarge: 96px;
    }

    .desktop-only {
        display: block;
    }
    
    .mobile-only {
        display: none;
    }

    .container {
        width: var(--container-desktop); /* 1140px */
    }
}

/* Ultrawide Laptops & Desktops (1400px+) */
@media only screen and (min-width: 1400px) {

    .desktop-only {
        display: block;
    }
    
    .mobile-only {
        display: none;
    }

    .container {
        width: var(--container-wide-desktop); /* 1320px */
    }
}