/* Boatcible Core : Espace vendeur (/espace-vendeur/). Charte catalogue. */

.vp-wrap{max-width:960px;margin:0 auto;padding:10px var(--pad-x) 80px}

/* ---------- Messages ---------- */
.vp-msg{border-radius:12px;padding:14px 18px;font-size:14px;font-weight:500;margin:0 0 22px}
.vp-msg-ok{background:#eef7ee;border:1px solid #bfe0bf;color:#22562c}
.vp-msg-err{background:#fbeeee;border:1px solid #ecc3c3;color:#7a2222}

/* ---------- Cartes ---------- */
.vp-card{background:var(--paper);border:1px solid var(--ink-12);border-radius:16px;padding:26px 28px;margin:0 0 22px;
  box-shadow:0 1px 2px rgba(17,19,42,.04)}
.vp-card h2{font-family:var(--head);font-weight:600;font-size:20px;margin:0 0 18px;letter-spacing:-.01em}
.vp-card h3{font-family:var(--head);font-weight:600;font-size:16px;margin:24px 0 12px}

/* ---------- Champs ---------- */
.vp-card label{display:block;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-75);
  font-weight:600;margin:14px 0 6px}
.vp-card label:first-child{margin-top:0}
.vp-card input[type=text],.vp-card input[type=number],.vp-card input[type=password],.vp-card input[type=tel],
.vp-card select,.vp-card textarea{width:100%;box-sizing:border-box;font-family:var(--sans);font-size:15px;color:var(--ink);
  background:#fff;border:1px solid var(--ink-25);border-radius:10px;padding:10px 13px;transition:border-color .2s var(--ease-out)}
.vp-card input:focus,.vp-card select:focus,.vp-card textarea:focus{outline:none;border-color:var(--gold-deep)}
.vp-card textarea{resize:vertical;line-height:1.55}
.vp-card textarea.vp-mono{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:13px}
.vp-card input[type=file]{font-size:14px;padding:8px 0}
.vp-hint{font-size:12.5px;color:var(--ink-50);margin:7px 0 0;line-height:1.5;text-transform:none;letter-spacing:0;font-weight:400}
.vp-hint a{color:var(--gold-deep)}

.vp-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 22px}
.vp-grid-3{grid-template-columns:1fr 1fr 1fr}
.vp-grid label{margin-top:14px}
.vp-mt{margin-top:16px}

.vp-check{display:flex !important;align-items:center;gap:9px;text-transform:none !important;letter-spacing:0 !important;
  font-size:14px !important;font-weight:500 !important;color:var(--ink) !important;cursor:pointer}
.vp-check input{width:auto !important;margin:0}

/* ---------- Boutons ---------- */
.vp-btn{display:inline-block;font-family:var(--sans);font-size:14px;font-weight:600;border-radius:999px;
  padding:11px 22px;cursor:pointer;text-decoration:none;transition:.2s var(--ease-out);border:1px solid transparent;text-align:center}
.vp-btn-main{background:var(--ink);color:#fff;border-color:var(--ink)}
.vp-btn-main:hover{background:var(--gold-deep);border-color:var(--gold-deep)}
.vp-btn-line{background:transparent;color:var(--ink);border-color:var(--ink-25)}
.vp-btn-line:hover{border-color:var(--gold);color:var(--gold-deep)}
.vp-btn-ghost{background:transparent;color:var(--ink-75);border-color:transparent}
.vp-btn-ghost:hover{color:var(--gold-deep)}

.vp-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin:0 0 22px;flex-wrap:wrap}
.vp-actions{display:flex;justify-content:flex-end;align-items:center;gap:12px;flex-wrap:wrap;margin:6px 0 0}

/* ---------- Connexion ---------- */
.vp-login{max-width:440px;margin-left:auto;margin-right:auto}
.vp-login .vp-btn{width:100%;margin-top:18px}
.vp-login .vp-check{margin-top:14px}
.vp-login .vp-hint{margin-top:14px;text-align:center}

/* ---------- Liste des bateaux ---------- */
.vp-list{display:flex;flex-direction:column;gap:12px}
.vp-row{display:flex;align-items:center;gap:18px;background:var(--paper);border:1px solid var(--ink-12);
  border-radius:14px;padding:12px 16px}
.vp-row-thumb{width:96px;height:64px;flex:0 0 auto;border-radius:8px;overflow:hidden;background:var(--champ-3);
  display:flex;align-items:center;justify-content:center}
.vp-row-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.vp-noimg{font-size:11px;color:var(--ink-50)}
.vp-row-main{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:6px}
.vp-row-main strong{font-family:var(--head);font-weight:600;font-size:16px}
.vp-badges{display:flex;gap:7px;flex-wrap:wrap}
.vp-badge{font-size:11px;font-weight:600;letter-spacing:.05em;border-radius:999px;padding:3px 10px}
.vp-b-on{background:#eef7ee;color:#22562c;border:1px solid #bfe0bf}
.vp-b-off{background:var(--champ-2);color:var(--ink-75);border:1px solid var(--ink-12)}
.vp-b-sold{background:#fbeeee;color:#7a2222;border:1px solid #ecc3c3}
.vp-b-price{background:#f0f6ff;color:#1c3a6e;border:1px solid #cfe0ff}
.vp-row-actions{display:flex;gap:8px;flex:0 0 auto}

/* ---------- Photos ---------- */
.vp-photos,.vp-preview{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px;margin:12px 0 18px}
.vp-photo{border:1px solid var(--ink-12);border-radius:10px;overflow:hidden;background:#fff}
.vp-photo img{width:100%;height:110px;object-fit:cover;display:block}
.vp-photo-main,.vp-photo-del{display:flex !important;align-items:center;gap:6px;font-size:12px !important;
  text-transform:none !important;letter-spacing:0 !important;font-weight:500 !important;margin:0 !important;padding:7px 10px;cursor:pointer}
.vp-photo-main input,.vp-photo-del input{width:auto !important;margin:0}
.vp-photo-del{border-top:1px solid var(--ink-12);color:#7a2222 !important}
.vp-preview img{width:100%;height:110px;object-fit:cover;border-radius:10px;border:1px dashed var(--gold)}

/* ---------- Blocs avances (admin) ---------- */
.vp-adv{margin:0 0 22px;border:1px solid var(--gold);border-radius:16px;overflow:hidden;background:#fffdf8}
.vp-adv summary{cursor:pointer;font-family:var(--head);font-weight:600;font-size:15px;padding:15px 22px;
  color:var(--gold-deep);letter-spacing:.02em;list-style:none}
.vp-adv summary::-webkit-details-marker{display:none}
.vp-adv summary::before{content:"+ ";font-weight:700}
.vp-adv[open] summary::before{content:"- "}
.vp-adv .vp-card{border:none;border-top:1px solid var(--ink-12);border-radius:0;margin:0;box-shadow:none;background:transparent}

/* ---------- Lignes repetables (FAQ / options) ---------- */
.vp-rep{border:1px solid var(--ink-12);border-radius:10px;padding:12px 14px;margin:0 0 10px;background:#fff}
.vp-rep input{margin-bottom:8px}
.vp-rep .vp-rep-del{padding:6px 12px;font-size:12.5px}
.vp-rep-line{display:flex;align-items:center;gap:14px}
.vp-rep-line input[type=text]{flex:1 1 auto;margin:0}
.vp-rep-line .vp-check{flex:0 0 auto;margin:0}

/* ---------- Responsive ---------- */
@media (max-width:760px){
  .vp-grid,.vp-grid-3{grid-template-columns:1fr}
  .vp-row{flex-wrap:wrap}
  .vp-row-actions{width:100%;justify-content:flex-end}
  .vp-actions{justify-content:stretch;flex-direction:column-reverse}
  .vp-actions .vp-btn{width:100%}
  .vp-rep-line{flex-wrap:wrap}
}

/* ---------- Vignettes d'upload AJAX ---------- */
.vp-up{position:relative;border:1px solid var(--ink-12);border-radius:10px;overflow:hidden;background:#fff}
.vp-up img{width:100%;height:110px;object-fit:cover;display:block;opacity:.55;transition:opacity .3s var(--ease-out)}
.vp-up-ok img{opacity:1}
.vp-up-state{display:block;font-size:11.5px;font-weight:600;padding:6px 9px;color:var(--ink-75)}
.vp-up-ok .vp-up-state{color:#22562c}
.vp-up-err{border-color:#ecc3c3}
.vp-up-err .vp-up-state{color:#7a2222}
.vp-up-del{display:block;width:100%;border:none;border-top:1px solid var(--ink-12);background:transparent;
  color:#7a2222;font-size:12px;font-weight:500;padding:6px 9px;cursor:pointer;font-family:var(--sans)}
.vp-up-del:hover{background:#fbeeee}

/* ---------- Navigation du portail ---------- */
.vp-nav{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin:0 0 24px;padding:8px 10px;
  background:rgba(255,255,255,.72);border:1px solid var(--ink-12);border-radius:999px}
.vp-nav a{font-family:var(--sans);font-size:13.5px;font-weight:600;color:var(--ink-75);text-decoration:none;
  padding:8px 16px;border-radius:999px;transition:.2s var(--ease-out)}
.vp-nav a:hover{color:var(--gold-deep)}
.vp-nav a.vp-nav-on{background:var(--ink);color:#fff}
.vp-nav .vp-nav-out{margin-left:auto;color:var(--ink-50)}
.vp-nav .vp-nav-out:hover{color:#7a2222}

/* ---------- Bouton danger ---------- */
.vp-btn-danger{background:transparent;color:#7a2222;border-color:#ecc3c3}
.vp-btn-danger:hover{background:#fbeeee;border-color:#d99a9a;color:#5d1616}

@media (max-width:760px){
  .vp-nav{border-radius:16px}
  .vp-nav .vp-nav-out{margin-left:0}
}

/* ---------- Texte explicatif ---------- */
.vp-explain{font-size:14px;line-height:1.6;color:var(--ink-75);background:var(--champ-1);
  border:1px solid var(--ink-12);border-radius:12px;padding:12px 16px;margin:0 0 18px}
.vp-explain strong{color:var(--gold-deep)}

/* ---------- Autocomplete custom ---------- */
.vp-ac{position:relative}
.vp-ac-list{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:60;background:#fff;
  border:1px solid var(--ink-25);border-radius:12px;box-shadow:0 14px 34px rgba(17,19,42,.14);
  max-height:288px;overflow:auto;overscroll-behavior:contain}
.vp-ac-item{padding:11px 15px;font-size:14.5px;color:var(--ink);cursor:pointer;
  border-bottom:1px solid rgba(17,19,42,.05)}
.vp-ac-item:last-child{border-bottom:none}
.vp-ac-item:hover,.vp-ac-item.on{background:var(--champ-1)}
.vp-ac-item b{color:var(--gold-deep);font-weight:700}
.vp-ac-empty{padding:11px 15px;font-size:13px;color:var(--ink-50);font-style:italic}

/* ---------- Badge proprietaire (vue admin) ---------- */
.vp-b-owner{background:#f4f1fb;color:#4a3d78;border:1px solid #d9d0ef}

/* ---------- Placeholders discrets (jamais confondus avec une vraie valeur) ---------- */
.vp-card input::placeholder,.vp-card textarea::placeholder{color:var(--ink-25);font-style:italic;opacity:1;font-weight:400}

/* ---------- Avertissement coordonnees ---------- */
.vp-warn{font-size:12.5px;line-height:1.5;color:#8a5a12;background:#fdf6e9;border:1px solid #ecd3a0;
  border-radius:8px;padding:8px 12px;margin:7px 0 0}
input.vp-flag,textarea.vp-flag{border-color:#c98a2c !important}

/* ---------- Bandeau Forfait Premium ---------- */
.vp-premium{display:flex;align-items:center;gap:22px;margin:0 0 22px;padding:24px 28px;border-radius:18px;
  background:linear-gradient(120deg,#1a1c38 0%,#11132A 55%,#3a2f12 100%);border:1px solid var(--gold);
  box-shadow:0 12px 34px rgba(17,19,42,.22);position:relative;overflow:hidden}
.vp-premium::before{content:"";position:absolute;top:-60px;right:-40px;width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,168,124,.22),transparent 70%);pointer-events:none}
.vp-premium-body{flex:1 1 auto;min-width:0}
.vp-premium-badge{display:inline-block;background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:#fff;
  font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.11em;text-transform:uppercase;
  border-radius:999px;padding:6px 13px;margin:0 0 10px}
.vp-premium-title{margin:0 0 6px;font-family:var(--head);font-weight:600;font-size:24px;line-height:1.15;
  letter-spacing:-.015em;color:#fff}
.vp-premium-title em{font-family:var(--display,serif);font-style:italic;font-weight:500;color:var(--gold)}
.vp-premium-sub{margin:0 0 13px;font-size:13.5px;line-height:1.5;color:rgba(255,255,255,.78)}
.vp-premium-list{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin:0;padding:0}
.vp-premium-list li{display:flex;align-items:center;gap:7px;background:rgba(201,168,124,.13);
  border:1px solid rgba(201,168,124,.45);border-radius:999px;padding:7px 14px;font-size:13px;font-weight:600;color:#fff}
.vp-premium-list li::before{content:"\2713";color:var(--gold);font-weight:700}
.vp-premium .vp-btn-premium{align-self:center;margin-left:auto;flex:0 0 auto;font-size:15px;padding:14px 26px}
@media (max-width:760px){
  .vp-premium{flex-direction:column;align-items:stretch;gap:16px;padding:20px}
  .vp-premium-title{font-size:21px}
  .vp-premium .vp-btn-premium{margin-left:0;text-align:center}
}

/* ---------- Bouton Premium (a brancher : data-premium-cta) ---------- */
.vp-btn-premium{background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:#fff;border:none;
  font-weight:700;letter-spacing:.02em;box-shadow:0 6px 18px rgba(156,110,50,.35);white-space:nowrap}
.vp-btn-premium:hover{background:linear-gradient(135deg,var(--gold-deep),#7d5624);color:#fff;
  box-shadow:0 8px 22px rgba(156,110,50,.45)}
.vp-premium .vp-btn-premium{align-self:center;margin-left:auto;flex:0 0 auto}
.vp-photos-premium{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
  background:linear-gradient(135deg,#fdf8ef,#f8efdd);border:1px solid var(--gold);border-radius:12px;
  padding:13px 18px;margin:4px 0 16px}
.vp-photos-premium p{margin:0;font-size:13.5px;color:var(--ink-75)}
.vp-photos-premium strong{color:var(--ink)}
@media (max-width:760px){
  .vp-premium .vp-btn-premium{margin-left:0;align-self:flex-start}
}

/* ---------- Bandeau Premium : version deux offres ---------- */
.vp-premium{display:block}
.vp-offers{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}
.vp-offer{background:rgba(255,255,255,.05);border:1px solid rgba(201,168,124,.38);border-radius:14px;
  padding:18px 20px;display:flex;flex-direction:column;gap:14px}
.vp-offer-plus{border-color:var(--gold);background:rgba(201,168,124,.13)}
.vp-offer .vp-premium-badge{align-self:flex-start;margin:0}
.vp-premium-badge-plus{background:#fff;color:var(--gold-deep)}
.vp-offer .vp-premium-list{flex-direction:column;align-items:flex-start;gap:7px;flex:1}
.vp-offer .vp-premium-list li{width:100%;box-sizing:border-box}
.vp-offer .vp-btn-premium{align-self:flex-start;margin-left:0;font-size:14px;padding:12px 22px}
@media (max-width:860px){
  .vp-offers{grid-template-columns:1fr}
}

/* ---------- Encart flux pro (import d'annonces) ---------- */
.vp-flux{background:var(--paper);border:1px solid var(--ink-12);border-radius:16px;padding:26px 28px;
  margin:26px 0 0;box-shadow:0 1px 2px rgba(17,19,42,.04)}
.vp-flux-kicker{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep);
  font-weight:700;margin:0 0 7px}
.vp-flux h2{font-family:var(--head);font-weight:600;font-size:20px;letter-spacing:-.01em;margin:0 0 8px}
.vp-flux-sub{font-size:14px;line-height:1.6;color:var(--ink-75);margin:0 0 16px;max-width:640px}
.vp-flux-list{list-style:none;margin:0 0 20px;padding:0;display:flex;flex-wrap:wrap;gap:9px}
.vp-flux-list li{background:var(--champ-1);border:1px solid var(--ink-12);border-radius:999px;
  padding:8px 15px;font-size:13px;font-weight:600;color:var(--ink-75)}
.vp-flux-free{border-color:#bfe0bf !important;background:#eef7ee !important;color:#22562c !important;
  display:flex;align-items:center;gap:8px}
.vp-flux-free span{background:#22562c;color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;border-radius:999px;padding:2px 8px}
.vp-login + .vp-flux{max-width:640px;margin-left:auto;margin-right:auto}

/* ---------- Bandeau Premium compact (hauteur reduite de moitie) ---------- */
.vp-premium{padding:15px 20px 17px}
.vp-premium-title{font-size:18px;margin:0 0 10px}
.vp-offers{gap:12px;margin-top:0}
.vp-offer{padding:12px 16px 14px;gap:9px}
.vp-offer .vp-premium-badge{font-size:11px;padding:5px 12px}
.vp-offer .vp-premium-list{gap:3px}
.vp-offer .vp-premium-list li{background:transparent;border:none;padding:0;border-radius:0;
  font-size:13px;font-weight:500;color:rgba(255,255,255,.86)}
.vp-offer .vp-btn-premium{font-size:13px;padding:8px 17px;box-shadow:0 4px 12px rgba(156,110,50,.3)}

/* ---------- Ligne d'accroche vers l'encart flux ---------- */
.vp-flux-line{margin:0 0 18px;font-size:13.5px}
.vp-flux-line a{color:var(--gold-deep);font-weight:600;text-decoration:none;border-bottom:1px dashed var(--gold)}
.vp-flux-line a:hover{color:var(--ink)}

/* ---------- Gratuite : badge global flux + badge titre formulaire ---------- */
.vp-flux-gratuit{display:inline-block;vertical-align:middle;background:#eef7ee;color:#22562c;border:1px solid #bfe0bf;
  border-radius:999px;font-family:var(--sans);font-size:11.5px;font-weight:700;letter-spacing:.05em;
  text-transform:uppercase;padding:4px 11px;margin-left:10px}
.vp-free-badge{display:inline-block;vertical-align:middle;background:#eef7ee;color:#22562c;border:1px solid #bfe0bf;
  border-radius:999px;font-family:var(--sans);font-size:.36em;font-weight:700;letter-spacing:.05em;
  text-transform:uppercase;padding:.5em 1.1em;margin-left:14px;white-space:nowrap}
@media (max-width:640px){
  .vp-free-badge{display:block;margin:10px 0 0;width:fit-content}
}
html{scroll-behavior:smooth}

/* Bandeau : compactage final */
.vp-premium{padding:13px 18px 15px}
.vp-premium-title{font-size:17px;margin:0 0 8px}
.vp-offer{padding:10px 14px 12px;gap:8px}
.vp-offer .vp-premium-list li{font-size:12.5px;line-height:1.4}
.vp-offer .vp-btn-premium{font-size:12.5px;padding:7px 15px}

/* ---------- Landing espace vendeur (vue connexion) ---------- */
.vp-landing{display:grid;grid-template-columns:1fr 400px;gap:22px;align-items:start;margin:0 0 22px}
.vp-landing .vp-login{margin:0;position:sticky;top:22px;max-width:none}
.vp-pitch{display:flex;flex-direction:column;gap:18px;min-width:0}
.vp-pitch .vp-card{margin:0}
.vp-sell h2{margin-bottom:16px}
.vp-args{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:13px}
.vp-args li{position:relative;padding-left:28px;font-size:14.5px;line-height:1.55;color:var(--ink-75)}
.vp-args li::before{content:"\2713";position:absolute;left:0;top:1px;width:18px;height:18px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:#fff;font-size:11px;font-weight:700;
  display:flex;align-items:center;justify-content:center}
.vp-args strong{color:var(--ink)}
.vp-args .vp-flux-gratuit{margin-left:2px}
.vp-seo-geo{background:linear-gradient(135deg,#fdf8ef,#f6eee1);border:1px solid var(--gold);border-radius:16px;
  padding:22px 24px;box-shadow:0 1px 2px rgba(17,19,42,.04)}
.vp-exclu-badge{display:inline-block;background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:#fff;
  font-size:11px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;border-radius:999px;
  padding:5px 13px;margin:0 0 12px}
.vp-seo-geo h2{font-family:var(--head);font-weight:600;font-size:20px;letter-spacing:-.01em;margin:0 0 9px}
.vp-seo-geo p{margin:0;font-size:14px;line-height:1.65;color:var(--ink-75)}
.vp-seo-geo p strong{color:var(--gold-deep)}
@media (max-width:900px){
  .vp-landing{grid-template-columns:1fr}
  .vp-landing .vp-login{position:static;order:-1}
}

/* ---------- Bloc SEO/GEO : fond blanc net ---------- */
.vp-seo-geo{background:var(--paper)}

/* ---------- Item Premium dans les arguments ---------- */
.vp-args-premium{background:#fffdf8;border:1px solid var(--gold);border-radius:12px;padding:12px 14px 12px 38px !important;margin-top:4px}
.vp-args-premium::before{content:"\2605";left:13px !important;top:13px !important;background:linear-gradient(135deg,var(--gold),var(--gold-deep))}
.vp-args-premium a{color:var(--gold-deep);font-weight:600;text-decoration:none;border-bottom:1px dashed var(--gold);white-space:nowrap}
.vp-args-premium a:hover{color:var(--ink)}
.vp-args li.vp-args-premium::before{content:"\2605";font-size:10px}
