/* Frontend booking form styling aligned with site design (see web reference HTML). */

/* Remove background from Elementor containers that might wrap the form */
.elementor-shortcode .mbc-frontend-wrapper,
.elementor-widget-shortcode .mbc-frontend-wrapper,
.elementor-widget-container .mbc-frontend-wrapper {
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
}

.mbc-frontend-wrapper {
    --mbc-primary-dark: #1e3a5f;
    --mbc-primary-blue: #2d5a87;
    --mbc-accent-cyan: #21bfcb;
    --mbc-accent-cyan-light: #3fd4df;
    --mbc-text-light: #ffffff;
    --mbc-text-muted: rgba(255, 255, 255, 0.8);
    --mbc-border-color: rgba(255, 255, 255, 0.25);
    --mbc-bg-glass: rgba(255, 255, 255, 0.05);

    /* Background removed - style with Elementor */
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
    border: none !important;
    box-shadow: none !important;
    max-width: none !important;
    margin: 0 !important;
    color: var(--mbc-text-light);
    box-sizing: border-box;
}

.mbc-booking-form {
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
}

.mbc-booking-form .elementor-form-fields-wrapper {
    display: flex;
    flex-wrap: wrap;
    margin-left: -8px;
    margin-right: -8px;
    margin-bottom: -20px;
    background: transparent !important;
    background-color: transparent !important;
}

.mbc-booking-form .elementor-field-group {
    display: block !important;
    padding-left: 8px;
    padding-right: 8px;
    margin-bottom: 20px;
    box-sizing: border-box;
}

.mbc-booking-form .elementor-col-50 {
    width: 50%;
}

.mbc-booking-form .elementor-col-100 {
    width: 100%;
}

.mbc-datetime-row {
    display: flex;
    gap: 0.6rem;
}

.mbc-date-wrapper {
    flex: 0 0 55%;
    position: relative;
}

.mbc-datetime-row .mbc-date {
    width: 100%;
    position: relative;
    z-index: 1;
    cursor: pointer;
}

.mbc-date-placeholder {
    position: absolute;
    left: 0.9rem;
    top: 0;
    bottom: 0;
    display: flex;
    align-items: center;
    pointer-events: none;
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.9rem;
    line-height: 1.4;
    transition: opacity 0.3s ease, visibility 0.3s ease;
    z-index: 2;
    white-space: nowrap;
    user-select: none;
    margin: 0;
    padding: 0;
}

.mbc-date-wrapper.has-value .mbc-date-placeholder {
    opacity: 0;
    visibility: hidden;
}

.mbc-datetime-row .mbc-time-wrapper {
    flex: 1 1 45%;
}

.mbc-datetime-row .mbc-date::-webkit-calendar-picker-indicator {
    filter: invert(1);
    cursor: pointer;
    position: relative;
    z-index: 3;
}

.mbc-datetime-row .mbc-date::-moz-focus-inner {
    color: #ffffff;
}

/* Hide native date input text when empty to show our placeholder */
.mbc-date:invalid::-webkit-datetime-edit {
    color: transparent !important;
    background: transparent !important;
    opacity: 0 !important;
}

.mbc-date:invalid::-webkit-datetime-edit-text {
    color: transparent !important;
    opacity: 0 !important;
}

.mbc-date:invalid::-webkit-datetime-edit-month-field,
.mbc-date:invalid::-webkit-datetime-edit-day-field,
.mbc-date:invalid::-webkit-datetime-edit-year-field {
    color: transparent !important;
    opacity: 0 !important;
}

/* Firefox - hide placeholder text */
.mbc-date:invalid {
    color: transparent !important;
    text-shadow: 0 0 0 rgba(255, 255, 255, 0) !important;
}

/* Additional Firefox support */
@-moz-document url-prefix() {
    .mbc-date:invalid {
        color: transparent !important;
    }
    
    .mbc-date:invalid::-moz-placeholder {
        color: transparent !important;
        opacity: 0 !important;
    }
}

/* Ensure placeholder is visible when input is empty */
.mbc-date-wrapper:not(.has-value) .mbc-date-placeholder {
    display: flex !important;
    opacity: 1 !important;
    visibility: visible !important;
}

.mbc-date:valid,
.mbc-date:valid::-webkit-datetime-edit,
.mbc-date:valid::-webkit-datetime-edit-text,
.mbc-date:valid::-webkit-datetime-edit-month-field,
.mbc-date:valid::-webkit-datetime-edit-day-field,
.mbc-date:valid::-webkit-datetime-edit-year-field {
    color: var(--mbc-text-light) !important;
}

/* Firefox - show text when valid */
.mbc-date:valid {
    color: var(--mbc-text-light);
}

.mbc-booking-form .elementor-field-label {
    display: block !important;
    margin-bottom: 0.4rem;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--mbc-text-light);
}

.mbc-booking-form .elementor-field-textual,
.mbc-booking-form .elementor-field.elementor-size-sm,
.mbc-booking-form textarea.elementor-field {
    width: 100%;
    padding: 0.7rem 0.9rem;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid var(--mbc-border-color);
    border-radius: 8px;
    color: var(--mbc-text-light);
    font-size: 0.9rem;
    line-height: 1.4;
    transition: all 0.3s ease;
}

.mbc-booking-form .elementor-field-textual::placeholder,
.mbc-booking-form textarea.elementor-field::placeholder {
    color: rgba(255, 255, 255, 0.5);
}

.mbc-booking-form .elementor-field-textual:focus,
.mbc-booking-form textarea.elementor-field:focus,
.mbc-booking-form select.elementor-field-textual:focus {
    outline: none;
    border-color: var(--mbc-accent-cyan);
    background: rgba(255, 255, 255, 0.12);
}

.mbc-booking-form textarea.elementor-field {
    min-height: 100px;
    resize: vertical;
}

.mbc-booking-form .elementor-select-wrapper {
    position: relative;
}

.mbc-booking-form .select-caret-down-wrapper {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
}

.mbc-booking-form .select-caret-down-wrapper svg {
    width: 14px;
    height: 14px;
    fill: #adb5bd;
}

.mbc-booking-form select.elementor-field-textual {
    appearance: none;
    background-color: rgba(255, 255, 255, 0.08);
    padding-right: 2.5rem;
    color: var(--mbc-text-light);
}

/* Fix Windows dropdown styling - make options readable with dark text on white background */
.mbc-booking-form select.elementor-field-textual option {
    background-color: #ffffff !important;
    background: #ffffff !important;
    color: #333333 !important;
    color: #212529 !important;
    padding: 0.5rem 0.8rem !important;
}

/* Selected/highlighted option - blue background with white text */
.mbc-booking-form select.elementor-field-textual option:checked,
.mbc-booking-form select.elementor-field-textual option[selected] {
    background-color: var(--mbc-accent-cyan) !important;
    background: var(--mbc-accent-cyan) !important;
    color: var(--mbc-text-light) !important;
    color: #ffffff !important;
}

/* For browsers that support option:hover (limited support) */
.mbc-booking-form select.elementor-field-textual option:hover {
    background-color: var(--mbc-accent-cyan) !important;
    background: var(--mbc-accent-cyan) !important;
    color: #ffffff !important;
}

/* When select is focused/open, ensure options are readable */
.mbc-booking-form select.elementor-field-textual:focus option {
    background-color: #ffffff !important;
    background: #ffffff !important;
    color: #212529 !important;
}

.mbc-booking-form select.elementor-field-textual:focus option:checked,
.mbc-booking-form select.elementor-field-textual:focus option[selected] {
    background-color: var(--mbc-accent-cyan) !important;
    background: var(--mbc-accent-cyan) !important;
    color: #ffffff !important;
}

.mbc-booking-form .elementor-acceptance-field {
    width: 18px !important;
    min-width: 18px !important;
    max-width: 18px !important;
    height: 18px;
    margin-right: 0.75rem;
    margin-top: 2px;
    cursor: pointer;
    accent-color: var(--mbc-accent-cyan);
    flex-shrink: 0 !important;
    flex-grow: 0 !important;
}

.mbc-booking-form .elementor-field-type-acceptance .elementor-field-subgroup {
    display: flex !important;
    align-items: center;
    justify-content: center !important;
    width: 100%;
    text-align: left !important;
}

.mbc-booking-form .elementor-field-type-acceptance .elementor-field-option {
    display: flex !important;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    width: 100%;
}

.mbc-booking-form .elementor-field-type-acceptance .elementor-field-option label {
    font-size: 0.8rem;
    color: var(--mbc-text-muted);
    flex: 1 1 auto;
    margin: 0;
}

.mbc-booking-form .elementor-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.75rem 1.5rem;
    border-radius: 999px;
    border: none;
    background: var(--mbc-accent-cyan);
    color: var(--mbc-primary-dark);
    font-weight: 700;
    text-transform: uppercase;
    font-size: 0.85rem;
    letter-spacing: 1px;
    cursor: pointer;
    transition: all 0.3s ease;
    width: 100%;
}

.mbc-booking-form .elementor-button:hover {
    background: var(--mbc-accent-cyan-light);
    transform: translateY(-2px);
    box-shadow: 0 15px 40px rgba(33, 191, 203, 0.35);
}

.mbc-slots {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.mbc-slot-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.5rem 0.9rem;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.25);
    background: rgba(255, 255, 255, 0.06);
    color: var(--mbc-text-light);
    font-size: 0.85rem;
    cursor: pointer;
    transition: all 0.2s ease;
}

.mbc-slot-btn:hover {
    border-color: var(--mbc-accent-cyan);
    background: rgba(33, 191, 203, 0.15);
}

.mbc-slot-btn.selected {
    background: var(--mbc-accent-cyan);
    border-color: var(--mbc-accent-cyan);
    color: var(--mbc-primary-dark);
}

.mbc-message {
    margin-top: 0.75rem;
    font-size: 0.9rem;
}

.mbc-message.mbc-success {
    color: #7bdcb5;
}

.mbc-message.mbc-error {
    color: #ffb4b4;
}

@media (max-width: 768px) {
    .mbc-frontend-wrapper {
        padding: 0;
        border-radius: 0;
    }
    .mbc-booking-form .elementor-col-50 {
        width: 100%;
    }
}

