/* This CSS file will be loaded at last. Any CSS customization should be placed here */

/* Grille responsive pour VikBooking - Version corrigée */
.vblistcontainer-grid .vblist {
    display: grid !important;
    grid-template-columns: 1fr; /* 1 colonne par défaut (mobile) */
    gap: 20px;
    list-style: none;
    padding: 0;
    margin: 0;
}

/* 2 colonnes sur tablettes et écrans plus grands */
@media (min-width: 768px) {
    .vblistcontainer-grid .vblist {
        grid-template-columns: repeat(2, 1fr); /* 2 colonnes maximum */
    }
}

.vblistcontainer-grid .vblistroomblock .vbimglistdiv {
	flex: auto;
}

/* IMPORTANT: Forcer le layout vertical pour chaque room_result */
.vblistcontainer-grid .vblist .room_result {
    width: 100%;
    margin: 0;
	border: none;
    display: block !important; /* Forcer block au lieu de flex horizontal */
}

.vblistcontainer-grid .vblist .room_result .room_result-inner {
    display: flex;
    height: 100%;
    overflow: hidden;
	gap: 10px;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

/* Forcer le vblistroomblock à prendre toute la largeur */
.vblistcontainer-grid .vblistroomblock {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    flex-grow: 1;
}

.vblistcontainer-grid .vblistimg {
    width: 100% !important;
    height: 200px;
    object-fit: cover;
    display: block;
}

/* Contenu au milieu */
.vblistcontainer-grid .vbo-info-room {
    flex-grow: 1;
    width: 100%;
}

.vblistroomblock .vbo-info-room {
	padding: 0;
    padding-top: 30px;
}

.vbdescrlistdiv {
	display: flex;
	flex-direction: column;
	gap: 5px;
	padding: 0;
}

.vbdescrlistdiv .vbrowcname {
	margin: 0;
	font-weight: 600;
	font-size: 28px;
}

.vbdescrlistdiv .vbrowcdescr {
	margin: 0;
}

/* Prix et bouton EN BAS - CORRECTION PRINCIPALE */
.vblistcontainer-grid .vbcontdivtot {
    width: 100%;
	margin: 0;
	padding: 0;
    background-color: #f8f9fa;
    display: block !important; /* Forcer block */
    position: relative !important; /* Annuler tout positionnement absolu */
    float: none !important; /* Annuler tout float */
}

.vblistcontainer-grid .vbdivtot {
    width: 100% !important;
    display: block !important;
}

.vblistcontainer-grid .vbdivtotinline {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
}

.vblistcontainer-grid .roomlist_carats {
    display: none;
}

/* Section prix */
.vblistcontainer-grid .vbsrowprice {
    display: flex;
	padding: 0;
    flex-direction: column;
    align-items: flex-start;
}

/* Icônes de capacité */
.vblistcontainer-grid .vbrowroomcapacity {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
    font-size: 0.875rem;
}

.vblistcontainer-grid .vbrowroomcapacity i {
	color: inherit;
}

/* Prix */
.vblistcontainer-grid .vbo_price {
    font-size: 1.5rem;
    font-weight: 300;
    color: #111827;
    font-family: inherit;
}

/* Devise */
.vblistcontainer-grid .vbo_currency {
    font-size: 1.125rem;
    font-weight: 300;
    color: #374151;
    font-family: inherit;
}

/* "Par nuit" */
.vblistcontainer-grid .vbliststartfrom {
    font-size: 0.875rem;
    color: #6b7280;
    font-weight: 300;
    text-transform: uppercase;
    letter-spacing: 0.025em;
    margin-top: 0.25rem;
}

/* Bouton - Style exact de votre CSS */
.vblistcontainer-grid .btn.vbo-pref-color-btn {
    background-color: #02010100 !important;
    fill: var(--e-global-color-astglobalcolor0) !important;
    color: var(--e-global-color-astglobalcolor0) !important;
    border-style: solid !important;
    border-width: 0px 0px 2px 0px !important;
    border-color: var(--e-global-color-astglobalcolor0) !important;
    border-radius: 0px 0px 0px 0px !important;
    padding: 0px 0px 8px 0px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    font-size: 0.875rem !important;
    font-weight: 500 !important;
    text-decoration: none !important;
    cursor: pointer !important;
    transition: border-color 0.3s ease !important;
}

.vblistcontainer-grid .btn.vbo-pref-color-btn:hover {
    border-color: var(--e-global-color-astglobalcolor0) !important;
    opacity: 0.8 !important;
}

.vblistcontainer-grid .vbselectordiv {
    width: 100%;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    padding: 0;
    border-top: none;
    box-sizing: border-box;
}

/* Image Cover */
.vblistcontainer-grid .vblistimg {
	height: 400px;
}

/* Responsive pour très petits écrans */
@media (max-width: 480px) {
    .vblistcontainer-grid .vblist {
        gap: 15px;
    }
    
    .vblistcontainer-grid .vblistimg {
        height: 180px;
    }
    
    .vblistcontainer-grid .vbdivtotinline {
        flex-direction: column !important;
        gap: 10px;
    }
}

<!-- Room details view -->

.vbo-listing-amenities-wrap {
    display: none;
}

.vbo-listing-details-wrap .vbo-listing-details-desc-cont {
	background: transparent;
}

<!-- Disable border radius on the book button -->
<!-- .vbo-listing-details-wrap .vbo-listing-details-divsearch .vbo-search-submit .btn {
	border-radius: none !important;
	border: none;
} -->

.vbdetbooksubmit.vbo-pref-color-btn {
    border-style: solid;
    border-top-width: 1px;
    border-right-width: 1px;
    border-left-width: 1px;
    border-bottom-width: 1px;
    color: #ffffff;
    border-color: var(--ast-global-color-0);
    background-color: var(--ast-global-color-0);
    padding-top: 18px;
    padding-right: 34px;
    padding-bottom: 18px;
    padding-left: 34px;
    font-family: 'Open Sans', sans-serif;
    font-weight: 600;
    font-size: 12px;
    font-size: 0.75rem;
    line-height: 1em;
    text-transform: uppercase;
    letter-spacing: 2px;
    border-top-left-radius: 0px;
    border-top-right-radius: 0px;
    border-bottom-right-radius: 0px;
    border-bottom-left-radius: 0px;
}

ol.vbo-stepbar li.vbo-step-complete, ol.vbo-stepbar li.vbo-step-current {
    border-bottom: 4px solid var(--e-global-color-astglobalcolor0) !important;
}

<!-- TODO: Revisit, pretty ugly way to override the color -->
.vbo-pref-color-text,
.vbo-pref-color-btn,
[class*="vbo-"] {
    --vbo-blue-color: #2a2a2a;
}

<!-- Booking form inputs -->


<!-- Adults/Childlren Selects -->
.vbo-listing-details-wrap .vbo-listing-details-divsearch .vb-search-inner span > select {
    color: #666;
    transition: all .2s linear;
    width: 100% !important;
    height: 50px !important;
    padding: 4px 30px 4px 10px;
}

/* Override universel pour tous les éléments de formulaire VikBooking */
[class*="vbo"] select,
[class*="vbo"] input:not([type="checkbox"]):not([type="radio"]):not([type="submit"]),
[class*="vbo"] textarea,
[class*="vbo"] .input-group {
    background: var(--ast-comment-inputs-background) !important;
    color: #666 !important;
    border-width: 1px !important;
    border-style: solid !important;
    border-color: var(--ast-border-color) !important;
    border-radius: 2px !important;
    box-shadow: none !important;
    box-sizing: border-box !important;
    transition: all .2s linear !important;
    height: auto !important;
}

/* Focus states */
[class*="vbo"] select:focus,
[class*="vbo"] input:focus,
[class*="vbo"] textarea:focus,
[class*="vbo"] .input-group:focus-within {
    border-color: #111827 !important;
    outline: none !important;
}

/* CORRECTION pour les icônes - plus spécifique */
[class*="vbo"] .input-group i,
[class*="vbo"] .input-group svg,
[class*="vbo"] .vbo-caltrigger,
[class*="vbo"] i.fa,
[class*="vbo"] i.fas,
[class*="vbo"] i.far,
[class*="vbo"] i[class*="fa-"] {
    background: transparent !important;
    color: #666 !important;
}

/* Début search form */
.vbmodhorsearchmaindiv {
    background: yellow !important;
}
/* Fin search form */

/* Réinitialiser tous les floats et positionnements qui pourraient causer le problème */
.vblistcontainer-grid * {
    box-sizing: border-box;
}

.vblistcontainer-grid .vbcontdivtot,
.vblistcontainer-grid .vbdivtot,
.vblistcontainer-grid .vbdivtotinline {
    clear: both !important;
    float: none !important;
    position: static !important;
}