/* Public CSS */

.annonces-auto-container {

    max-width: 1200px;

    margin: 0 auto;

    padding: 20px;

}

/* Grille d'annonces */

.annonces-auto-grid {

    display: grid;

    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));

    gap: 20px;

    margin-top: 20px;

}

.annonces-auto-card {

    background: #fff;

    border: 1px solid #ddd;

    border-radius: 5px;

    overflow: hidden;

    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);

    transition: transform 0.3s ease, box-shadow 0.3s ease;

}

.annonces-auto-card:hover {

    transform: translateY(-5px);

    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1);

}

.annonces-auto-card-image {

    height: 200px;

    overflow: hidden;

    position: relative;

}

.annonces-auto-card-image img {

    width: 100%;

    height: 100%;

    object-fit: cover;

    transition: transform 0.3s;

}

.annonces-auto-card:hover .annonces-auto-card-image img {

    transform: scale(1.05);

}

.annonces-auto-card-image a {

    display: block;

    width: 100%;

    height: 100%;

    position: relative;

    overflow: hidden;

}

.annonces-auto-card-image a::before {

    content: '';

    position: absolute;

    top: 0;

    left: 0;

    width: 100%;

    height: 100%;

    background-color: rgba(0, 115, 170, 0);

    transition: background-color 0.3s ease;

    z-index: 1;

}

.annonces-auto-card-image a::after {

    content: '\f002';

    font-family: 'Font Awesome 5 Free';

    font-weight: 900;

    position: absolute;

    top: 50%;

    left: 50%;

    transform: translate(-50%, -50%) scale(0);

    color: #fff;

    font-size: 24px;

    z-index: 2;

    opacity: 0;

    transition: all 0.3s ease;

}

.annonces-auto-card-image a:hover::before {

    background-color: rgba(0, 115, 170, 0.5);

}

.annonces-auto-card-image a:hover::after {

    transform: translate(-50%, -50%) scale(1);

    opacity: 1;

}

.annonces-auto-card-content {

    padding: 15px;

}

.annonces-auto-card-title {

    font-size: 18px;

    font-weight: 600;

    margin: 0 0 10px 0;

}

.annonces-auto-card-price {

    font-size: 20px;

    font-weight: 700;

    color: #0073aa;

    margin: 0 0 10px 0;

}

.annonces-auto-card-location {

    font-size: 14px;

    color: #666;

    margin: 0 0 10px 0;

}

.annonces-auto-card-category {

    display: inline-block;

    background: #f1f1f1;

    padding: 3px 8px;

    border-radius: 3px;

    font-size: 12px;

    margin-bottom: 10px;

}

.annonces-auto-card-footer {

    display: flex;

    justify-content: space-between;

    align-items: center;

    padding: 10px 15px;

    background: #f9f9f9;

    border-top: 1px solid #eee;

}

.annonces-auto-card-date {

    font-size: 12px;

    color: #666;

}

.annonces-auto-card-views {

    font-size: 12px;

    color: #666;

}

.annonces-auto-card-actions {

    padding: 15px;

}

/* Formulaire de recherche */

.annonces-auto-search-form {

    background: #f9f9f9;

    padding: 20px;

    border-radius: 5px;

    margin-bottom: 20px;

}

.annonces-auto-search-form form {

    display: grid;

    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));

    gap: 15px;

}

.annonces-auto-search-form .form-field {

    margin-bottom: 0;

}

.annonces-auto-search-form .form-submit {

    grid-column: 1 / -1;

    text-align: right;

}

/* Pagination */

.annonces-auto-pagination {

    margin-top: 30px;

    text-align: center;

}

.annonces-auto-pagination .page-numbers {

    display: inline-block;

    padding: 5px 10px;

    margin: 0 3px;

    border: 1px solid #ddd;

    border-radius: 3px;

    text-decoration: none;

    color: #333;

}

.annonces-auto-pagination .page-numbers.current {

    background: #0073aa;

    color: #fff;

    border-color: #0073aa;

}

.annonces-auto-pagination .page-numbers:hover {

    background: #f1f1f1;

}

/* Détail d'annonce */

.annonces-auto-detail {

    background: #fff;

    border: 1px solid #ddd;

    border-radius: 5px;

    padding: 20px;

    margin-bottom: 30px;

}

.annonces-auto-detail-header {

    margin-bottom: 20px;

}

.annonces-auto-detail-title {

    font-size: 24px;

    font-weight: 600;

    margin: 0 0 10px 0;

}

.annonces-auto-detail-price {

    font-size: 24px;

    font-weight: 700;

    color: #0073aa;

    margin: 0 0 10px 0;

}

.annonces-auto-detail-meta {

    display: flex;

    flex-wrap: wrap;

    gap: 15px;

    margin-bottom: 20px;

}

.annonces-auto-detail-meta-item {

    display: flex;

    align-items: center;

    font-size: 14px;

    color: #666;

}

.annonces-auto-detail-meta-item i {

    margin-right: 5px;

}

.annonces-auto-detail-gallery {

    margin-bottom: 30px;

}

.annonces-auto-detail-main-image {

    width: 100%;

    height: 400px;

    overflow: hidden;

    border-radius: 5px;

    margin-bottom: 10px;

}

.annonces-auto-detail-main-image img {

    width: 100%;

    height: 100%;

    object-fit: cover;

}

.annonces-auto-detail-thumbnails {

    display: flex;

    gap: 10px;

    overflow-x: auto;

    padding-bottom: 10px;

}

.annonces-auto-detail-thumbnail {

    width: 80px;

    height: 80px;

    border-radius: 5px;

    overflow: hidden;

    cursor: pointer;

    opacity: 0.7;

    transition: opacity 0.2s;

}

.annonces-auto-detail-thumbnail.active {

    opacity: 1;

    border: 2px solid #0073aa;

}

.annonces-auto-detail-thumbnail:hover {

    opacity: 1;

}

.annonces-auto-detail-thumbnail img {

    width: 100%;

    height: 100%;

    object-fit: cover;

}

.annonces-auto-detail-description {

    margin-bottom: 30px;

}

.annonces-auto-detail-description h3 {

    font-size: 18px;

    font-weight: 600;

    margin: 0 0 15px 0;

    padding-bottom: 10px;

    border-bottom: 1px solid #eee;

}

.annonces-auto-detail-seller {

    background: #f9f9f9;

    padding: 20px;

    border-radius: 5px;

    margin-bottom: 30px;

}

.annonces-auto-detail-seller h3 {

    font-size: 18px;

    font-weight: 600;

    margin: 0 0 15px 0;

}

.annonces-auto-detail-seller-info {

    display: flex;

    flex-wrap: wrap;

    gap: 20px;

}

.annonces-auto-detail-seller-meta {

    flex: 1;

    min-width: 200px;

}

.annonces-auto-detail-seller-meta p {

    margin: 0 0 10px 0;

}

.annonces-auto-detail-seller-rating {

    flex: 1;

    min-width: 200px;

}

.annonces-auto-detail-seller-rating-stars {

    font-size: 24px;

    color: #f0c33c;

    margin-bottom: 10px;

}

.annonces-auto-detail-seller-actions {

    margin-top: 20px;

}

.annonces-auto-detail-seller-actions .button {

    margin-right: 10px;

}

.annonces-auto-detail-actions {

    display: flex;

    gap: 10px;

    margin-top: 30px;

}

/* Formulaires */

.annonces-auto-form {

    background: #fff;

    border: 1px solid #ddd;

    border-radius: 5px;

    padding: 20px;

    margin-bottom: 30px;

}

.annonces-auto-form h2 {

    font-size: 20px;

    font-weight: 600;

    margin: 0 0 20px 0;

    padding-bottom: 10px;

    border-bottom: 1px solid #eee;

}

.annonces-auto-form .form-field {

    margin-bottom: 20px;

}

.annonces-auto-form .form-field label {

    display: block;

    margin-bottom: 5px;

    font-weight: 600;

}

.annonces-auto-form .form-field input[type="text"],

.annonces-auto-form .form-field input[type="email"],

.annonces-auto-form .form-field input[type="password"],

.annonces-auto-form .form-field input[type="tel"],

.annonces-auto-form .form-field input[type="number"],

.annonces-auto-form .form-field select,

.annonces-auto-form .form-field textarea {

    width: 100%;

    padding: 8px;

    border: 1px solid #ddd;

    border-radius: 3px;

}

.annonces-auto-form .form-field .description {

    font-size: 12px;

    color: #666;

    margin-top: 5px;

}

.annonces-auto-form .form-submit {

    margin-top: 30px;

}

/* Onglets */

/* Styles personnalisés pour les onglets Bootstrap */
.annonces-auto-tabs {
    margin-bottom: 30px;
}

/* Personnalisation légère des onglets Bootstrap */
.annonces-auto-tabs .nav-tabs {
    border-bottom: 1px solid #dee2e6;
}

.annonces-auto-tabs .nav-link {
    color: #495057;
    border: 1px solid transparent;
    border-top-left-radius: 0.25rem;
    border-top-right-radius: 0.25rem;
    padding: 0.5rem 1rem;
    transition: all 0.3s ease;
}

.annonces-auto-tabs .nav-link.active {
    color: #0d6efd;
    background-color: #fff;
    border-color: #dee2e6 #dee2e6 #fff;
    font-weight: 500;
}

.annonces-auto-tabs .nav-link:hover:not(.active) {
    background-color: rgba(13, 110, 253, 0.1);
    border-color: transparent;
}

.annonces-auto-tabs-content {

    background: #fff;

    border: 1px solid #ddd;

    border-radius: 5px;

    padding: 20px;

}

/* Messages */

.annonces-auto-message {

    padding: 15px;

    border-radius: 5px;

    margin-bottom: 20px;

}

.annonces-auto-message.success {

    background: #d4edda;

    color: #155724;

    border: 1px solid #c3e6cb;

}

.annonces-auto-message.error {

    background: #f8d7da;

    color: #721c24;

    border: 1px solid #f5c6cb;

}

.annonces-auto-message.info {

    background: #d1ecf1;

    color: #0c5460;

    border: 1px solid #bee5eb;

}

.annonces-auto-message.warning {

    background: #fff3cd;

    color: #856404;

    border: 1px solid #ffeeba;

}

/* Téléchargement de photos */

.annonces-auto-photos-upload {

    margin-bottom: 20px;

}

.annonces-auto-photos-preview {

    display: flex;

    flex-wrap: wrap;

    gap: 10px;

    margin-top: 10px;

}

.annonces-auto-photo-item {

    position: relative;

    width: 100px;

    height: 100px;

    border-radius: 5px;

    overflow: hidden;

}

.annonces-auto-photo-item img {

    width: 100%;

    height: 100%;

    object-fit: cover;

}

.annonces-auto-photo-item .delete-photo {

    position: absolute;

    top: 5px;

    right: 5px;

    width: 20px;

    height: 20px;

    background: rgba(0, 0, 0, 0.5);

    color: #fff;

    border-radius: 50%;

    display: flex;

    align-items: center;

    justify-content: center;

    cursor: pointer;

    font-size: 12px;

}

/* Prévisualisation des photos à télécharger */

.photo-preview-container {

    display: flex;

    flex-wrap: wrap;

    gap: 10px;

    margin-top: 15px;

}

.annonces-auto-photo-preview-item {

    position: relative;

    width: 100px;

    height: 100px;

    border-radius: 5px;

    overflow: hidden;

    border: 1px dashed #ccc;

}

.annonces-auto-photo-preview-item img {

    width: 100%;

    height: 100%;

    object-fit: cover;

}

.annonces-auto-photo-preview-item .remove-preview {

    position: absolute;

    top: 5px;

    right: 5px;

    width: 20px;

    height: 20px;

    background: rgba(0, 0, 0, 0.5);

    color: #fff;

    border-radius: 50%;

    display: flex;

    align-items: center;

    justify-content: center;

    cursor: pointer;

    font-size: 12px;

}

.annonces-auto-photos-upload-button {

    margin-top: 15px;

}

.annonces-auto-photos-upload-button input[type="file"] {

    display: none;

}

.photo-upload-info {

    margin-top: 10px;

}

/* Notation */

.annonces-auto-rating {

    margin-bottom: 20px;

}

.annonces-auto-rating-stars {

    font-size: 24px;

    color: #f0c33c;

    cursor: pointer;

}

.annonces-auto-rating-stars i {

    margin-right: 5px;

}

.annonces-auto-rating-stars i:hover~i {

    color: #ddd;

}

/* Commentaires */

.annonces-auto-comments {

    margin-top: 30px;

}

.annonces-auto-comments h3 {

    font-size: 18px;

    font-weight: 600;

    margin: 0 0 15px 0;

    padding-bottom: 10px;

    border-bottom: 1px solid #eee;

}

.annonces-auto-comment {

    background: #f9f9f9;

    padding: 15px;

    border-radius: 5px;

    margin-bottom: 15px;

}

.annonces-auto-comment-header {

    display: flex;

    justify-content: space-between;

    margin-bottom: 10px;

}

.annonces-auto-comment-author {

    font-weight: 600;

}

.annonces-auto-comment-date {

    font-size: 12px;

    color: #666;

}

.annonces-auto-comment-rating {

    color: #f0c33c;

    margin-bottom: 10px;

}

/* Responsive */

@media screen and (max-width: 768px) {

    .annonces-auto-search-form form {

        grid-template-columns: 1fr;

    }

    .annonces-auto-detail-seller-info {

        flex-direction: column;

    }

    .annonces-auto-detail-actions {

        flex-direction: column;

    }

    .annonces-auto-detail-actions .button {

        width: 100%;

        margin-bottom: 10px;

    }

    /* Styles responsive pour les onglets Bootstrap */
    .annonces-auto-tabs .nav-tabs {
        flex-wrap: wrap;
    }

    .annonces-auto-tabs .nav-item {
        flex: 1;
        text-align: center;
        min-width: 120px;
        margin-bottom: -1px;
    }

    .annonces-auto-tabs .nav-link {
        padding: 0.5rem;
        font-size: 0.9rem;
    }

    /* Pour afficher les icônes plus grandes sur mobile */
    .annonces-auto-tabs .nav-link .bi {
        font-size: 1.2rem;
        display: block;
        margin: 0 auto 5px;
    }

}

/* Ajouter à la fin du fichier CSS */

/* Styles spécifiques pour le sélecteur de catégories */

#categorie_id {

    position: relative;

    display: block;

    width: 100%;

    height: auto;

    padding: 10px;

    box-sizing: border-box;

    border: 1px solid #ddd;

    border-radius: 4px;

    background-color: #fff;

    cursor: pointer;

    appearance: auto;

    -webkit-appearance: menulist;

    -moz-appearance: menulist;

    z-index: 100;

}

#categorie_id option,

#categorie_id optgroup {

    padding: 8px;

    cursor: pointer;

    background-color: #fff;

}

#categorie_id:focus,

#categorie_id:active {

    border-color: #007cba;

    box-shadow: 0 0 2px rgba(0, 124, 186, 0.8);

    outline: none;

}

/* Assurez-vous que l'élément select soit au-dessus des autres éléments */

.form-field {

    position: relative;

}

/* Styles pour les images cliquables */

.annonces-auto-card-image a {

    display: block;

    width: 100%;

    height: 100%;

    position: relative;

    overflow: hidden;

}

.annonces-auto-card-image a::before {

    content: '';

    position: absolute;

    top: 0;

    left: 0;

    width: 100%;

    height: 100%;

    background-color: rgba(0, 115, 170, 0);

    transition: background-color 0.3s ease;

    z-index: 1;

}

.annonces-auto-card-image a::after {

    content: '\f002';

    font-family: 'Font Awesome 5 Free';

    font-weight: 900;

    position: absolute;

    top: 50%;

    left: 50%;

    transform: translate(-50%, -50%) scale(0);

    color: #fff;

    font-size: 24px;

    z-index: 2;

    opacity: 0;

    transition: all 0.3s ease;

}

.annonces-auto-card-image a:hover::before {

    background-color: rgba(0, 115, 170, 0.5);

}

.annonces-auto-card-image a:hover::after {

    transform: translate(-50%, -50%) scale(1);

    opacity: 1;

}

/* Style amélioré pour le bouton "Voir l'annonce" */

.annonces-auto-view-button {

    display: inline-flex;

    align-items: center;

    justify-content: center;

    padding: 10px 15px;

    font-weight: 600;

    text-transform: uppercase;

    letter-spacing: 0.5px;

    border-radius: 4px;

    transition: all 0.3s ease;

    width: 100%;

    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.15);

}

.annonces-auto-view-button i {

    margin-right: 8px;

}

.annonces-auto-view-button:hover {

    transform: translateY(-2px);

    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);

}

/* Styles pour les boutons d'action dans la liste des annonces */
.annonces-auto-account-table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 20px;
}

.annonces-auto-account-table th,
.annonces-auto-account-table td {
    padding: 10px;
    text-align: left;
    border-bottom: 1px solid #eee;
}

.annonces-auto-account-table th {
    background-color: #f8f8f8;
    font-weight: bold;
}

.annonces-auto-account-table tr:hover {
    background-color: #f9f9f9;
}

/* Espacement des boutons dans la cellule d'actions */
.annonces-auto-action-buttons .btn-group {
    gap: 5px;
}

.annonces-auto-action-buttons .btn {
    margin: 0 2px;
    white-space: nowrap;
}





/* Styles Bootstrap supplémentaires */
@media (max-width: 768px) {

    /* Sur mobile, garder uniquement les icônes */
    .annonces-auto-action-buttons .btn span:not(.bi) {
        display: none;
    }

    /* Réduire la taille des boutons sur mobile */
    .annonces-auto-action-buttons .btn {
        padding: 0.25rem 0.5rem;
    }
}