/* Shared booking form patterns for Bus, Hotel, Ticket, Car and future booking modules. */
body:not(.admin-layout) .site-booking-page,
body:not(.admin-layout) .bus-booking-page,
body:not(.admin-layout) .hotel-booking-page,
body:not(.admin-layout) .cruise-booking-page,
body:not(.admin-layout) .ticket-book,
body:not(.admin-layout) .cr-book {
    padding: 30px 0 52px;
    background: var(--cbe-page-gradient, linear-gradient(180deg, #f5f9fd 0, #fff 220px));
    color: var(--cbe-ink, #17324d);
}

body:not(.admin-layout) .site-booking-panel,
body:not(.admin-layout) .ticket-panel,
body:not(.admin-layout) .cr-panel,
body:not(.admin-layout) .hotel-booking-box,
body:not(.admin-layout) .cruise-box {
    min-width: 0;
    padding: 22px;
}

body:not(.admin-layout) .site-booking-panel h1,
body:not(.admin-layout) .site-booking-panel h2,
body:not(.admin-layout) .site-booking-panel h3 {
    margin-top: 0;
    color: var(--cbe-ink, #17324d);
}

body:not(.admin-layout) .site-booking-intro {
    margin: 0 0 18px;
    color: var(--cbe-muted, #5d7287);
    line-height: 1.7;
}

body:not(.admin-layout) .site-booking-grid,
body:not(.admin-layout) .ticket-form-grid,
body:not(.admin-layout) .cr-grid,
body:not(.admin-layout) .hotel-booking-fields,
body:not(.admin-layout) .cruise-fields {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

body:not(.admin-layout) .site-booking-grid--3,
body:not(.admin-layout) .ticket-form-grid--3,
body:not(.admin-layout) .cr-grid--3,
body:not(.admin-layout) .cruise-fields--three {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

body:not(.admin-layout) .site-booking-grid--4,
body:not(.admin-layout) .hotel-booking-fields {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

body:not(.admin-layout) .site-booking-field,
body:not(.admin-layout) .ticket-field,
body:not(.admin-layout) .cr-field,
body:not(.admin-layout) .hotel-booking-field,
body:not(.admin-layout) .cruise-field {
    min-width: 0;
}

body:not(.admin-layout) .site-booking-field--note {
    margin-top: 16px;
}

body:not(.admin-layout) .site-booking-label,
body:not(.admin-layout) .site-booking-field > label,
body:not(.admin-layout) .ticket-field > label,
body:not(.admin-layout) .cr-field > label,
body:not(.admin-layout) .hotel-booking-field > label,
body:not(.admin-layout) .cruise-field > label {
    display: block;
    margin-bottom: 7px;
    color: var(--cbe-ink, #17324d);
    font-weight: 800;
    line-height: 1.35;
}

body:not(.admin-layout) .site-booking-field .site-form-field,
body:not(.admin-layout) .ticket-field .site-form-field,
body:not(.admin-layout) .cr-field .site-form-field,
body:not(.admin-layout) .hotel-booking-field .site-form-field,
body:not(.admin-layout) .cruise-field .site-form-field {
    width: 100%;
    min-height: 46px;
    border-radius: 14px;
}

body:not(.admin-layout) .site-booking-control {
    display: block;
    width: 100%;
    min-height: 46px;
    padding: 11px 14px;
    border: 1px solid var(--cbe-line, #dce8f2);
    border-radius: 14px;
    background: #fff;
    color: var(--cbe-ink, #17324d);
    font: inherit;
    line-height: 1.35;
    box-shadow: none;
    transition: border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

body:not(.admin-layout) .site-booking-control:focus {
    border-color: var(--cbe-accent, #0e74a5);
    outline: 0;
    box-shadow: 0 0 0 4px rgba(14, 116, 165, .13);
}

body:not(.admin-layout) textarea.site-booking-control {
    min-height: 88px;
    resize: vertical;
}

body:not(.admin-layout) .site-booking-field .site-form-field--textarea,
body:not(.admin-layout) .ticket-field .site-form-field--textarea,
body:not(.admin-layout) .cr-field .site-form-field--textarea {
    align-items: flex-start;
    padding-top: 12px;
    padding-bottom: 12px;
}

body:not(.admin-layout) .site-booking-field textarea,
body:not(.admin-layout) .ticket-field textarea,
body:not(.admin-layout) .cr-field textarea,
body:not(.admin-layout) .hotel-booking-field textarea,
body:not(.admin-layout) .cruise-field textarea {
    min-height: 88px;
    resize: vertical;
}

body:not(.admin-layout) .site-booking-divider {
    height: 1px;
    margin: 22px 0;
    border: 0;
    background: var(--cbe-line, #dce8f2);
}

body:not(.admin-layout) .site-booking-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
    margin-top: 18px;
}

body:not(.admin-layout) .site-booking-check-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 16px;
    margin: 16px 0;
}

body:not(.admin-layout) .site-booking-check-row label {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    margin: 0;
    color: var(--cbe-muted, #5d7287);
    font-weight: 700;
}

body:not(.admin-layout) .site-booking-price-note,
body:not(.admin-layout) .ticket-price-note,
body:not(.admin-layout) .cr-price-note {
    color: var(--cbe-muted, #60748a);
    font-weight: 800;
}

body:not(.admin-layout) .site-booking-price-note strong,
body:not(.admin-layout) .ticket-price-note strong,
body:not(.admin-layout) .cr-price-note {
    color: var(--cbe-success, #00805e);
}

@media (max-width: 991px) {
    body:not(.admin-layout) .site-booking-grid--4,
    body:not(.admin-layout) .hotel-booking-fields,
    body:not(.admin-layout) .cruise-fields--three {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    body:not(.admin-layout) .site-booking-page,
    body:not(.admin-layout) .bus-booking-page,
    body:not(.admin-layout) .hotel-booking-page,
    body:not(.admin-layout) .cruise-booking-page,
    body:not(.admin-layout) .ticket-book,
    body:not(.admin-layout) .cr-book {
        padding: 24px 0 42px;
    }

    body:not(.admin-layout) .site-booking-panel,
    body:not(.admin-layout) .ticket-panel,
    body:not(.admin-layout) .cr-panel,
    body:not(.admin-layout) .hotel-booking-box,
    body:not(.admin-layout) .cruise-box {
        padding: 16px;
    }

    body:not(.admin-layout) .site-booking-grid,
    body:not(.admin-layout) .site-booking-grid--3,
    body:not(.admin-layout) .site-booking-grid--4,
    body:not(.admin-layout) .ticket-form-grid,
    body:not(.admin-layout) .ticket-form-grid--3,
    body:not(.admin-layout) .cr-grid,
    body:not(.admin-layout) .cr-grid--3,
    body:not(.admin-layout) .hotel-booking-fields,
    body:not(.admin-layout) .cruise-fields,
    body:not(.admin-layout) .cruise-fields--three {
        grid-template-columns: 1fr;
    }

    body:not(.admin-layout) .site-booking-actions {
        align-items: stretch;
        flex-direction: column;
    }

    body:not(.admin-layout) .site-booking-actions .site-button {
        justify-content: center;
        width: 100%;
    }
}
