/**
 * Casalmar - VikBooking Custom Styles
 * Elegant, modern booking interface matching Casalmar design language
 */

/* ============================================
   VikBooking Variables
   ============================================ */
:root {
    --vb-primary: #006666;
    --vb-primary-hover: #004D4D;
    --vb-accent: #DFAD2B;
    --vb-surface: #ffffff;
    --vb-sand: #F7F5F2;
    --vb-bg: #F8F7F5;
    --vb-text: #1a1a1a;
    --vb-text-light: #6b7280;
    --vb-text-muted: #9ca3af;
    --vb-border: #e5e7eb;
    --vb-radius: 0.25rem;
    --vb-radius-sm: 0.25rem;
    --vb-radius-lg: 0.25rem;
    --vb-transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ============================================
   Hero Search Widget — Floating Booking Bar
   ============================================ */

/* Main container — card with shadow */
.csm-hero-booking .vbdivsearch {
    background: var(--vb-surface);
    border-radius: var(--vb-radius-lg);
    box-shadow: 0 4px 20px -4px rgba(0, 0, 0, 0.08);
    padding: 1.5rem 2rem;
    max-width: min(960px, 92%);
    margin: 0 auto;
}

/* Layout: two rows — labels on top, fields on bottom, all aligned */
.csm-hero-booking .vb-search-inner {
    align-items: stretch !important;
    gap: 0 !important;
    flex-wrap: nowrap !important;
}

/* Every direct child flush with no margin */
.csm-hero-booking .vb-search-inner > div {
    margin: 0 !important;
}

/* ALL labels — same size, position, spacing */
.csm-hero-booking .vb-search-inner label,
.csm-hero-booking .vbo-search-num-adults-entry > label,
.csm-hero-booking .vbo-search-num-children-entry > label {
    font-family: var(--csm-font-sans) !important;
    font-size: 0.625rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.12em !important;
    color: var(--vb-primary) !important;
    margin: 0 0 6px 0 !important;
    padding: 0 !important;
    line-height: 1 !important;
    display: block !important;
    text-align: left !important;
}

/* ALL inputs and selects — exact same height and look */
.csm-hero-booking .vb-search-inner input[type="text"],
.csm-hero-booking .vb-search-inner select {
    height: 48px !important;
    padding: 0 0.875rem !important;
    font-family: var(--csm-font-sans) !important;
    font-size: 0.875rem !important;
    color: var(--vb-text) !important;
    background: var(--vb-bg) !important;
    border: none !important;
    border-radius: 0 !important;
    box-sizing: border-box !important;
    margin: 0 !important;
    transition: var(--vb-transition) !important;
    vertical-align: top !important;
}

.csm-hero-booking .vb-search-inner input[type="text"]:focus,
.csm-hero-booking .vb-search-inner select:focus {
    outline: none !important;
    background: #eee9df !important;
}

/* ---- Dates: fused pair (input + icon = one visual block per date) ---- */
.csm-hero-booking .vbo-search-inpblock {
    flex: 1 !important;
}

/* Input group — make input and icon sit flush */
.csm-hero-booking .vbo-search-inpblock .input-group {
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: stretch !important;
}

/* Date inputs — no right rounding, icon completes the shape */
.csm-hero-booking .vbo-search-inpblock input[type="text"] {
    border-radius: var(--vb-radius-sm) 0 0 var(--vb-radius-sm) !important;
    flex: 0 1 auto !important;
    width: 130px !important;
    max-width: 140px !important;
}

/* Calendar icon — acts as right cap of the input */
.csm-hero-booking .vbo-caltrigger {
    position: static !important;
    transform: none !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 44px !important;
    height: 48px !important;
    background: var(--vb-bg) !important;
    border-radius: 0 var(--vb-radius-sm) var(--vb-radius-sm) 0 !important;
    color: var(--vb-primary) !important;
    opacity: 0.4;
    cursor: pointer !important;
    flex-shrink: 0;
    padding: 0 !important;
    border: none !important;
    font-size: 0.875rem !important;
    transition: var(--vb-transition) !important;
}

.csm-hero-booking .vbo-caltrigger:hover {
    opacity: 0.8;
    background: #eee9df !important;
}

/* Gap between the two date blocks */
.csm-hero-booking .vbo-search-inpblock-checkout {
    margin-left: 1rem !important;
}

/* ---- Guests: fused pair ---- */
.csm-hero-booking .vbo-search-num-racblock {
    margin: 0 0 0 1.25rem !important;
    align-self: stretch;
}

.csm-hero-booking .vbo-search-num-rooms {
    display: none !important;
}

.csm-hero-booking .vbo-search-num-aduchild-block {
    width: auto !important;
    float: none !important;
}

.csm-hero-booking .vbo-search-num-aduchild-entry {
    margin: 0 !important;
    align-items: stretch !important;
}

.csm-hero-booking .vbo-search-num-adults-entry {
    margin: 0 !important;
}

.csm-hero-booking .vbo-search-num-adults-entry {
    margin-right: 0.5rem !important;
}

.csm-hero-booking .vbo-search-num-adults-entry select {
    border-radius: var(--vb-radius-sm) !important;
    text-align-last: center;
    min-width: 72px;
}

.csm-hero-booking .vbo-search-num-children-entry select {
    border-radius: var(--vb-radius-sm) !important;
    text-align-last: center;
    min-width: 72px;
}

/* Hide "Habitación 1" & nights counter */
.csm-hero-booking .vbo-search-roomnum,
.csm-hero-booking #vbjstotnights {
    display: none !important;
}

/* ---- Submit button ---- */
.csm-hero-booking .vbdivsearch .vbo-search-submit {
    margin: 0 0 0 1.5rem !important;
    align-self: flex-end !important;
    padding-left: 0 !important;
}

.csm-hero-booking .vbdivsearch .vbo-search-submit .btn {
    background: var(--vb-primary) !important;
    color: var(--vb-surface) !important;
    border: none !important;
    border-radius: var(--vb-radius-sm) !important;
    height: 48px !important;
    padding: 0 2rem !important;
    font-family: var(--csm-font-sans) !important;
    font-size: 0.6875rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.15em !important;
    transition: background 0.2s ease !important;
    white-space: nowrap !important;
}

.csm-hero-booking .vbdivsearch .vbo-search-submit .btn:hover {
    background: var(--vb-primary-hover) !important;
}

/* ---- Tablet (up to 980px): dates row + guests/button row ---- */
@media only screen and (max-width: 980px) {
    .csm-hero-booking .vb-search-inner {
        flex-wrap: wrap !important;
        gap: 0.75rem !important;
    }

    /* Dates take full width as a row */
    .csm-hero-booking .vbo-search-inpblock {
        flex: 1 1 0 !important;
    }

    /* Guests block: inline with button */
    .csm-hero-booking .vbo-search-num-racblock {
        margin-left: 0 !important;
        flex: 0 0 auto !important;
    }

    /* Button fills remaining space */
    .csm-hero-booking .vbdivsearch .vbo-search-submit {
        margin-left: auto !important;
        flex: 1 !important;
    }

    .csm-hero-booking .vbdivsearch .vbo-search-submit .btn {
        width: 100% !important;
    }
}

/* ---- Mobile (up to 780px): everything stacked ---- */
@media only screen and (max-width: 780px) {
    .csm-hero-booking .vbdivsearch {
        padding: 1.25rem 1rem;
        border-radius: var(--vb-radius);
    }

    /* Override VikBooking's flex:100% to keep our layout */
    .csm-hero-booking .vb-search-inner {
        flex-wrap: wrap !important;
        gap: 0.75rem !important;
    }

    .csm-hero-booking .vb-search-inner > div {
        margin: 0 !important;
    }

    /* Each date field: full width */
    .csm-hero-booking .vbo-search-inpblock {
        flex: 1 1 calc(50% - 0.375rem) !important;
    }

    .csm-hero-booking .vbo-search-inpblock-checkout {
        margin-left: 0 !important;
    }

    /* Date inputs expand to fill */
    .csm-hero-booking .vbo-search-inpblock input[type="text"] {
        flex: 1 !important;
        width: auto !important;
        max-width: none !important;
    }

    /* Guests: full row, side by side */
    .csm-hero-booking .vbo-search-num-racblock {
        flex: 1 1 100% !important;
        margin: 0 !important;
    }

    .csm-hero-booking .vbo-search-num-aduchild-block {
        width: 100% !important;
    }

    .csm-hero-booking .vbo-search-num-aduchild-entry {
        display: flex !important;
        gap: 0.5rem;
    }

    .csm-hero-booking .vbo-search-num-adults-entry,
    .csm-hero-booking .vbo-search-num-children-entry {
        flex: 1 !important;
        margin: 0 !important;
    }

    .csm-hero-booking .vbo-search-num-adults-entry select,
    .csm-hero-booking .vbo-search-num-children-entry select {
        width: 100% !important;
        min-width: 0 !important;
    }

    /* Button: full width */
    .csm-hero-booking .vbdivsearch .vbo-search-submit {
        flex: 1 1 100% !important;
        margin: 0 !important;
        width: 100% !important;
    }

    .csm-hero-booking .vbdivsearch .vbo-search-submit .btn {
        width: 100% !important;
    }
}

/* ---- Small phone (up to 480px): dates stacked ---- */
@media only screen and (max-width: 480px) {
    .csm-hero-booking .vbo-search-inpblock {
        flex: 1 1 100% !important;
    }
}

/* ============================================
   General Search Form (non-hero pages)
   ============================================ */

/* Inputs - rounded corners */
.vbdivsearch input[type="text"],
.vbdivsearch select {
    border-radius: var(--vb-radius-sm);
    border: 1.5px solid var(--vb-border);
    padding: 0.625rem 0.875rem;
    font-family: var(--csm-font-sans);
    font-size: 0.9375rem;
    transition: var(--vb-transition);
}

.vbdivsearch input[type="text"]:focus,
.vbdivsearch select:focus {
    outline: none;
    border-color: var(--vb-primary);
    box-shadow: 0 0 0 3px rgba(0, 102, 102, 0.08);
}

/* Labels outside hero */
.vbdivsearch label {
    font-family: var(--csm-font-sans);
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--vb-text);
}

/* Submit button - theme color */
.vbo-search-submit button,
.vbo-search-submit .btn,
button.vbo-pref-color-btn,
a.vbo-pref-color-btn,
input.vbo-pref-color-btn,
.btn.vbo-pref-color-btn,
.vbo-pref-color-btn {
    background: #006666 !important;
    background-color: #006666 !important;
    color: white !important;
    border: none !important;
    border-radius: 9999px !important;
    padding: 0.75rem 1.75rem !important;
    font-family: var(--csm-font-sans) !important;
    font-size: 0.75rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.12em !important;
    transition: all 0.25s ease !important;
    cursor: pointer !important;
    display: inline-block !important;
    text-decoration: none !important;
    line-height: 1.4 !important;
}

.vbo-search-submit button:hover,
.vbo-search-submit .btn:hover,
button.vbo-pref-color-btn:hover,
a.vbo-pref-color-btn:hover,
.btn.vbo-pref-color-btn:hover,
.vbo-pref-color-btn:hover {
    background: #004D4D !important;
    background-color: #004D4D !important;
    border-radius: 9999px !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 102, 102, 0.25);
}

/* Override VikBooking's .btn and .room_selected states that change font-size and border-radius */
.btn.vbselectr-result,
.btn.vbsubmit,
.btn.vbo-pref-color-btn,
.room_selected .vbselectr-result,
.room_selected .btn.vbselectr-result,
.vbselectr-result {
    font-size: 0.75rem !important;
    border-radius: 9999px !important;
    background: #006666 !important;
    background-color: #006666 !important;
    color: white !important;
}

/* Fix active/focus/hover states */
.vbo-pref-color-btn:active,
.vbo-pref-color-btn:focus,
.vbselectr-result:active,
.vbselectr-result:focus,
.room_selected .vbselectr-result:hover {
    background: #004D4D !important;
    background-color: #004D4D !important;
    border-radius: 9999px !important;
    font-size: 0.75rem !important;
    transform: translateY(0) !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(0, 102, 102, 0.3) !important;
}

/* ============================================
   Room Cards
   ============================================ */
.vbo-searchres-room {
    border-radius: var(--vb-radius);
    overflow: hidden;
    border: 1px solid var(--vb-border);
    transition: var(--vb-transition);
    background: var(--vb-surface, #ffffff);
}

.vbo-searchres-room:hover {
    box-shadow: 0 10px 30px -5px rgba(0, 102, 102, 0.12);
    transform: translateY(-2px);
}

/* Room Title */
.vbo-searchres-roomname a {
    font-family: var(--csm-font-serif);
    color: var(--vb-primary);
    text-decoration: none;
    font-size: 1.4375rem;
    font-weight: 600;
}

.vbo-searchres-roomname a:hover {
    color: var(--vb-accent);
}

/* Select Button */
.vbo-searchres-roomselect a,
.vbo-pref-room-sel {
    background: var(--vb-primary);
    color: white !important;
    border-radius: var(--vb-radius-sm);
    text-decoration: none;
    transition: var(--vb-transition);
    font-family: var(--csm-font-sans);
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    padding: 0.75rem 1.5rem;
    display: inline-block;
}

.vbo-searchres-roomselect a:hover,
.vbo-pref-room-sel:hover {
    background: var(--vb-primary-hover);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 102, 102, 0.25);
}

/* ============================================
   Booking Form (oconfirm page)
   ============================================ */
.vbo-booking-form input[type="text"],
.vbo-booking-form input[type="email"],
.vbo-booking-form input[type="tel"],
.vbo-booking-form select,
.vbo-booking-form textarea {
    border-radius: var(--vb-radius-sm);
    border: 1.5px solid var(--vb-border);
    padding: 0.75rem 1rem;
    font-family: var(--csm-font-sans);
    font-size: 0.9375rem;
    transition: var(--vb-transition);
}

.vbo-booking-form input:focus,
.vbo-booking-form select:focus,
.vbo-booking-form textarea:focus {
    outline: none;
    border-color: var(--vb-primary);
    box-shadow: 0 0 0 3px rgba(0, 102, 102, 0.08);
}

/* ============================================
   General Buttons
   ============================================ */
.vbo-btn,
button.vbo-btn,
a.vbo-btn {
    background: var(--vb-primary);
    color: white !important;
    border-radius: var(--vb-radius-sm);
    text-decoration: none;
    transition: var(--vb-transition);
    font-family: var(--csm-font-sans);
    font-weight: 600;
}

.vbo-btn:hover {
    background: var(--vb-primary-hover);
    transform: translateY(-1px);
}

/* ============================================
   Calendar / Datepicker
   ============================================ */
.ui-datepicker {
    border-radius: var(--vb-radius);
    border: 1px solid var(--vb-border);
    box-shadow: 0 20px 50px -10px rgba(0, 0, 0, 0.15);
    padding: 0.75rem;
    font-family: var(--csm-font-sans);
}

.ui-datepicker-header {
    border-radius: var(--vb-radius-sm);
    background: var(--vb-primary) !important;
    color: white !important;
    border: none !important;
    padding: 0.625rem 0.75rem !important;
    font-family: var(--csm-font-sans);
    position: relative;
}

.ui-datepicker-header .ui-datepicker-title {
    color: white !important;
    font-weight: 600;
    font-size: 0.9375rem;
}

/* Arrows — inside the header, white, properly centered */
.ui-datepicker .ui-datepicker-prev,
.ui-datepicker .ui-datepicker-next,
.ui-datepicker .ui-datepicker-prev-hover,
.ui-datepicker .ui-datepicker-next-hover {
    top: 50% !important;
    transform: translateY(-50%);
    border: none !important;
    background: rgba(255,255,255,0.15) !important;
    width: 30px !important;
    height: 30px !important;
    border-radius: 50% !important;
    transition: background 0.2s ease;
}

.ui-datepicker .ui-datepicker-prev:hover,
.ui-datepicker .ui-datepicker-next:hover {
    background: rgba(255,255,255,0.3) !important;
}

.ui-datepicker .ui-datepicker-prev {
    left: 6px !important;
}

.ui-datepicker .ui-datepicker-next {
    right: 6px !important;
}

.ui-datepicker .ui-datepicker-prev span,
.ui-datepicker .ui-datepicker-next span {
    width: 30px !important;
    height: 30px !important;
    line-height: 30px !important;
}

.ui-datepicker .ui-datepicker-prev span:after,
.ui-datepicker .ui-datepicker-next span:after {
    color: white !important;
    width: 30px !important;
    height: 30px !important;
    line-height: 30px !important;
    font-size: 14px !important;
}

.ui-datepicker td a,
.ui-datepicker td span {
    border-radius: var(--vb-radius-sm);
    text-align: center;
    transition: var(--vb-transition);
}

.ui-datepicker td a:hover {
    background: var(--vb-sand) !important;
    color: var(--vb-primary) !important;
}

.ui-datepicker .ui-state-active {
    background: var(--vb-primary) !important;
    color: white !important;
    border-radius: var(--vb-radius-sm);
}

.ui-datepicker .ui-state-highlight {
    background: var(--vb-sand) !important;
    color: var(--vb-primary) !important;
}

/* VBO Dates Range Picker override */
.vbo-drp-container {
    border-radius: var(--vb-radius) !important;
    box-shadow: 0 25px 60px -10px rgba(0, 0, 0, 0.18) !important;
    border: 1px solid var(--vb-border) !important;
}

/* Apply button (button inside .vbo-drp-command-close div) */
.vbo-drp-commands-bottom .vbo-drp-command-close {
    background: none !important;
    border: none !important;
    padding: 0 !important;
    border-radius: 0 !important;
}

.vbo-drp-commands-bottom .vbo-drp-command-close button {
    font-family: var(--csm-font-sans) !important;
    font-size: 0.6875rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.12em !important;
    text-transform: uppercase !important;
    background: var(--vb-primary) !important;
    color: var(--vb-surface) !important;
    border: none !important;
    border-radius: var(--vb-radius-sm) !important;
    padding: 0.625rem 1.5rem !important;
    cursor: pointer !important;
    transition: var(--vb-transition) !important;
}

.vbo-drp-commands-bottom .vbo-drp-command-close button:hover {
    background: var(--vb-primary-hover) !important;
}

/* Clear dates link */
.vbo-drp-commands-bottom .vbo-drp-command-clear a {
    font-family: var(--csm-font-sans) !important;
    font-size: 0.8125rem !important;
    color: var(--vb-text-light) !important;
}

/* ============================================
   Alerts & System Messages (unified style)
   ============================================ */
.vbo-alert,
.vbo-notice,
.vbo-warning,
.vbo-success,
.vbo-error,
#system-message-container,
.system-message-container,
.vik-system-message,
[class*="system-message"],
.vbtdwarning,
.vberror,
dd.message {
    font-family: var(--csm-font-sans) !important;
    font-size: 0.875rem !important;
    line-height: 1.6 !important;
    border-radius: var(--vb-radius) !important;
    padding: 1rem 1.25rem !important;
    margin: 0 0 1.5rem !important;
    border: none !important;
    border-left: 3px solid var(--vb-accent) !important;
    background: var(--vb-bg, #F5F0E8) !important;
    color: var(--vb-primary) !important;
}

#system-message-container .alert,
.system-message-container .alert,
[class*="system-message"] .alert {
    font-family: var(--csm-font-sans) !important;
    font-size: 0.875rem !important;
    border-radius: var(--vb-radius) !important;
    padding: 1rem 1.25rem !important;
    border: none !important;
    border-left: 3px solid var(--vb-accent) !important;
    background: var(--vb-bg, #F5F0E8) !important;
    color: var(--vb-primary) !important;
}

/* Error variant */
.vbo-error,
.alert-danger,
.alert-error,
dd.error.message {
    border-left-color: #c0392b !important;
    background: #fef2f2 !important;
    color: #7f1d1d !important;
}

/* Success variant */
.vbo-success,
.alert-success,
dd.message:not(.error) {
    border-left-color: var(--vb-primary) !important;
    background: #f0fdf4 !important;
    color: var(--vb-primary) !important;
}

/* Warning variant - the "seleccione fechas" message */
.alert-warning,
.vbo-warning,
.vbtdwarning {
    border-left-color: var(--vb-accent) !important;
    background: var(--vb-bg, #F5F0E8) !important;
    color: var(--vb-primary) !important;
}

/* Remove default WordPress/VikBooking alert icons and close buttons styling */
#system-message-container .close,
.system-message-container .close,
.alert .close {
    font-size: 1.25rem !important;
    opacity: 0.5 !important;
    color: inherit !important;
    text-shadow: none !important;
}

/* CF7 form messages */
.wpcf7-response-output {
    font-family: var(--csm-font-sans) !important;
    font-size: 0.875rem !important;
    border-radius: var(--vb-radius) !important;
    padding: 1rem 1.25rem !important;
    border: none !important;
    border-left: 3px solid var(--vb-primary) !important;
    background: var(--vb-bg, #F5F0E8) !important;
    color: var(--vb-primary) !important;
    margin: 1rem 0 !important;
}

.wpcf7-not-valid-tip {
    font-family: var(--csm-font-sans) !important;
    font-size: 0.75rem !important;
    color: #c0392b !important;
}

.wpcf7 .wpcf7-response-output.wpcf7-validation-errors {
    border-left-color: var(--vb-accent) !important;
}

.wpcf7 .wpcf7-response-output.wpcf7-mail-sent-ok {
    border-left-color: var(--vb-primary) !important;
    background: #f0fdf4 !important;
}

/* ============================================
   Results Header (Noches, Adultos, etc)
   ============================================ */
.vbo-results-head,
.vbo-showprc-head-wrapper .vbo-results-head {
    border-radius: var(--vb-radius);
    font-family: var(--csm-font-sans);
}

/* ============================================
   Room Container & Gallery
   ============================================ */
.room_container,
.vbo-showprc-room-block {
    border-radius: var(--vb-radius);
    overflow: hidden;
}

.vikfx-gallery-container,
.vikfx-gallery-fade-container {
    border-radius: var(--vb-radius);
    overflow: hidden;
}

.vikfx-gallery-container img,
.vikfx-gallery-fade-container img,
.vblistimg {
    border-radius: var(--vb-radius);
}

.vikfx-gallery img {
    border-radius: var(--vb-radius-sm);
}

/* ============================================
   Price Table
   ============================================ */
.vbo-showprc-rateplans-wrapper,
.vbo-showprc-pricetable {
    border-radius: var(--vb-radius);
}

.vbo-showprc-price-entry {
    border-radius: var(--vb-radius-sm);
    transition: var(--vb-transition);
}

.vbo-showprc-price-entry:hover {
    background: rgba(0, 102, 102, 0.02);
}

/* ============================================
   Room Carats (Features)
   ============================================ */
.room_carats,
.vbo-room-carats {
    border-radius: var(--vb-radius-sm);
}

/* ============================================
   Back Links & Secondary Buttons
   ============================================ */
.vbo-goback-link,
.vbo-pref-color-btn-secondary {
    border-radius: var(--vb-radius-sm);
    font-family: var(--csm-font-sans);
    font-size: 0.875rem;
    font-weight: 500;
    text-decoration: none;
    transition: var(--vb-transition);
}

input[type="submit"].booknow,
.btn.booknow {
    border-radius: 9999px !important;
    font-family: var(--csm-font-sans);
    font-weight: 700;
    font-size: 0.875rem;
    padding: 1rem 2.5rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    background: var(--vb-primary) !important;
    color: white !important;
    border: none !important;
    cursor: pointer;
    transition: var(--vb-transition);
}

input[type="submit"].booknow:hover,
.btn.booknow:hover {
    background: #004D4D !important;
    border-radius: 9999px !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 102, 102, 0.25);
}

/* ============================================
   VikBooking Icons - All black
   ============================================ */

/* PNG icons */
.vbo-room-carat img,
.vbo-room-carats img,
.vbo-expl img {
    width: 20px !important;
    height: 20px !important;
    max-width: 20px !important;
    object-fit: contain;
    display: inline-block;
    vertical-align: middle;
    filter: brightness(0);
}

/* FontAwesome icons */
.vbo-room-carat i,
.vbo-room-carats i,
.vbo-expl i,
.vbo-icn-carat,
.vbo-pref-color-text {
    color: var(--vb-primary) !important;
}

.vbo-room-carat i,
.vbo-room-carats i,
.vbo-expl i {
    font-size: 20px !important;
    line-height: 1;
    display: inline-block !important;
    vertical-align: middle;
    width: auto !important;
    height: auto !important;
}

/* ============================================
   Room Title & Description Typography
   ============================================ */

.vbo-showprc-roominfo h3,
.vbo-showprc-roomname h3,
.vbo-roomdet-heading h3,
.room_container h3 {
    font-family: var(--csm-font-serif);
    font-size: 1.5rem;
    font-weight: 500;
    margin-bottom: 1rem;
    color: var(--vb-primary);
}

.vbo-showprc-roomdescr,
.vbo-room-descr,
.room_descr,
.vbo-roomdet-descr {
    font-family: var(--csm-font-sans);
    font-size: 0.9375rem;
    line-height: 1.7;
    color: var(--vb-text-light);
}

/* ============================================
   Confirmation Page (oconfirm)
   ============================================ */

.vbo-oconfirm-wrapper {
    border-radius: var(--vb-radius);
}

.vbo-oconfirm-summary-container {
    border-radius: var(--vb-radius);
    overflow: hidden;
}

.vbo-oconfirm-summary-room-head {
    font-family: var(--csm-font-sans);
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--vb-text-light);
}

.vbo-oconfirm-roomname {
    font-family: var(--csm-font-serif);
    font-size: 1.125rem;
    font-weight: 500;
    color: var(--vb-primary);
}

.vbo-oconfirm-priceinfo {
    font-family: var(--csm-font-sans);
    font-size: 0.875rem;
    color: var(--vb-text-light);
}

.vbo-oconfirm-total-block {
    font-family: var(--csm-font-sans);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.vbo_price {
    font-family: var(--csm-font-sans);
    font-weight: 600;
    color: var(--vb-primary);
}

/* ============================================
   Coupon Section
   ============================================ */

.vbo-coupon-outer {
    border-radius: var(--vb-radius-sm);
}

.vbhaveacoupon {
    font-family: var(--csm-font-sans);
    font-size: 0.875rem;
    color: var(--vb-text-light);
}

.vbinputcoupon {
    border-radius: var(--vb-radius-sm) !important;
    border: 1.5px solid var(--vb-border) !important;
    font-family: var(--csm-font-sans);
}

.vbinputcoupon:focus {
    border-color: var(--vb-primary) !important;
    outline: none;
    box-shadow: 0 0 0 3px rgba(0, 102, 102, 0.08);
}

.vbsubmitcoupon {
    border-radius: var(--vb-radius-sm) !important;
}

/* ============================================
   Custom Fields Form
   ============================================ */

.vbcustomfields {
    font-family: var(--csm-font-sans);
}

.vbo-oconfirm-cfield-entry {
    border-radius: var(--vb-radius-sm);
}

.vbo-oconfirm-cfield-label label {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--vb-text);
}

.vbrequired {
    color: #dc2626;
}

.vbinput,
.vbtextarea,
.vbcustomfields input[type="text"],
.vbcustomfields select,
.vbcustomfields textarea {
    border-radius: var(--vb-radius-sm) !important;
    border: 1.5px solid var(--vb-border) !important;
    font-family: var(--csm-font-sans);
    font-size: 0.9375rem;
    padding: 0.75rem 1rem;
    transition: var(--vb-transition);
}

.vbinput:focus,
.vbtextarea:focus,
.vbcustomfields input[type="text"]:focus,
.vbcustomfields select:focus,
.vbcustomfields textarea:focus {
    border-color: var(--vb-primary) !important;
    outline: none;
    box-shadow: 0 0 0 3px rgba(0, 102, 102, 0.08);
}

/* ============================================
   Payment Methods
   ============================================ */

.vbo-oconfirm-paymentopts h4 {
    font-family: var(--csm-font-serif);
    font-size: 1.25rem;
    font-weight: 500;
    margin-bottom: 1rem;
    color: var(--vb-primary);
}

.vbo-oconfirm-paymethods-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.vbo-oconfirm-paymethod-item {
    border-radius: var(--vb-radius-sm);
    border: 1.5px solid var(--vb-border);
    transition: var(--vb-transition);
    margin-bottom: 0.5rem;
    padding: 1rem;
}

.vbo-oconfirm-paymethod-item:hover {
    border-color: var(--vb-primary);
}

.vbo-oconfirm-paymethod-item-active {
    border-color: var(--vb-primary);
    background: rgba(0, 102, 102, 0.03);
}

.vbo-paymeth-info {
    font-family: var(--csm-font-sans);
    font-size: 0.9375rem;
    font-weight: 500;
}

.vbo-payment-image img {
    border-radius: var(--vb-radius-sm);
}

/* ============================================
   Confirm Bottom (Buttons)
   ============================================ */

.vboconfirmbottom {
    margin-top: 2rem;
}

.vbo-goback-link {
    font-family: var(--csm-font-sans);
    font-size: 0.875rem;
    font-weight: 500;
    text-decoration: none;
    color: var(--vb-text-light);
}

.vbo-goback-link:hover {
    color: var(--vb-primary);
}

/* ============================================
   Alert Container
   ============================================ */

.vbo-alert-container-confirm {
    border-radius: var(--vb-radius-sm);
    font-family: var(--csm-font-sans);
}

.vbo-alert-close {
    border-radius: 50%;
}

/* ============================================
   Step Bar / Breadcrumb
   ============================================ */
.vbstepsbarcont {
    margin: 0 0 2rem;
}

.vbo-stepbar {
    list-style: none;
    display: flex;
    align-items: center;
    padding: 0;
    margin: 0;
    position: relative;
    font-family: var(--csm-font-sans);
    font-size: 0.8125rem;
    font-weight: 500;
    counter-reset: step;
}

.vbo-stepbar .vbo-step {
    flex: 1;
    text-align: center;
    position: relative;
    padding-top: 2rem;
    color: var(--vb-text-muted, #9ca3af);
}

.vbo-stepbar .vbo-step::before {
    counter-increment: step;
    content: '';
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: #d1d5db;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2;
}

.vbo-stepbar .vbo-step::after {
    content: '';
    position: absolute;
    top: 5px;
    left: -50%;
    right: 50%;
    height: 2px;
    background: #d1d5db;
    z-index: 1;
}

.vbo-stepbar .vbo-step:first-child::after {
    display: none;
}

.vbo-stepbar .vbo-step-complete::before {
    background: var(--vb-primary);
}

.vbo-stepbar .vbo-step-complete::after {
    background: var(--vb-primary);
}

.vbo-stepbar .vbo-step-complete {
    color: var(--vb-primary);
    font-weight: 600;
}

.vbo-stepbar .vbo-step-current::before {
    background: var(--vb-surface, #fff);
    border: 2px solid var(--vb-primary);
    width: 14px;
    height: 14px;
    top: -1px;
}

.vbo-stepbar .vbo-step-current::after {
    background: var(--vb-primary);
}

.vbo-stepbar .vbo-step-current {
    color: var(--vb-primary);
    font-weight: 700;
}

.vbo-stepbar a {
    color: var(--vb-primary);
    text-decoration: none;
}

.vbo-stepbar a:hover {
    color: var(--vb-accent);
}

/* ============================================
   Results Summary Header
   ============================================ */
.vbo-results-head {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0;
    background: var(--vb-surface, #fff) !important;
    border-radius: var(--vb-radius-lg) !important;
    padding: 1rem 1.5rem !important;
    box-shadow: 0 4px 16px rgba(0, 102, 102, 0.08) !important;
    font-family: var(--csm-font-sans) !important;
    margin-bottom: 2rem;
}

.vbo-results-head > div {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 1.25rem;
    border-right: 1px solid var(--vb-border, #e5e7eb);
}

/* VikBooking default applies margin-left: auto to the icon, reset it */
.vbo-results-head > div > i {
    margin: 0 !important;
    flex-shrink: 0;
}

.vbo-results-head > div:last-child {
    border-right: none;
}

/* Push the "Cambio de fechas" button to the right end of the bar */
.vbo-results-chdates {
    margin-left: auto !important;
}

.vbo-results-head-det-lbl {
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--vb-text-muted, #737880);
    display: block;
}

.vbo-results-head-det-val {
    font-size: 1rem;
    font-weight: 600;
    color: var(--vb-primary);
}

.vbo-results-head .vbo-pref-color-text {
    color: var(--vb-primary);
    font-size: 1.125rem;
}

/* Change dates button */
.vbo-pref-color-btn-secondary {
    font-family: var(--csm-font-sans) !important;
    font-size: 0.75rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.05em !important;
    text-transform: uppercase !important;
    padding: 0.6rem 1.25rem !important;
    border-radius: 9999px !important;
    border: 1.5px solid var(--vb-primary) !important;
    color: var(--vb-primary) !important;
    background: transparent !important;
    text-decoration: none !important;
    transition: all 0.2s ease !important;
    display: inline-block !important;
}

.vbo-pref-color-btn-secondary:hover {
    background: var(--vb-primary) !important;
    color: var(--vb-surface, #fff) !important;
}

/* ============================================
   Responsive: Results Summary Header
   ============================================ */
@media (max-width: 768px) {
    .vbo-results-head {
        flex-wrap: wrap;
    }
    .vbo-results-head > div {
        flex: 1 1 45%;
        padding: 0.75rem 1rem;
    }
    .vbo-results-head > div:nth-child(2n) {
        border-right: none;
    }
    .vbo-results-head > div:nth-child(1),
    .vbo-results-head > div:nth-child(2) {
        border-bottom: 1px solid var(--vb-border, #e5e7eb);
    }
}

@media (max-width: 480px) {
    .vbo-results-head > div {
        flex: 1 1 100%;
        border-right: none;
        border-bottom: 1px solid var(--vb-border, #e5e7eb);
        padding: 0.625rem 1rem;
    }
    .vbo-results-head > div:last-child {
        border-bottom: none;
        margin-left: 0;
    }
}

/* ============================================
   Responsive: Room detail — image top, text below
   ============================================ */
@media (max-width: 768px) {
    .vbo-showprc-room-block .vbroomimgdesc {
        flex-direction: column;
    }
    .vbo-showprc-room-block .vbroomimgdesc .vikfx-showprc-gallery-container,
    .vbo-showprc-room-block .vbroomimgdesc .vikfx-thumbslide-container {
        flex-basis: 100%;
        max-width: 100%;
        margin-right: 0;
        margin-bottom: 1rem;
    }
    .vbo-showprc-room-block .vbroomimgdesc img.vblistimg {
        width: 100%;
        max-width: 100%;
        margin-right: 0;
        border-radius: var(--vb-radius);
    }
    .vbo-showprc-room-block .room_description_box {
        width: 100%;
        margin: 0;
    }
}

/* Room pre-selection mini-card */
.csm-room-selected {
    display: flex;
    align-items: center;
    gap: 0.875rem;
    background: var(--csm-bg, #F3F2EF);
    padding: 0.625rem 1rem;
    border-radius: var(--vb-radius);
    margin-bottom: 1.25rem;
    border: 1px solid rgba(0, 102, 102, 0.08);
}

.csm-room-selected img {
    width: 64px;
    height: 48px;
    object-fit: cover;
    border-radius: 0.5rem;
    flex-shrink: 0;
}

.csm-room-selected-info {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    min-width: 0;
}

.csm-room-selected-info strong {
    font-size: 0.8125rem;
    color: var(--csm-primary, #006666);
    line-height: 1.3;
}

.csm-room-selected-amenities {
    display: flex;
    gap: 0.375rem;
    align-items: center;
    flex-wrap: wrap;
}

.csm-room-selected-icon {
    display: inline-flex;
    color: var(--csm-primary, #006666);
    opacity: 0.6;
}

.csm-room-selected-icon i {
    font-size: 15px !important;
    line-height: 1 !important;
    display: inline-block !important;
    width: 16px !important;
    text-align: center !important;
}

.csm-room-selected-icon-hidden {
    display: none;
}

.csm-room-selected-amenities.is-expanded .csm-room-selected-icon-hidden {
    display: inline-flex;
}

.csm-room-selected-toggle {
    display: inline-flex;
    align-items: center;
    font-size: 0.6875rem;
    color: var(--csm-primary, #006666);
    background: none;
    border: 1px solid rgba(0, 102, 102, 0.2);
    border-radius: 9999px;
    padding: 0.125rem 0.4rem;
    cursor: pointer;
    font-weight: 600;
    transition: all 0.2s;
}

.csm-room-selected-toggle:hover {
    background: rgba(0, 102, 102, 0.05);
}

.csm-room-selected-amenities.is-expanded .csm-room-selected-toggle {
    display: none;
}

/* Capacity warning message */
.csm-capacity-warning {
    text-align: center;
    font-size: 0.8125rem;
    color: #92400e;
    background: #fef3c7;
    padding: 0.5rem 1rem;
    border-radius: 0.5rem;
    margin-top: 0.5rem;
    border: 1px solid #fcd34d;
    animation: csm-fadeIn 0.3s ease;
}

@keyframes csm-fadeIn {
    from { opacity: 0; transform: translateY(-4px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Extras: center the option image */
.vbo-showprc-option-entry-img {
    text-align: center;
}

.vbo-showprc-option-entry-img img {
    display: block;
    margin: 0 auto;
    max-width: 48px;
    max-height: 48px;
    object-fit: contain;
}

/* VikBooking room cards: rounded corners */
.room_item,
.vblistroomblock {
    border-radius: var(--csm-radius, 0.25rem) !important;
    overflow: hidden;
}

.room_item .vbimglistdiv,
.vblistroomblock .vbimglistdiv {
    border-radius: var(--csm-radius, 0.25rem) var(--csm-radius, 0.25rem) 0 0 !important;
    overflow: hidden;
}

.room_item .vblistimg {
    border-radius: 0 !important;
}

/* ============================================
   Room Detail Modal (Fancybox)
   Modern, clean overlay for room details
   ============================================ */

/* Overlay backdrop */
.fancybox-overlay {
    background: rgba(0, 0, 0, 0.6) !important;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}

/* Modal wrapper */
.fancybox-wrap {
    border-radius: var(--vb-radius) !important;
    overflow: hidden;
    box-shadow: 0 25px 60px -12px rgba(0, 0, 0, 0.3) !important;
}

/* Skin (inner padding container) */
.fancybox-skin {
    background: #ffffff !important;
    border-radius: var(--vb-radius) !important;
    padding: 0 !important;
}

/* Content area */
.fancybox-inner {
    border-radius: var(--vb-radius) !important;
    scrollbar-width: thin;
    scrollbar-color: rgba(0, 102, 102, 0.2) transparent;
}

.fancybox-inner::-webkit-scrollbar {
    width: 6px;
}

.fancybox-inner::-webkit-scrollbar-track {
    background: transparent;
}

.fancybox-inner::-webkit-scrollbar-thumb {
    background: rgba(0, 102, 102, 0.2);
    border-radius: 3px;
}

.fancybox-inner::-webkit-scrollbar-thumb:hover {
    background: rgba(0, 102, 102, 0.4);
}

/* Close button - modern circle */
.fancybox-close,
a.fancybox-item.fancybox-close {
    top: 12px !important;
    right: 20px !important;
    width: 36px !important;
    height: 36px !important;
    background: rgba(255, 255, 255, 0.9) !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15) !important;
    transition: all 0.2s ease !important;
    z-index: 10 !important;
    border: none !important;
    text-indent: 0 !important;
    font-size: 0 !important;
}

.fancybox-close::after {
    content: '\00d7';
    font-size: 20px;
    line-height: 1;
    color: #006666;
    font-weight: 300;
}

.fancybox-close:hover {
    background: #ffffff !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2) !important;
    transform: scale(1.05);
}

/* Fix the iframe body padding-top (VikBooking adds padding for admin bar + header) */
.fancybox-iframe {
    border-radius: var(--vb-radius) !important;
}

/* ============================================
   Room Detail Modal - iframe content overrides
   Applied when VikBooking loads the detail in tmpl=component
   ============================================ */
body.tmpl-component,
body[class*="tmpl"] {
    padding-top: 0 !important;
    margin-top: 0 !important;
    background: #ffffff !important;
}

/* Detail content inside the modal */
.vbo-searchdet-wrap,
.vbo-searchdet-main {
    padding: 0 !important;
    margin: 0 !important;
}

/* Image carousel inside modal */
.vbo-searchdet-img {
    border-radius: 0 !important;
    margin: 0 !important;
}

.vbo-searchdet-img img {
    border-radius: 0 !important;
    width: 100% !important;
    height: auto !important;
    display: block !important;
}

/* Room name inside modal */
.vbo-searchdet-roomname,
.vbo-searchdet-roomname h3 {
    font-family: var(--csm-font-serif) !important;
    color: #006666 !important;
    font-weight: 500 !important;
    font-size: 1.25rem !important;
    margin: 1.25rem 1.5rem 0.75rem !important;
}

/* Description inside modal */
.vbo-searchdet-desc,
.vbo-searchdet-desc p {
    font-size: 0.875rem !important;
    line-height: 1.7 !important;
    color: #6b7280 !important;
    padding: 0 1.5rem !important;
    margin: 0 0 1rem !important;
}

/* Amenities inside modal */
.vbo-searchdet-amenities,
.vbo-searchdet-features {
    padding: 0.75rem 1.5rem !important;
}

/* Price breakdown inside modal */
.vbo-searchdet-prices,
.vbo-searchdet-pricetable {
    margin: 0 1.5rem 1.5rem !important;
    border-radius: var(--vb-radius) !important;
    overflow: hidden !important;
    border: 1px solid #e5e7eb !important;
}

.vbo-searchdet-pricetable th,
.vbo-searchdet-pricetable td {
    padding: 0.625rem 1rem !important;
    font-size: 0.8125rem !important;
}

.vbo-searchdet-total {
    font-family: var(--csm-font-serif) !important;
    font-size: 1.125rem !important;
    font-weight: 600 !important;
    color: #006666 !important;
    padding: 1rem 1.5rem !important;
    border-top: 1px solid #e5e7eb !important;
}

/* ============================================
   Results Page (task=search) — Fixes
   ============================================ */

/* Hide grid/list toggle — grid view is broken on mobile */
.vbo-results-filtering {
    display: none !important;
}

/* Image slider: prevent white flash (slide bg was rgb(255,255,255)) */
.vik-dots-slider-slide {
    background: transparent !important;
}

/* Ensure slider container clips properly */
.vik-dots-slider-container,
.vik-dots-slider-inner {
    overflow: hidden !important;
}

/* Images fill slide completely without gaps */
.vik-dots-slider-slide img {
    object-fit: cover !important;
    width: 100% !important;
    height: 100% !important;
    display: block !important;
    border-radius: 0 !important;
}

/* Price + Seleccionar block: subtle warm background */
.vbcontdivtot {
    background: var(--vb-bg, #F3F2EF) !important;
    border-top: 1px solid var(--vb-border, #e5e7eb) !important;
}

/* Bottom form: Cambio de Fechas + Continuar side by side */
#vbselectroomform {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
    flex-wrap: wrap !important;
    padding: 0.5rem 0 2rem !important;
}

.vbsearchmainsbmt {
    flex-shrink: 0;
}

/* ============================================
   Summary Head — oconfirm date/time text
   ============================================ */

/* Dates include time on oconfirm ("Miércoles, 22-04-2026 15:00") — handle overflow */
.vbo-summary-date .vbo-results-head-det-val {
    font-size: 0.875rem !important;
    word-break: break-word;
}

@media (max-width: 480px) {
    .vbo-summary-date .vbo-results-head-det-val {
        font-size: 0.8125rem !important;
    }
}

/* ============================================
   oConfirm Page — Buttons mobile alignment
   ============================================ */

@media (max-width: 768px) {
    .vboconfirmbottom {
        display: flex !important;
        flex-direction: column !important;
        gap: 0.75rem !important;
        width: 100% !important;
    }

    .vboconfirmbottom .booknow {
        width: 100% !important;
        text-align: center !important;
        box-sizing: border-box !important;
    }

    .vboconfirmbottom .vbo-goback-link {
        width: 100% !important;
        text-align: center !important;
        display: block !important;
        box-sizing: border-box !important;
    }
}

/* ============================================
   Booking View — Status badges
   ============================================ */

/* Pending (awaiting payment): alert banner, full-width, centered
   VikBooking default is display:inline-block — override to block for alert look */
.vbo-booking-details-head-pending {
    display: block !important;
    width: 100% !important;
    box-sizing: border-box !important;
    background: #FFFBEB !important;
    color: #78350F !important;
    border: 1.5px solid #F59E0B !important;
    border-left: 4px solid #D97706 !important;
    border-radius: 0.5rem !important;
    padding: 1rem 1.5rem !important;
    margin: 0 0 1.5rem 0 !important;
    text-align: center !important;
}

.vbo-booking-details-head-pending > h4 {
    color: #78350F !important;
    font-size: 0.9375rem !important;
    font-weight: 600 !important;
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.5rem !important;
}

.vbo-booking-details-head-pending > h4::before {
    content: "⚠";
    font-style: normal;
    font-size: 1rem;
    line-height: 1;
}

/* ============================================
   Bank Transfer Payment — Visual text separation
   ============================================ */

/* Container for bank transfer instructions */
.vbvordpaybutton {
    background: var(--vb-bg, #F3F2EF) !important;
    border-radius: var(--vb-radius-sm, 0.625rem) !important;
    padding: 1.5rem !important;
    margin-top: 1.5rem !important;
    border: 1px solid var(--vb-border, #e5e7eb) !important;
    text-align: left !important;
    max-width: 600px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Each paragraph = one info block, visually separated */
.vbvordpaybutton p {
    font-size: 0.9375rem !important;
    line-height: 1.7 !important;
    color: var(--vb-text, #1a1a1a) !important;
    padding-bottom: 1rem !important;
    margin-bottom: 1rem !important;
    border-bottom: 1px solid var(--vb-border, #e5e7eb) !important;
    text-align: left !important;
}

.vbvordpaybutton p:last-child {
    padding-bottom: 0 !important;
    margin-bottom: 0 !important;
    border-bottom: none !important;
}

/* Deposit amount line */
.vbo-leave-deposit {
    font-weight: 600 !important;
    font-size: 1.0625rem !important;
    color: var(--vb-primary, #006666) !important;
}

/* When JS moves the content to paycontainer */
.vbo-paycontainer-pos {
    margin-top: 1.5rem;
}

/* ============================================
   Booking Summary — Info rows (NOCHES, ADULTO, LLEGADA, SALIDA)
   ============================================ */

/* Container */
.vbo-booking-details-bookinfos {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

/* Each row: icon + label + value, always left-aligned */
.vbo-booking-details-bookinfo {
    display: flex !important;
    align-items: center !important;
    gap: 0.75rem !important;
    text-align: left !important;
    margin: 0 !important;
}

/* Icon */
.vbo-booking-details-bookinfo > i,
.vbo-booking-details-bookinfo .vbo-booking-details-bookinfo-icon {
    flex-shrink: 0 !important;
    width: 1.25rem !important;
    text-align: center !important;
    color: var(--vb-primary, #006666) !important;
}

/* Label */
.vbo-booking-details-bookinfo-lbl {
    display: block !important;
    text-align: left !important;
    font-size: 0.6875rem !important;
    letter-spacing: 0.08em !important;
    color: var(--vb-text-muted, #9ca3af) !important;
    font-weight: 600 !important;
}

/* Value */
.vbo-booking-details-bookinfo-val {
    display: block !important;
    text-align: left !important;
    font-size: 1rem !important;
    font-weight: 500 !important;
    color: var(--vb-text, #1a1a1a) !important;
    line-height: 1.3 !important;
}

/* -----------------------------------------------
   Room image fill (search results)
   ----------------------------------------------- */
.vbimglistdiv {
    overflow: hidden !important;
    aspect-ratio: 4 / 3 !important;
    align-self: stretch !important;
}

.vbimglistdiv img.vblistimg,
.vbimglistdiv img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
    display: block !important;
}

@media (max-width: 768px) {
    .vbimglistdiv {
        aspect-ratio: 16 / 9 !important;
        flex: 0 0 100% !important;
        max-width: 100% !important;
    }
}

/* -----------------------------------------------
   "A la espera del pago" badge contrast
   ----------------------------------------------- */
.vbo-booking-status-awaiting,
.vbo-status-awaiting,
[class*="awaiting"] .vbo-order-status,
.vbo-order-status.vbo-status-4 {
    background-color: #B45309 !important;
    color: #ffffff !important;
    font-weight: 700 !important;
}

/* Botón de estado con texto oscuro sobre dorado */
.vbo-confirm-btn[class*="awaiting"],
.vbo-booking-pay-btn {
    background-color: #92400E !important;
    color: #ffffff !important;
    font-weight: 700 !important;
    letter-spacing: 0.05em !important;
}

/* -----------------------------------------------
   Check-in / Check-out: consistencia en la misma línea
   ----------------------------------------------- */
.vbo-showprc-dates,
.vbo-oconfirm-dates {
    display: flex !important;
    gap: 1.5rem !important;
    flex-wrap: wrap !important;
}

.vbo-showprc-dates > div,
.vbo-oconfirm-dates > div {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    white-space: nowrap !important;
}

/* ============================================
   Booking View — Section Titles & Customer Data
   ============================================ */

.vbvordudatatitle {
    display: block !important;
    font-family: var(--csm-font-sans) !important;
    font-size: 0.6875rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.15em !important;
    text-transform: uppercase !important;
    color: var(--vb-text-muted, #9ca3af) !important;
    margin-bottom: 1rem !important;
    padding-bottom: 0.625rem !important;
    border-bottom: 1px solid var(--vb-border, #e5e7eb) !important;
}

.vbo-booking-details-midcontainer {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 2rem !important;
    margin-top: 1.5rem !important;
    background: var(--vb-surface, #ffffff) !important;
    border-radius: var(--vb-radius) !important;
    padding: 1.5rem !important;
    border: 1px solid var(--vb-border, #e5e7eb) !important;
}

@media (max-width: 600px) {
    .vbo-booking-details-midcontainer {
        grid-template-columns: 1fr !important;
    }
}

.vbo-bookingdet-custdata {
    display: flex !important;
    flex-direction: column !important;
    gap: 0.625rem !important;
}

.vbo-bookingdet-userdetail {
    display: flex !important;
    gap: 0.5rem !important;
    flex-wrap: wrap !important;
}

.vbo-bookingdet-userdetail-lbl {
    font-family: var(--csm-font-sans) !important;
    font-size: 0.6875rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.05em !important;
    color: var(--vb-text-muted, #9ca3af) !important;
    text-transform: uppercase !important;
    min-width: 90px !important;
    flex-shrink: 0 !important;
}

.vbo-bookingdet-userdetail-val {
    font-family: var(--csm-font-sans) !important;
    font-size: 0.9375rem !important;
    color: var(--vb-text, #1a1a1a) !important;
    font-weight: 400 !important;
}

/* White background for key booking sections */
.vbo-booking-details-topcontainer {
    background: var(--vb-surface, #ffffff);
    border-radius: var(--vb-radius);
    border: 1px solid var(--vb-border, #e5e7eb);
    overflow: hidden;
    margin-bottom: 2rem;
}
