/* Imports */
@import url('open-iconic/font/css/open-iconic-bootstrap.min.css');
@import url('https://fonts.googleapis.com/css2?family=Noto+Color+Emoji&display=swap');


/* ===============================
   Design Tokens - All CSS Variables
   =============================== */
:root {
    /* Brand Colors */
    --brand-blue: var(--brand-blue);
    --brand-blue-light: var(--brand-blue-light);
    --brand-blue-dark: var(--brand-blue-dark);
    --brand-blue-hover: var(--brand-blue-hover);
    --brand-blue-50: #F2F6FF;
    --brand-gold: var(--brand-gold);
    --brand-border: #DFE3EE;
    --white: #ffffff;
    --text-dark: #333333;
    /* Status Colors */
    --cell-red: #d9534f;
    --cell-green: #5cb85c;
    --cell-yellow: #f0ad4e;
    --cell-grey: #dee2e6;
    /* Typography */
    --font-base: 'Montserrat', sans-serif;
    --heading-color: var(--brand-blue);
    /* Bootstrap Overrides */
    --bs-modal-color: var(--brand-gold);
    /* Field Sizing */
    --field-font-size: 16px; /* prevents iPhone zoom */
    --field-line: 1.45;
    --field-min-h: 56px; /* overall field height */
    --field-pad-x: 14px; /* left/right padding */
    --field-pad-top: 24px; /* top "label lane" */
    --field-pad-bot: 10px; /* bottom padding */
    --field-radius: 12px; /* border radius for fields & buttons */
    --chip-radius: 6px; /* border radius for small elements (chips, tags, labels) */
    /* Field Colors */
    --field-border: #ced4da;
    --field-focus: #86b7fe;
    --field-ring: rgba(13,110,253,.25);
    /* Label Sizing */
    --label-inside: 15px;
    --label-float: 12px;
    --label-float-top: 8px;
    /* Hints */
    --hint-color: var(--brand-blue);
    /* Radzen Dropdown Overrides */
    --rz-dropdown-item-padding: 3.75px 10px;
    --rz-dd-header-bg: var(--brand-blue-dark, #0a2b56);
    --rz-dd-header-fg: #fff;
    --rz-dd-header-radius: 10px;
    --rz-dd-header-pad: 1px 1px;
    --rz-dd-header-margin: 1px 6px;
    --rz-dd-header-font: .84rem;
}



/* ===============================
   Accessibility Utilities
   =============================== */

/* Screen reader only - visually hidden but accessible to assistive tech */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* Screen reader only but visible when focused (for skip links) */
.sr-only-focusable:focus,
.sr-only-focusable:focus-within {
    position: fixed;
    top: 10px;
    left: 10px;
    width: auto;
    height: auto;
    padding: 12px 20px;
    margin: 0;
    overflow: visible;
    clip: auto;
    white-space: normal;
    background: var(--brand-blue, #0a2b56);
    color: #fff;
    font-weight: 600;
    font-size: 1rem;
    text-decoration: none;
    border-radius: var(--field-radius, 12px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
    z-index: 9999;
}

.sr-only-focusable:focus:hover {
    background: var(--brand-blue-dark, #061a36);
}

/* Global styles */

html {
    font-family: var(--font-base);
    font-size: clamp(16px, 1.6vw, 18px); /* Responsive root font size */
    height: 100%;
    margin: 0;
    padding: 0;
    overflow-x: hidden;
    min-height: 100vh;
    height: auto;
}

body {
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
    padding-top: env(safe-area-inset-top);
    padding-bottom: env(safe-area-inset-bottom);
    font-size: inherit; /* Uses html font-size */
    line-height: 1.5;
    font-family: var(--font-base);
}

.page-wrapper {
    flex: 1 1 auto;
    width: 100%;
    max-width: 580px;
    margin: 0 auto;
    overflow-y: auto;
    box-sizing: border-box;
    padding: 0 5px;
}

/* Modals */
.airport-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.6);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 1100;
    height: 100%;
    overflow-y: auto;
}

/* Focus styling */
h1:focus {
    outline: none;
}

/* Links and buttons */
a,
.btn-link {
    color: var(--brand-blue-light);
}

.btn-primary {
    /*color: #fff;*/
    color: var(--white);
    background-color: var(--brand-blue);
    border: 0px solid var(--brand-blue);
    border-radius: 50px;
    font-weight: 400;
    transition: all 0.1s ease;
    padding: 9px 7px;
    min-width: 76px;
    font-size: 1.0rem;
}

    .btn-primary:hover {
        background-color: var(--brand-blue-dark);
        color: var(--brand-gold);
        border: 1px solid var(--brand-blue-dark);
    }

    .btn-primary:focus,
    .btn-primary:active,
    .btn-primary.active,
    .btn-primary:focus-visible {
        background-color: var(--brand-blue-dark) !important;
        border-color: var(--brand-blue-dark) !important;
        box-shadow: 0 0 0 0.2rem color-mix(in srgb, var(--brand-blue) 50%, transparent) !important;
    }

.btn-secondary {
    color: var(--brand-blue-dark);
    background-color: var(--white);
    border: 1px solid var(--brand-blue-dark);
    border-color: var(--brand-blue-dark);
    border-radius: 50px;
    font-weight: 400;
    transition: all 0.1s ease;
    padding: 9px 7px;
    min-width: 76px;
    font-size: 1.0rem;
}

    .btn-secondary:hover {
        background-color: var(--brand-gold);
        color: var(--brand-blue-dark);
        border: 1px solid var(--brand-blue-dark);
    }




/* Page content */
.content {
    padding-top: 1.1rem;
}

/* Remove top padding when navbar is first child - navbar should be flush to top */
.content:has(> .navbar:first-child),
.content:has(> #booking-page-container:first-child) {
    padding-top: 0;
}

/* Validation */
.valid.modified:not([type=checkbox]) {
    outline: 1px solid var(--brand-gold);
}

.invalid {
    outline: 1px solid var(--cell-red);
}

.validation-message {
    color: red;
}

/* Global checkbox and radio button styling - use brand color */
input[type="checkbox"],
input[type="radio"] {
    accent-color: var(--brand-blue);
}

/* Form check inputs (Bootstrap) */
.form-check-input:checked {
    background-color: var(--brand-blue);
    border-color: var(--brand-blue);
}

.form-check-input:focus {
    border-color: var(--brand-blue);
    box-shadow: 0 0 0 0.2rem color-mix(in srgb, var(--brand-blue) 25%, transparent);
}

.modal-title-display {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--brand-blue);
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

/* Error UI */
#blazor-error-ui {
    background: var(--cell-yellow);
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

    #blazor-error-ui .dismiss {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,...) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occurred.";
    }

/* Field separators */
.field-separator {
    border-bottom: 1px solid var(--cell-grey);
    padding-bottom: 1rem;
    padding-top: 1rem;
}

    .field-separator:last-of-type {
        border-bottom: none;
    }

/* Typography */
body, p, label, input, textarea, button {
    font-size: inherit;
}

h1 {
    font-size: 2rem; /* ~32px max */
}

h2 {
    font-size: 1.5rem; /* ~24px max */
}

h4 {
    font-size: 0.8rem; /* ~24px max */
}

small {
    font-size: 0.875rem; /* ~14px */
}

h1, h2, h3, h4, h5, h6 {
    color: var(--brand-blue-dark) !important;
    font-family: var(--font-base); /* e.g., Montserrat */
    font-weight: 600;
}

label, p {
    color: var(--brand-blue);
}

.section-frame .address-arrow {
    font-size: 24px !important;
    color: var(--brand-blue) !important;
    display: flex !important;
    align-items: center !important;
}

@media (max-width: 768px) {
    .section-frame .address-container {
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        width: 100% !important;
    }

    .section-frame .address-box {
        min-width: 0 !important;
        flex: 1 !important;
    }

    .section-frame .address-arrow {
        flex: 0 0 auto !important;
    }
}

.custom-submit-button {
    background-color: var(--brand-blue) !important;
    border-color: var(--brand-border) !important;
    color: white;
    text-align: center;
    min-width: 200px;
    padding: 10px 20px;
    font-size: 1.1rem;
    border-radius: 6px;
}

    .custom-submit-button:hover {
        /*        background-color: #3267d6;
        border-color: #3267d6;*/
        background-color: #ffffff;
        color: var(--brand-gold);
    }

    .custom-submit-button:focus {
        outline: none;
        box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.6), 0 0 0 7px var(--brand-gold), 0 0 20px rgba(201, 151, 58, 0.6);
    }

.home-top p.bookNow {
    float: right;
    font-size: 14px;
    font-size: 1.4rem;
    color: #ffffff;
    padding: 9px 7px;
    margin-left: 25px;
    text-align: center;
    min-width: 96px;
    border: 0px solid var(--brand-border);
    -webkit-border-radius: 50px;
    -moz-border-radius: 50px;
    border-radius: 50px;
    -moz-transition: all 0.1s ease;
    -webkit-transition: all 0.1s ease;
    transition: all 0.1s ease;
    background-color: var(--brand-gold);
    text-transform: none;
    font-weight: 400;
    letter-spacing: normal;
    line-height: normal;
}




.form-heading {
    font-weight: bold;
    font-size: 1.6rem;
    text-align: center;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    margin-bottom: 1rem;
}

.form-instructions {
    font-size: 1rem;
    color: #555;
    margin-bottom: 1.5rem;
    line-height: 1.5;
}

.styled-input {
    color: #333333;
    font-family: var(--font-base);
    font-size: 1rem;
    font-weight: 400;
    width: 100%;
    padding: 10px 12px;
    border: 1px solid #ccc;
    border-radius: 8px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    appearance: none; /* hides default arrow in some browsers */
    background-color: white;
    box-sizing: border-box;
}

    .styled-input::placeholder {
        color: var(--brand-blue); /* Or a specific hex like #999 */
        font-family: var(--font-base); /* e.g., 'Montserrat', sans-serif */
        font-size: 0.95rem;
        opacity: .7; /* Ensure it's not faded */
    }

.styled-button {
    background-color: var(--brand-gold);
    color: white;
    border: none;
    border-radius: 50px;
    padding: 12px 24px;
    font-size: 1.2rem;
    cursor: pointer;
    transition: background-color 0.2s ease;
}

    .styled-button:hover {
        background-color: #ffffff;
        color: var(--brand-gold);
    }

.styled-input:focus {
    outline: none;
    border-color: var(--brand-gold);
    box-shadow: 0 0 3px var(--brand-gold)66;
}


.styled-input option[disabled] {
    color: #888888;
    font-style: italic;
}

.centered-image {
    display: block;
    margin: 0 auto;
    width: 150px; /* or any fixed size */
    height: auto; /* maintain aspect ratio */
}

.text-blue {
    /*color: var(--brand-blue-dark);*/
    color: var(--brand-blue);
}

.text-gold {
    color: var(--brand-gold);
}

label.label-heading {
    font-size: 1.3rem; /* Slightly larger than normal labels */
    font-weight: 600; /* Bold but not fully heavy */
    color: var(--brand-gold); /* Gold color from the PDF */
    display: block; /* Ensure block layout */
    margin-bottom: 0.25rem;
    margin-top: 1rem;
}

.styled-input {
    color: var(--brand-blue-dark);
}

textarea.styled-input {
    color: var(--brand-blue-dark);
    font-family: var(--font-base);
    font-size: 1rem;
}

.flag-emoji {
    /*don't change this font its for the flags*/
    font-family: "Noto Color Emoji", "Segoe UI Emoji", "Arial", sans-serif;
    font-size: 1.1em; /* Reduced from 1.2em */
    margin-right: 4px;
    display: inline-block;
    width: 22px; /* Reduced from 24px */
    text-align: center;
    line-height: 1;
}


label.smaller-label-heading {
    font-size: 1rem;
    font-weight: 600; /* Bold but not fully heavy */
    color: var(--brand-gold); /* Gold color from the PDF */
    display: block; /* Ensure block layout */
    margin-bottom: 0.25rem;
    margin-top: 1rem;
}

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
textarea:-webkit-autofill,
textarea:-webkit-autofill:hover,
textarea:-webkit-autofill:focus,
select:-webkit-autofill {
    -webkit-box-shadow: 0 0 0px 1000px #fff inset !important;
    -webkit-text-fill-color: black !important;
    background-color: var(--white) !important;
    transition: background-color 9999s ease-out, color 9999s ease-out;
}

/* Override Bootstrap's px-4 */
.px-4 {
    padding-left: 0.25rem !important; /* half of original */
    padding-right: 0.25rem !important;
}


/*new css for floating entry fields*/

/* === Floating label system === */

.float-field {
    position: relative;
    margin-bottom: 22px; /* space between fields */
}

.float-input.form-control {
    height: auto !important; /* kill Bootstrap�s fixed height */
    min-height: 56px; /* adjust as needed */
    max-height: 56px;
    padding: 30px 14px 12px 14px; /* room at top for label */
    font-size: 16px; /* avoids iPhone zoom */
    line-height: 1.45;
    box-sizing: border-box;
}

    .float-input.form-control::placeholder {
        color: #666; /* faint gray placeholder text */
        opacity: 0.6;
    }

.float-label {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    font-size: 15px;
    background: #fff;
    padding: 0 2px;
    transition: top .18s, font-size .18s, transform .18s, opacity .18s;
    opacity: .92;
}

.float-input:focus + .float-label,
.float-field.has-value .float-label {
    top: 8px;
    transform: none;
    font-size: 12px;
    opacity: .85;
}

textarea.float-input {
    min-height: 120px;
    padding-top: 38px;
}


/* === Global Floating Labels === */
/* Field sizing variables moved to top of file */


/* Wrapper */
.float-field {
    position: relative;
    margin-bottom: 22px;
}


/* Textareas (optional) */
textarea.float-input {
    min-height: 120px;
    padding-top: calc(var(--field-pad-top) + 8px);
}

/* Inputs: defeat Bootstrap height calc and create label lane */
.float-input.form-control {
    height: auto !important;
    min-height: var(--field-min-h);
    padding: var(--field-pad-top) var(--field-pad-x) var(--field-pad-bot) var(--field-pad-x);
    font-size: var(--field-font-size);
    line-height: var(--field-line);
    border: 1px solid var(--field-border) !important;
    border-radius: var(--field-radius);
    background: #fff;
    box-sizing: border-box;
}

    .float-input.form-control::placeholder {
        color: #666;
        opacity: 0.6;
    }

/* Label */
.float-label {
    position: absolute;
    left: var(--field-pad-x);
    top: 50%;
    transform: translateY(-50%);
    font-size: var(--label-inside);
    background: #fff;
    padding: 0 2px;
    pointer-events: none;
    opacity: .92;
    transition: top .18s,font-size .18s,transform .18s,opacity .18s;
}

/* Float on focus or when wrapper has value */
.float-input:focus + .float-label,
.float-field.has-value .float-label,
.float-field:focus-within .float-label {
    top: var(--label-float-top);
    transform: none;
    font-size: var(--label-float);
    opacity: .85;
}

/* Focus ring (Bootstrap-like) */
.float-input.form-control:focus {
    border-color: var(--field-focus) !important;
    box-shadow: 0 0 0 .25rem var(--field-ring) !important;
    outline: 0;
}

/* Always-float variant (pin label at top-left) */
.float-field.always-float .float-label {
    top: var(--label-float-top);
    transform: none;
    font-size: var(--label-float);
    opacity: .85;
}

/* Country selector styled like an input (shared across components) */
.float-field .selected-country,
.float-field .selected-picker {
    min-height: var(--field-min-h);
    padding: 0 var(--field-pad-x);
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: var(--field-font-size);
    line-height: var(--field-line);
    border: 1px solid var(--brand-border) !important;
    border-radius: var(--field-radius);
    background: #fff;
    box-sizing: border-box;
    cursor: pointer;
    position: relative;
    z-index: 1;
}
/* =========================
   Global Floating Labels
   ========================= */

/* Field sizing variables moved to top of file */

/* Wrapper around each floating field */
.float-field {
    position: relative;
    margin-bottom: 22px;
}

/* Inputs styled for floating labels
   - Disable Bootstrap's fixed height calc
   - Create a top "lane" for the label
*/
.float-input.form-control {
    height: auto !important;
    min-height: var(--field-min-h);
    padding: var(--field-pad-top) var(--field-pad-x) var(--field-pad-bot) var(--field-pad-x);
    font-size: var(--field-font-size);
    line-height: var(--field-line);
    border: 1px solid var(--field-border) !important;
    border-radius: var(--field-radius);
    background: #fff;
    box-sizing: border-box;
}

    /* Hide literal placeholder text (label is the hint) */
    .float-input.form-control::placeholder {
        color: #666;
        opacity: 0.6;
    }

/* The label that lives inside the field */
.float-label {
    position: absolute;
    left: var(--field-pad-x);
    top: 50%;
    transform: translateY(-50%);
    font-size: var(--label-inside);
    background: #fff; /* prevents visual clash with border */
    padding: 0 2px;
    pointer-events: none;
    opacity: .92;
    transition: top .18s ease, font-size .18s ease, transform .18s ease, opacity .18s ease;
    z-index: 2; /* sit above input/selector */
}

/* Float the label when focused or when wrapper indicates it has a value */
.float-input:focus + .float-label,
.float-field.has-value .float-label,
.float-field:focus-within .float-label {
    top: var(--label-float-top);
    transform: none;
    font-size: var(--label-float);
    opacity: .85;
}

/* Focus ring that matches Bootstrap .form-control:focus */
.float-input.form-control:focus {
    border-color: var(--field-focus) !important;
    box-shadow: 0 0 0 .25rem var(--field-ring) !important;
    outline: 0;
}

/* Always-float variant (pin label at top-left even with default value) */
.float-field.always-float .float-label {
    top: var(--label-float-top);
    transform: none;
    font-size: var(--label-float);
    opacity: .85;
}

/* =========================
   Country selector (div) styled like input
   ========================= */

.float-field .selected-country {
    position: relative;
    z-index: 1;
    min-height: var(--field-min-h);
    padding: 0 var(--field-pad-x);
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: var(--field-font-size);
    line-height: var(--field-line);
    border: 1px solid var(--field-border) !important;
    border-radius: var(--field-radius);
    background: #fff;
    box-sizing: border-box;
    cursor: pointer;
}

.float-field:focus-within .selected-country,
.float-field:focus-within .selected-picker {
    border-color: var(--field-focus) !important;
    box-shadow: 0 0 0 .25rem var(--field-ring) !important;
    outline: 0;
}

.selected-country .flag-emoji {
    margin-right: 6px;
    margin-top: 10px;
}

.selected-country .dial-code {
    flex: 1;
    margin-top: 10px;
}

.selected-country .chevron {
    font-size: 12px;
    margin-left: 6px;
    color: #666;
    margin-top: 10px;
}

/* =========================
   Textareas (optional)
   ========================= */
textarea.float-input {
    min-height: 120px;
    padding-top: calc(var(--field-pad-top) + 8px);
}

/* =========================
   Mobile compact tweaks
   ========================= */
@media (max-width: 420px) {
    :root {
        --field-pad-x: 10px;
        --field-pad-top: 20px;
        --field-pad-bot: 8px;
        --field-min-h: 56px; /* still >44px for comfortable taps */
    }

    .float-field {
        margin-bottom: 14px;
    }
}

.selected-picker .picker-value {
    flex: 1;
}

.selected-picker .chevron {
    font-size: 12px;
    margin-left: 6px;
    color: #666;
}

/* Give pickers the same top padding as inputs so the label has a lane */
.float-field .selected-picker,
.float-field .selected-country {
    padding: var(--field-pad-top) var(--field-pad-x) var(--field-pad-bot) var(--field-pad-x);
    min-height: var(--field-min-h);
    display: flex;
    align-items: center; /* keep text vertically pleasant */
    box-sizing: border-box;
}

/* Ensure the label stays above the picker panel */
.float-label {
    z-index: 2;
}

.float-field .selected-picker,
.float-field .selected-country {
    position: relative;
    z-index: 1;
}


/* Unify floating label size across all fields/pickers */
.float-field.has-value .float-label,
.float-field:focus-within .float-label,
.float-field.always-float .float-label,
.airline-picker .float-label,
.triptype-picker .float-label {
    font-size: var(--label-float) !important;
}


/* Primary section heading with left accent stripe */
.app-heading {
    margin: 10px 0 6px 0;
    padding: 8px 10px;
    color: var(--brand-blue-dark);
    background: var(--brand-blue-50);
    */ /* Light blue background */
    border-left: 6px solid var(--brand-blue);
    border-radius: 0 8px 8px 0; /* Round only right side */
    font-weight: 600;
    font-size: 14px;
    line-height: 1;
}

    .app-heading > label {
        display: block;
        margin: 0;
        width: 100%;
        color: var(--brand-blue-dark);
    }
/* Smaller heading (for sub-sections) */
.app-subheading {
    margin: 8px 0 4px 0;
    padding: 6px 10px;
    color: var(--brand-blue-dark);
    background: #F7FAFF;
    border-left: 4px solid var(--brand-blue);
    border-radius: 6px;
    font-weight: 600;
    line-height: 1.2;
}

/* Optional: a subtle framed block to pair with headings */
.app-block {
    border: 1px solid var(--brand-border);
    border-radius: 10px;
    padding: 10px;
    background: #fff;
}

/* Utility: highlighted �route� row (e.g., PHX ? LGB) */
.app-route {
    background: var(--brand-blue-50);
    border-left: 4px solid var(--brand-blue);
    border-radius: 6px;
    padding: 6px 10px;
    color: var(--brand-blue-dark);
    font-weight: 600;
    line-height: 1.25;
}


/* default: hide headers for mobile */
.app-heading {
    display: none;
}

/* tablet/desktop: show headers */
@media (min-width: 768px) {
    .app-heading {
        display: block;
        padding: .5rem .75rem;
        border-radius: 0 8px 8px 0; /* Round only right side */
        border-left: 6px solid var(--brand-blue); /* Ensure left border shows */
        background: var(--brand-blue-50); /* Light blue background */
        font-weight: 700;
    }
}

/* Brand colors defined at top of file */

.wc-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.6rem;
    height: 1.6rem;
    border: 2px solid var(--brand-blue);
    border-radius: .45rem; /* or 50% for a circle */
    background: #fff; /* white fill */
    color: var(--brand-blue); /* blue lines */
    font-size: 1rem;
    line-height: 1;
    font-weight: 700;
    margin-right: .375rem;
}


/* ===== Vertically center checkbox + text on narrow screens ===== */
@media (max-width: 520px) {
    /* Treat each toggle row as a 2-col grid: [checkbox | text] */
    .address-entry-content .return-switch,
    .address-entry-content .wc-toggle {
        display: grid;
        grid-template-columns: 24px 1fr; /* 18px box + breathing room */
        column-gap: 8px;
        align-items: center; /* centers text vs. checkbox */
    }

    /* Center the actual checkbox in its cell (remove optical nudge) */
    .address-entry-content #ReturnTripToggle,
    .address-entry-content #HourlyServiceToggle,
    .address-entry-content .return-switch-input {
        margin: 0; /* overrides any top offset */
        align-self: center; /* vertical center in the first column */
    }

    /* Make the text block vertically centered relative to the box */
    .address-entry-content .return-switch-label,
    .address-entry-content .hourly-service-label,
    .address-entry-content .return-trip-summary {
        display: flex;
        align-items: center; /* centers the text within its own line box */
        min-height: 18px; /* match checkbox size so single-line aligns */
        line-height: 1.25;
    }
}







/* === Address entry (global/shared) ===================================== */

/* Row spacing around each address field */
.address-row {
    margin: 10px 0 14px;
}

/* Anchor for absolute-positioned icon/clear button */
.address-field {
    position: relative;
    margin-bottom: 0;
}

/* Input: tall enough for floated label + text, iOS-safe font size */
.address-input {
    width: 100%;
    min-height: 50px;
    padding: 20px 36px 5px 36px; /* label+icon left, clear on right */
    border: 1px solid #ccc;
    border-radius: 4px;
    font-size: 16px; /* prevent iPhone zoom */
    box-sizing: border-box;
    color: var(--brand-blue);
    background: #fff;
}

/* Float label pattern */
.float-field {
    position: relative;
}

.float-input::placeholder {
    color: #666;
    opacity: 0.6;
}
/* keep for :placeholder-shown */

.float-label {
    position: absolute;
    left: 36px; /* sits past the icon */
    top: 50%;
    transform: translateY(-50%);
    font-size: 1rem; /* larger when empty */
    line-height: 1;
    pointer-events: none;
    opacity: .8;
    transition: top .15s ease, transform .15s ease, font-size .15s ease, opacity .15s ease;
}

.float-input:focus + .float-label,
.float-input:not(:placeholder-shown) + .float-label {
    top: 6px; /* float up */
    transform: none;
    font-size: .78rem;
    opacity: .95;
}

/* Leading icon (?? by default, ?? when [data-kind="airport"]) */
.address-icon {
    position: absolute;
    left: 10px;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    font-size: 14px;
    line-height: 1;
}

    .address-icon::before {
        content: "\F3E8"; /* Bootstrap Icons geo-alt U+F3E8 */
        font-family: "bootstrap-icons";
    }

    .address-icon[data-kind="airport"]::before {
        content: "\F7CD"; /* Bootstrap Icons airplane */
        font-family: "bootstrap-icons";
    }

/* Clear (X) button on the right */
.clear-button {
    position: absolute;
    top: 50%;
    right: 8px;
    transform: translateY(-50%);
    background: none;
    border: none;
    font-size: .9em;
    cursor: pointer;
    color: #666;
    z-index: 1000; /* above the dropdown list */
}

    .clear-button:hover {
        color: #000;
    }

/* Optional read-only line under the field for full street address */
.readonly-address {
    margin: 4px 0 0;
    padding: 0;
    display: block;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    border: 0 !important;
    background: transparent !important;
    color: #374151;
    font-size: 0.65rem;
    line-height: 1.025;
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
}

/* Google Places-style dropdown: keep above footers/modals */
.pac-container {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    background: #fff;
    border: 1px solid #dfe1e5;
    border-radius: 8px;
    box-shadow: 0 2px 6px rgba(60,64,67,.30);
    z-index: 6000 !important;
    max-height: 320px;
    overflow-y: auto;
    padding: 6px 0;
}

/* Optional: item hover/selected feel */
.pac-item {
    padding: 6px 12px;
    line-height: 1;
    cursor: pointer;
}

    .pac-item:hover, .pac-item.pac-item-selected {
        background: #f1f3f4;
    }


/* Hide empty Google Places dropdowns */
.pac-container:empty {
    display: none !important;
}

/* Also hide when it exists but contains no .pac-item rows */
.pac-container:not(:has(.pac-item)) {
    display: none !important;
    padding: 0 !important;
    border: 0 !important;
    box-shadow: none !important;
}

/* If your template sometimes leaves only a section label, hide that too */
.pac-container:has(.pac-section-label):not(:has(.pac-item)) {
    display: none !important;
    padding: 0 !important;
    border: 0 !important;
    box-shadow: none !important;
}



/* === Google Places suggestion formatting (global) === */

/* Container */
.pac-container {
    background: #fff;
    border: 1px solid #dfe1e5;
    border-radius: 8px;
    box-shadow: 0 2px 6px rgba(60,64,67,.30);
    z-index: 6000 !important;
    max-height: 320px;
    overflow-y: auto;
    padding: 6px 0;
}

/* Row */
.pac-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 6px 12px;
    cursor: pointer;
    line-height: 1.0;
    user-select: none;
}

    .pac-item:hover,
    .pac-item.pac-item-selected {
        background: #f1f3f4;
    }

/* Leading icon */
.pac-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    margin-top: 2px;
    opacity: .7;
}

    .pac-icon::before {
        content: "\F3E8"; /* Bootstrap Icons geo-alt U+F3E8 */
        font-family: "bootstrap-icons";
    }

.pac-item-airport .pac-icon::before {
    content: "\F7CD"; /* Bootstrap Icons airplane */
    font-family: "bootstrap-icons";
}

/* Text block */
.pac-item-text {
    min-width: 0;
}

.pac-item-primary-text {
    display: inline;
    color: #202124;
    font-weight: 600; /* <-- bold main line */
    font-size: 14px;
}

.pac-item-secondary-text {
    display: inline;
    margin-left: 4px;
    color: #5f6368;
    font-weight: 700;
    font-size: 14px; /* <-- smaller city/state line */
}

.pac-matched {
    font-weight: 700;
}
/* bold the matched characters */

/* Hide empty dropdowns (stops the blank box) */
.pac-container:empty {
    display: none !important;
}

.pac-container:not(:has(.pac-item)) {
    display: none !important;
    padding: 0 !important;
    border: 0 !important;
    box-shadow: none !important;
}


/* make this specific toggle a 3-col grid: [checkbox] [icon] [text] */
.toggle-row.has-icon {
    display: grid;
    grid-template-columns: auto auto 1fr; /* checkbox | icon | text */
    align-items: center;
    column-gap: 8px;
}

/* icon column */
.rt-col-icon {
    margin: 0;
    line-height: 1;
    font-size: 1rem; /* match your brand size */
    color: var(--brand-blue, #216fed);
}

/* text column already wraps; keep it inline with title */
.toggle-row.has-icon .toggle-text {
    white-space: normal;
}


/* Unified row for checkbox + text */
.toggle-row {
    display: flex;
    align-items: flex-start; /* aligns checkbox top with first line of text */
    gap: 8px;
    margin: 4px 7px 2px 4px;
}

/* small screens still wrap nicely (no change needed) */
@media (max-width:520px) {
    .toggle-row.has-icon {
        grid-template-columns: auto 1fr; /* checkbox + [icon+text] stack if you prefer */
        grid-auto-flow: column;
    }
}
/* Global hint color */
/* Hint color defined at top of file */

/* All floating hints (labels that sit on top of boxes) use the global color */
.float-label {
    color: var(--brand-blue-dark) !important;
}

/* If you also use a smaller hint line under fields */
.input-hint {
    color: var(--brand-blue-dark) !important;
}
/* ============================
   Radzen Date/Time popups � brand them globally
   ============================ */

/* Shrink Radzen DatePicker popup (overlay + inner panel + calendar) */
body > div[class*="rz-overlay"] {
    transform-origin: top left !important;
    transform: scale(.92) !important; /* try .95� .85 */
}

    /* If Radzen wraps the popup in an inner panel, scale that too */
    body > div[class*="rz-overlay"] .rz-overlaypanel,
    body > div[class*="rz-overlay"] .rz-overlaypanel-content,
    body > div[class*="rz-overlay"] .rz-popup,
    body > div[class*="rz-overlay"] .rz-calendar {
        transform-origin: top left !important;
        transform: scale(.92) !important;
    }

    /* Make internal targets smaller so hit-areas feel consistent */
    body > div[class*="rz-overlay"] .rz-calendar {
        font-size: 0.875rem !important;
    }

        body > div[class*="rz-overlay"] .rz-calendar .rz-calendar-day,
        body > div[class*="rz-overlay"] .rz-calendar .rz-calendar-month {
            width: 2rem !important;
            height: 2rem !important;
            line-height: 2rem !important;
            padding: 0 !important;
        }

    body > div[class*="rz-overlay"] .rz-timepicker .rz-inputtext {
        width: 2.6rem !important;
    }

    /* === Radzen DatePicker popup shrink (applied to the CALENDAR root) === */
    /* You already confirmed the overlay selector sticks (blue outline). */
    body > div[class*="rz-overlay"] .rz-calendar {
        transform: scale(0.92) !important; /* try 0.95 � 0.85 */
        transform-origin: top left !important; /* keeps it anchored */
    }

    /* Time panel usually sits adjacent; scale it too for consistency */
    body > div[class*="rz-overlay"] .rz-timepicker {
        transform: scale(0.92) !important;
        transform-origin: top left !important;
    }

    /* Optional: nudge if the popup ends up a few px off after scaling */
    body > div[class*="rz-overlay"] .rz-calendar,
    body > div[class*="rz-overlay"] .rz-timepicker {
        /* uncomment and tweak if needed */
        /* translate: -4px -4px; */

        body > div[class*="rz-overlay"] .rz-calendar outline: 2px dashed magenta !important;
    }



/* Airline dialog: responsive shell */
.dlg-airline {
    width: 96vw !important;
    max-width: 420px !important;
}

@media (max-width: 430px) {
    .dlg-airline {
        width: 90vw !important;
        max-width: 380px !important;
    }
}

/* Optional: remove default inner padding if you want edge-to-edge list */
.dlg-airline .rz-dialog-content {
    padding: 0 !important;
}

/* ===================================
   NUMBER SELECTOR MODAL DIALOG
   Used for passengers/bags selection
   =================================== */
.number-selector-dialog {
    width: min(90vw, 360px) !important;
    max-height: min(70vh, 420px) !important;
}

.number-selector-dialog .rz-dialog-content {
    padding: 0 !important;
    overflow: hidden !important;
}

/* ===================================
   ADJUST PASSENGERS DIALOG
   Used when capacity is exceeded
   =================================== */
.adjust-passengers-dialog .rz-dialog-content {
    padding: 16px !important;
    overflow: visible !important;
}

.adjust-passengers-dialog-content {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.adjust-passengers-dialog-buttons {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    padding-top: 16px;
    border-top: 1px solid #e0e0e0;
    margin-top: 8px;
}

@media (max-width: 480px) {
    .adjust-passengers-dialog-buttons {
        flex-direction: column-reverse;
    }

    .adjust-passengers-dialog-buttons .rz-button {
        width: 100%;
    }
}

/* Make the popup taller/scrollable if you want */
.airline-dd-popup .rz-dropdown-items {
    max-height: 80vh;
    overflow: auto;
}

/* ===================================
   ADDRESS INPUT MODAL DIALOG SIZING
   =================================== */
.dlg-address {
    width: 96vw !important;
    max-width: 700px !important;
}

/* Fullscreen on mobile - covers all mobile sizes */
@media (max-width: 768px) {
    .rz-dialog-wrapper .rz-dialog.dlg-address {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        width: 100vw !important;
        height: 100dvh !important;
        max-width: 100vw !important;
        max-height: 100dvh !important;
        margin: 0 !important;
        border-radius: 0 !important;
        transform: none !important;
        animation: none !important;
    }

    .rz-dialog.dlg-address .rz-dialog-content {
        height: calc(100dvh - 50px) !important;
        max-height: calc(100dvh - 50px) !important;
        padding: 0 !important;
        overflow: visible !important;
        display: flex;
        flex-direction: column;
    }

    .rz-dialog.dlg-address .rz-dialog-titlebar {
        border-radius: 0 !important;
        flex-shrink: 0;
    }
}

/* Halve vertical padding on each row */
.airline-dd-popup li.rz-dropdown-item {
    padding-block: 6.75px !important; /* was ~13.5px */
    padding-inline: 12px !important; /* tweak if needed */
    line-height: 1.2;
}

    /* Some Radzen builds add an inner wrapper�kill extra padding there too */
    .airline-dd-popup li.rz-dropdown-item > .rz-dropdown-item-content {
        padding: 0 !important;
        margin: 0 !important;
    }


/* Make the popup scroll tall like your list */
.airline-dd-popup .rz-dropdown-items {
    max-height: 80vh;
    overflow: auto;
}

/* HALVE the default row padding (Radzen ~13.5px block by default) */
.airline-dd-popup li.rz-dropdown-item {
    padding-block: 6.75px !important; /* 13.5px -> 6.75px */
    padding-inline: 10px !important;
    line-height: 1.15 !important;
    min-height: 0 !important; /* defeat any min-height */
}

    /* Some builds wrap content; remove inner padding too */
    .airline-dd-popup li.rz-dropdown-item > .rz-dropdown-item-content {
        padding: 0 !important;
        margin: 0 !important;
    }

/* Your template row: very compact, matching the old list */
.airline-dd-popup .dd-row {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 2px 0 !important; /* keep it tight inside the li padding */
    font-size: 0.95rem;
}

/* Group headers look like your existing section bars */
.airline-dd-popup .dd-group-title {
    display: block;
    text-align: center;
    color: #fff;
    margin: 4px 6px 2px;
    padding: 4px 8px !important;
    border-radius: 8px;
    font-weight: 700;
    background: var(--brand-blue-dark);
    pointer-events: none;
}

/* Code chip and name to match your screenshot */
.airline-dd-popup .dd-code {
    display: inline-block;
    min-width: 2.1rem;
    text-align: center;
    font-weight: 700;
    border-radius: 10px;
    border: 1px solid #c8d8ff;
    background: #eaf1ff;
    padding: 2px 6px;
}

.airline-dd-popup .sep {
    opacity: .55;
}

.airline-dd-popup .dd-name {
    color: var(--brand-blue);
}
/* Apply directly to the popup container that Radzen inserts under <body> */
:root :where(.airline-dd-popup) {
    /* halve the padding Radzen uses */
    --rz-dropdown-item-padding: 6.75px 10px; /* was ~13.5px 18px */
    --rz-dropdown-item-line-height: 1.15;
    /* some themes use these too */
    --rz-dropdown-item-content-padding: 0;
    --rz-dropdown-item-min-height: 0;
}

    /* Safety: if the theme also sets a min-height, kill it */
    :root :where(.airline-dd-popup) li.rz-dropdown-item {
        min-height: 0 !important;
    }


/* Radzen dropdown variables defined at top of file */

.rz-dialog-title,
.rz-dialog-side-title {
    color: var(--brand-blue-dark);
    text-align: center !important;
}

/* ===============================
   Radzen Dialog Header Background
   =============================== */
.rz-dialog-titlebar,
.rz-dialog-side-titlebar {
    background-color: #eef1f5 !important;
    border-bottom: 1px solid #dde0e5 !important;
}

/* Ensure close button looks good on gray background */
.rz-dialog-titlebar-close {
    color: #666 !important;
}

    .rz-dialog-titlebar-close:hover {
        color: #333 !important;
        background-color: rgba(0, 0, 0, 0.05) !important;
    }


/* Show hand cursor when hovering over the dropdown area */
.airline-picker ::deep(.rz-dropdown),
.airline-picker ::deep(.rz-dropdown-label),
.airline-picker ::deep(.rz-dropdown-trigger),
.airline-picker ::deep(.rz-dropdown-item) {
    cursor: pointer !important;
}


.airline-picker {
    cursor: pointer !important;
}

/* Global Radzen dropdown header styling */
/* Radzen dropdown header variables defined at top of file */

/* 1) Convention header: anything with .rz-dd-header inside any dropdown popup */
:root :where(.rz-dropdown-panel) .rz-dd-header {
    display: block; /* or grid/flex in your specific header */
    background: var(--rz-dd-header-bg);
    color: var(--rz-dd-header-fg);
    font-weight: 700;
    border-radius: var(--rz-dd-header-radius);
    padding: var(--rz-dd-header-pad);
    margin: var(--rz-dd-header-margin);
    pointer-events: none; /* non-selectable */
}

/* Optional: make the <li> wrapper non-selectable if your header sits inside it */
:root :where(.rz-dropdown-panel) li.rz-dropdown-item:has(.rz-dd-header) {
    pointer-events: none;
}

/* 2) Built-in group headers (if you use GroupProperty on RadzenDropDown) */
:root :where(.rz-dropdown-panel) .rz-dropdown-group {
    background: var(--rz-dd-header-bg);
    color: var(--rz-dd-header-fg);
    font-weight: 700;
    border-radius: var(--rz-dd-header-radius);
    padding: var(--rz-dd-header-pad);
    margin: var(--rz-dd-header-margin);
    display: grid;
}

/* Keep normal rows� hover unaffected */
:root :where(.rz-dropdown-panel) .rz-dropdown-item:hover .rz-dd-header {
    background: var(--rz-dd-header-bg);
}


/* Make all dropdown headers shorter */
/* Radzen dropdown header variables defined at top of file */

:root :where(.rz-dropdown-panel) .rz-dd-header,
:root :where(.rz-dropdown-panel) .rz-dropdown-group {
    padding: var(--rz-dd-header-pad);
    font-size: var(--rz-dd-header-font);
    line-height: 1.105; /* tighter vertical rhythm */
    align-items: center;
    margin: 2px 6px; /* was 4px 6px */
    border-radius: 2px; /* keep consistent but could use 4px */
}


/* ============================================
   Normalize Radzen dropdown header appearance
   ============================================ */

/* Force consistent header font across ALL dropdowns */
:root :where(.rz-dropdown-panel) .rz-dd-header {
    font-size: var(--rz-dd-header-font, 0.84rem) !important;
    font-weight: 600; /* match airline header weight */
    line-height: 1.15;
}

/* Optional: slightly tighter header for flight dropdown grid */
:root :where(.flightnum-dd-popup) .rz-dd-header {
    font-size: var(--rz-dd-header-font, 0.84rem) !important;
    line-height: 1.1;
    padding-top: 3px;
    padding-bottom: 3px;
}
/* ============================================
   Normalize Radzen dropdown header appearance
   ============================================ */

/* Force consistent header font across ALL dropdowns */
:root :where(.rz-dropdown-panel) .rz-dd-header {
    font-size: var(--rz-dd-header-font, 0.64rem) !important;
    font-weight: 600; /* match airline header weight */
    line-height: 1.15;
    padding-left: 1px;
    padding-right: 1px;
}

/* Optional: slightly tighter header for flight dropdown grid */
:root :where(.flightnum-dd-popup) .rz-dd-header {
    font-size: var(--rz-dd-header-font, 0.64rem) !important;
    line-height: 1.1;
    padding-top: 3px;
    padding-bottom: 3px;
    padding-left: 1px;
    padding-right: 1px;
}


:root :where(.rz-dropdown-panel) .dd-grid .dd-cell {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    padding: 0 6px;
    border-right: 1px solid var(--dd-col-sep);
    color: var(--brand-blue);
    font-size: 15px;
}
/* ===============================
   DateTimeEntryComponent Dialog Styles
   Add this to your site.css file
   =============================== */

/* Mobile-first: stacked layout */
.dlg-datetime {
    width: 96vw !important;
    max-width: 420px !important;
}

/* Desktop: wider dialog for side-by-side layout */
@media (min-width: 769px) {
    .dlg-datetime {
        max-width: 720px !important;
    }
}

/* Small mobile: full width */
@media (max-width: 430px) {
    .dlg-datetime {
        max-width: 96vw !important;
    }
}

.dlg-datetime .rz-dialog-content {
    padding: 0 !important;
}


/* Alternative: Apply to ALL Radzen buttons regardless of style */
.rz-button {
    border-radius: var(--field-radius, 12px) !important;
}

/* ========================================
   REUSABLE 3-COLUMN BUTTON LAYOUT
   
   Usage: Add "rz-button-3col" class to any RadzenButton
   
   Example:
   <RadzenButton class="rz-button-3col">
       <RadzenIcon Icon="place" />
       <span>Centered Text</span>
       <RadzenIcon Icon="chevron_right" />
   </RadzenButton>
   
   Layout: [Icon - Left] | [Text - Centered] | [Icon - Right]
   ======================================== */

.rz-button-3col.rz-button {
    padding: 0 16px !important;
}

    /* Target the button-box wrapper with grid */
    .rz-button-3col.rz-button .rz-button-box {
        display: grid !important;
        grid-template-columns: auto 1fr auto !important;
        align-items: center !important;
        width: 100% !important;
        gap: 12px !important;
    }

        /* First child (typically an icon) - far left */
        .rz-button-3col.rz-button .rz-button-box > :nth-child(1) {
            justify-self: start !important;
        }

        /* Second child (typically text span) - centered */
        .rz-button-3col.rz-button .rz-button-box > :nth-child(2) {
            justify-self: center !important;
            text-align: center !important;
        }

        /* Third child (typically chevron icon) - far right */
        .rz-button-3col.rz-button .rz-button-box > :nth-child(3) {
            justify-self: end !important;
        }

/* SIMPLIFIED FIX: Address button 3-column grid layout */
/* Only apply grid to the button-box wrapper, not the button itself */

.address-button.rz-button {
    padding: 0 16px !important;
}

    /* Target ONLY the button-box wrapper with grid */
    .address-button.rz-button .rz-button-box {
        display: grid !important;
        grid-template-columns: auto 1fr auto !important;
        align-items: center !important;
        width: 100% !important;
        gap: 8px !important;
        overflow: hidden !important;
    }

        /* First child (icon) - far left */
        .address-button.rz-button .rz-button-box > :nth-child(1) {
            justify-self: start !important;
        }

        /* Second child (text span) - left aligned for truncation */
        .address-button.rz-button .rz-button-box > :nth-child(2) {
            justify-self: start !important;
            text-align: left !important;
            min-width: 0 !important; /* Critical for text truncation in grid */
            overflow: hidden !important; /* Clip overflowing content */
        }

        /* Third child (chevron) - far right */
        .address-button.rz-button .rz-button-box > :nth-child(3) {
            justify-self: end !important;
        }


/* ========================================
   POI (Hotel/Landmark) Two-Line Display
   
   These styles MUST be in site.css (global) because
   Blazor scoped CSS doesn't apply to dynamically
   generated HTML from MarkupString.
   
   Line 1: Name (truncates with ellipsis)
   Line 2: Street, City, State (smaller, muted)
   ======================================== */

/* When POI content is present, use flex column layout */
.address-text-multiline.poi-display {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    -webkit-line-clamp: unset !important;
    -webkit-box-orient: unset !important;
    overflow: hidden !important;
    min-width: 0 !important;
    width: 100% !important;
}

/* POI Name - Line 1: Bold, truncates */
.poi-name {
    display: block !important;
    font-weight: 600 !important;
    color: var(--brand-blue-dark, var(--brand-blue-dark)) !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    line-height: 1.3 !important;
    min-width: 0 !important;
    width: 100% !important;
}

/* POI Location - Line 2: Smaller, muted, truncates */
.poi-location {
    display: block !important;
    font-size: 0.8em !important;
    font-weight: 400 !important;
    color: #666 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    line-height: 1.3 !important;
    margin-top: 1px !important;
    min-width: 0 !important;
    width: 100% !important;
}

/* Mobile adjustments for POI display */
@media (max-width: 480px) {
    .poi-name {
        font-size: 14px !important;
    }

    .poi-location {
        font-size: 12px !important;
    }
}

/* ========================================
   STATIONARY LABEL DROPDOWN PATTERN
   
   Add this section to your site.css file
   
   Features:
   - 100% width dropdowns
   - Labels ALWAYS overlap the top border (stationary)
   - Smaller label font (0.75rem)
   - Works with Radzen and standard selects
   - Reusable across entire site
   - NO animation - labels stay in place
   ======================================== */

.float-dropdown {
    position: relative;
    margin-bottom: 20px;
}

    /* Dropdown/select styling - works with Radzen and standard selects */
    .float-dropdown .rz-dropdown,
    .float-dropdown select,
    .float-dropdown .dropdown-control {
        width: 100% !important;
        min-height: 48px;
        padding: 16px 12px 8px 12px;
        border: 1px solid #ced4da;
        border-radius: 4px;
        font-size: 1rem;
        background-color: white;
        box-sizing: border-box;
        transition: border-color 0.2s ease;
    }

    /* Stationary label - outline pill positioned over top border */
    .float-dropdown .float-label {
        position: absolute;
        left: 12px;
        top: -10px;
        background-color: white;
        padding: 2px 10px;
        font-size: 0.6rem;
        font-weight: 600;
        color: var(--brand-blue, var(--brand-blue));
        border: 1px solid var(--brand-blue, var(--brand-blue));
        border-radius: var(--chip-radius, 6px);
        pointer-events: none;
        z-index: 1;
        display: inline-flex;
        align-items: center;
        gap: 5px;
    }

/* Inside section-frame: plain text labels (no border) for hierarchy */
.section-frame .float-dropdown .float-label {
    border: none;
    padding: 0 6px;
    font-weight: 500;
}

/* Focus states - label stays in same position */
.float-dropdown .rz-dropdown:focus,
.float-dropdown select:focus,
.float-dropdown .dropdown-control:focus {
    outline: none;
    border-color: var(--brand-blue, var(--brand-blue));
    box-shadow: 0 0 0 2px rgba(41, 99, 168, 0.1);
}

    .float-dropdown .rz-dropdown:focus ~ .float-label,
    .float-dropdown select:focus ~ .float-label,
    .float-dropdown .dropdown-control:focus ~ .float-label {
        color: var(--brand-blue, var(--brand-blue));
        border-color: var(--brand-blue, var(--brand-blue));
    }

/* Ensure Radzen dropdowns take full width */
.float-dropdown .rz-dropdown {
    display: block !important;
}

.float-dropdown .rz-dropdown-label-container {
    width: 100% !important;
}

/* Validation states */
.float-dropdown.invalid .rz-dropdown,
.float-dropdown.invalid select,
.float-dropdown.invalid .dropdown-control {
    border-color: var(--cell-red, #d9534f);
}

.float-dropdown.invalid .float-label {
    color: var(--cell-red, #d9534f);
    border-color: var(--cell-red, #d9534f);
}

.float-dropdown.valid .rz-dropdown,
.float-dropdown.valid select,
.float-dropdown.valid .dropdown-control {
    border-color: var(--cell-green, #5cb85c);
}

/* Mobile responsive adjustments */
@media (max-width: 400px) {
    .float-dropdown .rz-dropdown,
    .float-dropdown select,
    .float-dropdown .dropdown-control {
        min-height: 44px;
        padding: 14px 10px 6px 10px;
        font-size: 0.95rem;
    }

    .float-dropdown .float-label {
        font-size: 0.6rem;
        top: -7px;
    }
}




/* ========================================
   REUSABLE: Stationary Label Dropdown Pattern
   Add this to your site.css
   Can be used across all components
   ======================================== */

.float-dropdown {
    position: relative;
    margin-bottom: 20px;
}

    /* Label - outline pill at top, overlapping border */
    .float-dropdown .float-label {
        position: absolute !important;
        left: 12px !important;
        top: -10px !important;
        background-color: white !important;
        padding: 2px 10px !important;
        font-size: 0.6rem !important;
        font-weight: 600 !important;
        color: var(--brand-blue, var(--brand-blue)) !important;
        border: 1px solid var(--brand-blue, var(--brand-blue)) !important;
        border-radius: var(--chip-radius, 6px) !important;
        pointer-events: none !important;
        z-index: 10 !important;
        display: inline-flex !important;
        align-items: center !important;
        gap: 5px !important;
        visibility: visible !important;
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
        line-height: 1.2 !important;
    }

/* Inside section-frame: plain text labels (no border) for hierarchy */
.section-frame .float-dropdown .float-label {
    border: none !important;
    padding: 0 6px !important;
    font-weight: 500 !important;
}

/* Radzen dropdown base styling */
.float-dropdown .rz-dropdown {
    width: 100% !important;
    min-height: 56px !important;
    padding: 18px 16px 10px 16px !important;
    border: 1px solid #ced4da !important;
    border-radius: 12px !important;
    font-size: 1rem !important;
    background-color: white !important;
    box-sizing: border-box !important;
    transition: border-color 0.2s ease;
}

/* Standard select/dropdown-control styling */
.float-dropdown select,
.float-dropdown .dropdown-control {
    width: 100% !important;
    min-height: 56px !important;
    padding: 18px 12px 10px 12px !important;
    border: 1px solid #ced4da !important;
    border-radius: 4px !important;
    font-size: 1rem !important;
    background-color: white !important;
    box-sizing: border-box !important;
    transition: border-color 0.2s ease;
}

    /* Focus states */
    .float-dropdown .rz-dropdown:focus,
    .float-dropdown .rz-dropdown:focus-within,
    .float-dropdown select:focus,
    .float-dropdown .dropdown-control:focus {
        outline: none !important;
        border-color: var(--brand-blue, var(--brand-blue)) !important;
        box-shadow: 0 0 0 2px rgba(41, 99, 168, 0.1) !important;
    }

        /* Label gets bolder on focus */
        .float-dropdown .rz-dropdown:focus ~ .float-label,
        .float-dropdown .rz-dropdown:focus-within ~ .float-label,
        .float-dropdown select:focus ~ .float-label,
        .float-dropdown .dropdown-control:focus ~ .float-label {
            font-weight: 600 !important;
        }

/* Ensure Radzen dropdown takes full width */
/*.float-dropdown .rz-dropdown {
        display: block !important;
    }*/
.float-dropdown .dropdown-text {
    text-align: center !important;
}

.float-dropdown .rz-dropdown-label-container {
    width: 100% !important;
    display: flex !important;
    justify-content: center !important; /* ? ADD THIS */
    align-items: center !important; /* ? ADD !important */
    padding: 0 !important;
}


.float-dropdown .rz-dropdown .rz-dropdown-label {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important; /* ? ADD THIS */
    gap: 8px !important;
}


/* Make all float-dropdown elements show pointer cursor */
.float-dropdown .rz-dropdown,
.float-dropdown .rz-dropdown .rz-dropdown-label,
.float-dropdown .rz-dropdown .rz-dropdown-trigger,
.float-dropdown .rz-dropdown input {
    cursor: pointer !important;
}



/* Validation states */
.float-dropdown.invalid .rz-dropdown,
.float-dropdown.invalid select,
.float-dropdown.invalid .dropdown-control {
    border-color: var(--cell-red, #d9534f) !important;
}

.float-dropdown.invalid .float-label {
    color: var(--cell-red, #d9534f) !important;
}


/* Center placeholder text in Radzen dropdowns */
.float-dropdown .rz-placeholder {
    text-align: center !important;
}

.float-dropdown.valid .rz-dropdown,
.float-dropdown.valid select,
.float-dropdown.valid .dropdown-control {
    border-color: var(--cell-green, #5cb85c) !important;
}

.float-dropdown.valid .float-label {
    color: var(--cell-green, #5cb85c) !important;
}

/* Mobile adjustments */
@media (max-width: 400px) {
    .float-dropdown .rz-dropdown,
    .float-dropdown select,
    .float-dropdown .dropdown-control {
        min-height: 52px !important;
        padding: 16px 10px 8px 10px !important;
        font-size: 0.95rem !important;
    }

    .float-dropdown .float-label {
        font-size: 0.6rem !important;
        top: -5px !important;
    }
}


/* ========================================
   ADDRESS ENTRY BUTTONS
   Styled to match Passengers/Luggage dropdowns
   ======================================== */

/* Always hide the old desktop-only address input fields */
.address-field.desktop-only,
.readonly-address.desktop-only {
    display: none !important;
}

/* Address Summary Button - Matches dropdown styling */
.address-summary-button {
    width: 100%;
    display: flex;
    align-items: center;
    min-height: 56px;
    padding: 12px 16px 12px 48px;
    background: white;
    border: 1px solid #ced4da;
    border-radius: 50px;
    cursor: pointer;
    transition: all 0.2s ease;
    margin-bottom: 16px;
    text-align: left;
    gap: 12px;
    font-family: var(--font-base);
    position: relative;
    box-sizing: border-box;
}

    .address-summary-button:hover,
    .address-summary-button:active {
        border-color: var(--brand-blue, var(--brand-blue));
        box-shadow: 0 0 0 2px rgba(41, 99, 168, 0.1);
    }

/* Address Button Icon - Integrated like dropdowns */
.address-button-icon {
    position: absolute !important;
    left: 14px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    font-size: 20px !important;
    flex-shrink: 0;
    width: 24px !important;
    height: 24px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    pointer-events: none;
    z-index: 2 !important;
    background: none !important;
    border-radius: 0 !important;
}

    /* Icon variants */
    .address-button-icon[data-kind="pin"]::before {
        content: "\F3E8"; /* Bootstrap Icons geo-alt U+F3E8 */
        font-family: "bootstrap-icons";
        font-weight: 600;
        color: var(--brand-blue, var(--brand-blue));
    }

    .address-button-icon[data-kind="airport-takeoff"]::before,
    .address-button-icon[data-kind="airport-landing"]::before {
        content: "\F7CD"; /* Bootstrap Icons airplane */
        font-family: "bootstrap-icons";
        font-weight: 700;
        color: var(--brand-blue-dark, var(--brand-blue-hover));
    }

    .address-button-icon[data-kind="airport-takeoff"]::before {
        transform: rotate(-22deg);
        display: inline-block;
    }

    .address-button-icon[data-kind="airport-landing"]::before {
        transform: rotate(22deg);
        display: inline-block;
    }

/* Address Button Content */
.address-button-content {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.address-button-label {
    font-size: 0.6rem;
    font-weight: 600;
    color: var(--brand-blue, var(--brand-blue));
    text-transform: uppercase;
    letter-spacing: 0.3px;
    line-height: 1.2;
}

.address-button-value {
    font-size: 0.95rem;
    font-weight: 400;
    color: var(--brand-blue-dark, var(--brand-blue-dark));
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 1.3;
}

/* Chevron indicator - subtle like dropdown arrow */
.address-button-chevron {
    flex-shrink: 0;
    font-size: 1.3rem;
    color: #666;
    font-weight: 300;
    transition: transform 0.2s ease;
    margin-left: auto;
}

.address-summary-button:hover .address-button-chevron {
    color: var(--brand-blue, var(--brand-blue));
    transform: translateX(2px);
}

/* Mobile adjustments */
@media (max-width: 480px) {
    .address-summary-button {
        min-height: 52px;
        padding: 10px 12px 10px 44px;
    }

    .address-button-icon {
        left: 12px !important;
        font-size: 18px !important;
    }

    .address-button-label {
        font-size: 0.65rem;
    }

    .address-button-value {
        font-size: 0.9rem;
    }

    .address-button-chevron {
        font-size: 1.2rem;
    }
}

/* Tablet and up adjustments */
@media (min-width: 481px) {
    .address-summary-button {
        min-height: 58px;
        padding: 14px 18px 14px 52px;
    }

    .address-button-icon {
        left: 16px !important;
        font-size: 22px !important;
    }

    .address-button-value {
        font-size: 1rem;
    }
}

/* Desktop adjustments */
@media (min-width: 769px) {
    .address-summary-button {
        max-width: 600px;
        margin-left: auto;
        margin-right: auto;
    }
}

/* Ensure address-row doesn't add extra spacing */
.address-row {
    margin-bottom: 8px;
}

/* Focus state for accessibility */
.address-summary-button:focus {
    outline: none;
    border-color: var(--brand-blue, var(--brand-blue));
    box-shadow: 0 0 0 2px rgba(41, 99, 168, 0.1);
}

/* Radzen Button Overrides for address-summary-button */
.address-summary-button.rz-button {
    background: white !important;
    border: 1px solid #ced4da !important;
    color: inherit !important;
    box-shadow: none !important;
    font-family: var(--font-base) !important;
    height: auto !important;
    line-height: normal !important;
    justify-content: flex-start !important;
}

    .address-summary-button.rz-button:hover,
    .address-summary-button.rz-button:active {
        background: white !important;
        border-color: var(--brand-blue, var(--brand-blue)) !important;
        box-shadow: 0 0 0 2px rgba(41, 99, 168, 0.1) !important;
    }

    .address-summary-button.rz-button:focus {
        background: white !important;
        border-color: var(--brand-blue, var(--brand-blue)) !important;
        box-shadow: 0 0 0 3px rgba(41, 99, 168, 0.4), 0 0 8px rgba(41, 99, 168, 0.3) !important;
    }

/* Ensure responsive padding works with Radzen */
@media (max-width: 480px) {
    .address-summary-button.rz-button {
        padding: 10px 12px 10px 44px !important;
    }
}

@media (min-width: 481px) {
    .address-summary-button.rz-button {
        padding: 14px 18px 14px 52px !important;
    }
}

/* ===============================
   DateTime Component - Force Pill Shapes for Hour/Minute
   Add this at the END of site.css
   =============================== */
.time-input-group input[type="number"],
.datetime-entry-modal-content input[type="number"] {
    border-radius: 8px !important;
    -webkit-border-radius: 8px !important;
    -moz-border-radius: 8px !important;
    border: 2px solid #ced4da !important;
    box-sizing: border-box !important;
}

    .time-input-group input[type="number"]:focus,
    .datetime-entry-modal-content input[type="number"]:focus {
        border-color: var(--brand-blue, var(--brand-blue)) !important;
        box-shadow: 0 0 0 0.2rem rgba(10, 74, 138, 0.15) !important;
    }

@media (max-width: 480px) {
    .time-input-group input[type="number"],
    .datetime-entry-modal-content input[type="number"] {
        border-radius: 8px !important;
        min-height: 52px !important;
        max-height: 52px !important;
        height: 52px !important;
    }
}
/* AM/PM RadzenDropDown styling */
.time-dropdown .rz-dropdown {
    border-radius: 8px !important;
    border: 2px solid #ced4da !important;
    box-sizing: border-box !important;
}

    .time-dropdown .rz-dropdown:focus,
    .time-dropdown .rz-dropdown:focus-within {
        border-color: var(--brand-blue, var(--brand-blue)) !important;
        box-shadow: 0 0 0 0.2rem rgba(10, 74, 138, 0.15) !important;
    }

/* Dropdown toggle button - make arrows bigger */
.datetime-entry-modal-content .dropdown-toggle-btn {
    width: 36px !important;
    height: 36px !important;
}

    .datetime-entry-modal-content .dropdown-toggle-btn .rz-icon {
        font-size: 32px !important;
    }

/* Mobile styles for AM/PM dropdown */
@media (max-width: 480px) {
    .time-dropdown .rz-dropdown {
        border-radius: 8px !important;
        min-height: 52px !important;
        max-height: 52px !important;
        height: 52px !important;
    }
}


/* Style the AM/PM dropdown trigger with brand colors */
.time-dropdown .rz-dropdown-trigger,
.time-dropdown .rz-multiselect-trigger {
    background-color: var(--brand-blue-light, #0a4a8a) !important;
    color: white !important;
    cursor: pointer !important;
    border-radius: 0 6px 6px 0 !important;
    transition: background-color 0.15s ease !important;
}

/* ===============================
   ADD THIS TO YOUR site.css FILE
   Radzen Dropdown Trigger Styling for DateTime Component
   =============================== */

/* Style the AM/PM dropdown trigger with brand colors */
.time-dropdown .rz-dropdown-trigger,
.time-dropdown .rz-multiselect-trigger {
    background-color: var(--brand-blue-light, #0a4a8a) !important;
    color: white !important;
    cursor: pointer !important;
    border-radius: 0 6px 6px 0 !important;
    transition: background-color 0.15s ease !important;
}

    .time-dropdown .rz-dropdown-trigger:hover,
    .time-dropdown .rz-multiselect-trigger:hover {
        background-color: var(--brand-blue-dark, #06325f) !important;
    }

    /* Style the icon inside the dropdown trigger */
    .time-dropdown .rz-dropdown-trigger .rz-dropdown-trigger-icon,
    .time-dropdown .rz-multiselect-trigger .rz-multiselect-trigger-icon {
        color: white !important;
    }

/* Make the entire dropdown clickable with pointer cursor */
.time-dropdown .rz-dropdown {
    cursor: pointer !important;
}

/* Mobile responsive styles */
@media (max-width: 480px) {
    .time-dropdown .rz-dropdown-trigger .rz-dropdown-trigger-icon,
    .time-dropdown .rz-multiselect-trigger .rz-multiselect-trigger-icon {
        font-size: 28px !important;
    }
}


/* ===============================
   ADD THIS TO YOUR site.css FILE
   Radzen Dropdown Trigger Styling for DateTime Component
   =============================== */

/* Style the AM/PM dropdown trigger with subtle gray colors */
.time-dropdown .rz-dropdown-trigger,
.time-dropdown .rz-multiselect-trigger {
    background-color: #e9ecef !important;
    color: #6c757d !important;
    cursor: pointer !important;
    border-radius: 0 6px 6px 0 !important;
    transition: background-color 0.15s ease !important;
}

    .time-dropdown .rz-dropdown-trigger:hover,
    .time-dropdown .rz-multiselect-trigger:hover {
        background-color: #dee2e6 !important;
        color: #495057 !important;
    }

    /* Style the icon inside the dropdown trigger */
    .time-dropdown .rz-dropdown-trigger .rz-dropdown-trigger-icon,
    .time-dropdown .rz-multiselect-trigger .rz-multiselect-trigger-icon {
        color: #6c757d !important;
    }

/* Make the entire dropdown clickable with pointer cursor */
.time-dropdown .rz-dropdown {
    cursor: pointer !important;
}

/* Mobile responsive styles */
@media (max-width: 480px) {
    .time-dropdown .rz-dropdown-trigger .rz-dropdown-trigger-icon,
    .time-dropdown .rz-multiselect-trigger .rz-multiselect-trigger-icon {
        font-size: 28px !important;
    }
}


/* ===============================
   ADD THIS TO THE END OF site.css
   Update float-field system for Passenger Contact Info
   =============================== */

/* Make float-field inputs full width with pill shape */
.passenger-contact-info-content .float-input.form-control {
    width: 100% !important;
    border-radius: 12px !important;
    border: 2px solid #ced4da !important;
    min-height: 56px !important;
    max-height: 56px !important;
    padding: 24px 20px 10px 20px !important;
    font-size: 16px !important;
    box-sizing: border-box !important;
}

    .passenger-contact-info-content .float-input.form-control:focus {
        border-color: var(--brand-blue, var(--brand-blue)) !important;
        box-shadow: 0 0 0 0.2rem rgba(41, 99, 168, 0.15) !important;
        outline: none !important;
    }

    .passenger-contact-info-content .float-input.form-control:hover {
        border-color: var(--brand-blue, var(--brand-blue)) !important;
    }

/* Float label positioning for passenger contact */
.passenger-contact-info-content .float-label {
    left: 20px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    color: var(--brand-blue, var(--brand-blue)) !important;
    background: white !important;
    padding: 0 8px !important;
}

.passenger-contact-info-content .float-input:focus + .float-label,
.passenger-contact-info-content .float-field.has-value .float-label {
    top: 0 !important;
    transform: translateY(-50%) !important;
    font-size: 12px !important;
}

/* Country selector button with pill shape */
.passenger-contact-info-content .selected-country {
    width: 100% !important;
    min-height: 56px !important;
    height: 56px !important;
    border: 2px solid #ced4da !important;
    border-radius: 12px !important;
    padding: 20px 12px 10px 12px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    transition: border-color 0.2s ease !important;
    background: white !important;
    box-sizing: border-box !important;
}

    .passenger-contact-info-content .selected-country:hover {
        border-color: var(--brand-blue, var(--brand-blue)) !important;
    }

    .passenger-contact-info-content .selected-country:focus {
        border-color: var(--brand-blue, var(--brand-blue)) !important;
        box-shadow: 0 0 0 0.2rem rgba(41, 99, 168, 0.15) !important;
        outline: none !important;
    }

/* Make checkboxes look good */
.passenger-contact-info-content .form-check {
    padding: 12px !important;
    background: #f8f9fa !important;
    border-radius: 8px !important;
    margin-bottom: 16px !important;
}

    .passenger-contact-info-content .form-check:hover {
        background: #e9ecef !important;
    }

/* Mobile responsive */
@media (max-width: 480px) {
    .passenger-contact-info-content .float-input.form-control {
        min-height: 52px !important;
        max-height: 52px !important;
        padding: 18px 16px 8px 16px !important;
    }

    .passenger-contact-info-content .selected-country {
        min-height: 52px !important;
        height: 52px !important;
        padding: 18px 10px 8px 10px !important;
    }

    .passenger-contact-info-content .float-label {
        font-size: 11px !important;
        left: 16px !important;
    }
}

/* Calendar selected date styling - dark blue with white text */
.rz-calendar-view td .rz-state-active.rz-state-focused,
.rz-calendar-view td .rz-state-active:hover,
.rz-calendar-view td .rz-state-active.rz-calendar-today.rz-state-focused,
.rz-calendar-view td .rz-state-active.rz-calendar-today:hover {
    color: white !important;
    background-color: var(--brand-blue-dark) !important;
}

/* Also style the selected date without focus/hover states */
.rz-calendar-view td .rz-state-active {
    color: white !important;
    background-color: var(--brand-blue-dark) !important;
}


/* ===============================
   FeedbackPage - Material Design Labels - COMPLETE
   Replace the existing FeedbackPage section in site.css with this
   =============================== */

/* Page wrapper with margins */
.feedback-page {
    padding-left: 15px;
    padding-right: 15px;
    max-width: 600px;
    margin: 0 auto;
}

    /* Make logo smaller */
    .feedback-page .centered-image {
        max-width: 120px !important;
        height: auto !important;
    }

    /* Target labels specifically on FeedbackPage using page-specific wrapper */
    .feedback-page .form-group {
        position: relative;
        margin-bottom: 1.5rem;
    }

        .feedback-page .form-group.row {
            margin-bottom: 1rem;
        }

            /* Ensure col-md-* within rows also have relative positioning for labels */
            .feedback-page .form-group.row > [class*="col-"] {
                position: relative;
            }

        /* Material Design label on top border */
        .feedback-page .form-group .label-heading {
            position: absolute !important;
            top: 0 !important;
            left: 20px !important;
            transform: translateY(-50%) !important;
            font-size: 11px !important;
            font-weight: 600 !important;
            color: var(--brand-blue, var(--brand-blue)) !important;
            background: white !important;
            padding: 0 8px !important;
            z-index: 10 !important;
            margin: 0 !important;
            display: block !important;
        }

    /* Override input styling for FeedbackPage - Changed border color to brand-blue-dark */
    .feedback-page .styled-input {
        width: 100% !important;
        border-radius: 12px !important;
        border: 2px solid var(--brand-blue-dark, var(--brand-blue-dark)) !important;
        min-height: 56px !important;
        padding: 12px 20px !important;
        font-size: 16px !important;
        box-sizing: border-box !important;
        transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
    }

        .feedback-page .styled-input:focus {
            border-color: var(--brand-blue, var(--brand-blue)) !important;
            box-shadow: 0 0 0 0.2rem rgba(41, 99, 168, 0.15) !important;
            outline: none !important;
        }

        .feedback-page .styled-input:hover {
            border-color: var(--brand-blue, var(--brand-blue)) !important;
        }

    /* Form text (comments/instructions) - subtle styling */
    .feedback-page .form-text {
        border: none !important;
        background: transparent !important;
        padding: 8px 20px !important;
        font-size: 13px !important;
        color: #666 !important;
        line-height: 1.5 !important;
        font-style: italic;
        margin-top: 8px;
        min-height: auto !important;
    }

    /* Select dropdowns */
    .feedback-page select.styled-input {
        appearance: none !important;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%232963A8' d='M6 9L1 4h10z'/%3E%3C/svg%3E") !important;
        background-repeat: no-repeat !important;
        background-position: right 20px center !important;
        padding-right: 45px !important;
    }

    /* Textarea */
    .feedback-page textarea.styled-input {
        min-height: 120px !important;
        border-radius: 12px !important;
        padding: 16px 20px !important;
        resize: vertical !important;
    }

    /* Country selector styling - brand-blue-dark border */
    .feedback-page .selected-country {
        width: 100%;
        min-height: 56px;
        padding: 10px 12px;
        border: 2px solid var(--brand-blue-dark, var(--brand-blue-dark));
        border-radius: 12px;
        background: white;
        font-size: 1rem;
        font-family: var(--font-base);
        color: #333333;
        box-sizing: border-box;
        transition: border-color 0.2s ease, box-shadow 0.2s ease;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 6px;
        cursor: pointer;
    }

        .feedback-page .selected-country:hover {
            border-color: var(--brand-blue, var(--brand-blue));
        }

        .feedback-page .selected-country:focus,
        .feedback-page .selected-country:focus-within {
            outline: none;
            border-color: var(--brand-blue, var(--brand-blue));
            box-shadow: 0 0 0 0.2rem rgba(41, 99, 168, 0.15);
        }

    /* Radio group container with border - brand-blue-dark */
    .feedback-page .radio-group-container {
        position: relative;
        border: 2px solid var(--brand-blue-dark, var(--brand-blue-dark));
        border-radius: 12px;
        padding: 20px;
        margin-bottom: 1.5rem;
    }

        .feedback-page .radio-group-container .label-heading {
            position: absolute !important;
            top: 0 !important;
            left: 20px !important;
            transform: translateY(-50%) !important;
            font-size: 11px !important;
            font-weight: 600 !important;
            color: var(--brand-blue, var(--brand-blue)) !important;
            background: white !important;
            padding: 0 8px !important;
            z-index: 10 !important;
            margin: 0 !important;
        }

    /* Checkbox alignment fix */
    .feedback-page .checkbox-inline-group {
        display: flex;
        align-items: center;
        gap: 8px;
    }

        .feedback-page .checkbox-inline-group input[type="checkbox"] {
            margin: 0;
            flex-shrink: 0;
        }

        .feedback-page .checkbox-inline-group label {
            margin: 0;
            line-height: 20px; /* Match checkbox height */
        }

            /* Checkbox labels should NOT be on border */
            .feedback-page .checkbox-inline-group label.label-heading,
            .feedback-page .smaller-label-heading {
                position: static !important;
                transform: none !important;
                background: transparent !important;
            }

    /* Submit button - larger and styled */
    .feedback-page .btn-primary {
        min-width: 200px !important;
        padding: 14px 32px !important;
        font-size: 18px !important;
        font-weight: 600 !important;
    }

    /* Validation message styling */
    .feedback-page .validation-message {
        background-color: #fff3cd;
        color: #856404;
        border-left: 4px solid #ffeeba;
        padding: 0.25rem;
        margin-top: 0.25rem;
        border-radius: 4px;
    }

/* Mobile responsive */
@media (max-width: 768px) {
    .feedback-page {
        padding-left: 10px;
        padding-right: 10px;
    }
}

@media (max-width: 480px) {
    .feedback-page {
        padding-left: 8px;
        padding-right: 8px;
    }

        .feedback-page .centered-image {
            max-width: 100px !important;
        }

        .feedback-page .styled-input {
            min-height: 52px !important;
            padding: 12px 16px !important;
        }

        .feedback-page textarea.styled-input {
            min-height: 100px !important;
            padding: 14px 16px !important;
        }

        .feedback-page .form-group .label-heading {
            font-size: 10px !important;
            left: 16px !important;
        }

        .feedback-page .selected-country {
            min-height: 52px;
        }

        .feedback-page select.styled-input {
            background-position: right 16px center !important;
            padding-right: 40px !important;
        }

        .feedback-page .radio-group-container {
            padding: 16px;
        }

        .feedback-page .form-text {
            font-size: 12px !important;
            padding: 6px 16px !important;
        }
}
/* ===============================
   Flight Dropdown Spacing Fix - Match Airline List
   =============================== */
/* Apply generous vertical spacing to flight dropdown items to match airline list */
.rz-dropdown-panel.flightnum-dd-popup li.rz-dropdown-item,
body .rz-dropdown-panel.flightnum-dd-popup .rz-dropdown-item,
body .rz-dropdown-panel.flightnum-dd-popup .rz-dropdown-items li {
    padding-block: 6.75px !important;
    padding-inline: 12px !important;
    line-height: 1.2 !important;
}

/* Ensure airline dropdown has consistent spacing too */
.rz-dropdown-panel.airline-dd-popup li.rz-dropdown-item,
body .rz-dropdown-panel.airline-dd-popup .rz-dropdown-item,
body .rz-dropdown-panel.airline-dd-popup .rz-dropdown-items li {
    padding-block: 6.75px !important;
    padding-inline: 12px !important;
    line-height: 1.2 !important;
}

/* ===============================
   Passengers & Bags Dropdown Popup
   Limit height to prevent oversized dropdown
   =============================== */
.rz-dropdown-panel.pax-bags-dropdown-popup,
body .rz-dropdown-panel.pax-bags-dropdown-popup {
    max-height: 280px !important;
}

.rz-dropdown-panel.pax-bags-dropdown-popup .rz-dropdown-items-wrapper {
    max-height: 260px !important;
    overflow-y: auto !important;
}

.rz-dropdown-panel.pax-bags-dropdown-popup li.rz-dropdown-item {
    padding: 10px 14px !important;
    font-size: 0.9375rem !important;
}

.rz-dropdown-panel.pax-bags-dropdown-popup li.rz-dropdown-item:hover {
    background-color: var(--brand-blue-50, #e6f0fa) !important;
}

.rz-dropdown-panel.pax-bags-dropdown-popup li.rz-dropdown-item.rz-state-highlight {
    background-color: var(--brand-blue, #0066cc) !important;
    color: #fff !important;
}


.rz-menuitem, .rz-autocomplete-list-item, .rz-multiselect-item, .rz-autocomplete-items li, .rz-dropdown-items li, .rz-multiselect-items li, .rz-dropdown-item {
    padding: 6px !important;
}

/* ===============================
   Reusable Frame Styles
   =============================== */

/* Frame container - bordered section with background */
.section-frame {
    position: relative;
    background-color: var(--brand-blue-50);
    border: 2px solid var(--brand-border);
    border-radius: 12px;
    padding: 20px 8px 6px 8px; /* Reduced bottom padding for compact help link */
    margin: 10px 0;
}

/* Mobile: Tighter spacing for flight info expanded sections */
@media (max-width: 600px) {
    .flight-info-content .section-frame:not(.section-frame-collapsed) {
        padding-bottom: 4px;
        margin: 6px 0 0 0;
    }

    .flight-info-content .section-frame-collapsed {
        padding-bottom: 12px;
        margin-bottom: 0;
    }
}

/* Consistent spacing for flight info fields - using flexbox gap */
/* Desktop: comfortable spacing */
.flight-info-content .section-frame:not(.section-frame-collapsed) {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.flight-info-content .section-frame .flight-top {
    margin-bottom: 0;
}

.flight-info-content .section-frame .flight-info-summary {
    margin-bottom: 0;
    padding-top: 6px;
}

    /* Remove float-dropdown margin inside flight-info-summary - gap handles spacing */
    .flight-info-content .section-frame .flight-info-summary .float-dropdown {
        margin-bottom: 0;
    }

.flight-info-content .section-frame .flight-help-info {
    margin-top: 0;
    margin-bottom: 0;
}

/* Mobile: tighter spacing */
@media (max-width: 600px) {
    .flight-info-content .section-frame:not(.section-frame-collapsed) {
        gap: 0;
    }
}

/* Frame heading - outline pill that sits on the top border */
.section-frame .frame-heading {
    position: absolute;
    top: -10px;
    left: 12px;
    background: var(--white);
    padding: 2px 10px;
    font-size: 0.6rem;
    font-weight: 500;
    color: var(--brand-blue);
    border: 1px solid var(--brand-blue);
    z-index: 2;
    white-space: nowrap;
    border-radius: var(--chip-radius, 6px);
    display: inline-flex;
    align-items: center;
    gap: 5px;
}

/* Alternative frame heading placement (centered) - outline pill */
.section-frame .frame-heading-center {
    position: absolute;
    top: -10px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--white);
    padding: 2px 10px;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--brand-blue);
    border: 1px solid var(--brand-blue);
    z-index: 2;
    white-space: nowrap;
    border-radius: var(--chip-radius, 6px);
    display: inline-flex;
    align-items: center;
    gap: 5px;
}

/* Reduce vertical spacing around centered elements (like Flight Info Help link) in section-frame */
.section-frame > div:last-child,
.section-frame > p:last-child {
    margin-bottom: 0;
    margin-top: 8px;
}

/* Specifically reduce spacing around flight info help link */
.section-frame a[href*="help"],
.section-frame .text-center:last-child,
.section-frame > *:last-child {
    margin-top: 6px !important;
    margin-bottom: 0 !important;
}



/* Add to site.css for global scope */
.datetime-footer .rz-button .rz-button-text {
    font-size: 12px !important;
    line-height: 1.3 !important;
}
/* Fullscreen modals on mobile devices */
/*@media (max-width: 768px) {
    .rz-dialog {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        width: 100vw !important;
        height: 100vh !important;
        max-width: 100vw !important;
        max-height: 100vh !important;
        margin: 0 !important;
        border-radius: 0 !important;
        transform: none !important;
    }

        .rz-dialog .rz-dialog-content {
            height: calc(100vh - 56px) !important;
            max-height: calc(100vh - 56px) !important;
            overflow-y: auto !important;
            padding: 16px !important;
        }

        .rz-dialog .rz-dialog-titlebar {
            border-radius: 0 !important;
        }

    .rz-dialog-mask {
        background-color: rgba(0, 0, 0, 0.7) !important;
    }
}
*/



/* ===========================================
   LOGGED-IN DASHBOARD LAYOUT (No browser scroll when viewing reservations)
   =========================================== */

/* Only when logged in and viewing reservations */
/* Uses flexbox to fill available space - parent chain must also be flex */
.page-wrapper-logged-in {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 !important;
    min-height: 0 !important; /* Critical: allows flex item to shrink below content size */
    overflow: hidden !important;
    max-width: 100% !important;
}

.page-header-logged-in {
    flex-shrink: 0 !important;
}

.reservations-wrapper {
    flex: 1 !important;
    min-height: 0 !important;
    max-height: 100% !important;
    height: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
}

/* Prevent body scroll when viewing logged-in dashboard */
/* Make the entire layout height-constrained for proper flexbox sizing */
html:has(.page-wrapper-logged-in),
body:has(.page-wrapper-logged-in) {
    height: 100vh;
    overflow: hidden;
}

body:has(.page-wrapper-logged-in) .page {
    height: 100vh;
    display: flex;
    flex-direction: column;
}

body:has(.page-wrapper-logged-in) .page > main {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

body:has(.page-wrapper-logged-in) .page > main > .content {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    overflow: hidden;
    padding-bottom: 0 !important; /* Remove bottom padding that creates extra space */
}

/* The booking page container wraps the page content - must participate in flex chain */
body:has(.page-wrapper-logged-in) #booking-page-container {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

/* The page-wrapper-logged-in is on a nested main element inside booking-page-container */
body:has(.page-wrapper-logged-in) #booking-page-container > .page-wrapper-logged-in {
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

/* Mobile-specific fixes */
@media (max-width: 768px) {
    /* Lock viewport height on mobile */
    html:has(.page-wrapper-logged-in),
    body:has(.page-wrapper-logged-in) {
        height: 100vh !important;
        overflow: hidden !important;
    }

    /* Ensure reservations wrapper takes full available height on mobile */
    .reservations-wrapper {
        flex: 1 !important;
        min-height: 0 !important;
        overflow: hidden !important;
    }

        /* Target the actual component element */
        .reservations-wrapper > * {
            height: 100% !important;
            max-height: 100% !important;
        }
}

/* Fallback for browsers without :has() support - use .logged-in-mobile class on body */
body.logged-in-mobile {
    height: 100vh !important;
    overflow: hidden !important;
}

body.logged-in-mobile .page {
    height: 100vh;
    display: flex;
    flex-direction: column;
}

body.logged-in-mobile .page > main {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

body.logged-in-mobile .page > main > .content {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    overflow: hidden;
    padding-bottom: 0 !important;
}

body.logged-in-mobile #booking-page-container {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

body.logged-in-mobile #booking-page-container > .page-wrapper-logged-in {
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

/* ===============================
   Address Button - Dynamic Border States
   Reusable: apply .address-button-picker to wrapper,
   .has-value when filled, .address-button to the button
   =============================== */
/* Empty state - bold brand-blue border, pill shape */
.address-button-picker .rz-button.address-button {
    border: 2px solid var(--brand-blue) !important;
    border-radius: var(--field-radius, 12px) !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

/* Filled state - subtle border */
.address-button-picker.has-value .rz-button.address-button {
    border: 1px solid var(--field-border, #d9d9d9) !important;
    border-radius: var(--field-radius, 12px) !important;
}

/* Hover on empty state */
.address-button-picker:not(.has-value) .rz-button.address-button:hover {
    border-color: var(--brand-blue-dark) !important;
    box-shadow: 0 0 0 3px rgba(41, 99, 168, 0.1);
}

/* Hover on filled state */
.address-button-picker.has-value .rz-button.address-button:hover {
    border-color: var(--brand-blue) !important;
}

/* Focus state - prominent visibility for keyboard navigation */
.address-button-picker .rz-button.address-button:focus {
    border-color: var(--brand-blue) !important;
    box-shadow: 0 0 0 3px rgba(41, 99, 168, 0.4), 0 0 10px rgba(41, 99, 168, 0.3) !important;
    outline: none !important;
}

/* Address button height - base and mobile */
.address-button-picker .rz-button.address-button {
    min-height: 56px !important;
}

@media (max-width: 480px) {
    .address-button-picker .rz-button.address-button {
        min-height: 70px !important;
    }
}

/* ===================================
   FLIGHT COMPONENT BUTTON FOCUS STATES
   (DateTime, Airline, Flight buttons)
   =================================== */
.rz-button.datetime-button:focus,
.rz-button.airline-button:focus,
.rz-button.flightinfo-button:focus {
    border-color: var(--brand-blue) !important;
    box-shadow: 0 0 0 3px rgba(41, 99, 168, 0.35), 0 0 8px rgba(41, 99, 168, 0.25) !important;
    outline: none !important;
}

/* ===================================
   AUTOCOMPLETE DROPDOWN SECTION HEADERS
   (Global styles for JS-rendered dropdown)
   =================================== */
.section-header {
    padding: 10px 14px 6px !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    color: var(--brand-blue-dark, var(--brand-blue-dark)) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.8px !important;
    background: linear-gradient(to bottom, #e8eef5, #f4f6f9) !important;
    border-left: 3px solid var(--brand-blue, var(--brand-blue)) !important;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
}

    .section-header .material-icons {
        font-size: 16px !important;
        color: var(--brand-blue, var(--brand-blue)) !important;
    }

/* Mobile */
@media (max-width: 480px) {
    .section-header {
        padding: 8px 12px 5px !important;
        font-size: 10px !important;
    }
}
/* Route Hint Styles - Add to site.css or global stylesheet */

.route-hint {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-weight: 500;
    color: #444;
    font-size: 0.95em;
}

    .route-hint .material-icons {
        font-size: 20px;
        color: var(--brand-blue, #005EB8);
        vertical-align: middle;
    }

        .route-hint .material-icons.arrow {
            font-size: 18px;
            color: #666;
            margin: 0 4px;
        }



.content.px-4:has(.page-wrapper-logged-in) {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

body.logged-in-mobile .content.px-4 {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

body.logged-in-mobile .navbar {
    margin-bottom: 0 !important;
}



/* Shuttle Loader Animation - Global to avoid CSS isolation issues */
.shuttle-loader {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}

    .shuttle-loader i {
        font-size: 2rem;
        color: var(--brand-blue, var(--brand-blue));
        animation: drive 1.2s ease-in-out infinite;
    }

    .shuttle-loader .road {
        width: 60px;
        height: 3px;
        background: repeating-linear-gradient(90deg, #ccc 0px, #ccc 8px, transparent 8px, transparent 16px);
        border-radius: 2px;
        animation: roadMove 0.4s linear infinite;
    }

@keyframes drive {
    0%, 100% {
        transform: translateX(-3px) rotate(0deg);
    }

    25% {
        transform: translateX(0px) rotate(-1deg);
    }

    50% {
        transform: translateX(3px) rotate(0deg);
    }

    75% {
        transform: translateX(0px) rotate(1deg);
    }
}

@keyframes roadMove {
    0% {
        background-position: 0 0;
    }

    100% {
        background-position: -16px 0;
    }
}

.loading-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 20px 10px;
}

.loading-message {
    text-align: center;
    color: var(--brand-blue-dark);
    font-size: 1em;
    margin: 0;
}

/* ===============================
   Hourly Duration - Compact Inline Style
   =============================== */
.hourly-duration-section {
    margin: 8px 0 12px 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    flex-wrap: wrap !important;
}

.hourly-duration-label {
    font-size: 0.8rem !important;
    font-weight: 500 !important;
    color: var(--brand-blue, var(--brand-blue)) !important;
    margin-bottom: 0 !important;
    white-space: nowrap !important;
}

.hourly-duration-row {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}

.hourly-dropdown-wrapper {
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
}

    .hourly-dropdown-wrapper .rz-dropdown {
        min-height: 36px !important;
        padding: 4px 8px !important;
        min-width: 70px !important;
    }

.hourly-dropdown-suffix {
    font-size: 0.8rem !important;
    color: var(--brand-blue, var(--brand-blue)) !important;
    font-weight: 500 !important;
}

/* ===============================
   Pickup Time Row - restore pill style for label
   and center the entire button (narrower width)
   =============================== */
.pickup-time-row {
    display: flex !important;
    justify-content: center !important;
    width: 100% !important;
    margin-top: 12px !important;
}

    .pickup-time-row > .float-dropdown,
    .pickup-time-row > .pickup-time-dropdown,
    .pickup-time-row .float-dropdown.pickup-time-dropdown {
        width: 500px !important;
        min-width: 360px !important;
        max-width: 94% !important;
        flex: 0 0 500px !important;
    }

    /* Position the badge to the right - stronger override */
    .pickup-time-row .float-dropdown .pickup-time-badge,
    .pickup-time-badge {
        position: absolute !important;
        right: 8px !important;
        left: auto !important;
        top: -12px !important;
        transform: none !important;
    }

/* Mobile - allow full width */
@media (max-width: 540px) {
    .pickup-time-row > .float-dropdown,
    .pickup-time-row > .pickup-time-dropdown,
    .pickup-time-row .float-dropdown.pickup-time-dropdown {
        width: 100% !important;
        flex: 1 1 100% !important;
    }
}

.section-frame .pickup-time-row .float-dropdown .float-label,
.pickup-time-row .float-dropdown .float-label {
    border: 1px solid #ccc !important;
    padding: 2px 10px !important;
    font-weight: 500 !important;
    border-radius: 12px !important;
    color: #666 !important;
}

/* Make the pickup time button not full width */
.pickup-time-row .float-dropdown .rz-button {
    width: 100% !important;
}



/* =====================================================
   ADD THIS TO YOUR GLOBAL app.css or site.css FILE
   (Since Blazor CSS isolation isn't working properly)
   ===================================================== */

/* =====================================================
   FIND MY TRIP CARD - BookingPage guest section
   ===================================================== */

.find-trip-card {
    background: linear-gradient(135deg, #f5f9ff 0%, #eef4fb 100%);
    border: 2px solid #d0e3f0;
    border-radius: 12px;
    padding: 20px;
    margin: 0 auto 24px auto;
    max-width: 400px;
    text-align: center;
}

.find-trip-header {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-weight: 600;
    color: var(--brand-blue-dark);
    margin-bottom: 8px;
    font-size: 1rem;
}

    .find-trip-header i {
        color: var(--brand-blue);
        font-size: 1.2rem;
    }

.find-trip-description {
    color: #555;
    font-size: 0.9rem;
    margin-bottom: 16px;
    line-height: 1.4;
}

button.find-trip-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 12px 20px;
    background-color: transparent;
    border: 2px solid var(--brand-blue);
    border-radius: 50px;
    color: var(--brand-blue);
    font-weight: 600;
    font-size: 0.95rem;
    cursor: pointer;
    transition: all 0.2s ease;
    box-shadow: none;
}

    button.find-trip-button:hover {
        background-color: var(--brand-blue);
        color: white;
        border-color: var(--brand-blue);
    }

    button.find-trip-button:focus {
        outline: none;
        box-shadow: 0 0 0 3px rgba(41, 99, 168, 0.25);
    }

    button.find-trip-button i {
        font-size: 1rem;
        color: inherit;
    }

/* Responsive */
@media (max-width: 480px) {
    .find-trip-card {
        padding: 16px;
        margin-left: 12px;
        margin-right: 12px;
    }

    button.find-trip-button {
        padding: 10px 16px;
        font-size: 0.9rem;
    }
}

/* =====================================================
   FIND MY TRIP COMPONENT - Dialog styles
   Add these too if the component styles aren't loading
   ===================================================== */

.find-my-trip-container {
    width: 100%;
    max-width: 800px;
    margin: 0 auto;
    padding: 16px;
}

    .find-my-trip-container .search-form-card {
        background: #fff;
        border: 1px solid #e0e0e0;
        border-radius: 8px;
        padding: 24px;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    }

    .find-my-trip-container .form-header {
        display: flex;
        align-items: center;
        gap: 12px;
        margin-bottom: 16px;
    }

        .find-my-trip-container .form-header h3 {
            margin: 0;
            font-size: 1.5rem;
            color: #222;
        }

    .find-my-trip-container .form-description {
        color: #666;
        margin-bottom: 20px;
        font-size: 0.95rem;
    }

    .find-my-trip-container .form-fields {
        display: flex;
        flex-direction: column;
        gap: 16px;
    }

    .find-my-trip-container .form-field {
        display: flex;
        flex-direction: column;
        gap: 4px;
    }

        .find-my-trip-container .form-field label {
            font-size: 0.85rem;
            font-weight: 500;
            color: #555;
        }

    .find-my-trip-container .form-input {
        width: 100%;
        padding: 12px 14px;
        font-size: 1rem;
        border: 1px solid #ccc;
        border-radius: 6px;
        transition: border-color 0.2s, box-shadow 0.2s;
        box-sizing: border-box;
    }

        .find-my-trip-container .form-input:focus {
            outline: none;
            border-color: #4285F4;
            box-shadow: 0 0 0 3px rgba(66, 133, 244, 0.15);
        }

        .find-my-trip-container .form-input:disabled {
            background-color: #f5f5f5;
            cursor: not-allowed;
        }

    .find-my-trip-container .action-buttons {
        display: flex;
        justify-content: flex-end;
        gap: 12px;
        margin-top: 8px;
    }

    .find-my-trip-container .btn-reset {
        padding: 10px 20px;
        font-size: 0.95rem;
        font-weight: 500;
        border: 2px solid #6c757d;
        border-radius: 6px;
        background: transparent;
        color: #6c757d;
        cursor: pointer;
        transition: all 0.2s;
    }

        .find-my-trip-container .btn-reset:hover:not(:disabled) {
            background: rgba(108, 117, 125, 0.1);
        }

    .find-my-trip-container .btn-search {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 8px;
        padding: 10px 24px;
        font-size: 0.95rem;
        font-weight: 600;
        border: none;
        border-radius: 6px;
        background: #4285F4;
        color: white;
        cursor: pointer;
        transition: all 0.2s;
    }

        .find-my-trip-container .btn-search:hover:not(:disabled) {
            background: #3367D6;
        }

        .find-my-trip-container .btn-search:disabled,
        .find-my-trip-container .btn-search.disabled {
            background: #a0c4ff;
            cursor: not-allowed;
        }

    .find-my-trip-container .round-trip-note {
        color: #666;
        font-size: 0.85rem;
        margin-top: 12px;
        padding: 10px;
        background: #f8f9fa;
        border-radius: 4px;
    }

    .find-my-trip-container .recaptcha-container {
        display: flex;
        justify-content: center;
        margin: 8px 0;
    }

    .find-my-trip-container .loading-container {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 16px;
        padding: 60px 20px;
        color: #555;
    }

    .find-my-trip-container .loading-spinner {
        width: 40px;
        height: 40px;
        border: 4px solid #e0e0e0;
        border-top: 4px solid #4285F4;
        border-radius: 50%;
        animation: findtrip-spin 1s linear infinite;
    }

@keyframes findtrip-spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

.find-my-trip-container .spinner-small {
    width: 16px;
    height: 16px;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-top-color: white;
    border-radius: 50%;
    animation: findtrip-spin 0.8s linear infinite;
}

/* Results and reservation card styles */
.find-my-trip-container .results-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 20px;
    flex-wrap: wrap;
    gap: 12px;
}

    .find-my-trip-container .results-header h3 {
        margin: 0;
        font-size: 1.25rem;
        color: #222;
    }

.find-my-trip-container .back-button {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    background: transparent;
    border: 2px solid #4285F4;
    border-radius: 50px;
    color: #4285F4;
    font-size: 0.9rem;
    cursor: pointer;
}

    .find-my-trip-container .back-button:hover {
        background: rgba(66, 133, 244, 0.1);
    }

.find-my-trip-container .reservation-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.find-my-trip-container .reservation-item {
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    border: 1px solid #e0e0e0;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.05);
    border-radius: 8px;
    padding: 16px;
    background: #fff;
}

    .find-my-trip-container .reservation-item.canceled {
        opacity: 0.85;
        background: linear-gradient(135deg, #fff 0%, #fff5f5 100%);
        border-color: #f5c6cb;
    }

.find-my-trip-container .canceled-watermark {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 3rem;
    font-weight: 900;
    color: rgba(220, 53, 69, 0.25);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    pointer-events: none;
    z-index: 1;
}

.find-my-trip-container .trip-direction-label {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 12px;
    background: #E8F0FE;
    color: #4285F4;
    border-radius: 4px;
    font-size: 0.85rem;
    font-weight: 600;
    margin-bottom: 12px;
    width: fit-content;
}

.find-my-trip-container .reservation-details {
    display: flex;
    flex-direction: column;
    gap: 6px;
    position: relative;
    z-index: 2;
}

.find-my-trip-container .detail-line {
    display: flex;
    align-items: center;
    gap: 8px;
}

    .find-my-trip-container .detail-line.date-time {
        font-weight: 600;
        color: #222;
    }

.find-my-trip-container .location-indicator {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-right: 4px;
}

.find-my-trip-container .location-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background-color: #4285F4;
    border: 2px solid #3367D6;
}

.find-my-trip-container .location-line {
    width: 2px;
    height: 20px;
    background-image: linear-gradient(to bottom, #666 50%, transparent 50%);
    background-size: 2px 6px;
    background-repeat: repeat-y;
    margin-top: 2px;
}

.find-my-trip-container .detail-line.meta-info {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
    font-size: 0.9rem;
    color: #555;
    margin-top: 8px;
    padding-top: 8px;
    border-top: 1px solid #f0f0f0;
}

.find-my-trip-container .service-type-image {
    width: 50px;
    height: 28px;
    object-fit: contain;
}

.find-my-trip-container .service-name {
    font-weight: 500;
    color: #333;
}

.find-my-trip-container .meta-separator {
    color: #ccc;
}

.find-my-trip-container .trip-cost {
    font-weight: 600;
    color: #2ecc71;
}

.find-my-trip-container .reservation-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid #f0f0f0;
    position: relative;
    z-index: 2;
}

.find-my-trip-container .action-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    font-size: 0.9rem;
    border: 2px solid #4285F4;
    border-radius: 50px;
    background: transparent;
    color: #4285F4;
    cursor: pointer;
}

    .find-my-trip-container .action-btn:hover {
        background-color: rgba(66, 133, 244, 0.1);
    }

.find-my-trip-container .not-found-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 16px;
    padding: 60px 20px;
    text-align: center;
}

    .find-my-trip-container .not-found-container h3 {
        margin: 0;
        color: #dc3545;
    }

    .find-my-trip-container .not-found-container p {
        color: #666;
        max-width: 400px;
        margin: 0;
    }



/* =====================================================
   (Required because .trip-details-hint is rendered via MarkupString)
   ===================================================== */

.trip-details-hint {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

    .trip-details-hint .material-icons {
        font-size: 1.1em;
    }




/* ============================================
   Vehicle Capacity Table Styles
   Add this to site.css for ServiceTypeSelectionComponent
   ============================================ */

/* Capacity Exceeded Section - Not styled as an error */
.capacity-exceeded-container {
    background-color: #f8f9fa;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    padding: 16px;
}

.capacity-exceeded-message {
    color: var(--brand-blue, var(--brand-blue));
    font-size: 1em;
    margin-bottom: 16px;
    line-height: 1.5;
}

.capacity-table-header {
    color: #333;
    margin-bottom: 8px;
    text-align: left;
}

/* Vehicle Capacity Table */
.vehicle-capacity-table {
    width: 100%;
    border-collapse: collapse;
    margin: 0 0 16px 0;
    font-size: 0.9em;
    background-color: #fff;
    border: 1px solid #dee2e6;
    border-radius: 6px;
    overflow: hidden;
}

    .vehicle-capacity-table thead {
        background-color: var(--brand-blue, var(--brand-blue));
        color: #fff;
    }

    .vehicle-capacity-table th {
        padding: 10px 12px;
        font-weight: 600;
    }

    .vehicle-capacity-table .vehicle-name-header {
        text-align: left;
    }

    .vehicle-capacity-table .capacity-header {
        text-align: center;
        width: 50px;
    }

    .vehicle-capacity-table .price-header {
        text-align: right;
        width: 90px;
    }

    .vehicle-capacity-table th .material-icons {
        font-size: 1.1em;
        vertical-align: middle;
    }

    .vehicle-capacity-table tbody tr {
        border-bottom: 1px solid #e0e0e0;
    }

        .vehicle-capacity-table tbody tr:last-child {
            border-bottom: none;
        }

        .vehicle-capacity-table tbody tr.alt-row {
            background-color: #f8f9fa;
        }

    .vehicle-capacity-table td {
        padding: 8px 12px;
        color: #333;
    }

    .vehicle-capacity-table .vehicle-name-cell {
        text-align: left;
    }

    .vehicle-capacity-table .capacity-cell {
        text-align: center;
        font-weight: 500;
        color: var(--brand-blue-dark, var(--brand-blue-dark));
    }

    .vehicle-capacity-table .price-cell {
        text-align: right;
        font-weight: 600;
        color: var(--brand-blue-dark, var(--brand-blue-dark));
    }

.capacity-actions {
    margin-top: 12px;
}

    .capacity-actions .btn {
        min-width: 100px;
    }


/* ============================================
   SHUTTLE LOADER VARIANTS
   ============================================ */

/* Light variant for use on dark/colored backgrounds (e.g., inside buttons) */
.shuttle-loader.shuttle-loader-light i {
    color: white;
}

.shuttle-loader.shuttle-loader-light .road {
    background: repeating-linear-gradient(90deg, rgba(255,255,255,0.7) 0px, rgba(255,255,255,0.7) 6px, transparent 6px, transparent 12px);
}

/* Smaller inline variant for buttons */
.shuttle-loader.shuttle-loader-sm {
    gap: 4px;
    display: inline-flex;
}

    .shuttle-loader.shuttle-loader-sm i {
        font-size: 1.25rem;
    }

    .shuttle-loader.shuttle-loader-sm .road {
        width: 40px;
        height: 2px;
    }

/* Large variant for overlay/modal use */
.shuttle-loader.shuttle-loader-lg {
    gap: 12px;
}

    .shuttle-loader.shuttle-loader-lg i {
        font-size: 4rem;
        color: var(--brand-blue, var(--brand-blue));
    }

    .shuttle-loader.shuttle-loader-lg .road {
        width: 120px;
        height: 5px;
    }

/* ExecuCar brand: show car instead of van */
/* Hide the van icon and show a car (side profile) icon using CSS */
[data-brand="ExecuCar"] .shuttle-loader i.fa-van-shuttle::before,
[data-brand="ExecuCar"] .shuttle-loader i.fa-shuttle-van::before {
    content: "\f5e4"; /* Font Awesome car-side icon (profile view) */
}

/* ============================================
   BOOKING OVERLAY - Full screen loading state
   ============================================ */
.booking-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(255, 255, 255, 0.95);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    animation: fadeIn 0.2s ease-out;
}

.booking-overlay-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 40px;
}

.booking-overlay-message {
    margin-top: 24px;
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--brand-blue-dark, var(--brand-blue-dark));
}

.booking-overlay-submessage {
    margin-top: 8px;
    font-size: 1rem;
    color: #666;
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

/* ========================================
   Edit Gratuity Dialog
   ======================================== */
.gratuity-dialog-content {
    display: flex;
    flex-direction: column;
    min-width: 320px;
    max-width: 450px;
}

.gratuity-dialog-body {
    padding: 0 0 16px 0;
}

/* Quick Selection Buttons */
.gratuity-quick-select {
    display: grid !important;
    grid-template-columns: 1fr 1fr 1fr !important;
    gap: 8px !important;
    margin-bottom: 16px !important;
}

/* Reset browser button defaults and apply custom styling */
/* Target within Radzen dialog context for maximum specificity */
.rz-dialog .gratuity-option-btn,
.rz-dialog-content .gratuity-option-btn,
.gratuity-quick-select .gratuity-option-btn,
.gratuity-dialog-content .gratuity-option-btn,
button.gratuity-option-btn {
    all: unset !important;
    display: block !important;
    padding: 12px 8px !important;
    border: 2px solid #e0e0e0 !important;
    border-radius: 8px !important;
    background-color: white !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #333 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    font-family: inherit !important;
    line-height: 1.2 !important;
    text-align: center !important;
    box-sizing: border-box !important;
}

.rz-dialog .gratuity-option-btn:hover,
.rz-dialog-content .gratuity-option-btn:hover,
.gratuity-quick-select .gratuity-option-btn:hover,
.gratuity-dialog-content .gratuity-option-btn:hover,
button.gratuity-option-btn:hover {
    border-color: var(--brand-blue-dark) !important;
    background-color: #f5f8fc !important;
}

.rz-dialog .gratuity-option-btn.selected,
.rz-dialog-content .gratuity-option-btn.selected,
.gratuity-quick-select .gratuity-option-btn.selected,
.gratuity-dialog-content .gratuity-option-btn.selected,
button.gratuity-option-btn.selected {
    border-color: var(--brand-blue-dark) !important;
    background-color: var(--brand-blue-dark) !important;
    color: white !important;
}

.rz-dialog .gratuity-option-btn.tip-in-vehicle,
.rz-dialog-content .gratuity-option-btn.tip-in-vehicle,
.gratuity-quick-select .gratuity-option-btn.tip-in-vehicle,
.gratuity-dialog-content .gratuity-option-btn.tip-in-vehicle,
button.gratuity-option-btn.tip-in-vehicle {
    grid-column: span 3 !important;
    background-color: #f9f9f9 !important;
}

.rz-dialog .gratuity-option-btn.tip-in-vehicle.selected,
.rz-dialog-content .gratuity-option-btn.tip-in-vehicle.selected,
.gratuity-quick-select .gratuity-option-btn.tip-in-vehicle.selected,
.gratuity-dialog-content .gratuity-option-btn.tip-in-vehicle.selected,
button.gratuity-option-btn.tip-in-vehicle.selected {
    background-color: #666 !important;
    border-color: #666 !important;
    color: white !important;
}

/* Custom Percentage Input */
.gratuity-custom-input {
    margin-bottom: 16px;
    padding: 12px;
    background: #f5f8fc;
    border-radius: 8px;
}

.custom-percent-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.custom-percent-row label {
    font-size: 14px;
    color: #666;
}

.percent-input-wrapper {
    display: flex;
    align-items: center;
    gap: 4px;
}

.percent-input {
    width: 85px;
    height: 40px;
    padding: 8px 12px;
    border: 1px solid #ddd;
    border-radius: 6px;
    font-size: 16px;
    text-align: right;
}

.percent-input:focus {
    outline: none;
    border-color: var(--brand-blue-dark);
}

.percent-symbol {
    font-size: 16px;
    font-weight: 600;
    color: #333;
}

/* Custom spinner buttons for gratuity inputs */
.gratuity-dialog-content .spinner-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border: 1px solid #ddd;
    border-radius: 6px;
    background: #f5f5f5;
    color: #333;
    cursor: pointer;
    transition: all 0.15s ease;
    flex-shrink: 0;
}

.gratuity-dialog-content .spinner-btn:hover {
    background: #e0e0e0;
    border-color: #ccc;
}

.gratuity-dialog-content .spinner-btn:active {
    background: #d0d0d0;
    transform: scale(0.95);
}

.gratuity-dialog-content .spinner-btn i {
    font-size: 12px;
}

.gratuity-dialog-content .spinner-btn.small {
    width: 28px;
    height: 28px;
}

.gratuity-dialog-content .spinner-btn.small i {
    font-size: 10px;
}

/* Total Gratuity Row */
.gratuity-total-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    background: #f0f4f8;
    border-radius: 8px;
    margin-bottom: 16px;
}

.gratuity-total-row .total-label {
    font-size: 14px;
    font-weight: 600;
    color: #333;
}

.gratuity-total-row .total-amount {
    font-size: 18px;
    font-weight: 700;
    color: var(--brand-blue-dark);
}

/* Per-Trip Section */
.per-trip-section {
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    overflow: hidden;
}

.per-trip-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    background: #f9f9f9;
    cursor: pointer;
    font-size: 14px;
    font-weight: 600;
    color: #333;
}

.per-trip-header:hover {
    background: #f0f0f0;
}

.per-trip-header i {
    color: #666;
    font-size: 12px;
}

.per-trip-list {
    padding: 8px;
}

.trip-row {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 12px;
    border-bottom: 1px solid #eee;
}

.trip-row:last-child {
    border-bottom: none;
}

.trip-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.trip-route {
    font-size: 14px;
    font-weight: 600;
    color: #333;
}

.trip-fare {
    font-size: 12px;
    color: #666;
}

.trip-gratuity {
    display: flex;
    align-items: center;
}

.gratuity-included {
    font-size: 13px;
    color: #28a745;
    font-weight: 500;
    font-style: italic;
}

.gratuity-not-allowed {
    font-size: 13px;
    color: #6c757d;
    font-weight: 500;
    font-style: italic;
}

.trip-gratuity-input {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.input-toggle {
    display: flex !important;
    border: 1px solid #ddd !important;
    border-radius: 6px !important;
    overflow: hidden !important;
}

/* Toggle buttons within Radzen dialog context */
.rz-dialog .toggle-btn,
.rz-dialog-content .toggle-btn,
.input-toggle .toggle-btn,
.gratuity-dialog-content .toggle-btn,
button.toggle-btn {
    all: unset !important;
    display: block !important;
    padding: 6px 12px !important;
    border: none !important;
    background-color: white !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #666 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    font-family: inherit !important;
}

.rz-dialog .input-toggle .toggle-btn:first-child,
.rz-dialog-content .input-toggle .toggle-btn:first-child,
.input-toggle .toggle-btn:first-child,
.gratuity-dialog-content .input-toggle .toggle-btn:first-child,
button.toggle-btn:first-child {
    border-right: 1px solid #ddd !important;
}

.rz-dialog .toggle-btn.active,
.rz-dialog-content .toggle-btn.active,
.input-toggle .toggle-btn.active,
.gratuity-dialog-content .toggle-btn.active,
button.toggle-btn.active {
    background-color: var(--brand-blue-dark) !important;
    color: white !important;
}

.rz-dialog .toggle-btn:hover:not(.active),
.rz-dialog-content .toggle-btn:hover:not(.active),
.input-toggle .toggle-btn:hover:not(.active),
.gratuity-dialog-content .toggle-btn:hover:not(.active),
button.toggle-btn:hover:not(.active) {
    background-color: #f5f5f5 !important;
}

.value-input-wrapper {
    display: flex;
    align-items: center;
    gap: 2px;
}

.value-input {
    width: 85px;
    height: 40px;
    padding: 6px 8px;
    border: 1px solid #ddd;
    border-radius: 6px;
    font-size: 16px;
    text-align: right;
}

.value-input:focus {
    outline: none;
    border-color: var(--brand-blue-dark);
}

.value-input.dollar-input {
    padding-left: 4px;
    text-align: right;
}

.input-symbol {
    font-size: 14px;
    font-weight: 600;
    color: #333;
}

.input-symbol.dollar {
    margin-right: -4px;
}

.calculated-amount {
    font-size: 13px;
    color: #666;
    margin-left: auto;
}

/* Footer */
.gratuity-dialog-footer {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    padding-top: 16px;
    border-top: 1px solid #eee;
}

/* Hide native number input spinners - using custom +/- buttons instead */
.gratuity-dialog-content input[type="number"]::-webkit-inner-spin-button,
.gratuity-dialog-content input[type="number"]::-webkit-outer-spin-button {
    -webkit-appearance: none !important;
    appearance: none !important;
    margin: 0 !important;
}

.gratuity-dialog-content input[type="number"] {
    -moz-appearance: textfield !important;
    appearance: textfield !important;
}

/* Responsive adjustments for gratuity dialog */
@media (max-width: 400px) {
    .gratuity-dialog-content {
        min-width: 280px;
    }

    .gratuity-quick-select {
        grid-template-columns: 1fr 1fr !important;
    }

    .rz-dialog .gratuity-option-btn.tip-in-vehicle,
    .gratuity-quick-select .gratuity-option-btn.tip-in-vehicle,
    .gratuity-option-btn.tip-in-vehicle {
        grid-column: span 2 !important;
    }

    .trip-gratuity-input {
        flex-direction: column;
        align-items: flex-start;
    }

    .calculated-amount {
        margin-left: 0;
        margin-top: 4px;
    }
}

/* ===============================
   Chat Widget Visibility
   =============================== */

/* Hide chat widget when booking modal is open (covers continue button) */
body:has(.icd-container) .chat-widget-container {
    display: none !important;
}


