/* =========================================================
LAUTOMATIK — MODELE SCOPE (UI KIT → PROD)
Scope : .lauto.lauto-scope

Objectif :
- 1 seul CSS central pour tous les shortcodes
- Composants partagés (typo, cards, forms, boutons, tables, badges, FAQ, etc.)
- Compatible builders (pas de :root)
========================================================= */

/* =========================================================
BASE + VARIABLES
========================================================= */
.lauto.lauto-scope{
  --la-font: system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;

  --la-ink:#0f172a;
  --la-muted:#475569;
  --la-muted2:#64748b;

  --la-line:#e5e7eb;
  --la-line2:#d1d5db;

  --la-soft:#f8fafc;
  --la-soft2:#f6f7f7;

  /* Primary = Pine premium (V2) */
  --la-primary:#0F8F6A;
  --la-primary-ink:#06281c;
  --la-primary-soft:#ecfdf5;
  --la-primary-line:#bbf7d0;

  /* Deep green premium (dark) */
  --la-primary-deep:#06281c;

  --la-info-soft:#eff6ff;
  --la-info-line:#bfdbfe;
  --la-info-ink:#1e3a8a;

  --la-danger-soft:#fff1f2;
  --la-danger-line:#fecdd3;
  --la-danger-ink:#9f1239;

  --la-warning-soft:#fff7ed;
  --la-warning-line:#fed7aa;
  --la-warning-ink:#9a3412;

  --la-radius-xl:22px;
  --la-radius-lg:18px;
  --la-radius-md:14px;

  /* Buttons radius léger */
  --la-btn-radius:6px;

  --la-shadow2: 0 14px 34px rgba(2,6,23,.06);

  font-family:var(--la-font);
  color:var(--la-ink);

  background:
    radial-gradient(700px 320px at 10% 0%, rgba(15,143,106,.10), transparent 60%),
    radial-gradient(700px 320px at 95% 20%, rgba(2,132,199,.06), transparent 60%),
    linear-gradient(180deg,#fff 0%, var(--la-soft2) 100%);

  padding-bottom:12px;
}

.lauto.lauto-scope *{ box-sizing:border-box; }
.lauto.lauto-scope a{ color:inherit; }
.lauto.lauto-scope strong{ font-weight:950; }

/* Wrap / Conteneur */
.lauto.lauto-scope .lauto-conteneur{
  max-width:1120px;
  margin:0 auto;
  padding:18px 18px 28px;
}

/* =========================================================
HEADER / EN-TÊTE
========================================================= */
.lauto.lauto-scope .lauto-en-tete{
  margin-top:14px;
  margin-bottom:14px;
}

.lauto.lauto-scope .lauto-en-tete-ligne{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:10px;
}

.lauto.lauto-scope .lauto-en-tete-actions{
  margin-top:0;
}

/* =========================================================
TYPO (FR only) — VERSION 1 (Moderne premium)
========================================================= */

/* Titre 1 */
.lauto.lauto-scope .lauto-titre-1{
  font-size:40px;
  line-height:1.06;
  margin:0 0 10px;
  letter-spacing:-.02em;
  font-weight:950;
}

/* Titre 1 bis */
.lauto.lauto-scope .lauto-titre-1-bis{
  margin:0;
  font-weight:800;
  line-height:1.1;
  font-size:clamp(18px, 2.2vw, 30px);
  letter-spacing:-0.2px;
}

/* Titre 2 */
.lauto.lauto-scope .lauto-titre-2{
  font-size:18px;
  line-height:1.25;
  margin:0 0 8px;
  letter-spacing:-.01em;
  font-weight:950;
}

/* Titre 3 */
.lauto.lauto-scope .lauto-titre-3{
  font-size:15px;
  line-height:1.25;
  margin:12px 0 8px;
  font-weight:950;
}

/* Sous-texte */
.lauto.lauto-scope .lauto-sous-texte{
  font-size:15px;
  line-height:1.65;
  color:var(--la-muted);
  margin:0;
  max-width:85ch;
}

/* Texte */
.lauto.lauto-scope .lauto-texte{
  margin:10px 0 0;
  color:var(--la-muted);
  line-height:1.7;
  font-weight:800;
  font-size:15px;
}

/* Texte secondaire */
.lauto.lauto-scope .lauto-texte-secondaire{
  margin:10px 0 0;
  color:var(--la-muted);
  line-height:1.65;
  font-weight:800;
  font-size:14.5px;
}

/* Mini / note */
.lauto.lauto-scope .lauto-texte-mini{
  font-size:12.5px;
  color:var(--la-muted2);
  font-weight:850;
  margin-top:8px;
}

/* Underline prénom */
.lauto.lauto-scope .lauto-souligne-prenom{
  position:relative;
  display:inline-block;
}
.lauto.lauto-scope .lauto-souligne-prenom::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-3px;
  height:3px;
  border-radius:999px;
  background: var(--la-primary);
}

/* =========================================================
DIVIDER + PANEL
========================================================= */
.lauto.lauto-scope .lauto-separateur{
  height:1px;
  background:rgba(229,231,235,.95);
  margin:14px 0;
}

.lauto.lauto-scope .lauto-panneau{
  border-radius:var(--la-radius-xl);
  border:1px solid var(--la-line);
  background:rgba(255,255,255,.72);
  box-shadow:var(--la-shadow2);
  padding:18px 18px;
}

.lauto.lauto-scope .lauto-panneau + .lauto-panneau{
  margin-top: 12px;
}

.lauto.lauto-scope .lauto-formulaire + .lauto-panneau{
  margin-top: 12px;
}

/* =========================================================
ACTIONS + BUTTONS
========================================================= */
.lauto.lauto-scope .lauto-actions{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  margin-top:12px;
}

/* Bouton (base) */
.lauto.lauto-scope .lauto-bouton{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;

  padding:7px 10px;
  border-radius:var(--la-btn-radius);
  line-height:1.1;
  font-size:14px;
  text-decoration:none;
  font-weight:900;

  border:1px solid rgba(209,213,219,.95);
  background:#fff;
  color:var(--la-ink);

  transition:
    transform .16s ease,
    box-shadow .18s ease,
    filter .18s ease,
    background .18s ease,
    border-color .18s ease,
    color .18s ease;

  cursor:pointer;
  white-space:nowrap;
}
.lauto.lauto-scope .lauto-bouton:active{ transform:translateY(1px); }
.lauto.lauto-scope .lauto-bouton:focus{ outline:none; }
.lauto.lauto-scope .lauto-bouton:focus-visible{
  box-shadow:0 0 0 4px rgba(15,143,106,.18);
}

/* Bouton principal */
.lauto.lauto-scope .lauto-bouton-principal{
  overflow:hidden;
  border-color:transparent;
  color:#ecfdf5;

  background: linear-gradient(135deg, var(--la-primary), var(--la-primary-deep));
  box-shadow:0 10px 18px rgba(0,0,0,.18);
    -webkit-text-stroke: 1px #000;
  paint-order: stroke fill;
}
.lauto.lauto-scope .lauto-bouton-principal::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,.22), rgba(255,255,255,0));
  opacity:.42;
  pointer-events:none;
}
.lauto.lauto-scope .lauto-bouton-principal::after{
  content:"";
  position:absolute;
  top:-40%;
  left:-30%;
  width:60%;
  height:180%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.28), transparent);
  transform:rotate(18deg) translateX(-120%);
  transition:transform .55s ease;
  pointer-events:none;
}
.lauto.lauto-scope .lauto-bouton-principal:hover{
  transform:translateY(-2px);
  box-shadow:0 16px 26px rgba(0,0,0,.22);
  filter:brightness(1.01);
}
.lauto.lauto-scope .lauto-bouton-principal:hover::after{
  transform:rotate(18deg) translateX(220%);
}
.lauto.lauto-scope .lauto-bouton-principal:active{
  transform:translateY(-1px);
}

/* Bouton secondaire (ghost) */
.lauto.lauto-scope .lauto-bouton-secondaire{
  background:#fff;
  color:var(--la-ink);
  border-color:rgba(15,143,106,.28);
  box-shadow:0 10px 18px rgba(0,0,0,.08);
}
.lauto.lauto-scope .lauto-bouton-secondaire::after{
  content:"";
  position:absolute;
  left:10px;
  right:10px;
  bottom:6px;
  height:2px;
  border-radius:2px;
  background:linear-gradient(90deg, transparent, var(--la-primary), transparent);
  opacity:.35;
  transform:scaleX(.65);
  transition:opacity .18s ease, transform .18s ease;
  pointer-events:none;
}
.lauto.lauto-scope .lauto-bouton-secondaire:hover{
  transform:translateY(-2px);
  border-color:rgba(15,143,106,.45);
  background:rgba(15,143,106,.04);
  box-shadow:0 16px 26px rgba(0,0,0,.10);
}
.lauto.lauto-scope .lauto-bouton-secondaire:hover::after{
  opacity:.55;
  transform:scaleX(1);
}
.lauto.lauto-scope .lauto-bouton-secondaire:active{
  transform:translateY(-1px);
  box-shadow:0 12px 20px rgba(0,0,0,.09);
}

/* Bouton pleine largeur */
.lauto.lauto-scope .lauto-bouton-plein{
  width:100%;
}

/* Lien */
.lauto.lauto-scope .lauto-lien{
  text-decoration:underline;
  font-weight:900;
}

/* =========================================================
ALERTES
========================================================= */
.lauto.lauto-scope .lauto-alerte{
  margin-top:12px;
  position:relative;
  overflow:hidden;

  border-radius:6px;
  padding:10px 14px;

  border:1px solid var(--la-line);
  background:#fff;
  color:var(--la-muted);
  font-weight:850;
}

/* Bande gauche */
.lauto.lauto-scope .lauto-alerte::before{
  content:"";
  pointer-events:none;
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:6px;
  border-radius:6px 0 0 6px;
  background: rgba(100,116,139,.35);
}

/* INFO : bande + texte */
.lauto.lauto-scope .lauto-alerte-info{
  background:#fff;
  border-color: var(--la-line);
  color: var(--la-info-ink);
}
.lauto.lauto-scope .lauto-alerte-info::before{
  background: rgba(30,58,138,.55);
}

/* SUCCÈS : bande + texte */
.lauto.lauto-scope .lauto-alerte-succes{
  background:#fff;
  border-color: var(--la-line);
  color: var(--la-primary-deep);
}
.lauto.lauto-scope .lauto-alerte-succes::before{
  background: rgba(6,95,70,.60);
}

/* ERREUR : bande + texte */
.lauto.lauto-scope .lauto-alerte-erreur{
  background:#fff;
  border-color: var(--la-line);
  color: var(--la-danger-ink);
}
.lauto.lauto-scope .lauto-alerte-erreur::before{
  background: rgba(159,18,57,.60);
}

/* Liste dans alerte */
.lauto.lauto-scope .lauto-liste{
  margin:8px 0 0;
  padding-left:18px;
}

/* =========================================================
FORMULAIRE — VERSION 2C ULTRA CLEAN (focus ring net partout)
========================================================= */
.lauto.lauto-scope .lauto-formulaire{
  margin-top:10px;
}

.lauto.lauto-scope .lauto-grille{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:16px;
  margin-top:10px;
}

.lauto.lauto-scope .lauto-ligne-champ{
  grid-template-columns: clamp(90px, 14vw, 140px) 1fr;
  align-items:center;
}

.lauto.lauto-scope .lauto-ligne-champ .lauto-etiquette{
  white-space:nowrap;
}


.lauto.lauto-scope .lauto-champ-plein{
  grid-column:1 / -1;
}

/* Labels compacts */
.lauto.lauto-scope .lauto-etiquette{
  font-size:12px;
  color:var(--la-ink);
  font-weight:950;
}

/* Inputs — version fondue globale */
.lauto.lauto-scope .lauto-saisie{
  width:100%;
  border:0;
  border-bottom:1px solid rgba(15,23,42,.18);
  background:rgba(255,255,255,.28);
  border-radius:0;

  padding:7px 6px 8px;
  line-height:1.2;
  outline:none;

  color:var(--la-muted);
  font-weight:850;
  font-size:14px;

  box-shadow:none;
  transition:
    border-color .18s ease,
    background .18s ease,
    box-shadow .18s ease;
}

.lauto.lauto-scope .lauto-saisie:hover{
  border-bottom-color:rgba(15,23,42,.30);
  background:rgba(255,255,255,.42);
}

.lauto.lauto-scope .lauto-saisie:focus{
  border-bottom-color:rgba(15,143,106,.95);
  background:rgba(255,255,255,.58);
  box-shadow:none;
}

/* Readonly / disabled plus doux */
.lauto.lauto-scope .lauto-saisie[readonly],
.lauto.lauto-scope .lauto-saisie:disabled{
  background:rgba(255,255,255,.12);
  border-bottom-color:rgba(15,23,42,.14);
  color:rgba(71,85,105,.92);
  cursor:default;
}

.lauto.lauto-scope select.lauto-saisie{
  padding-right:28px;
  cursor:pointer;
}

.lauto.lauto-scope textarea.lauto-saisie,
.lauto.lauto-scope .lauto-zone-texte{
  min-height:60px;
  resize:vertical;
  border:1px solid rgba(15,23,42,.12);
  border-radius:8px;
  padding:10px 12px;
  background:rgba(255,255,255,.40);
}

.lauto.lauto-scope textarea.lauto-saisie:focus,
.lauto.lauto-scope .lauto-zone-texte:focus{
  border-color:rgba(15,143,106,.45);
  box-shadow:none;
  background:rgba(255,255,255,.62);
}

.lauto.lauto-scope .lauto-zone-texte{
  resize:vertical;
  min-height:60px;
}

/* Ligne champ (desktop align) */
.lauto.lauto-scope .lauto-ligne-champ{
  display:grid;
  grid-template-columns: max-content 1fr;
  align-items:center;
  gap:8px;
}
.lauto.lauto-scope .lauto-ligne-champ .lauto-etiquette{ margin:0; }
.lauto.lauto-scope .lauto-ligne-champ .lauto-saisie{ margin:0; }

/* Choix inline */
.lauto.lauto-scope .lauto-choix-inline{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}

/* Ligne choix — ultra clean */
.lauto.lauto-scope .lauto-ligne-choix{
  position:relative;
  display:flex;
  gap:10px;
  align-items:flex-start;

  padding:10px 12px;
  border-radius:10px;

  border:1px solid rgba(229,231,235,.9);
  background:#fff;

  color:var(--la-muted);
  font-weight:850;
  font-size:13px;

  box-shadow:none;
  transition: border-color .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease;
}

/* Inputs inside */
.lauto.lauto-scope .lauto-ligne-choix input[type="radio"],
.lauto.lauto-scope .lauto-ligne-choix input[type="checkbox"]{
  margin-top:2px;
}

/* Hover léger (sans glow) */
.lauto.lauto-scope .lauto-ligne-choix:hover{
  background: rgba(248,250,252,.85);
  border-color: rgba(209,213,219,.95);
}

/* Checked = léger fond + texte plus dark */
.lauto.lauto-scope .lauto-ligne-choix.is-checked{
  border-color: rgba(15,143,106,.45);
  background: rgba(236,253,245,.30);
  color: var(--la-primary-deep);
}

/* ✅ Focus ring ULTRA CLEAN quand tu focuses le radio/checkbox */
@supports selector(:has(*)){
  .lauto.lauto-scope .lauto-ligne-choix:has(input[type="radio"]:focus),
  .lauto.lauto-scope .lauto-ligne-choix:has(input[type="checkbox"]:focus),
  .lauto.lauto-scope .lauto-ligne-choix:has(input[type="radio"]:focus-visible),
  .lauto.lauto-scope .lauto-ligne-choix:has(input[type="checkbox"]:focus-visible){
    border-color: rgba(15,143,106,.85);
    background:#fff;
    box-shadow: 0 0 0 3px rgba(15,143,106,.14);
    color: var(--la-primary-deep);
  }

  /* Checked (auto) */
  .lauto.lauto-scope .lauto-ligne-choix:has(input[type="radio"]:checked),
  .lauto.lauto-scope .lauto-ligne-choix:has(input[type="checkbox"]:checked){
    border-color: rgba(15,143,106,.45);
    background: rgba(236,253,245,.30);
    color: var(--la-primary-deep);
  }
}

/* Obligatoire */
.lauto.lauto-scope .lauto-obligatoire{
  color: var(--la-danger-ink);
  font-weight: 950;
}

/* =========================================================
LAYOUT “MODE PIECE”
========================================================= */
.lauto.lauto-scope .lauto-mode-piece{
  margin-top:10px;
}
.lauto.lauto-scope .lauto-mode-piece[hidden]{ display:none !important; }

.lauto.lauto-scope .lauto-mode-piece-simple .lauto-ligne-champ{
  display:grid;
  grid-template-columns: max-content 1fr;
  column-gap:8px;
  align-items:center;
}

.lauto.lauto-scope .lauto-mode-piece-simple .lauto-grille{
  grid-template-columns: 2fr 1.2fr minmax(100px, .6fr);
  gap:12px;
}

.lauto.lauto-scope .lauto-elements-kit{
  display:grid;
  gap:10px;
  margin-top:10px;
}

.lauto.lauto-scope .lauto-mode-piece-kit .lauto-ligne-kit{
  border:0;
  background:transparent;
  box-shadow:none;
  padding:0;
  border-radius:0;
  width:100%;
}

.lauto.lauto-scope .lauto-mode-piece-kit .lauto-ligne-kit .lauto-grille{
  width:100%;
  margin-top:0;
  grid-template-columns: 2fr 1.2fr minmax(100px, .6fr) max-content;
  gap:12px;
  align-items:center;
}

.lauto.lauto-scope .lauto-mode-piece-kit .lauto-ligne-kit .lauto-ligne-champ{
  display:grid;
  grid-template-columns: max-content minmax(0, 1fr);
  column-gap:8px;
  align-items:center;
  width:100%;
  min-width:0;
}

.lauto.lauto-scope .lauto-mode-piece-kit .lauto-col-supprimer-kit{
  display:flex;
  justify-content:flex-end;
  align-items:center;
  padding-left:6px;
  white-space:nowrap;
}

/* Fix largeur inputs */
.lauto.lauto-scope .lauto-mode-piece-kit .lauto-ligne-kit .lauto-champ{
  width:100%;
  min-width:0;
  justify-self:stretch;
}
.lauto.lauto-scope .lauto-mode-piece-kit .lauto-ligne-kit input.lauto-saisie{
  display:block;
  width:100% !important;
  min-width:0 !important;
}

/* =========================================================
BADGES + STATUTS
========================================================= */
.lauto.lauto-scope .lauto-ligne-badges{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:6px;
}

.lauto.lauto-scope .lauto-badge-fr{
  display:inline-flex;
  align-items:center;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(209,213,219,.95);
  background: rgba(255,255,255,.88);
  font-weight:950;
  font-size:12px;
  white-space:nowrap;
}

.lauto.lauto-scope .lauto-badge-doux{
  background: rgba(239,246,255,.7);
  border-color: rgba(191,219,254,.9);
  color: #1e3a8a;
}

.lauto.lauto-scope .lauto-statut{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(209,213,219,.95);
  background:rgba(248,250,252,.9);
  font-weight:950;
  font-size:12px;
  white-space:nowrap;
}
.lauto.lauto-scope .lauto-statut-actif{
  background:var(--la-primary-soft);
  border-color:var(--la-primary-line);
  color:var(--la-primary-deep);
}
.lauto.lauto-scope .lauto-statut-off{
  background:var(--la-warning-soft);
  border-color:var(--la-warning-line);
  color:var(--la-warning-ink);
}
.lauto.lauto-scope .lauto-statut-brouillon{
  background:#f1f5f9;
  border-color:#e2e8f0;
  color:#334155;
}

/* =========================================================
PASTILLES
========================================================= */
.lauto.lauto-scope .lauto-pastilles{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:10px;
}
.lauto.lauto-scope .lauto-pastille{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid rgba(229,231,235,.9);
  background:rgba(255,255,255,.9);
  color:var(--la-ink);
  font-weight:900;
  font-size:13px;
  text-decoration:none;
  transition:transform .08s ease, background .18s ease;
}
.lauto.lauto-scope .lauto-pastille:hover{ background:rgba(248,250,252,.9); }
.lauto.lauto-scope .lauto-pastille:active{ transform:translateY(1px); }

/* =========================================================
BARRE FORMULAIRE
========================================================= */
.lauto.lauto-scope .lauto-barre-formulaire{
  display:grid;
  grid-template-columns: 1.4fr 1fr 1fr .8fr auto;
  gap:10px;
  align-items:end;
  margin-top:10px;
}
.lauto.lauto-scope .lauto-champ-bouton{ align-self:end; }

/* =========================================================
TABLES
========================================================= */
.lauto.lauto-scope .lauto-tableau-conteneur{
  overflow:auto;
  border-radius:16px;
  border:1px solid rgba(229,231,235,.9);
  background:rgba(255,255,255,.72);
  margin-top:10px;
}

.lauto.lauto-scope .lauto-tableau{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  min-width:980px;
}

.lauto.lauto-scope .lauto-tableau thead th{
  position:sticky;
  top:0;
  z-index:2;
  text-align:left;
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--la-muted2);
  font-weight:950;
  padding:12px 12px;
  background: rgba(248,250,252,.92);
  border-bottom:1px solid rgba(229,231,235,.9);
}

.lauto.lauto-scope .lauto-tableau tbody td{
  padding:12px 12px;
  border-bottom:1px solid rgba(229,231,235,.75);
  vertical-align:top;
  font-weight:850;
}
.lauto.lauto-scope .lauto-tableau tbody tr:hover td{
  background: rgba(255,255,255,.65);
}

.lauto.lauto-scope .lauto-th-droite{ text-align:right; }
.lauto.lauto-scope .lauto-td-droite{ text-align:right; white-space:nowrap; }

/* =========================================================
TABLE MODE EXCEL
========================================================= */
.lauto.lauto-scope .lauto-tableau-conteneur.lauto-tableau-excel-conteneur{
  margin-top:12px;
  border-radius:var(--la-radius-xl);
  border:1px solid var(--la-line);
  background: rgba(255,255,255,.65);
  box-shadow: 0 18px 44px rgba(2,6,23,.08);
  overflow:hidden;

  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
}

.lauto.lauto-scope .lauto-tableau.lauto-tableau-excel{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  background:#fff;
  min-width:980px;
}

.lauto.lauto-scope .lauto-tableau.lauto-tableau-excel thead th{
  text-align:left;
  background: rgba(6,95,70,.06);
  color:#065f46;
  font-weight:950;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:12px;
  padding:12px;
  border-bottom:1px solid var(--la-line);
  border-right:1px solid rgba(229,231,235,.75);
  white-space:nowrap;
}
.lauto.lauto-scope .lauto-tableau.lauto-tableau-excel thead th:last-child{ border-right:0; }

.lauto.lauto-scope .lauto-tableau.lauto-tableau-excel tbody td{
  padding:12px;
  border-bottom:1px solid var(--la-line);
  border-right:1px solid rgba(229,231,235,.55);
  font-size:13.5px;
  vertical-align:middle;
  font-weight:800;
}
.lauto.lauto-scope .lauto-tableau.lauto-tableau-excel tbody td:last-child{ border-right:0; }
.lauto.lauto-scope .lauto-tableau.lauto-tableau-excel tbody tr:last-child td{ border-bottom:0; }
.lauto.lauto-scope .lauto-tableau.lauto-tableau-excel tbody tr:hover td{
  background: rgba(248,250,252,.8);
}

.lauto.lauto-scope .lauto-lien-vd{
  color:#065f46;
  font-weight:950;
  text-decoration:none;
}
.lauto.lauto-scope .lauto-lien-vd:hover{ text-decoration:underline; }

.lauto.lauto-scope .lauto-statut-vd{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:4px 12px;
  border-radius:999px;
  border:1px solid rgba(15,143,106,.35);
  background: rgba(236,253,245,.75);
  color:#065f46;
  font-weight:950;
  font-size:12.5px;
  white-space:nowrap;
}

/* Statut envoyée = vert (déjà actuel mais on sécurise) */
.lauto.lauto-scope .lauto-statut-vd--envoyee{
  border-color: rgba(15,143,106,.35);
  background: rgba(236,253,245,.75);
  color:#065f46;
}

/* Statut cloturée + expirée = rouge */
.lauto.lauto-scope .lauto-statut-vd--cloturee,
.lauto.lauto-scope .lauto-statut-vd--expiree{
  border-color: rgba(159,18,57,.35);
  background: rgba(255,241,242,.75);
  color:#9f1239;
}

/* =========================================================
GRILLE CARTES + CLES/VALEURS
========================================================= */
.lauto.lauto-scope .lauto-grille-cartes{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:14px;
  margin-top:12px;
}

.lauto.lauto-scope .lauto-carte{
  border-radius:var(--la-radius-lg);
  border:1px solid rgba(229,231,235,.95);
  background:rgba(255,255,255,.86);
  box-shadow:0 10px 26px rgba(2,6,23,.04);
  padding:14px;
}

.lauto.lauto-scope .lauto-liste-cle-valeur{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top:10px;
}

.lauto.lauto-scope .lauto-cle-valeur{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:12px;
  padding-bottom:8px;
  border-bottom:1px dashed rgba(229,231,235,.9);
}
.lauto.lauto-scope .lauto-cle-valeur:last-child{
  border-bottom:0;
  padding-bottom:0;
}

.lauto.lauto-scope .lauto-cle{
  font-size:12px;
  font-weight:950;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--la-muted2);
}
.lauto.lauto-scope .lauto-valeur{
  font-weight:900;
  color:var(--la-ink);
}

/* Compteurs / footer helpers */
.lauto.lauto-scope .lauto-compteurs{
  margin:10px 0 0;
  font-size:13px;
  font-weight:850;
  color:var(--la-muted);
}
.lauto.lauto-scope .lauto-compteurs-muted{ color:var(--la-muted2); }

.lauto.lauto-scope .lauto-separateur-inline{
  margin:0 8px;
  color:rgba(100,116,139,.7);
}

.lauto.lauto-scope .lauto-liens-pied{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  align-items:center;
}
.lauto.lauto-scope .lauto-note-pied{
  margin:12px 0 0;
  font-size:12.5px;
  color:var(--la-muted2);
  font-weight:800;
}

/* =========================================================
FAQ
========================================================= */
.lauto.lauto-scope .lauto-faq{ display:grid; gap:10px; margin-top:10px; }

.lauto.lauto-scope .lauto-faq-item{
  border:1px solid rgba(229,231,235,.9);
  border-radius:18px;
  background:#fff;
  padding:10px 12px;
  box-shadow: 0 12px 30px rgba(2,6,23,.05);
}
.lauto.lauto-scope .lauto-faq-question{
  cursor:pointer;
  font-weight:950;
  color:var(--la-ink);
  list-style:none;
}
.lauto.lauto-scope .lauto-faq-question::-webkit-details-marker{ display:none; }
.lauto.lauto-scope .lauto-faq-reponse{
  margin-top:8px;
  color:var(--la-muted);
  font-weight:850;
  line-height:1.6;
  font-size:13.5px;
}

/* =========================================================
CTA SOMBRE
========================================================= */
.lauto.lauto-scope .lauto-cta-sombre{
  margin-top:14px;
  border-radius: var(--la-radius-xl);
  border:1px solid rgba(255,255,255,.12);
  background:#0f172a;
  color:#fff;
  box-shadow: var(--la-shadow2);
  padding:16px;
}
.lauto.lauto-scope .lauto-cta-sombre-interieur{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}
.lauto.lauto-scope .lauto-kicker-fr{
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#cbd5e1;
  font-weight:900;
  margin:0 0 6px;
}
.lauto.lauto-scope .lauto-cta-sombre-titre{ color:#fff; margin:0 0 6px; }
.lauto.lauto-scope .lauto-cta-sombre-sous-texte{ color:#cbd5e1; margin:0; }

.lauto.lauto-scope .lauto-cta-sombre-bouton{
  color:#fff;
  border-color:rgba(255,255,255,.22);
  background:transparent;
  box-shadow:none;
}
.lauto.lauto-scope .lauto-cta-sombre-bouton:hover{
  background:rgba(255,255,255,.06);
  transform:translateY(-1px);
}

/* =========================================================
MINI GRILLES (LOOK TABLE EXCEL)
========================================================= */
.lauto.lauto-scope .lauto-mini-tableau{
  margin-top:12px;
  border-radius:var(--la-radius-xl);
  border:1px solid var(--la-line);
  background: rgba(255,255,255,.65);
  box-shadow: 0 18px 44px rgba(2,6,23,.08);
  overflow:hidden;
  width:100%;
  max-width:520px;

  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
}

/* Ligne = row */
.lauto.lauto-scope .lauto-mini-ligne{
  display:grid;
  gap:0;
  padding:0;
  border-bottom:1px solid var(--la-line);
  background:#fff;
  font-weight:800;
  color:var(--la-ink);
}
.lauto.lauto-scope .lauto-mini-ligne:last-child{ border-bottom:0; }

/* 2 colonnes */
.lauto.lauto-scope .lauto-mini-ligne-2{
  grid-template-columns: 1fr 140px;
  align-items:stretch;
}

/* Cellules = td */
.lauto.lauto-scope .lauto-mini-cellule{
  padding:12px;
  font-size:13.5px;
  font-weight:800;
  color:var(--la-ink);
  border-right:1px solid rgba(229,231,235,.55);
}
.lauto.lauto-scope .lauto-mini-ligne-2 .lauto-mini-cellule:last-child{ border-right:0; }

/* En-tête = thead */
.lauto.lauto-scope .lauto-mini-ligne-entete{
  background: rgba(6,95,70,.06);
}
.lauto.lauto-scope .lauto-mini-ligne-entete .lauto-mini-cellule{
  background:transparent;
  color:#065f46;
  font-weight:950;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:12px;
  border-bottom:1px solid var(--la-line);
}

/* Align droite */
.lauto.lauto-scope .lauto-mini-cellule-droite{
  text-align:right;
  white-space:nowrap;
}

/* Hover comme Excel */
.lauto.lauto-scope .lauto-mini-ligne:not(.lauto-mini-ligne-entete):hover{
  background: rgba(248,250,252,.8);
}

/* Responsive quand ça stack (ton @media a déjà la partie columns) */
@media (max-width:980px){
  .lauto.lauto-scope .lauto-mini-ligne-2 .lauto-mini-cellule{
    border-right:0;
    border-bottom:1px solid rgba(229,231,235,.55);
  }
  .lauto.lauto-scope .lauto-mini-ligne-2 .lauto-mini-cellule:last-child{
    border-bottom:0;
  }
}


/* =========================================================
RESPONSIVE
========================================================= */
@media (max-width: 980px){
  .lauto.lauto-scope .lauto-titre-1{ font-size:32px; }

  .lauto.lauto-scope .lauto-conteneur{ padding:14px 14px 44px; }

  .lauto.lauto-scope .lauto-grille{ grid-template-columns:1fr; }

  .lauto.lauto-scope .lauto-barre-formulaire{ grid-template-columns:1fr; }

  .lauto.lauto-scope .lauto-choix-inline{ grid-template-columns:1fr; }

  .lauto.lauto-scope .lauto-ligne-champ{ grid-template-columns:1fr; align-items:stretch; }

  .lauto.lauto-scope .lauto-grille-cartes{ grid-template-columns:1fr; }

  .lauto.lauto-scope .lauto-mode-piece-kit .lauto-ligne-kit .lauto-grille{
    grid-template-columns:1fr;
  }
  .lauto.lauto-scope .lauto-mode-piece-kit .lauto-col-supprimer-kit{
    justify-content:flex-start;
  }
}

@media (max-width:980px){
  .lauto.lauto-scope .lauto-tableau.lauto-tableau-excel{ min-width:860px; }
}
@media (max-width:560px){
  .lauto.lauto-scope .lauto-tableau.lauto-tableau-excel{ min-width:820px; }
}









.lm-custom-select {
  position: relative;
  width: 100%;
}

.lm-select-suggest {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  width: 100%;
  background: #fff;
  border: 1px solid #cfd8dc;
  border-radius: 10px;
  box-shadow: 0 10px 24px rgba(0,0,0,0.08);
  overflow: hidden;
  z-index: 999;
}

.lm-select-item {
  padding: 12px 14px;
  cursor: pointer;
  font-size: 14px;
  line-height: 1.3;
}

.lm-select-item:hover {
  background: #f4f8f8;
}

.lm-select-item.is-active {
  background: #eaf6f3;
  font-weight: 700;
}

.lm-custom-select-label,
.lm-select-item {
  font-style: normal;
}

/* =========================================================
AUTOCOMPLETE (liste nom pièce)
IMPORTANT: PAS de scope .lauto ici car le menu est append dans <body>
========================================================= */

.lm-piece-suggest{
  position: absolute;
  z-index: 999999 !important;

  background: rgba(255,255,255,.98);
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  box-shadow: 0 18px 44px rgba(2,6,23,.14);

  overflow: auto;
  max-height: 260px;

  display: none; /* géré par le JS */
}

.lm-piece-suggest .lm-piece-item{
  padding: 10px 10px;
  cursor: pointer;
  font-size: 13.5px;
  line-height: 1.2;
  user-select: none;

  color: #0f172a;
  font-weight: 850;

  border-radius: 10px;
  margin: 4px;
}

.lm-piece-suggest .lm-piece-item:hover,
.lm-piece-suggest .lm-piece-item.is-active{
  background: rgba(236,253,245,.55);
  border: 1px solid rgba(15,143,106,.35);
  color: #06281c;
}

.lm-piece-suggest .lm-piece-empty{
  padding: 10px 12px;
  font-size: 13.5px;
  color: #64748b;
  font-weight: 850;
}


/* FIX alignement des inputs (colonne label "90px" + sécurité) */
.lauto.lauto-scope .lauto-champ.lauto-ligne-champ{
  grid-template-columns: minmax(90px, max-content) minmax(0, 1fr) !important;
  column-gap: 8px !important;
  align-items: center;
}

/* Sécurité label long : ne casse pas la grille, coupe proprement */
.lauto.lauto-scope .lauto-champ.lauto-ligne-champ .lauto-etiquette{
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}



/* Espace vertical entre les champs (sert de “réserve” pour les annotations en absolute) */
.lauto .lauto-grille{
  row-gap: 28px; /* ajuste si besoin (24 à 32px) */
}

/* Le champ reste “normal” dans la grille */
.lauto .lauto-ligne-champ{
  overflow: visible;
}

/* Nouveau wrapper : référence de positionnement JUSTE pour l’input + annotation */
.lauto .lauto-input-wrap{
  position: relative;
  overflow: visible;
}

/* Annotation : n’influence PAS la hauteur, se colle sous l’input */
.lauto .lauto-input-wrap .lauto-texte-mini{
  position: absolute;
  left: 0;
  top: calc(100% + 1px); /* collé sous la bulle */
  margin: 0;
  line-height: 1.2;
  pointer-events: none;
  z-index: 2;
}


.lauto-hRecapWrap{ margin-top:10px; }
.lauto-hRecapTable{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  border:1px solid #e3e8f0;
  border-radius:12px;
  overflow:hidden;
  background:#fff;
}
.lauto-hRecapTable th,
.lauto-hRecapTable td{
  padding:10px 12px;
  border-bottom:1px solid #edf1f7;
  font-size:13px;
  vertical-align:top;
}
.lauto-hRecapTable tr:last-child td{ border-bottom:none; }
.lauto-hRecapTable th{
  text-align:left;
  font-weight:700;
  background:#f7f9fc;
  font-size:12px;
}
.lauto-hRecapDay{ font-weight:700; white-space:nowrap; }
.lauto-hRecapClosed{ opacity:.75; font-style:italic; }
.lauto-hRecapSlot{ white-space:nowrap; }
.lauto-hRecapSmall{ font-size:12px; opacity:.85; }

.lauto-horairesGrid{
  display:grid;
  grid-template-columns: 1fr;
  gap:12px;
  margin-top:10px;
}
@media (min-width: 900px){
  .lauto-horairesGrid{ grid-template-columns: 1fr 1fr; }
}
.lauto-horairesCard{
  border:1px solid #e3e8f0;
  border-radius:12px;
  padding:12px;
  background:#fff;
}
.lauto-horairesCardHead{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  padding-bottom:10px;
  border-bottom:1px solid #edf1f7;
  margin-bottom:10px;
}
.lauto-horairesDayTitle{
  font-weight:700;
  font-size:14px;
  line-height:1.2;
}
.lauto-horairesChecks{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:flex-end;
  font-size:12px;
}
.lauto-horairesChecks .lauto-check{
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin:0;
  white-space:nowrap;
}
.lauto-horairesBlock{ margin-top:10px; }
.lauto-horairesBlockTitle{
  font-weight:700;
  font-size:12px;
  margin-bottom:6px;
}
.lauto-horairesRowGrid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
}
.lauto-horairesField label{
  display:block;
  font-size:11px;
  opacity:.85;
  margin-bottom:4px;
}
.lauto-horairesField select.lauto-input{
  width:100%;
  min-width:140px;
  height:34px;
  padding:6px 10px;
  border:1px solid #d7deea;
  border-radius:6px;
  background:#fff;
  font-size:13px;
}
.lauto-horairesCard.is-closed{ opacity:.65; }

.lauto-hEdit{ display:none; }
.lauto-hEdit.is-open{ display:block; }
.lauto-hRecap.is-hidden{ display:none; }

.lauto-hActionsRow{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:12px;
}


.lauto-btn-ajout-photo {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
}

.lauto-btn-ajout-photo svg {
  width: 32px;
  height: 32px;
  display: block;
}

.lauto-page--nouvelle-demande-particulier [data-photo-thumbs] img,
.lauto-page--nouvelle-demande-particulier .lauto-photo-thumb,
.lauto-page--nouvelle-demande-pro [data-photo-thumbs] img,
.lauto-page--nouvelle-demande-pro .lauto-photo-thumb{
  width:48px;
  height:48px;
  border-radius:9px;
}


.lauto-piecePresets {
  display: grid;
  gap: 12px;
  margin: 14px 0 18px;
}

.lauto-piecePresets--single {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.lauto-piecePresets--kit {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.lauto-piecePresetCard {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;

    min-height: 55px;
    padding: 7px 5px;

    border: 1px solid #d9d9d9;
    border-radius: 10px;
    background: #fff;

    cursor: pointer;
    text-align: center;
}

.lauto-piecePresetCard-icon svg {
  display: block;
  width: 30px;
  height: 30px;
}

.lauto-piecePresetCard-label {
    font-size: 11px;
    line-height: 1.2;
}

.lauto-btn-ajout-note svg {
  display: block;
  width: 24px;
  height: 24px;
}

@media (max-width: 980px) {
  .lauto-piecePresets--single {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .lauto-piecePresets--kit {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .lauto-piecePresets--single,
  .lauto-piecePresets--kit {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}


.lauto-btn-ajout-photo,
.lauto-btn-ajout-note{
  background:none;
  border:none;
  padding:0;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}

.lauto-btn-ajout-photo svg,
.lauto-btn-ajout-note svg{
  width:32px;
  height:32px;
  display:block;
}

.lauto-btn-ajout-note svg line{
  stroke: var(--la-primary);
  transition: stroke .18s ease;
}

.lauto-btn-ajout-note.is-filled svg line{
  stroke: #dc2626;
}

.lauto-notePieceBox{
  width:100%;
}

.lauto-notePieceBox [data-note-textarea]{
  margin-top:8px;
}

.lauto-grille > .lauto-champ.lauto-ligne-champ:has(.lauto-notePieceBox [data-note-textarea]:not([hidden])){
  grid-column:1 / -1;
  align-items:start;
}

.lauto-grille > .lauto-champ.lauto-ligne-champ:has(.lauto-notePieceBox [data-note-textarea]:not([hidden])) .lauto-notePieceBox{
  display:grid;
  grid-template-columns:max-content 1fr;
  column-gap:8px;
  row-gap:8px;
  align-items:start;
}

.lauto-grille > .lauto-champ.lauto-ligne-champ:has(.lauto-notePieceBox [data-note-textarea]:not([hidden])) .lauto-notePieceBox [data-note-toggle]{
  grid-column:2;
  justify-self:start;
}

.lauto-grille > .lauto-champ.lauto-ligne-champ:has(.lauto-notePieceBox [data-note-textarea]:not([hidden])) .lauto-notePieceBox [data-note-textarea]{
  grid-column:1 / -1;
  width:100%;
}










.lauto.lauto-scope .lauto-modal-confirm[hidden]{
  display:none !important;
}

.lauto.lauto-scope .lauto-modal-confirm{
  position:fixed;
  inset:0;
  z-index:999999;
}

.lauto.lauto-scope .lauto-modal-confirm-backdrop{
  position:absolute;
  inset:0;
  background:rgba(15,23,42,.42);
  backdrop-filter:blur(2px);
}

.lauto.lauto-scope .lauto-modal-confirm-dialog{
  position:relative;
  z-index:2;
  width:min(560px, calc(100vw - 28px));
  margin:12vh auto 0;
  background:#fff;
  border-radius:18px;
  box-shadow:0 24px 60px rgba(2,6,23,.22);
}

.lauto.lauto-scope .lauto-modal-confirm-dialog .lauto-actions{
  margin-top:16px;
}










/* ============================
   Nouvelle demande particulier + pro
   Numérotation des lignes en mode "Plusieurs pièces"
   ============================ */

[data-js="nouvelle-demande-particulier-form"] [data-kit-items],
[data-js="nouvelle-demande-pro-form"] [data-kit-items] {
  counter-reset: lauto-kit-row;
}

[data-js="nouvelle-demande-particulier-form"] [data-kit-row],
[data-js="nouvelle-demande-pro-form"] [data-kit-row] {
  position: relative;
  overflow: visible;
}

[data-js="nouvelle-demande-particulier-form"] [data-kit-row]::before,
[data-js="nouvelle-demande-pro-form"] [data-kit-row]::before {
  counter-increment: lauto-kit-row;
  content: counter(lauto-kit-row);
  position: absolute;
  left: -18px;
  top: 13%;
  transform: translateY(-50%);
  width: 11px;
  text-align: center;
  font-size: 13px;
  font-weight: 800;
  line-height: 1;
  color: #0F8F6A;
  pointer-events: none;
}

body.lautomatik-site{
  min-height:100vh;
  min-height:100dvh;
  margin:0;
  display:flex;
  flex-direction:column;
}

body.lautomatik-site > .lauto-siteFooterBlock{
  margin-top:auto !important;
}









.lauto-page--mes-informations-vendeur .lauto-image-preview {
  width: 220px;
  max-width: 100%;
  aspect-ratio: 4 / 3;
  border: 1px solid #d7dbe0;
  border-radius: 16px;
  background: #f8fafc;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.lauto-page--mes-informations-vendeur .lauto-image-preview-btn {
  border: 0;
  padding: 0;
  margin: 0;
  background: transparent;
  width: 100%;
  height: 100%;
  cursor: zoom-in;
}

.lauto-page--mes-informations-vendeur .lauto-image-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.lauto-page--mes-informations-vendeur .lauto-image-empty {
  color: #64748b;
  font-weight: 700;
}

.lauto-image-lightbox {
  position: fixed;
  inset: 0;
  z-index: 999999;
  background: rgba(15, 23, 42, .78);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.lauto-image-lightbox.is-open {
  display: flex;
}

.lauto-image-lightbox img {
  max-width: min(900px, 96vw);
  max-height: 86vh;
  border-radius: 18px;
  background: #fff;
}

.lauto-page--mes-informations-vendeur .lauto-image-zone {
  display: flex;
  align-items: center;
  gap: 34px;
}

.lauto-page--mes-informations-vendeur .lauto-image-actions {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
  padding-top: 0;
}

@media (max-width: 767px) {
  .lauto-page--mes-informations-vendeur .lauto-image-zone {
    display: block;
  }

  .lauto-page--mes-informations-vendeur .lauto-image-actions {
    flex-direction: row;
    flex-wrap: wrap;
    padding-top: 12px;
  }
}

/* =========================================================
IMAGE VENDEUR PUBLIQUE
========================================================= */

.lauto.lauto-scope .lauto-seller-hero .lauto-en-tete-ligne {
  align-items: center;
}

.lauto.lauto-scope .lauto-seller-hero-content {
  min-width: 0;
  flex: 1 1 auto;
}

.lauto.lauto-scope .lauto-seller-hero-visual {
  flex: 0 0 auto;
  margin-left: auto;
}

.lauto.lauto-scope .lauto-vendeur-image {
  width: 260px;
  max-width: 100%;
  aspect-ratio: 4 / 3;
  border: 1px solid #d7dbe0;
  border-radius: 16px;
  background: #f8fafc;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.lauto.lauto-scope .lauto-vendeur-image-img,
.lauto.lauto-scope .lauto-vendeur-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Taille spécifique fiche vendeur publique */
.lauto.lauto-scope .lauto-vendeur-image--hero {
  width: 220px;
}

@media (max-width: 767px) {
  .lauto.lauto-scope .lauto-seller-hero .lauto-en-tete-ligne {
    align-items: flex-start;
  }

  .lauto.lauto-scope .lauto-seller-hero-visual {
    width: 100%;
    margin-left: 0;
    margin-top: 12px;
  }

  .lauto.lauto-scope .lauto-vendeur-image--hero {
    width: 200px;
  }
}

/* =========================================================
MON PROFIL VENDEUR — IMAGE DANS MES INFORMATIONS
========================================================= */

.lauto.lauto-scope .lauto-profil-info-layout {
  display: grid;
  grid-template-columns: minmax(0, 82%) minmax(0, 18%);
  gap: 18px;
  align-items: center;
  margin-top: 10px;
}

.lauto.lauto-scope .lauto-profil-info-layout.no-image {
  grid-template-columns: 1fr;
}

.lauto.lauto-scope .lauto-profil-info-fields {
  min-width: 0;
}

.lauto.lauto-scope .lauto-profil-info-visual {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  min-width: 0;
}

.lauto.lauto-scope .lauto-vendeur-image--profil {
  width: 180px;
}

@media (max-width: 767px) {
  .lauto.lauto-scope .lauto-profil-info-layout {
    grid-template-columns: 1fr;
  }

  .lauto.lauto-scope .lauto-profil-info-visual {
    justify-content: flex-start;
    margin-top: 12px;
  }

  .lauto.lauto-scope .lauto-vendeur-image--profil {
    width: 220px;
  }
}

/* =========================================================
UPLOAD PHOTO VENDEUR — MODAL CUSTOM
========================================================= */

.lauto-upload-modal[hidden] {
  display: none !important;
}

.lauto-upload-modal {
  position: fixed;
  inset: 0;
  z-index: 999999;
}

.lauto-upload-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, .72);
}

.lauto-upload-modal-dialog {
  position: relative;
  z-index: 2;
  width: min(560px, calc(100vw - 28px));
  margin: 8vh auto 0;
  background: #fff;
  border-radius: 18px;
  box-shadow: 0 24px 60px rgba(2,6,23,.22);
  padding: 18px;
}

.lauto-upload-modal-head {
  margin-bottom: 14px;
}

.lauto-upload-modal-body {
  margin-bottom: 16px;
}

.lauto-upload-preview-wrap {
  width: 100%;
  aspect-ratio: 4 / 3;
  border: 1px solid #d7dbe0;
  border-radius: 16px;
  background: #f8fafc;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.lauto-upload-preview-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.lauto-upload-modal.is-uploading .lauto-upload-modal-dialog {
  pointer-events: auto;
}

.lauto-upload-modal.is-uploading .lauto-upload-preview-wrap {
  opacity: .55;
}

.lauto-upload-modal.is-uploading .lauto-upload-modal-dialog::after {
  content: "Envoi de l’image...";
  position: absolute;
  inset: 0;
  z-index: 5;
  border-radius: 18px;
  background: rgba(255,255,255,.68);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #0f172a;
  font-weight: 950;
  font-size: 15px;
}