/* demirovoyages/public/_assets/css/voyages.css */

@import url('./home.css');

.voyages-section {
    padding: 40px 20px; /* Réduit pour laisser de la place aux filtres */
    background-color: var(--off-white-bg);
}

/* Nouvelle structure pour filtres + grille */
.voyages-section .container-fluid {
    max-width: 1320px; /* Largeur max pour l'ensemble */
    margin: 0 auto;
}

.filters-sidebar {
    background-color: #fff;
    padding: 25px;
    border-radius: 8px;
    box-shadow: var(--box-shadow-light);
    margin-bottom: 30px; /* Pour mobile */
}

.filters-sidebar h4 { /* Titre "Filtres" */
    font-size: 1.6em;
    color: var(--dark-text);
    margin-bottom: 25px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--border-color);
}

.filter-group {
    margin-bottom: 25px;
}

.filter-group h5 { /* Titres de chaque groupe de filtre */
    font-size: 1.1em;
    color: var(--dark-text);
    font-weight: 600;
    margin-bottom: 12px;
}

.price-range-inputs {
    display: flex;
    align-items: center;
    gap: 8px;
}
.price-range-inputs input[type="number"] {
    width: 100px;
    padding: 6px 8px;
    border: 1px solid var(--border-color);
    border-radius: 4px;
    font-size: 0.9em;
    -moz-appearance: textfield; /* Pour Firefox */
}
.price-range-inputs input[type="number"]::-webkit-outer-spin-button,
.price-range-inputs input[type="number"]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
.price-range-inputs span {
    color: var(--light-text);
}

.filter-list {
    list-style: none;
    padding-left: 0;
}
.filter-list li {
    margin-bottom: 8px;
}
.filter-list label {
    font-size: 0.95em;
    color: var(--light-text);
    cursor: pointer;
    display: flex;
    align-items: center;
}
.filter-list input[type="checkbox"] {
    margin-right: 8px;
    accent-color: var(--primary-blue); /* Couleur de la coche */
}

.btn-apply-filters, .btn-reset-filters {
    width: 100%;
    padding: 10px;
    border-radius: 5px;
    font-weight: 600;
    text-align: center;
    cursor: pointer;
    transition: background-color 0.3s ease, color 0.3s ease;
    margin-top: 10px;
    font-size: 0.95em;
}
.btn-apply-filters {
    background-color: var(--primary-blue);
    color: var(--white);
    border: 1px solid var(--primary-blue);
}
.btn-apply-filters:hover {
    background-color: var(--secondary-blue);
}
.btn-reset-filters {
    background-color: var(--light-text);
    color: var(--white);
    border: 1px solid var(--light-text);
    display: block;
    text-decoration: none;
}
.btn-reset-filters:hover {
    background-color: var(--dark-text);
}


.voyages-main-content h2 { /* Titre "Nos Voyages" au-dessus de la grille */
    font-size: 2.2em;
    color: var(--dark-text);
    margin-bottom: 30px;
    font-weight: 600;
    text-align: center;
}

.results-summary {
    font-size: 0.9em;
    color: var(--light-text);
    margin-bottom: 20px;
    text-align: right;
}

.voyages-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); /* Ajusté pour le contenu principal */
    gap: 25px;
}

.voyage-box {
    background-color: var(--white);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: var(--box-shadow-light);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    text-align: left;
    display: flex;
    flex-direction: column;
}

.voyage-box:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1);
}

.voyage-box a {
    display: flex; /* Pour que le a prenne toute la hauteur */
    flex-direction: column;
    text-decoration: none;
    color: inherit;
    height: 100%; /* Permet au contenu de pousser le prix en bas */
}

.voyage-image {
    height: 200px; /* Hauteur fixe pour l'image */
    overflow: hidden;
}
.voyage-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.5s ease;
}
.voyage-box:hover .voyage-image img {
    transform: scale(1.05);
}

.voyage-content {
    padding: 15px; /* Réduit un peu */
    flex-grow: 1; /* Permet au contenu de pousser le prix vers le bas */
    display: flex;
    flex-direction: column;
}

.voyage-content h3 {
    margin: 0 0 8px 0;
    color: var(--dark-text);
    font-size: 1.25em; /* Un peu plus petit */
    font-weight: 600;
    line-height: 1.3;
}

.voyage-description {
    color: var(--light-text);
    margin-bottom: 10px;
    line-height: 1.45;
    font-size: 0.9em; /* Un peu plus petit */
    min-height: 3em; /* Pour 2 lignes approx. */
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2; /* Limite à 2 lignes */
    -webkit-box-orient: vertical;
}

.voyage-details {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: auto; /* Pousse cette section en bas */
    padding-top: 10px; /* Espace avant les détails */
    border-top: 1px solid var(--border-color); /* Séparateur léger */
}

.voyage-price {
    color: var(--primary-blue);
    font-weight: 700;
    font-size: 1.2em; /* Un peu plus petit */
}

.btn-details { 
    background-color: var(--primary-blue);
    color: var(--white);
    padding: 6px 15px; /* Un peu plus petit */
    border: none;
    border-radius: 20px;
    cursor: pointer;
    font-size: 0.85em; /* Un peu plus petit */
    font-weight: 500;
    transition: background-color 0.3s ease;
    text-decoration: none;
    display: inline-block;
}
.btn-details:hover {
    background-color: var(--secondary-blue);
}


/* Responsive adjustments */
@media (max-width: 991px) { /* Bootstrap lg breakpoint */
    .filters-sidebar {
        margin-bottom: 30px;
    }
    .voyages-main-content h2 {
        font-size: 2em;
    }
}

@media (max-width: 768px) {
    .voyages-grid {
        grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); /* S'adapte mieux sur mobile */
    }
    .results-summary { text-align: center; }
}