/* ==========================================================
   BCSL Score PRO — Scoped / Clean / Compact (FINAL)
   ========================================================== */

.bcsl-score-pro{
  /* Theme tokens */
  --primary:#02599C;
  --primary-hover:#0987C6;
  --danger:#5e2c99;

  --surface:#fff;
  --text:#0D1E40;
  --muted:rgba(13,30,64,.68);

  --border:rgba(15,23,42,.12);
  --border-strong:rgba(2,89,156,.30);

  --shadow:0 8px 24px rgba(15,23,42,.08);
  --shadow-sm:0 2px 10px rgba(15,23,42,.06);

  --r-xl:16px;
  --r-lg:12px;
  --r-md:10px;

  --ring:0 0 0 4px rgba(2,89,156,.12);

  font-family:Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  text-align:left;
  -webkit-tap-highlight-color:transparent;
}

.bcsl-score-pro :where(*){ box-sizing:border-box; }

/* ==========================================================
   Container
   ========================================================== */
.bcsl-score-pro.container{
  max-width:1000px;
  margin:0 auto;
  background:var(--surface);
  border-radius:var(--r-xl);
  box-shadow:none;
  overflow:hidden;
}

/* Content padding (compact) */
.bcsl-score-pro .form-content{ padding:16px; }
@media (min-width:769px){ .bcsl-score-pro .form-content{ padding:18px; } }

/* Instruction */
.bcsl-score-pro .instruction{
  color:rgba(13,30,64,.92);
  font-size:.95rem;
  line-height:1.35;
  margin:0 0 12px;
  padding:10px 12px;
  background:#fff;
  border-radius:var(--r-lg);
}

/* Steps */
.bcsl-score-pro .step{
  display:none;
  opacity:0;
  transform:translateY(10px);
  transition:opacity .25s ease, transform .25s ease;
}
.bcsl-score-pro .step.active{
  display:block;
  opacity:1;
  transform:none;
}

/* ==========================================================
   Form grid
   ========================================================== */
.bcsl-score-pro .form-row{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
  margin:0 0 12px;
  align-items:start;
}

@media (min-width:769px){
  .bcsl-score-pro .form-row{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:12px;
    margin-bottom:14px;
  }
  .bcsl-score-pro .form-row.cols-1{ grid-template-columns:1fr; }
  .bcsl-score-pro .form-row.cols-3{ grid-template-columns:repeat(3,minmax(0,1fr)); }
  .bcsl-score-pro .form-group.span-2{ grid-column:span 2; }
  .bcsl-score-pro .form-group.span-3{ grid-column:span 3; }
}

.bcsl-score-pro .form-group{ position:relative; min-height:auto; }

/* Labels + help */
.bcsl-score-pro label{
  margin:0 0 6px;
  font-weight:650;
  color:rgba(13,30,64,.95);
  line-height:1.35;
  letter-spacing:-.01em;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
}

.bcsl-score-pro .field-help{
  display:block;
  font-size:.82rem;
  color:var(--muted);
  margin-top:6px;
  line-height:1.35;
}

/* Desktop alignment: label + input same “rhythm” */
@media (min-width:769px){
  .bcsl-score-pro .form-group{
    display:grid;
    grid-template-rows:auto 42px;
    row-gap:4px;
    align-content:start;
  }
  .bcsl-score-pro label{ margin:0; }
}

/* Inputs */
.bcsl-score-pro input,
.bcsl-score-pro select{
  appearance:none;
  width:100%;
  height:42px !important;
  padding:10px 12px !important;
  border:1.5px solid rgba(15,23,42,.14) !important;
  border-radius:var(--r-md) !important;
  background:#fff !important;
  font-size:.96rem !important;
  box-shadow:none;
  transition:border-color .15s ease, box-shadow .15s ease;
}

.bcsl-score-pro input:hover,
.bcsl-score-pro select:hover{
  border-color:rgba(15,23,42,.22) !important;
}

.bcsl-score-pro input:focus,
.bcsl-score-pro select:focus{
  outline:none !important;
  border-color:var(--border-strong) !important;
  box-shadow:var(--ring) !important;
}

/* Validation */
.bcsl-score-pro .validation-message{
  color:rgba(179,0,110,.95) !important;
  font-size:.82rem;
  margin-top:4px;
  opacity:0;
  transition:opacity .15s ease;
  min-height:14px;
}
.bcsl-score-pro .validation-message.show{ opacity:1; }

/* Error global */
#bcslp-error-message{
  display:none;
  background:rgba(179,0,110,.06);
  border:1px solid rgba(179,0,110,.18);
  color:rgba(95,0,55,.95);
  padding:10px;
  border-radius:var(--r-lg);
  margin:10px 0;
}
#bcslp-error-message.show{ display:block; }

/* ==========================================================
   Buttons
   ========================================================== */
.bcsl-score-pro button{
  all:unset;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border-radius:999px;
  padding:10px 16px;
  font-size:.93rem;
  font-weight:600;
  cursor:pointer;
  user-select:none;
  text-align:center;
  background:#f8fafc;
  color:#0f172a;
  border:1px solid rgba(2,89,156,.18);
  transition:all .15s ease;
  -webkit-tap-highlight-color:transparent;
}
.bcsl-score-pro button:hover:not(:disabled){
  background:rgba(2,89,156,.08);
  border-color:rgba(2,89,156,.35);
  color:var(--primary);
}
.bcsl-score-pro button:disabled{ opacity:.6; cursor:not-allowed; }

/* Primary button */
#bcslp-btn-suivant{
  background:var(--primary);
  border-color:var(--primary);
  color:#fff;
  box-shadow:0 2px 6px rgba(2,89,156,.35);
}
#bcslp-btn-suivant:hover:not(:disabled){
  background:var(--primary-hover);
  border-color:var(--primary-hover);
}

.bcslp-btn-wrap{
  display:flex;
  flex-direction:column;
  align-items:flex-start; /* ✅ aligné à gauche */
  margin-top:8px;
}

/* sécurité : le bouton ne se recentre pas via margin auto */
#bcslp-btn-suivant{
  margin-left:0 !important;
  margin-right:0 !important;
}
.bcslp-btn-subtext{
  margin-top:5px;
  font-size:12px;
  line-height:1.3;
  color:rgba(15,23,42,.62);
  text-align:center;
  max-width:420px;
}

@media (max-width:1024px){
  #bcslp-btn-suivant{
    width:min(92%,420px);
    height:42px;
    padding:0 12px;
    font-size:14px;
    margin:0 auto;
  }
  .bcslp-btn-subtext{ width:min(92%,420px); }
}
@media (min-width:768px){ .bcslp-btn-subtext{ font-size:13px; } }

/* Step 2 visibility */
.bcsl-score-pro.is-results #bcslp-identity,
.bcsl-score-pro.is-results #bcslp-instruction-text,
.bcsl-score-pro.is-results #bcslp-error-message{ display:none !important; }

/* ==========================================================
   Results
   ========================================================== */
.bcsl-score-pro .resultats{
  text-align:left;
  padding:14px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  margin:0;
}
@media (min-width:769px){ .bcsl-score-pro .resultats{ padding:18px; } }

.bcsl-score-pro .stars-container{
  font-size:1.7em;
  margin:4px 0 10px;
  position:relative;
  display:inline-block;
  color:#FFD700;
}
.bcsl-score-pro .tooltip-hidden{
  visibility:hidden;
  opacity:0;
  position:absolute;
  bottom:120%;
  left:50%;
  transform:translateX(-50%);
  background:rgba(13,30,64,.92);
  color:#fff;
  padding:8px 10px;
  border-radius:10px;
  font-size:.55em;
  white-space:nowrap;
  transition:opacity .15s ease;
  z-index:10;
}
.bcsl-score-pro .stars-container:hover .tooltip-hidden{
  visibility:visible;
  opacity:1;
}

.bcsl-score-pro .disclaimer,
.bcsl-score-pro .summary{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--r-lg);
}
.bcsl-score-pro .disclaimer{
  font-size:.86em;
  color:var(--muted);
  padding:10px;
  margin-top:10px;
  line-height:1.5;
}
.bcsl-score-pro .summary{
  margin-top:10px;
  padding:10px 12px;
}
.bcsl-score-pro .summary h4{
  font-size:1rem;
  margin:0 0 10px;
  color:var(--text);
  letter-spacing:-.02em;
}
.bcsl-score-pro .summary li{
  margin-bottom:6px;
  font-size:.95em;
  color:rgba(15,23,42,.88);
}

.bcsl-score-pro #bcslp-summary-list .bcslp-section{
  padding-top:10px;
  border-top:1px solid rgba(15,23,42,.10);
  font-size:.98rem;
  color:var(--text);
  letter-spacing:-.01em;
}
.bcsl-score-pro #bcslp-summary-list .bcslp-subsection{
  font-size:.95rem;
  opacity:.95;
}
.bcsl-score-pro #bcslp-summary-list li span{ color:rgba(15,23,42,.72); }

/* Results grid */
.bcsl-score-pro .bcslp-results-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  margin-top:12px;
}
@media (min-width:900px){
  .bcsl-score-pro .bcslp-results-grid{ grid-template-columns:1fr 1fr; gap:16px; }
}

.bcsl-score-pro .bcslp-panel{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
}

.bcsl-score-pro .bcslp-panel-head{
  padding:12px 14px;
  background:rgba(2,89,156,.045);
  border-bottom:1px solid rgba(2,89,156,.10);
}
.bcsl-score-pro .bcslp-panel-head h4{
  margin:0;
  font-size:1.02rem;
  color:var(--text);
  letter-spacing:-.02em;
}
.bcsl-score-pro .bcslp-panel-sub{
  margin:4px 0 0;
  font-size:.86rem;
  color:var(--muted);
  line-height:1.25;
}

.bcsl-score-pro .bcslp-summary-list{
  list-style:none;
  margin:0;
  padding:10px 12px;
}
.bcsl-score-pro .bcslp-summary-list li{
  display:flex;
  justify-content:space-between;
  gap:10px;
  padding:7px 0;
  border-bottom:1px dashed rgba(15,23,42,.10);
  font-size:.95rem;
  color:rgba(15,23,42,.88);
}
.bcsl-score-pro .bcslp-summary-list li:last-child{ border-bottom:none; }
.bcsl-score-pro .bcslp-summary-list li span{ color:rgba(13,30,64,.70); }
.bcsl-score-pro .bcslp-summary-list li strong{
  color:rgba(13,30,64,.95);
  font-weight:750;
  text-align:right;
}

/* Section title */
.bcsl-score-pro .bcslp-summary-list .bcslp-section-title{
  border-bottom:none;
  padding:6px 0;
}
.bcsl-score-pro .bcslp-summary-list .bcslp-section-title strong{
  text-align:center;
  font-weight:900;
}

@media (max-width:480px){
  .bcsl-score-pro .bcslp-panel-head{ padding:11px 12px; }
  .bcsl-score-pro .bcslp-summary-list li{ font-size:.92rem; }
}

.bcslp-note{
  margin-top:8px;
  font-size:12px;
  line-height:1.35;
  color:#6b7280;
  font-style:italic;
}

/* ==========================================================
   Units INSIDE the input (fix definitive)
   ========================================================== */
.bcsl-score-pro .bcslp-unit-wrap{
  position: relative !important;
  display: block !important;
  height: 42px !important;          /* force same height as inputs */
}

.bcsl-score-pro .bcslp-unit-wrap input,
.bcsl-score-pro .bcslp-unit-wrap select{
  height: 42px !important;
  padding-right: 72px !important;   /* space for unit */
}

/* The unit overlays the input (inside, right) */
.bcsl-score-pro .bcslp-unit{
  position: absolute !important;
  right: 10px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  z-index: 2 !important;

  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  font-size: 0.9rem !important;
  font-weight: 800 !important;
  color: rgba(13,30,64,.75) !important;

  background: rgba(255,255,255) !important;
  border: 1px solid rgba(2,89,156,.16) !important;
  padding: 4px 8px !important;
  border-radius: 999px !important;

  pointer-events: none !important; /* never blocks typing/click */
}

/* Mobile tweak */
@media (max-width:480px){
  .bcsl-score-pro .bcslp-unit-wrap input,
  .bcsl-score-pro .bcslp-unit-wrap select{
    padding-right: 64px !important;
  }
  .bcsl-score-pro .bcslp-unit{
    right: 8px !important;
    font-size: 0.85rem !important;
  }
}

.bcsl-score-pro .bcslp-btn-primary{
  background: var(--primary);
  border-color: var(--primary);
  color:#fff;
  box-shadow: 0 2px 6px rgba(2,89,156,.35);
}
.bcsl-score-pro .bcslp-btn-primary:hover:not(:disabled){
  background: var(--primary-hover);
  border-color: var(--primary-hover);
}

/* ==========================================================
   Results — Mobile spacing between action buttons
   (Evaluer / Copier / Trouver d'autres offres)
   ========================================================== */
@media (max-width:480px){
  /* Si tes 3 boutons sont dans .bcslp-btn-wrap */
  .bcsl-score-pro.is-results .bcslp-btn-wrap{
    gap:10px;                 /* espace entre les boutons */
    align-items:stretch;      /* optionnel : même largeur */
  }

  /* Sécurité si certains boutons ne sont pas dans le wrap */
  .bcsl-score-pro.is-results button + button{
    margin-top:10px;
  }
}

/* ==========================================================
   Results — Button styles (no HTML change)
   ========================================================== */

/* Container des boutons */
.bcsl-score-pro .button-group{
  display:flex;
  flex-direction:column;
  gap:6px; /* espace entre boutons (mobile & desktop) */
}

/* 1️⃣ Évaluer un autre leasing → bleu clair */
.bcsl-score-pro .button-group button:not(.button-secondary):not(.bcslp-btn-primary){
  background: rgba(9,135,198,.14);       /* bleu clair */
  border-color: rgba(9,135,198,.45);
  color: var(--primary);
}
.bcsl-score-pro .button-group
button:not(.button-secondary):not(.bcslp-btn-primary):hover{
  background: rgba(9,135,198,.22);
  border-color: rgba(9,135,198,.65);
  color: var(--primary);
}

/* 2️⃣ Copier le résultat → gris */
.bcsl-score-pro .button-group .button-secondary{
  background: rgba(15,23,42,.07);
  border-color: rgba(15,23,42,.18);
  color: rgba(15,23,42,.95);
}
.bcsl-score-pro .button-group .button-secondary:hover{
  background: rgba(15,23,42,.12);
  border-color: rgba(15,23,42,.28);
}

/* ==========================================================
   Results — Desktop: buttons width = content (no full width)
   ========================================================== */
@media (min-width:769px){
  .bcsl-score-pro.is-results .button-group{
    display:flex;
    flex-direction:row;        /* en ligne sur desktop */
    flex-wrap:wrap;            /* si ça ne tient pas, retour à la ligne */
    gap:10px;
    justify-content:flex-start;
    align-items:center;        /* ⛔️ stop le stretch */
  }

  /* Chaque bouton reprend sa largeur naturelle */
  .bcsl-score-pro.is-results .button-group > button{
    width:auto !important;
    flex:0 0 auto;             /* ⛔️ empêche l’étirement */
    align-self:center;
    white-space:nowrap;        /* optionnel : évite les retours à la ligne */
  }
}

/* Mobile: on garde la pile pleine largeur si tu veux */
@media (max-width:768px){
  .bcsl-score-pro.is-results .button-group{
    flex-direction:column;
    align-items:stretch;       /* boutons full width en mobile */
  }
  .bcsl-score-pro.is-results .button-group > button{
    width:100%;
  }
}

/* ==========================================================
   FIX mobile overflow (buttons spilling to the right)
   ========================================================== */
@media (max-width:768px){
  /* Le container doit être strictement dans la largeur du parent */
  .bcsl-score-pro.is-results .button-group{
    width:100%;
    max-width:100%;
    box-sizing:border-box;
    align-items:stretch;
  }

  /* Les boutons ne doivent JAMAIS dépasser */
  .bcsl-score-pro.is-results .button-group > button{
    width:100% !important;
    max-width:100% !important;
    box-sizing:border-box !important;
    justify-content:center;
    white-space:normal !important;     /* ✅ autorise retour ligne si nécessaire */
    overflow-wrap:anywhere;            /* ✅ coupe si mot trop long */
    word-break:break-word;             /* ✅ sécurité */
  }
}