/*
Theme Name: Octane
Theme URI: https://example.com
Author: Alexandre
Description: Thème marketplace automobile — annonces de voitures d'occasion avec recherche filtrée, fiche véhicule, espace membre, messagerie, blog SEO et import d'annonce assisté.
Version: 5.0.0
Requires PHP: 7.4
Text Domain: octane
*/


:root{
  --bg:#FFFFFF; --soft:#F6F7F9; --ink:#1A1D21; --gray:#6B7280; --line:#E5E7EB;
  --blue:#1D4ED8; --blue-d:#1E40AF; --green:#15803D; --green-bg:#EAF6EE;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scrollbar-gutter:stable}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);line-height:1.55;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
.wrap{max-width:1160px;margin:0 auto;padding:0 24px}
.screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}

/* ===== Boutons / liens ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;font-family:inherit;font-weight:600;font-size:14.5px;border-radius:8px;padding:10px 18px;transition:.15s}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-d);color:#fff}
.btn-ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn-ghost:hover{border-color:#c4c9d0}
.link{color:var(--blue);font-weight:600;font-size:14px}
.link:hover{text-decoration:underline}

/* ===== Plaque prix (signature) ===== */
/* Prix : typographique, souligné d'un accent bleu */
.price{display:inline-block;font-weight:800;font-size:17px;letter-spacing:-.4px;color:var(--ink);line-height:1.15;white-space:nowrap;position:relative;padding-bottom:3px}
.price::after{content:"";position:absolute;left:0;bottom:0;width:26px;height:3px;border-radius:2px;background:var(--blue)}
.price.lg{font-size:30px;letter-spacing:-.8px;padding-bottom:5px}
.price.lg::after{width:38px;height:4px}

/* ===== Header ===== */
.site-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:28px;height:64px}
.logo{font-weight:700;font-size:19px;letter-spacing:-.3px;display:inline-flex;align-items:center;line-height:1}
.logo span{color:var(--blue)}
.logo img{max-height:34px;width:auto;display:block}
/* Logo image WordPress (the_custom_logo génère son propre lien) */
.custom-logo-link{display:inline-flex;align-items:center;line-height:0}
.custom-logo{max-height:34px;width:auto;display:block}
.nav-links{display:flex;gap:26px;font-size:14px;font-weight:500;color:var(--gray);list-style:none}
.nav-links a:hover{color:var(--ink)}
.nav .spacer{flex:1}
.burger{display:none;width:42px;height:42px;border:1px solid var(--line);border-radius:8px;background:#fff;cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:4px;padding:0}
.burger i{display:block;width:18px;height:2px;background:var(--ink);border-radius:2px;transition:.2s}
.burger.open i:nth-child(1){transform:translateY(6px) rotate(45deg)}
.burger.open i:nth-child(2){opacity:0}
.burger.open i:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
.mmenu{display:none;background:#fff;border-bottom:1px solid var(--line)}
.mmenu.open{display:block}
.mmenu a{display:block;padding:14px 24px;font-size:15px;font-weight:500;border-top:1px solid var(--soft)}
.mmenu .cta{color:var(--blue);font-weight:600}
.mmenu ul{list-style:none}

/* ===== Hero accueil (texte + carte de recherche) ===== */
.hero{background:var(--soft);border-bottom:1px solid var(--line);padding:56px 0}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero h1{font-size:clamp(28px,3.8vw,42px);font-weight:700;letter-spacing:-.8px;line-height:1.12;margin-bottom:12px}
.hero p.lead{font-size:16.5px;color:var(--gray);max-width:46ch}
.hero-stats{display:flex;gap:34px;margin-top:28px;flex-wrap:wrap}
.hstat b{display:block;font-size:22px;font-weight:700;letter-spacing:-.4px}
.hstat span{font-size:13px;color:var(--gray)}
.searchcard{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px;box-shadow:0 18px 50px -22px rgba(26,29,33,.18)}
.searchcard h2{font-size:17px;font-weight:700;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.searchcard h2 a{font-size:13px;font-weight:600;color:var(--blue)}
.s-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.s-grid .sfield label{display:block;font-size:11.5px;font-weight:600;color:var(--gray);margin-bottom:5px;text-transform:uppercase;letter-spacing:.06em}
.s-grid .sfield select,.s-grid .sfield input{width:100%;padding:11px 12px;border:1.5px solid var(--line);border-radius:10px;background:#fff;font-family:inherit;font-size:14.5px;color:var(--ink);appearance:none}
.s-grid .sfield select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B7280' stroke-width='1.6' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;cursor:pointer}
.s-grid .sfield select:focus,.s-grid .sfield input:focus{outline:none;border-color:var(--blue)}
.searchcard .btn{width:100%;margin-top:14px;padding:14px;font-size:15.5px}
.searchcard small{display:block;text-align:center;margin-top:10px;color:var(--gray);font-size:13px}
.searchcard small a{color:var(--blue);font-weight:600}

/* ===== Trust ===== */
.trust{padding:22px 0;border-bottom:1px solid var(--line)}
.trust .wrap{display:flex;justify-content:center;flex-wrap:wrap;gap:14px 44px;font-size:14px;color:var(--gray)}
.trust span::before{content:"✓";color:var(--blue);font-weight:700;margin-right:8px}

/* ===== Sections ===== */
section.pad{padding:56px 0}
.section-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:24px}
.section-head h2{font-size:22px;font-weight:700;letter-spacing:-.4px}
.brand-row{display:flex;flex-wrap:wrap;gap:8px}
.chip{display:inline-block;border:1px solid var(--line);background:#fff;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:500;transition:.15s;color:var(--ink)}
.chip:hover{border-color:var(--blue);color:var(--blue)}

/* ===== Cartes annonces ===== */
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;transition:.2s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-3px);box-shadow:0 14px 30px -16px rgba(0,0,0,.22);border-color:#d6dae0}
.card .ph{position:relative;aspect-ratio:4/3;background:var(--soft);overflow:hidden}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:.4s}
.card:hover .ph img{transform:scale(1.04)}
.badge{position:absolute;top:10px;left:10px;background:var(--ink);color:#fff;font-size:11.5px;font-weight:700;padding:5px 10px;border-radius:7px;letter-spacing:.02em}
.badge.new{background:#FFC400;color:var(--ink)}
.fav{position:absolute;top:9px;right:9px;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.92);border:1px solid var(--line);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--gray);font-size:15px;transition:.15s;z-index:2}
.fav:hover{color:#E0244B;transform:scale(1.08)}
.fav.on{color:#E0244B;border-color:#E0244B}
.card .body{padding:13px 15px 15px;display:flex;flex-direction:column;gap:9px;flex:1}
.card h3{font-size:14.5px;font-weight:600;line-height:1.3}
.card h3 span{display:block;font-size:12.5px;font-weight:500;color:var(--gray);margin-top:2px}
.specs{display:flex;flex-wrap:wrap;gap:5px;font-size:11.5px;color:var(--gray)}
.specs span{background:var(--soft);border:1px solid var(--line);border-radius:6px;padding:3px 7px}
.card .foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:4px}
.loc{font-size:11.5px;color:var(--gray)}
.more{display:flex;justify-content:center;margin-top:30px}
.no-results{padding:40px;border:1px dashed var(--line);border-radius:12px;text-align:center;color:var(--gray)}

/* ===== Page résultats (archive) ===== */
.crumb{padding-top:16px;font-size:13px;color:var(--gray)}
.crumb a:hover{color:var(--blue)}
.results-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 0 18px;flex-wrap:wrap}
.results-head h1{font-size:21px;font-weight:700;letter-spacing:-.4px}
.results-head h1 small{font-size:14px;font-weight:500;color:var(--gray);margin-left:8px}
.sort{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--gray)}
.sort select{padding:9px 32px 9px 12px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:14px;background:#fff;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B7280' stroke-width='1.6' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center;cursor:pointer}
.results-layout{display:grid;grid-template-columns:264px 1fr;gap:28px;padding-bottom:60px;align-items:start}
.filters{position:sticky;top:84px;border:1px solid var(--line);border-radius:12px;background:#fff;max-height:calc(100vh - 110px);overflow-y:auto}
.f-head{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;border-bottom:1px solid var(--line)}
.f-head b{font-size:15px}
.fgroup{padding:15px 18px;border-bottom:1px solid var(--soft)}
.fgroup:last-of-type{border-bottom:none}
.fgroup>b{display:block;font-size:13.5px;margin-bottom:10px}
.fgroup select,.fgroup input[type=number]{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:14px;background:#fff}
.fgroup select:focus,.fgroup input:focus{outline:none;border-color:var(--blue)}
.range{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.filters .apply{padding:14px 18px}
.filters .apply .btn{width:100%}
.f-toggle{display:none;width:100%;margin-bottom:14px;padding:12px;justify-content:center}
.pager{display:flex;justify-content:center;gap:6px;margin-top:32px;flex-wrap:wrap}
.pager .page-numbers{min-width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:8px;font-size:14px;font-weight:500;padding:0 10px}
.pager .page-numbers:hover{border-color:var(--blue);color:var(--blue)}
.pager .page-numbers.current{background:var(--blue);color:#fff;border-color:var(--blue)}

/* ===== Fiche véhicule ===== */
.vh-layout{display:grid;grid-template-columns:1fr 372px;gap:32px;padding-top:18px;padding-bottom:60px;align-items:start}
.gallery{border-radius:12px;overflow:hidden;border:1px solid var(--line)}
.gallery .main{position:relative;aspect-ratio:16/10;background:var(--soft)}
.gallery .main img{width:100%;height:100%;object-fit:cover}
.gcount{position:absolute;bottom:12px;right:12px;background:rgba(255,255,255,.95);border:1px solid var(--line);color:var(--ink);font-size:12.5px;font-weight:600;padding:5px 11px;border-radius:8px}
.thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:5px;padding:5px;background:#fff}
.thumbs button{border:2px solid transparent;border-radius:6px;overflow:hidden;cursor:pointer;padding:0;background:none;aspect-ratio:4/3}
.thumbs button.active{border-color:var(--blue)}
.thumbs img{width:100%;height:100%;object-fit:cover}
.vh-head{margin:24px 0 6px}
.vh-head h1{font-size:clamp(22px,2.8vw,28px);font-weight:700;letter-spacing:-.5px;line-height:1.15}
.vh-head .sub{color:var(--gray);font-size:14px;margin-top:6px}
.dash{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--line);border-radius:12px;overflow:hidden;margin:20px 0 24px;background:var(--line);gap:1px}
.gauge{background:#fff;padding:14px 16px}
.gauge b{display:block;font-size:15.5px;font-weight:700}
.gauge span{font-size:12px;color:var(--gray)}
.block{border:1px solid var(--line);border-radius:12px;padding:24px;margin-bottom:16px;background:#fff}
.block h2{font-size:17px;font-weight:700;margin-bottom:12px}
.block p{font-size:14.5px;color:#3A4150;margin-bottom:10px}
.block p:last-child{margin-bottom:0}
.equip{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;font-size:14px;list-style:none}
.equip li{display:flex;gap:8px;align-items:baseline}
.equip li::before{content:"✓";color:var(--blue);font-weight:700}
.hist{display:grid;gap:11px}
.hist .row{display:flex;gap:10px;align-items:center;font-size:14px}
.hist .ok{flex:none;width:22px;height:22px;border-radius:50%;background:var(--green-bg);color:var(--green);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}
.vh-aside{position:sticky;top:84px;display:grid;gap:14px}
.buybox{border:1px solid var(--line);border-radius:12px;padding:22px;background:#fff;box-shadow:0 4px 16px -10px rgba(0,0,0,.1)}
.price-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;gap:10px;flex-wrap:wrap}
.goodprice{font-size:12px;font-weight:700;color:var(--green);background:var(--green-bg);padding:4px 9px;border-radius:6px}
.fin{font-size:13px;color:var(--gray);margin-bottom:16px}
.fin b{color:var(--ink)}
.buybox .btn{width:100%;padding:12px;margin-bottom:9px;font-size:15px}
.seller{display:flex;gap:12px;align-items:center;border-top:1px solid var(--line);margin-top:12px;padding-top:15px}
.avatar{flex:none;width:42px;height:42px;border-radius:50%;background:var(--soft);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;color:var(--blue)}
.seller b{display:block;font-size:14px}
.seller span{font-size:12.5px;color:var(--gray)}
.safety{border:1px solid var(--line);border-radius:12px;padding:16px 18px;font-size:13px;color:var(--gray);display:grid;gap:8px;background:var(--soft)}
.safety b{color:var(--ink);font-size:13.5px}
.tel-reveal{display:none}
.tel-reveal.shown{display:inline-flex}
.mbar{display:none;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--line);padding:10px 16px calc(10px + env(safe-area-inset-bottom));z-index:60;align-items:center;gap:14px}
.mbar .btn{flex:1;padding:12px;margin:0}

/* ===== Section vendre (accueil) ===== */
.sell{background:var(--soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.sell .wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;padding-top:60px;padding-bottom:60px}
.sell h2{font-size:clamp(24px,3vw,32px);font-weight:700;letter-spacing:-.6px;line-height:1.15;margin-bottom:12px}
.sell p{color:var(--gray);font-size:15.5px;margin-bottom:24px}
.steps{display:grid}
.step{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid var(--line)}
.step:last-child{border-bottom:none}
.step .n{flex:none;width:32px;height:32px;border-radius:50%;border:1.5px solid var(--blue);color:var(--blue);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}
.step b{display:block;font-size:15px;margin-bottom:2px}
.step span{font-size:13.5px;color:var(--gray)}

/* ===== Formulaire vendre ===== */
.formpage{max-width:680px;margin:0 auto;padding:44px 24px 70px}
.formpage h1{font-size:clamp(24px,3.2vw,30px);font-weight:700;letter-spacing:-.6px;text-align:center}
.formpage .lead{text-align:center;color:var(--gray);font-size:15px;margin:8px 0 30px}
.formcard{background:#fff;border:1px solid var(--line);border-radius:14px;padding:30px;box-shadow:0 4px 18px -12px rgba(0,0,0,.08)}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:14.5px;background:#fff;color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(29,78,216,.1)}
.field small{display:block;font-size:12px;color:var(--gray);margin-top:5px}
.notice{border-radius:10px;padding:14px 16px;font-size:14px;margin-bottom:20px}
.notice.ok{background:var(--green-bg);color:var(--green);border:1px solid #BFE3CC}
.notice.err{background:#FDECEC;color:#B42318;border:1px solid #F5C6C6}
.args{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:26px}
.arg{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px;font-size:13px;color:var(--gray);text-align:center}
.arg b{display:block;color:var(--ink);font-size:14px;margin-bottom:3px}
.hp-field{position:absolute;left:-9999px;opacity:0}

/* ===== Contenu page standard ===== */
.page-content{max-width:760px;margin:0 auto;padding:44px 24px 70px}
.page-content h1{font-size:clamp(24px,3.2vw,32px);font-weight:700;letter-spacing:-.6px;margin-bottom:18px}
.page-content h2{font-size:20px;font-weight:700;margin:26px 0 10px}
.page-content p{margin-bottom:14px;color:#3A4150}
.page-content ul,.page-content ol{margin:0 0 14px 22px;color:#3A4150}

/* ===== Footer ===== */
.site-footer{background:linear-gradient(160deg,#0E1522,#15203A);color:#9AA6B8;padding:54px 0 28px;margin-top:60px}
.site-footer .logo{color:#fff}
.site-footer .f-about{font-size:14px;color:#8E99AC;max-width:30ch;margin-top:10px;line-height:1.6}
.f-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:32px;margin-bottom:34px}
.site-footer h4{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px;color:#5E6B82}
.site-footer ul{list-style:none;display:grid;gap:9px;font-size:14px;color:#9AA6B8}
.site-footer ul a{transition:color .15s}
.site-footer ul a:hover{color:#fff}
.f-social{display:flex;gap:10px;margin-top:16px}
.f-social a{width:34px;height:34px;border-radius:9px;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;color:#9AA6B8;font-size:15px;transition:.15s}
.f-social a:hover{background:rgba(255,255,255,.14);color:#fff}
.f-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:22px;border-top:1px solid rgba(255,255,255,.08);font-size:13px;color:#6E7A8E;flex-wrap:wrap;gap:8px}

/* ===== Responsive ===== */
@media(max-width:980px){
  .nav-links{display:none}
  .nav .btn-ghost{display:none}
  .burger{display:flex}
  .nav{gap:14px}
  .grid,.grid.cols-3{grid-template-columns:repeat(2,1fr)}
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .sell .wrap{grid-template-columns:1fr;gap:30px}
  .f-grid{grid-template-columns:1fr 1fr}
  .brand-row{flex-wrap:nowrap;overflow-x:auto;padding-bottom:6px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .brand-row::-webkit-scrollbar{display:none}
  .chip{flex:none}
  .results-layout{grid-template-columns:1fr;gap:0}
  .filters{display:none;position:static;max-height:none;margin-bottom:18px}
  .filters.open{display:block}
  .f-toggle{display:inline-flex}
  .vh-layout{grid-template-columns:1fr}
  .vh-aside{position:static}
  .dash{grid-template-columns:repeat(2,1fr)}
  .equip{grid-template-columns:1fr 1fr}
  .mbar{display:flex}
  body.single-vehicule{padding-bottom:72px}
}
@media(max-width:768px){
  .wrap{padding:0 20px}
}
@media(max-width:560px){
  .wrap{padding:0 16px}
  .grid,.grid.cols-3{grid-template-columns:1fr}
  .s-grid{grid-template-columns:1fr}
  .hero{padding:38px 0}
  .hero-stats{gap:22px}
  .trust .wrap{flex-direction:column;gap:10px;align-items:flex-start}
  section.pad{padding:40px 0}
  .nav .btn-primary{padding:9px 13px;font-size:13.5px}
  .f-grid{grid-template-columns:1fr}
  .f-bottom{flex-direction:column}
  .fgrid{grid-template-columns:1fr}
  .formcard{padding:22px 18px}
  .args{grid-template-columns:1fr}
  .equip{grid-template-columns:1fr}
  .thumbs{grid-template-columns:repeat(4,1fr)}
  /* Fiche véhicule : marges propres */
  .vh-layout{padding-top:8px;padding-bottom:60px;gap:18px}
  .vh-head{margin:18px 0 4px}
  .dash{grid-template-columns:repeat(2,1fr)}
  .block{padding:18px}
  .buybox{padding:18px}
  .crumb{padding-top:12px;white-space:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .gallery .main{aspect-ratio:4/3}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
:focus-visible{outline:2px solid var(--blue);outline-offset:2px}

/* ============================================================
   ESPACE MEMBRE (auth, dashboard, messagerie, profil, dépôt)
   ============================================================ */

/* --- Auth (connexion / inscription) --- */
.auth-page{display:flex;justify-content:center;padding:48px 20px 70px;background:var(--soft);min-height:60vh}
.authcard{width:100%;max-width:440px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:30px;box-shadow:0 4px 18px -12px rgba(0,0,0,.08)}
.auth-tabs{display:grid;grid-template-columns:1fr 1fr;background:var(--soft);border-radius:9px;padding:4px;margin-bottom:22px}
.auth-tabs a{text-align:center;padding:9px;font-size:14px;font-weight:600;color:var(--gray);border-radius:7px}
.auth-tabs a.on{background:#fff;color:var(--ink);box-shadow:0 1px 3px rgba(0,0,0,.08)}
.authcard h1{font-size:21px;font-weight:700;margin-bottom:4px}
.authcard .hint{font-size:13.5px;color:var(--gray);margin-bottom:20px}
.authcard .field{margin-bottom:14px}
.authcard .field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px}
.authcard .field input{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:14.5px}
.authcard .field input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(29,78,216,.1)}
.authcard .check{display:flex;gap:8px;align-items:center;font-size:13.5px;color:var(--gray);margin:4px 0 18px}
.authcard .btn{width:100%;padding:12px}
.auth-alt{text-align:center;font-size:13.5px;color:var(--gray);margin-top:16px}
.legal{font-size:12px;color:var(--gray);margin-top:14px;text-align:center}
.notice{border-radius:10px;padding:12px 14px;font-size:14px;margin-bottom:16px}
.notice.ok{background:var(--green-bg);color:var(--green);border:1px solid #BFE3CC}
.notice.err{background:#FDECEC;color:#B42318;border:1px solid #F5C6C6}

/* --- Layout espace membre --- */
.acct-layout{display:block;padding-top:26px;padding-bottom:60px}
.acct-side{position:sticky;top:84px;border:1px solid var(--line);border-radius:14px;background:#fff;overflow:hidden}
.acct-id{display:flex;gap:12px;align-items:center;padding:18px;border-bottom:1px solid var(--line)}
.acct-avatar{flex:none;width:46px;height:46px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;overflow:hidden}
.acct-avatar img{width:100%;height:100%;object-fit:cover}
.acct-avatar.lg{width:84px;height:84px;font-size:28px}
.acct-id b{display:block;font-size:14.5px}
.acct-id span{font-size:12px;color:var(--gray)}
.acct-nav{display:flex;flex-direction:column;padding:8px}
.acct-nav a{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:9px;font-size:14.5px;font-weight:500;color:var(--ink)}
.acct-nav a .ic{width:20px;text-align:center;color:var(--gray)}
.acct-nav a:hover{background:var(--soft)}
.acct-nav a.on{background:var(--blue);color:#fff}
.acct-nav a.on .ic{color:#fff}
.acct-nav a .pill{margin-left:auto;background:#E0244B;color:#fff;font-size:11px;font-weight:700;min-width:20px;height:20px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;padding:0 5px}
.acct-nav a.on .pill{background:#fff;color:var(--blue)}
.acct-nav .logout{color:var(--gray)}
.acct-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:20px;flex-wrap:wrap}
.acct-head h1{font-size:23px;font-weight:700;letter-spacing:-.5px}
.unread-banner{display:block;background:#FFF7E6;border:1px solid #F5D98A;color:#7A5A00;border-radius:10px;padding:12px 16px;font-size:14px;font-weight:600;margin-bottom:18px}

/* KPI */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 18px}
.kpi b{display:block;font-size:22px;font-weight:700;letter-spacing:-.4px}
.kpi span{font-size:12.5px;color:var(--gray)}

.acct-block{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px;margin-bottom:18px}
.acct-block h2{font-size:17px;font-weight:700;margin-bottom:14px}
.acct-block .field{margin-bottom:16px}
.acct-block .field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px}
.acct-block .field input,.acct-block .field select,.acct-block .field textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:14.5px;background:#fff}
.acct-block .field input:focus,.acct-block .field select:focus,.acct-block .field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(29,78,216,.1)}
.btn-sm{padding:7px 12px;font-size:13px}
.btn-ghost.danger:hover{border-color:#E0244B;color:#E0244B}

/* Liste annonces dashboard */
.listing-rows{display:grid;gap:12px}
.lrow{display:flex;gap:14px;align-items:center;border:1px solid var(--line);border-radius:12px;padding:12px}
.lrow-thumb{flex:none;width:84px;height:63px;border-radius:8px;overflow:hidden;background:var(--soft)}
.lrow-thumb img{width:100%;height:100%;object-fit:cover}
.lrow-main{flex:1;min-width:0}
.lrow-title{font-size:15px;font-weight:600;display:block;margin-bottom:6px}
.lrow-meta{display:flex;align-items:center;gap:10px}
.status{font-size:11.5px;font-weight:700;padding:3px 9px;border-radius:6px}
.status.ok{background:var(--green-bg);color:var(--green)}
.status.wait{background:#FFF7E6;color:#7A5A00}
.status.draft{background:var(--soft);color:var(--gray)}
.lrow-actions{display:flex;gap:8px;flex-none}
.empty{text-align:center;padding:36px 20px;color:var(--gray)}
.empty p{margin-bottom:14px}

/* Profil */
.profile-avatar{display:flex;align-items:center;gap:18px;margin-bottom:22px}
.link-file{color:var(--blue);font-weight:600;font-size:14px;cursor:pointer}
.link-file input{display:none}

/* Import IA */
.ia-import{background:linear-gradient(180deg,#F3F6FF,#fff);border-color:#CBD9FF}
.ia-import h2{color:var(--blue-d)}
.ia-row{display:flex;gap:10px}
.ia-row input{flex:1;padding:11px 13px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:14.5px}
.ia-row input:focus{outline:none;border-color:var(--blue)}
.ia-fallback{margin-top:12px;font-size:13.5px}
.ia-fallback summary{cursor:pointer;color:var(--blue);font-weight:600}
.ia-fallback textarea{width:100%;margin-top:10px;padding:11px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:13.5px}
.ia-status{margin-top:12px;padding:11px 14px;border-radius:9px;font-size:14px;font-weight:500}
.ia-status.loading{background:var(--soft);color:var(--gray)}
.ia-status.ok{background:var(--green-bg);color:var(--green)}
.ia-status.err{background:#FDECEC;color:#B42318}

/* Messagerie */
.msg-shell{display:grid;grid-template-columns:320px 1fr;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff;min-height:560px}
.msg-list{border-right:1px solid var(--line);overflow-y:auto;max-height:70vh}
.conv{display:flex;gap:11px;align-items:flex-start;padding:14px 16px;border-bottom:1px solid var(--soft);position:relative}
.conv:hover{background:var(--soft)}
.conv.on{background:#EEF3FF}
.conv-av{flex:none;width:40px;height:40px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}
.conv-main{flex:1;min-width:0}
.conv-top{display:flex;justify-content:space-between;align-items:baseline}
.conv-top b{font-size:14px}
.conv-top time{font-size:11.5px;color:var(--gray)}
.conv-veh{font-size:12px;color:var(--blue);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.conv-prev{font-size:12.5px;color:var(--gray);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.conv .pill{position:absolute;top:14px;right:14px;background:#E0244B;color:#fff;font-size:11px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 5px}
.msg-thread{display:flex;flex-direction:column;max-height:70vh}
.thread-head{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--line)}
.thread-head .back{display:none;font-size:24px;color:var(--gray);line-height:1}
.thread-head b{display:block;font-size:14.5px}
.thread-veh{font-size:12.5px;color:var(--blue);font-weight:600}
.thread-body{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:10px;background:var(--soft)}
.bubble{max-width:74%;padding:10px 13px;border-radius:14px;font-size:14px}
.bubble p{margin:0}
.bubble time{display:block;font-size:10.5px;margin-top:4px;opacity:.6}
.bubble.mine{align-self:flex-end;background:var(--blue);color:#fff;border-bottom-right-radius:4px}
.bubble.theirs{align-self:flex-start;background:#fff;border:1px solid var(--line);border-bottom-left-radius:4px}
.thread-reply{display:flex;gap:10px;padding:14px;border-top:1px solid var(--line);align-items:flex-end}
.thread-reply textarea{flex:1;resize:none;overflow-y:hidden;padding:11px 13px;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:14.5px;max-height:140px}
.thread-reply textarea:focus{outline:none;border-color:var(--blue)}
.thread-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--gray);font-size:14px;padding:30px}

@media(max-width:980px){
	.acct-side{position:static}
	.kpi-grid{grid-template-columns:1fr 1fr}
	.msg-shell{grid-template-columns:1fr}
	.msg-list{max-height:none;border-right:none}
	.msg-list.has-active{display:none}
	.thread-head .back{display:block}
}
@media(max-width:560px){
	.kpi-grid{grid-template-columns:1fr 1fr}
	.lrow{flex-wrap:wrap}
	.lrow-actions{width:100%}
	.lrow-actions .btn{flex:1}
}

/* Pastille messages dans le header */
.hdr-pill{background:#E0244B;color:#fff;font-size:11px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;padding:0 5px;margin-left:2px}

/* Formulaire de contact fiche véhicule */
.contact-form{margin:4px 0 6px;display:flex;flex-direction:column;gap:8px}
.contact-form textarea{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:14px;resize:vertical}
.contact-form textarea:focus{outline:none;border-color:var(--blue)}
.contact-note{font-size:12.5px;color:var(--gray);margin-top:6px;text-align:center}

/* Statut cliquable (toggle en ligne / hors ligne) */
.status-toggle{display:inline}
.status-btn{border:none;cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;gap:6px;transition:.15s}
.status-btn .dot{width:7px;height:7px;border-radius:50%;background:currentColor;flex:none}
.status-btn:hover{filter:brightness(.94);box-shadow:0 0 0 2px rgba(0,0,0,.04)}
.status-btn.ok{background:var(--green-bg);color:var(--green)}
.status-btn.draft{background:var(--soft);color:var(--gray)}

/* Overlay de progression d'upload (dépôt d'annonce) */
.upload-overlay{position:fixed;inset:0;z-index:200;background:rgba(21,29,33,.55);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:24px}
.upload-box{background:#fff;border-radius:16px;padding:30px 32px;width:100%;max-width:380px;text-align:center;box-shadow:0 24px 60px -20px rgba(0,0,0,.4)}
.upload-spinner{width:38px;height:38px;border:3px solid var(--line);border-top-color:var(--blue);border-radius:50%;margin:0 auto 16px;animation:octspin .8s linear infinite}
@keyframes octspin{to{transform:rotate(360deg)}}
.upload-box h3{font-size:17px;font-weight:700;margin-bottom:14px}
.upload-bar{height:9px;background:var(--soft);border-radius:99px;overflow:hidden;margin-bottom:14px}
.upload-fill{height:100%;width:4%;background:var(--blue);border-radius:99px;transition:width .25s ease}
.upload-box p{font-size:13.5px;color:var(--gray);margin:0}
@media(prefers-reduced-motion:reduce){.upload-spinner{animation:none}}

/* ============================================================
   HOME v3 — hero sombre, spotlight, catégories
   ============================================================ */
.vhero{background:
  radial-gradient(700px 420px at 82% 0%, rgba(29,78,216,.32), transparent 60%),
  radial-gradient(500px 300px at 0% 100%, rgba(255,196,0,.07), transparent 60%),
  linear-gradient(160deg,#0E1522 0%,#101A2E 60%,#15203A 100%);
  color:#fff;position:relative;overflow:hidden}
.vhero-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:52px;align-items:center;padding-top:64px;padding-bottom:72px}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#93AEF7;margin-bottom:18px}
.eyebrow::before{content:"";width:26px;height:2px;background:#93AEF7}
.vhero h1{font-size:clamp(30px,4.2vw,46px);font-weight:700;letter-spacing:-.5px;line-height:1.1;margin-bottom:16px}
.vhero h1 em{font-style:normal;background:linear-gradient(90deg,#7CA0FF,#B9CBFF);-webkit-background-clip:text;background-clip:text;color:transparent}
.vhero p.lead{font-size:16.5px;color:#AAB4C6;max-width:44ch}
.vhero-stats{display:flex;gap:34px;margin-top:26px;flex-wrap:wrap}
.vhero-stats b{display:block;font-size:24px;font-weight:800;letter-spacing:-.6px}
.vhero-stats span{font-size:12.5px;color:#8E99AC}

/* Carte recherche à onglets */
.searchcard{background:#fff;border-radius:18px;box-shadow:0 36px 70px -28px rgba(0,0,0,.55);color:var(--ink);overflow:hidden;border:none;padding:0}
.sc-tabs{display:grid;grid-template-columns:1fr 1fr;background:var(--soft);border-bottom:1px solid var(--line)}
.sc-tabs button{border:none;background:none;padding:14px;font-family:inherit;font-size:14px;font-weight:700;color:var(--gray);cursor:pointer;position:relative}
.sc-tabs button.on{background:#fff;color:var(--ink)}
.sc-tabs button.on::after{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:var(--blue)}
.sc-body{padding:22px}
.sc-body .btn{width:100%;margin-top:13px;padding:13px;font-size:15px}
.sc-body small{display:block;text-align:center;margin-top:9px;color:var(--gray);font-size:12.5px}
.btn-gold{background:#FFC400;color:var(--ink)}
.btn-gold:hover{filter:brightness(1.05)}

/* Spotlight */
.spot{display:grid;grid-template-columns:1.15fr .85fr;border:1px solid var(--line);border-radius:18px;overflow:hidden;background:#fff;box-shadow:0 24px 50px -30px rgba(0,0,0,.25)}
.spot .ph{position:relative;min-height:340px;background:var(--soft)}
.spot .ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.spot .tag{position:absolute;top:16px;left:16px;background:#FFC400;color:var(--ink);font-size:12px;font-weight:800;padding:6px 12px;border-radius:8px;letter-spacing:.03em}
.spot .body{padding:30px 32px;display:flex;flex-direction:column}
.spot h3{font-size:22px;font-weight:800;letter-spacing:-.5px}
.spot .sub{color:var(--gray);font-size:14px;margin:4px 0 16px}
.spot .specs{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:18px}
.spot .specs span{background:var(--soft);border:1px solid var(--line);border-radius:7px;padding:5px 10px;font-size:12.5px;color:#374151}
.spot .hist{display:grid;gap:8px;font-size:13.5px;color:#3A4150;margin-bottom:20px}
.spot .hist div::before{content:"✓";color:var(--blue);font-weight:700;margin-right:8px}
.spot .foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}

/* Tuiles catégories */
.cats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.cat{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:3/2;background:#222;color:#fff;display:block}
.cat img{width:100%;height:100%;object-fit:cover;transition:.35s}
.cat:hover img{transform:scale(1.05)}
.cat::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 35%,rgba(8,12,20,.72))}
.cat .lb{position:absolute;left:15px;bottom:13px;z-index:1}
.cat .lb b{display:block;font-size:15.5px;font-weight:700}
.cat .lb span{font-size:11.5px;color:#C9D2E0}

/* Bandeau confiance enrichi */
.trustband{background:var(--soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.trustband .wrap{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;padding:42px 24px}
.tcard{display:flex;gap:14px;align-items:flex-start}
.tcard .ic{flex:none;width:44px;height:44px;border-radius:12px;background:#E7EDFF;color:var(--blue);display:flex;align-items:center;justify-content:center;font-size:21px}
.tcard b{display:block;font-size:15px;margin-bottom:3px}
.tcard p{font-size:13px;color:var(--gray)}

/* CTA vendre sombre */
.sellcta{background:
  radial-gradient(500px 300px at 90% 10%, rgba(255,196,0,.12), transparent 60%),
  linear-gradient(135deg,#0E1522,#15203A);
  color:#fff;border-radius:20px;padding:44px 48px;display:grid;grid-template-columns:1.15fr .85fr;gap:42px;align-items:center;margin:58px 0}
.sellcta h2{font-size:29px;font-weight:800;letter-spacing:-.7px;line-height:1.1;margin-bottom:12px}
.sellcta h2 em{font-style:normal;color:#FFC400}
.sellcta p{color:#AAB4C6;font-size:15.5px;margin-bottom:22px}
.sell-steps{display:grid;gap:12px}
.sstep{display:flex;gap:13px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:14px 16px}
.sstep .n{flex:none;width:28px;height:28px;border-radius:50%;background:#FFC400;color:var(--ink);font-weight:800;display:flex;align-items:center;justify-content:center;font-size:14px}
.sstep b{display:block;font-size:14px}
.sstep span{font-size:12.5px;color:#94A0B4}

@media(max-width:980px){
  .vhero-grid{grid-template-columns:1fr;gap:34px;padding-top:46px;padding-bottom:54px}
  .spot{grid-template-columns:1fr}
  .spot .ph{min-height:240px}
  .cats{grid-template-columns:repeat(2,1fr)}
  .trustband .wrap{grid-template-columns:1fr}
  .sellcta{grid-template-columns:1fr;gap:28px;padding:32px 26px}
}
@media(max-width:560px){
  .cats{grid-template-columns:1fr}
  .vhero-stats{gap:20px}
  .spot .body{padding:22px}
}

/* L'attribut hidden doit toujours gagner sur les display utilitaires */
[hidden]{display:none!important}

/* ===== Menu avatar header (dropdown) ===== */
.hide-sm{display:inline-flex}
.uwrap{position:relative}
.uavatar{position:relative;width:40px;height:40px;border-radius:50%;border:2px solid var(--line);background:var(--blue);color:#fff;font-weight:700;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:visible;padding:0;font-family:inherit;transition:.15s}
.uavatar:hover{border-color:var(--blue)}
.uavatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.udot{position:absolute;top:-2px;right:-2px;width:12px;height:12px;border-radius:50%;background:#E0244B;border:2px solid #fff}
.umenu{position:absolute;right:0;top:calc(100% + 10px);width:248px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 18px 44px -16px rgba(0,0,0,.25);padding:8px;z-index:80}
.umenu-head{padding:10px 12px 12px;border-bottom:1px solid var(--soft);margin-bottom:6px}
.umenu-head b{display:block;font-size:14.5px}
.umenu-head span{font-size:12px;color:var(--gray)}
.umenu a{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:9px;font-size:14px;font-weight:500;color:var(--ink)}
.umenu a:hover{background:var(--soft)}
.umenu a .ic{width:18px;text-align:center;color:var(--gray)}
.umenu a .pill{margin-left:auto;background:#E0244B;color:#fff;font-size:11px;font-weight:700;min-width:19px;height:19px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;padding:0 5px}
.umenu-sep{height:1px;background:var(--soft);margin:6px 4px}
.umenu .logout{color:var(--gray)}
@media(max-width:768px){.hide-sm{display:none}}

/* ============================================================
   FICHE VÉHICULE v3 (galerie mosaïque, confiance, financement)
   ============================================================ */
.gal{display:grid;grid-template-columns:2fr 1fr;grid-template-rows:1fr 1fr;gap:10px;height:440px;margin-top:14px;border-radius:18px;overflow:hidden}
.gal a,.gal-item{position:relative;overflow:hidden;background:var(--soft);cursor:pointer;display:block;border:none;padding:0;margin:0;width:100%;height:100%;font:inherit;text-align:left}
.gal>:first-child{grid-row:1/3}
.gal a img,.gal-item img{width:100%;height:100%;object-fit:cover;transition:.4s}
.gal a:hover img,.gal-item:hover img{transform:scale(1.04)}
.gal img{width:100%;height:100%;object-fit:cover;transition:.4s}
.gal a:hover img{transform:scale(1.04)}
.gal .more{position:absolute;inset:0;background:rgba(8,12,20,.55);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px}
.gbadges{position:absolute;top:14px;left:14px;display:flex;gap:8px;z-index:2}
.gbadge{color:#fff;font-size:12px;font-weight:700;padding:6px 11px;border-radius:7px;display:flex;align-items:center;gap:5px;background:#0E1522}
.gbadge.deal{background:var(--green)}

.layout{display:grid;grid-template-columns:1fr 380px;gap:36px;padding-top:24px;padding-bottom:70px;align-items:start}
.vh-head h1{font-size:28px;font-weight:800;letter-spacing:-.8px}
.vh-head .sub{color:var(--gray);font-size:14.5px;margin-top:5px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.vh-head .sub .ref{margin-left:auto;font-size:12.5px}

.trustrow{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:22px 0}
.trustrow .ti{display:flex;gap:11px;align-items:center;border:1px solid var(--line);border-radius:12px;padding:13px 15px}
.trustrow .ti .ic{flex:none;width:36px;height:36px;border-radius:9px;background:var(--green-bg);color:var(--green);display:flex;align-items:center;justify-content:center;font-size:17px}
.trustrow .ti b{display:block;font-size:13.5px}
.trustrow .ti span{font-size:11.5px;color:var(--gray)}

.dash{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--line);border-radius:14px;overflow:hidden;margin:0 0 18px;background:var(--line);gap:1px}
.dcell{background:#fff;padding:15px 17px}
.dcell .k{font-size:11.5px;color:var(--gray)}
.dcell b{display:block;font-size:16px;font-weight:700;letter-spacing:-.3px;margin-top:3px}

.block{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px;margin-bottom:18px}
.block h2{font-size:18px;font-weight:700;margin-bottom:15px;display:flex;align-items:center;gap:9px}
.block p{font-size:14.5px;color:#374151}
.spec-table{display:grid;grid-template-columns:1fr 1fr;gap:0 36px}
.spec-table .r{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--soft);font-size:14px}
.spec-table .r span{color:var(--gray)}
.spec-table .r b{font-weight:600}
.equip{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.equip div{font-size:14px;color:#374151;display:flex;gap:9px;align-items:flex-start}
.equip div::before{content:"✓";color:var(--blue);font-weight:700;flex:none}
.hist{display:grid;gap:11px}
.hist .h{display:flex;gap:12px;align-items:flex-start;font-size:14px;color:#374151}
.hist .h .ic{flex:none;width:26px;height:26px;border-radius:8px;background:var(--green-bg);color:var(--green);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}

.finance{background:var(--soft)}
.fin-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:center}
.fin-big{font-size:30px;font-weight:800;letter-spacing:-.8px;color:var(--blue)}
.fin-note{font-size:11.5px;color:var(--gray);margin-top:10px}
.fin-slider label{font-size:12.5px;color:var(--gray);display:flex;justify-content:space-between;margin-bottom:5px}
.fin-slider input{width:100%;accent-color:var(--blue)}

.buybox{position:sticky;top:84px;border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:0 16px 40px -24px rgba(0,0,0,.28)}
.bb-price{display:flex;align-items:flex-end;justify-content:space-between;gap:10px}
.bb-fav{width:42px;height:42px;border-radius:50%;border:1px solid var(--line);background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--gray);font-size:18px;flex:none;transition:.15s}
.bb-fav:hover,.bb-fav.on{color:#E0244B;border-color:#F3C0C0}
.buybox .fin{font-size:13px;color:var(--gray);margin:6px 0 16px}
.seller{display:flex;align-items:center;gap:12px;padding:13px;background:var(--soft);border-radius:12px;margin-bottom:14px}
.seller .av{flex:none;width:46px;height:46px;border-radius:50%;background:var(--blue);color:#fff;font-weight:700;display:flex;align-items:center;justify-content:center;font-size:16px}
.seller b{display:block;font-size:14px}
.seller .verif{font-size:12px;color:var(--green);font-weight:600}
.seller .meta{font-size:11.5px;color:var(--gray)}
.buybox .btn+.btn{margin-top:9px}
.buybox form .btn{width:100%}
.bb-share{display:flex;gap:8px;margin-top:12px}
.bb-share button{flex:1;border:1px solid var(--line);background:#fff;border-radius:8px;padding:8px;font-size:12.5px;color:var(--gray);cursor:pointer;font-family:inherit}
.bb-share button:hover{border-color:#c2c8d2}
.safe-note{display:flex;gap:8px;align-items:flex-start;font-size:12px;color:var(--gray);margin-top:14px;padding-top:14px;border-top:1px solid var(--soft)}
.safe-note .ic{flex:none;color:var(--blue);font-size:14px}
.contact-note{font-size:12.5px;color:var(--gray);margin-top:8px;text-align:center}

.simil{padding-bottom:70px}
.simil .section-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:20px}
.simil .section-head h2{font-size:22px;font-weight:800;letter-spacing:-.5px}
.simil .section-head a{font-size:14px;font-weight:600;color:var(--blue)}

@media(max-width:980px){
	.layout{grid-template-columns:1fr;gap:24px}
	.buybox{position:static}
	.gal{height:340px}
}
@media(max-width:560px){
	.gal{grid-template-columns:1fr;grid-template-rows:1fr;height:260px}
	.gal a:not(:first-child){display:none}
	.dash{grid-template-columns:repeat(2,1fr)}
	.spec-table,.equip{grid-template-columns:1fr}
	.fin-grid,.trustrow{grid-template-columns:1fr}
	.vh-head h1{font-size:22px}
	body.single-vehicule{padding-bottom:78px}
	.buybox{border:none;box-shadow:none;padding:0}
}

/* Lightbox galerie */
.oct-lb{position:fixed;inset:0;z-index:300;background:rgba(8,12,20,.92);display:flex;align-items:center;justify-content:center;padding:40px}
.oct-lb img{max-width:92%;max-height:88%;object-fit:contain;border-radius:8px;cursor:pointer}
.oct-lb button{position:absolute;background:rgba(255,255,255,.12);color:#fff;border:none;cursor:pointer;border-radius:50%;width:48px;height:48px;font-size:24px;display:flex;align-items:center;justify-content:center}
.oct-lb button:hover{background:rgba(255,255,255,.22)}
.oct-lb .lb-close{top:24px;right:24px;width:42px;height:42px;font-size:18px}
.oct-lb .lb-prev{left:24px}.oct-lb .lb-next{right:24px}
@media(max-width:560px){.oct-lb .lb-prev{left:8px}.oct-lb .lb-next{right:8px}}

/* Descriptions : paragraphes aérés */
.block p+p{margin-top:14px}
.block p{line-height:1.7}

/* Section SEO locale (bas de home) */
.seo-block{background:var(--soft);border-top:1px solid var(--line);padding:54px 0}
.seo-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:40px;align-items:start}
.seo-eyebrow{display:inline-block;font-size:12px;font-weight:700;color:var(--blue);background:#E7EDFF;padding:5px 12px;border-radius:99px;margin-bottom:14px}
.seo-block h2{font-size:24px;font-weight:800;letter-spacing:-.6px;margin-bottom:14px;line-height:1.15}
.seo-block p{font-size:14.5px;color:#4B5563;line-height:1.75;margin-bottom:13px}
.seo-block strong{color:var(--ink);font-weight:600}
.seo-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.seo-links a{font-size:13px;font-weight:600;color:var(--blue);background:#fff;border:1px solid var(--line);border-radius:8px;padding:8px 14px;transition:.15s}
.seo-links a:hover{border-color:var(--blue)}
.seo-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px;box-shadow:0 14px 36px -24px rgba(0,0,0,.2)}
.seo-card h3{font-size:18px;font-weight:800;letter-spacing:-.3px;margin-bottom:10px}
.seo-card p{font-size:14px;color:#4B5563;line-height:1.7;margin-bottom:16px}
.seo-checks{list-style:none;display:grid;gap:9px;margin-bottom:20px}
.seo-checks li{font-size:14px;color:#374151;display:flex;gap:9px;align-items:flex-start}
.seo-checks li::before{content:"✓";color:var(--green);font-weight:800;flex:none}
.seo-card .btn{width:100%}
@media(max-width:860px){.seo-grid{grid-template-columns:1fr;gap:26px}}

/* ============================================================
   BLOG (archive + article)
   ============================================================ */
.blog-hero{background:linear-gradient(160deg,#0E1522,#15203A);color:#fff;padding:54px 0 50px}
.blog-hero .eyebrow{color:#93AEF7}
.blog-hero h1{font-size:clamp(26px,3.6vw,38px);font-weight:800;letter-spacing:-.9px;margin-bottom:12px}
.blog-hero p{font-size:16px;color:#AAB4C6;max-width:60ch}

.blog-wrap{padding-top:40px;padding-bottom:70px}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.bcard{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;transition:.2s}
.bcard:hover{transform:translateY(-3px);box-shadow:0 18px 38px -20px rgba(0,0,0,.26);border-color:#d6dae0}
.bcard-ph{position:relative;display:block;aspect-ratio:16/10;background:var(--soft);overflow:hidden}
.bcard-ph img{width:100%;height:100%;object-fit:cover;transition:.4s}
.bcard:hover .bcard-ph img{transform:scale(1.04)}
.bcard-noimg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:38px;opacity:.4}
.bcard-cat{position:absolute;top:12px;left:12px;background:rgba(255,255,255,.95);color:var(--blue);font-size:11.5px;font-weight:700;padding:5px 11px;border-radius:7px}
.bcard-body{padding:18px 18px 20px;display:flex;flex-direction:column;gap:10px;flex:1}
.bcard-body h2{font-size:17px;font-weight:700;line-height:1.3;letter-spacing:-.3px}
.bcard-body h2 a:hover{color:var(--blue)}
.bcard-ex{font-size:13.5px;color:var(--gray);line-height:1.6}
.bcard-meta{margin-top:auto;display:flex;gap:7px;font-size:12px;color:var(--gray);padding-top:4px}
/* Article mis en avant : pleine largeur, 2 colonnes */
.bcard.feature{grid-column:1/-1;flex-direction:row}
.bcard.feature .bcard-ph{flex:1.3;aspect-ratio:auto;min-height:300px}
.bcard.feature .bcard-body{flex:1;justify-content:center;padding:34px}
.bcard.feature h2{font-size:24px;letter-spacing:-.5px}
.bcard.feature .bcard-ex{font-size:15px}

.blog-pager{display:flex;justify-content:center;gap:8px;margin-top:36px}
.blog-pager .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 12px;border:1px solid var(--line);border-radius:9px;font-size:14px;font-weight:600;color:var(--ink)}
.blog-pager .page-numbers.current{background:var(--blue);color:#fff;border-color:var(--blue)}
.blog-pager a.page-numbers:hover{border-color:var(--blue);color:var(--blue)}

/* Article */
.post-head{padding-top:28px}
.post-head h1{max-width:820px}
.post-cat{display:inline-block;background:#E7EDFF;color:var(--blue);font-size:12px;font-weight:700;padding:5px 12px;border-radius:99px;margin:14px 0 12px}
.post-head h1{font-size:clamp(26px,3.6vw,38px);font-weight:800;letter-spacing:-.9px;line-height:1.12}
.post-meta{display:flex;gap:8px;font-size:13.5px;color:var(--gray);margin-top:12px}
.post-cover{margin:24px 0 8px;border-radius:18px;overflow:hidden;aspect-ratio:16/8}
.post-cover img{width:100%;height:100%;object-fit:cover}
.post-layout{display:grid;grid-template-columns:1fr 320px;gap:44px;padding-top:28px;padding-bottom:70px;align-items:start}
.post-content{max-width:740px;font-size:16px;line-height:1.8;color:#2A2F37}
.post-content h2{font-size:23px;font-weight:800;letter-spacing:-.5px;margin:34px 0 14px}
.post-content h3{font-size:18px;font-weight:700;margin:26px 0 10px}
.post-content p{margin-bottom:18px}
.post-content ul,.post-content ol{margin:0 0 18px 22px;display:grid;gap:8px}
.post-content li{padding-left:4px}
.post-content a{color:var(--blue);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.post-content strong{font-weight:700;color:var(--ink)}
.post-content blockquote{border-left:3px solid var(--blue);padding:4px 0 4px 18px;margin:22px 0;color:#4B5563;font-style:italic}
.post-side{position:sticky;top:84px;display:grid;gap:18px}
.post-cta{background:linear-gradient(135deg,#0E1522,#15203A);color:#fff;border-radius:16px;padding:24px}
.post-cta h3{font-size:18px;font-weight:800;margin-bottom:8px}
.post-cta p{font-size:13.5px;color:#AAB4C6;margin-bottom:16px}
.post-cta .btn{width:100%}.post-cta .btn+.btn{margin-top:9px}
.post-cta .btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.2)}
.post-related{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px}
.post-related h3{font-size:16px;font-weight:700;margin-bottom:14px}
.prel{display:flex;gap:12px;align-items:center;padding:8px 0;border-bottom:1px solid var(--soft)}
.prel:last-child{border-bottom:none}
.prel-ph{flex:none;width:56px;height:42px;border-radius:8px;overflow:hidden}
.prel-ph img{width:100%;height:100%;object-fit:cover}
.prel-t{font-size:13.5px;font-weight:600;line-height:1.35}
.prel:hover .prel-t{color:var(--blue)}

@media(max-width:860px){
	.blog-grid{grid-template-columns:repeat(2,1fr)}
	.bcard.feature{flex-direction:column}
	.bcard.feature .bcard-ph{min-height:0;aspect-ratio:16/10}
	.bcard.feature .bcard-body{padding:20px}
	.post-layout{grid-template-columns:1fr;gap:28px}
	.post-side{position:static}
}
@media(max-width:560px){
	.blog-grid{grid-template-columns:1fr}
}

/* Bloc actualités sur la home */
.actus-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.acard{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;transition:.2s}
.acard:hover{transform:translateY(-3px);box-shadow:0 16px 34px -20px rgba(0,0,0,.24);border-color:#d6dae0}
.acard-ph{position:relative;display:block;aspect-ratio:16/10;background:var(--soft);overflow:hidden}
.acard-ph img{width:100%;height:100%;object-fit:cover;transition:.4s}
.acard:hover .acard-ph img{transform:scale(1.04)}
.acard-noimg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:34px;opacity:.4}
.acard-cat{position:absolute;top:12px;left:12px;background:rgba(255,255,255,.95);color:var(--blue);font-size:11.5px;font-weight:700;padding:5px 11px;border-radius:7px}
.acard-body{padding:16px 17px 18px;display:flex;flex-direction:column;gap:8px;flex:1}
.acard-body time{font-size:12px;color:var(--gray);font-weight:600}
.acard-body h3{font-size:16px;font-weight:700;line-height:1.3;letter-spacing:-.3px}
.acard-body h3 a:hover{color:var(--blue)}
.acard-body p{font-size:13.5px;color:var(--gray);line-height:1.6}
.acard-more{margin-top:auto;font-size:13px;font-weight:600;color:var(--blue);padding-top:4px}
@media(max-width:860px){.actus-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.actus-grid{grid-template-columns:1fr}}

/* Contenu éditeur de la home (rendu via the_content) */
.seo-content h2{font-size:22px;font-weight:700;letter-spacing:-.4px;margin:22px 0 12px;line-height:1.2}
.seo-content h2:first-child{margin-top:0}
.seo-content p{font-size:14.5px;color:#4B5563;line-height:1.75;margin-bottom:13px}
.seo-content strong{color:var(--ink);font-weight:600}
.seo-content a{color:var(--blue);font-weight:600}
.seo-content a:hover{text-decoration:underline}
.seo-content figure{margin:0 0 20px}
.seo-content img{width:100%;border-radius:14px;display:block}

/* Bloc SEO ajouté en bas de la description véhicule */
.vh-seo{margin-top:18px;padding-top:16px;border-top:1px solid var(--soft)}
.vh-seo p{font-size:13.5px;color:var(--gray);line-height:1.7;margin-bottom:8px}
.vh-seo a{color:var(--blue);font-weight:600}
.vh-seo a:hover{text-decoration:underline}

/* Module optimisation WebP (dashboard) */
.webp-tool .hint{font-size:13.5px;color:var(--gray);margin-bottom:14px;line-height:1.6}
.webp-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.webp-engine{font-size:12px;color:var(--gray);background:var(--soft);padding:5px 10px;border-radius:7px}
.webp-progress{margin-top:16px}
.webp-bar{height:10px;background:var(--soft);border-radius:99px;overflow:hidden;margin-bottom:8px}
.webp-fill{height:100%;width:0;background:var(--blue);border-radius:99px;transition:width .3s ease}
.webp-progress p{font-size:13px;color:var(--gray)}

/* Zone glisser-déposer photos (dépôt d'annonce) */
.dropzone{border:2px dashed var(--line);border-radius:14px;padding:30px 20px;text-align:center;cursor:pointer;transition:.15s;background:#fff}
.dropzone:hover,.dropzone.drag{border-color:var(--blue);background:#F7F9FF}
.dz-inner .dz-ic{font-size:26px;display:block;margin-bottom:8px}
.dz-inner p{font-size:14.5px;margin-bottom:4px}
.dz-browse{border:none;background:none;color:var(--blue);font-weight:700;font-family:inherit;font-size:14.5px;cursor:pointer;text-decoration:underline}
.dz-inner small{font-size:12.5px;color:var(--gray)}
.dz-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px;margin-top:14px}
.dz-item{position:relative;aspect-ratio:4/3;border-radius:11px;overflow:hidden;border:1px solid var(--line);cursor:grab;background:var(--soft)}
.dz-item img{width:100%;height:100%;object-fit:cover}
.dz-item.dragging{opacity:.4}
.dz-main{position:absolute;bottom:8px;left:8px;background:var(--blue);color:#fff;font-size:11px;font-weight:700;padding:4px 9px;border-radius:6px}
.dz-del{position:absolute;top:7px;right:7px;width:26px;height:26px;border-radius:50%;border:none;background:rgba(8,12,20,.6);color:#fff;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center}
.dz-del:hover{background:#E0244B}

/* Photos importées (aperçu IA) dans la dropzone */
.dz-item.remote{cursor:grab}
.dz-tag{position:absolute;top:7px;left:7px;background:rgba(255,255,255,.92);color:var(--blue);font-size:10.5px;font-weight:700;padding:3px 8px;border-radius:6px}
.dz-info{font-size:12.5px;color:var(--gray);margin-top:10px}

/* Bloc SEO sur les pages marque */
.marque-seo{background:var(--soft);border-top:1px solid var(--line);padding:40px 0 48px;margin-top:10px}
.marque-seo h2{font-size:21px;font-weight:700;letter-spacing:-.4px;margin-bottom:12px}
.marque-seo p{font-size:14.5px;color:#4B5563;line-height:1.75;margin-bottom:12px;max-width:80ch}
.marque-seo strong{color:var(--ink);font-weight:600}
.marque-seo a{color:var(--blue);font-weight:600}
.marque-seo a:hover{text-decoration:underline}
