/* ================================================================
   AS24 Vehicles — Styles Faubourg Cars
   Utilise !important pour ne pas être écrasé par le thème
   ================================================================ */

/* -- Filtres ---------------------------------------------------- */

.as24-filters {
    background: #fff !important;
    border: 1px solid #e0ddd8 !important;
    border-radius: 4px !important;
    padding: 20px !important;
    margin-bottom: 32px !important;
    box-sizing: border-box !important;
    width: 100% !important;
}

.as24-filters__row {
    display: grid !important;
    grid-template-columns: 1fr 1fr 1fr 1fr auto auto !important;
    gap: 12px !important;
    align-items: flex-end !important;
}

.as24-filters__field {
    display: flex !important;
    flex-direction: column !important;
    gap: 5px !important;
    min-width: 0 !important;
}

.as24-filters__field label {
    font-size: 11px !important;
    font-weight: 600 !important;
    color: #666 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
    margin: 0 !important;
    padding: 0 !important;
    display: block !important;
}

.as24-filters__field select,
.as24-filters__field input[type="number"] {
    padding: 10px 14px !important;
    border: 1px solid #d5d0c8 !important;
    border-radius: 4px !important;
    font-size: 14px !important;
    background: #faf9f7 !important;
    color: #1a1a1a !important;
    outline: none !important;
    width: 100% !important;
    box-sizing: border-box !important;
    height: 42px !important;
    margin: 0 !important;
    box-shadow: none !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    line-height: normal !important;
}

.as24-filters__field select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 12px center !important;
    padding-right: 36px !important;
}

.as24-filters__field select:focus,
.as24-filters__field input[type="number"]:focus {
    border-color: #1a1a1a !important;
    box-shadow: 0 0 0 2px rgba(26,26,26,0.08) !important;
}

/* -- Boutons ---------------------------------------------------- */

.as24-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 20px !important;
    border-radius: 4px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    letter-spacing: 0.03em !important;
    text-decoration: none !important;
    cursor: pointer !important;
    white-space: nowrap !important;
    height: 42px !important;
    box-sizing: border-box !important;
    flex-shrink: 0 !important;
    line-height: 42px !important;
    vertical-align: middle !important;
    visibility: visible !important;
    opacity: 1 !important;
}

.as24-btn--primary {
    background: #1a1a1a !important;
    color: #fff !important;
    border: 1px solid #1a1a1a !important;
    -webkit-text-fill-color: #fff !important;
    text-shadow: none !important;
}

.as24-btn--primary:hover {
    background: #333 !important;
    color: #fff !important;
    border-color: #333 !important;
    -webkit-text-fill-color: #fff !important;
}

/* Cibler aussi input[type=submit] directement */
input.as24-btn--primary,
input[type="submit"].as24-btn--primary {
    background: #1a1a1a !important;
    color: #fff !important;
    -webkit-text-fill-color: #fff !important;
    border: 1px solid #1a1a1a !important;
    border-radius: 4px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    height: 42px !important;
    padding: 0 20px !important;
    cursor: pointer !important;
    letter-spacing: 0.03em !important;
    white-space: nowrap !important;
    flex-shrink: 0 !important;
    box-sizing: border-box !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    display: inline-flex !important;
    align-items: center !important;
    text-shadow: none !important;
    opacity: 1 !important;
    visibility: visible !important;
}

input.as24-btn--primary:hover,
input[type="submit"].as24-btn--primary:hover {
    background: #333 !important;
    color: #fff !important;
    -webkit-text-fill-color: #fff !important;
}

.as24-btn--secondary {
    background: #fff !important;
    color: #555 !important;
    border: 1px solid #d5d0c8 !important;
}

.as24-btn--secondary:hover {
    background: #f5f3ef !important;
    color: #1a1a1a !important;
}

/* -- Grille de cartes ------------------------------------------ */

.as24-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)) !important;
    gap: 24px !important;
    margin: 0 0 32px !important;
    padding: 0 !important;
    list-style: none !important;
}

/* -- Carte véhicule -------------------------------------------- */

.as24-card {
    background: #fff !important;
    border: 1px solid #e0ddd8 !important;
    border-radius: 4px !important;
    overflow: hidden !important;
    transition: transform 0.25s ease, box-shadow 0.25s ease !important;
    margin: 0 !important;
    padding: 0 !important;
}

.as24-card:hover {
    transform: translateY(-4px) !important;
    box-shadow: 0 16px 40px rgba(0,0,0,0.09) !important;
}

.as24-card__link {
    display: block !important;
    text-decoration: none !important;
    color: inherit !important;
}

.as24-card__image {
    position: relative !important;
    padding-top: 62% !important;
    background: #f5f3ef !important;
    overflow: hidden !important;
}

.as24-card__image img {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transition: transform 0.35s ease !important;
}

.as24-card:hover .as24-card__image img {
    transform: scale(1.05) !important;
}

.as24-card__no-image {
    position: absolute !important;
    inset: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: #bbb !important;
    font-size: 13px !important;
}

.as24-card__body {
    padding: 16px 18px 18px !important;
}

.as24-card__title {
    font-size: 17px !important;
    font-weight: 700 !important;
    margin: 0 0 3px !important;
    color: #1a1a1a !important;
    line-height: 1.3 !important;
}

.as24-card__version {
    font-size: 12px !important;
    color: #999 !important;
    margin: 0 0 12px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    text-transform: uppercase !important;
    letter-spacing: 0.04em !important;
}

.as24-card__specs {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
    margin-bottom: 14px !important;
}

.as24-spec {
    background: #f5f3ef !important;
    border-radius: 3px !important;
    padding: 4px 9px !important;
    font-size: 11px !important;
    color: #555 !important;
    letter-spacing: 0.02em !important;
    display: inline-block !important;
}

.as24-card__footer {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    border-top: 1px solid #f0ede8 !important;
    padding-top: 12px !important;
    margin-top: 4px !important;
}

.as24-card__price {
    font-size: 20px !important;
    font-weight: 800 !important;
    color: #1a1a1a !important;
}

.as24-card__cta {
    font-size: 12px !important;
    font-weight: 600 !important;
    color: #888 !important;
    letter-spacing: 0.05em !important;
    text-transform: uppercase !important;
}

.as24-card__cta::after {
    content: ' →' !important;
    display: inline-block !important;
    transition: margin-left 0.2s !important;
}

.as24-card:hover .as24-card__cta::after {
    margin-left: 4px !important;
}

/* -- Pagination ------------------------------------------------- */

.as24-pagination {
    display: flex !important;
    gap: 6px !important;
    justify-content: center !important;
    margin: 16px 0 8px !important;
    flex-wrap: wrap !important;
}

.as24-pagination__btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 36px !important;
    height: 36px !important;
    padding: 0 12px !important;
    border-radius: 4px !important;
    border: 1px solid #d5d0c8 !important;
    background: #fff !important;
    color: #555 !important;
    font-size: 13px !important;
    text-decoration: none !important;
    transition: all 0.15s !important;
}

.as24-pagination__btn:hover {
    border-color: #1a1a1a !important;
    color: #1a1a1a !important;
}

.as24-pagination__btn--active {
    background: #1a1a1a !important;
    border-color: #1a1a1a !important;
    color: #fff !important;
    pointer-events: none !important;
}

/* -- Divers ----------------------------------------------------- */

.as24-no-results {
    text-align: center !important;
    padding: 60px 0 !important;
    color: #aaa !important;
    font-size: 15px !important;
}

.as24-last-sync {
    text-align: right !important;
    font-size: 11px !important;
    color: #c0bdb8 !important;
    margin-top: 12px !important;
}

/* -- Responsive ------------------------------------------------- */

@media (max-width: 1024px) {
    .as24-filters__row {
        grid-template-columns: 1fr 1fr 1fr !important;
    }
}

@media (max-width: 768px) {
    .as24-filters__row {
        grid-template-columns: 1fr 1fr !important;
    }
    .as24-filters__row .as24-btn {
        width: 100% !important;
    }
}

@media (max-width: 480px) {
    .as24-grid {
        grid-template-columns: 1fr !important;
    }
    .as24-filters__row {
        grid-template-columns: 1fr !important;
    }
}

/* ================================================================
   AS24 Featured — Grille hero pour la home page
   Design : photo plein cadre + overlay prix/titre/description
   ================================================================ */

.as24-featured {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    grid-template-rows: auto auto !important;
    gap: 4px !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Première carte : grande, occupe 2 colonnes x 2 rangées */
.as24-featured__item:first-child {
    grid-column: 1 / 3 !important;
    grid-row: 1 / 3 !important;
}

/* Les autres : taille normale */
.as24-featured__item {
    position: relative !important;
    overflow: hidden !important;
    display: block !important;
    text-decoration: none !important;
    background: #111 !important;
    min-height: 280px !important;
}

.as24-featured__item:first-child {
    min-height: 580px !important;
}

/* Image plein cadre */
.as24-featured__img {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transition: transform 0.5s ease !important;
    display: block !important;
}

.as24-featured__item:hover .as24-featured__img {
    transform: scale(1.04) !important;
}

/* Overlay dégradé bas */
.as24-featured__overlay {
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(
        to bottom,
        rgba(0,0,0,0) 30%,
        rgba(0,0,0,0.75) 100%
    ) !important;
    z-index: 1 !important;
}

/* Contenu texte en bas à gauche */
.as24-featured__body {
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    padding: 20px 22px !important;
    z-index: 2 !important;
}

.as24-featured__price {
    font-size: 14px !important;
    font-weight: 500 !important;
    color: rgba(255,255,255,0.85) !important;
    margin: 0 0 4px !important;
    display: block !important;
    letter-spacing: 0.02em !important;
}

.as24-featured__title {
    font-size: 26px !important;
    font-weight: 700 !important;
    color: #fff !important;
    margin: 0 0 8px !important;
    line-height: 1.2 !important;
}

.as24-featured__item:not(:first-child) .as24-featured__title {
    font-size: 20px !important;
}

.as24-featured__desc {
    font-size: 13px !important;
    color: rgba(255,255,255,0.75) !important;
    margin: 0 !important;
    line-height: 1.5 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

/* Placeholder sans image */
.as24-featured__no-image {
    position: absolute !important;
    inset: 0 !important;
    background: #1a1a1a !important;
}

/* -- Responsive ------------------------------------------------- */

@media (max-width: 900px) {
    .as24-featured {
        grid-template-columns: 1fr 1fr !important;
    }
    .as24-featured__item:first-child {
        grid-column: 1 / 3 !important;
        grid-row: 1 !important;
        min-height: 360px !important;
    }
    .as24-featured__item {
        min-height: 220px !important;
    }
}

@media (max-width: 560px) {
    .as24-featured {
        grid-template-columns: 1fr !important;
    }
    .as24-featured__item:first-child {
        grid-column: 1 !important;
        min-height: 280px !important;
    }
}
/* ================================================================
   AS24 Single — Style hero premium (inspiré screenshot)
   ================================================================ */

/* Reset wrapper */
.as24s {
    margin: 0 !important;
    padding: 0 !important;
    font-family: inherit !important;
}

/* ---- HERO ---- */

.as24s-hero {
    position: relative !important;
    width: 100% !important;
    min-height: 560px !important;
    background-size: cover !important;
    background-position: center !important;
    background-color: #111 !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    transition: background-image 0.3s ease !important;
    overflow: hidden !important;
}

.as24s-hero__overlay {
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(
        to bottom,
        rgba(0,0,0,0.25) 0%,
        rgba(0,0,0,0.15) 40%,
        rgba(0,0,0,0.70) 100%
    ) !important;
    z-index: 1 !important;
}

/* Top bar */
.as24s-hero__top {
    position: relative !important;
    z-index: 2 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 28px 40px !important;
}

.as24s-hero__back {
    font-size: 13px !important;
    color: rgba(255,255,255,0.80) !important;
    text-decoration: none !important;
    letter-spacing: 0.04em !important;
    transition: color 0.2s !important;
    display: inline-block !important;
}

.as24s-hero__back:hover {
    color: #fff !important;
}

.as24s-hero__badge {
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 0.14em !important;
    color: rgba(255,255,255,0.70) !important;
    text-transform: uppercase !important;
    border: 1px solid rgba(255,255,255,0.30) !important;
    padding: 4px 12px !important;
    border-radius: 20px !important;
}

/* Centre : titre */
.as24s-hero__center {
    position: relative !important;
    z-index: 2 !important;
    text-align: center !important;
    padding: 0 40px !important;
}

.as24s-hero__title {
    font-size: 52px !important;
    font-weight: 800 !important;
    color: #fff !important;
    margin: 0 0 10px !important;
    line-height: 1.1 !important;
    text-shadow: 0 2px 20px rgba(0,0,0,0.3) !important;
}

.as24s-hero__version {
    font-size: 15px !important;
    color: rgba(255,255,255,0.75) !important;
    margin: 0 !important;
    letter-spacing: 0.04em !important;
}

/* Bottom : stats + vignettes */
.as24s-hero__bottom {
    position: relative !important;
    z-index: 2 !important;
    background: rgba(0,0,0,0.45) !important;
    backdrop-filter: blur(6px) !important;
    -webkit-backdrop-filter: blur(6px) !important;
    padding: 20px 40px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 24px !important;
}

.as24s-hero__stats {
    display: flex !important;
    gap: 40px !important;
    align-items: center !important;
}

.as24s-hero__stat {
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
    text-align: center !important;
}

.as24s-hero__stat-val {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: #fff !important;
    letter-spacing: 0.01em !important;
}

.as24s-hero__stat-lbl {
    font-size: 10px !important;
    font-weight: 600 !important;
    letter-spacing: 0.12em !important;
    color: rgba(255,255,255,0.55) !important;
    text-transform: uppercase !important;
}

/* Vignettes */
.as24s-hero__thumbs {
    display: flex !important;
    gap: 8px !important;
    flex-shrink: 0 !important;
}

.as24s-hero__thumb {
    width: 64px !important;
    height: 48px !important;
    border-radius: 4px !important;
    overflow: hidden !important;
    border: 2px solid rgba(255,255,255,0.25) !important;
    padding: 0 !important;
    cursor: pointer !important;
    background: none !important;
    transition: border-color 0.2s !important;
    flex-shrink: 0 !important;
}

.as24s-hero__thumb img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
}

.as24s-hero__thumb--active,
.as24s-hero__thumb:hover {
    border-color: #fff !important;
}

/* ---- BODY ---- */

.as24s-body {
    max-width: 1100px !important;
    margin: 0 auto !important;
    padding: 56px 40px !important;
}

/* Intro : description + prix côte à côte */
.as24s-intro {
    display: grid !important;
    grid-template-columns: 1fr 260px !important;
    gap: 60px !important;
    align-items: start !important;
    padding-bottom: 48px !important;
    border-bottom: 1px solid #e8e4df !important;
    margin-bottom: 48px !important;
}

.as24s-intro__desc p {
    font-size: 16px !important;
    color: #333 !important;
    line-height: 1.75 !important;
    margin: 0 !important;
}

.as24s-intro__price-box {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-end !important;
    text-align: right !important;
    padding-top: 4px !important;
}

.as24s-intro__price-lbl {
    font-size: 10px !important;
    font-weight: 700 !important;
    letter-spacing: 0.14em !important;
    color: #999 !important;
    text-transform: uppercase !important;
    margin-bottom: 6px !important;
    display: block !important;
}

.as24s-intro__price {
    font-size: 40px !important;
    font-weight: 800 !important;
    color: #1a1a1a !important;
    line-height: 1 !important;
    display: block !important;
    margin-bottom: 8px !important;
}

.as24s-intro__trans {
    font-size: 13px !important;
    color: #999 !important;
    letter-spacing: 0.04em !important;
}

/* ---- Specs ---- */

.as24s-specs {
    margin-bottom: 56px !important;
}

.as24s-specs__title {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: #1a1a1a !important;
    margin: 0 0 24px !important;
    padding-bottom: 12px !important;
    border-bottom: 1px solid #e8e4df !important;
}

.as24s-specs__grid {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 0 !important;
}

.as24s-specs__item {
    padding: 18px 0 !important;
    border-bottom: 1px solid #f0ede8 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
    padding-right: 24px !important;
}

.as24s-specs__lbl {
    font-size: 11px !important;
    color: #999 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
}

.as24s-specs__val {
    font-size: 15px !important;
    font-weight: 600 !important;
    color: #1a1a1a !important;
}

/* ---- Formulaire ---- */

.as24s-contact {
    background: #f7f5f2 !important;
    border-radius: 8px !important;
    padding: 48px !important;
}

.as24s-contact__title {
    font-size: 24px !important;
    font-weight: 700 !important;
    color: #1a1a1a !important;
    margin: 0 0 6px !important;
}

.as24s-contact__sub {
    font-size: 14px !important;
    color: #888 !important;
    margin: 0 0 28px !important;
}

.as24s-contact__row {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 16px !important;
    margin-bottom: 16px !important;
}

.as24s-contact__field {
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
    margin-bottom: 16px !important;
}

.as24s-contact__field label {
    font-size: 11px !important;
    font-weight: 700 !important;
    color: #666 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
}

.as24s-contact__field input,
.as24s-contact__field textarea {
    padding: 12px 16px !important;
    border: 1px solid #ddd8d0 !important;
    border-radius: 4px !important;
    font-size: 14px !important;
    background: #fff !important;
    color: #1a1a1a !important;
    outline: none !important;
    width: 100% !important;
    box-sizing: border-box !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    transition: border-color 0.2s !important;
}

.as24s-contact__field input:focus,
.as24s-contact__field textarea:focus {
    border-color: #1a1a1a !important;
    box-shadow: 0 0 0 2px rgba(26,26,26,0.07) !important;
}

.as24s-contact__field textarea {
    resize: vertical !important;
    min-height: 110px !important;
    line-height: 1.6 !important;
}

.as24s-success {
    background: #f0faf0 !important;
    border: 1px solid #a8d5a8 !important;
    border-radius: 4px !important;
    padding: 16px !important;
    font-size: 14px !important;
    color: #2d6a2d !important;
}

.as24s-error {
    background: #fff0f0 !important;
    border: 1px solid #f5c0c0 !important;
    border-radius: 4px !important;
    padding: 12px !important;
    font-size: 13px !important;
    color: #c0392b !important;
    margin-bottom: 16px !important;
}

.as24-single__not-found {
    text-align: center !important;
    padding: 80px 0 !important;
    color: #aaa !important;
    font-size: 15px !important;
}

/* ---- Responsive ---- */

@media (max-width: 900px) {
    .as24s-hero__title { font-size: 36px !important; }
    .as24s-hero__top,
    .as24s-hero__bottom { padding: 20px 24px !important; }
    .as24s-hero__center { padding: 0 24px !important; }
    .as24s-hero__stats { gap: 24px !important; }
    .as24s-body { padding: 40px 24px !important; }
    .as24s-intro { grid-template-columns: 1fr !important; gap: 32px !important; }
    .as24s-intro__price-box { align-items: flex-start !important; text-align: left !important; }
    .as24s-specs__grid { grid-template-columns: repeat(2, 1fr) !important; }
    .as24s-contact { padding: 32px 24px !important; }
}

@media (max-width: 560px) {
    .as24s-hero { min-height: 420px !important; }
    .as24s-hero__title { font-size: 28px !important; }
    .as24s-hero__stats { gap: 16px !important; }
    .as24s-hero__stat-val { font-size: 15px !important; }
    .as24s-hero__thumbs { display: none !important; }
    .as24s-specs__grid { grid-template-columns: 1fr 1fr !important; }
    .as24s-contact__row { grid-template-columns: 1fr !important; }
    .as24s-intro__price { font-size: 32px !important; }
}
