/* === Déco Cover Simulator V3.0 — FULL CSS === */

#dc-sim-app { width: 100%; }

.dc-wrap{
  --dc-primary:#2aa0a2;
  --dc-orange:#f59e0b;
  font-family: inherit;
  color:#111827;
  max-width: 980px;
  margin: 0 auto;
  padding: 18px 14px 30px;
}

.dc-head{ text-align:center; margin-bottom: 10px; }
.dc-title{ font-weight:800; font-size: 22px; letter-spacing:.2px; }
.dc-guarantee{
  margin: 10px auto 6px;
  font-weight: 800;
  font-size: 14px;
  background: rgba(243,187,95,.28);
  border: 1px solid rgba(243,187,95,.55);
  border-radius: 12px;
  padding: 10px 12px;
  max-width: 720px;
}
.dc-sub{ font-size: 13px; color:#4b5563; }

.dc-callout{
  margin: 14px 0 12px;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid #e5e7eb;
  background: #f9fafb;
  color:#374151;
  font-size: 13px;
}

.dc-stepper{
  display:flex;
  justify-content:center;
  gap:10px;
  flex-wrap:wrap;
  margin: 12px 0 10px;
}
.dc-step{
  display:flex;
  align-items:center;
  gap:8px;
  padding: 8px 10px;
  border: 1px solid #e5e7eb;
  border-radius: 999px;
  background:#fff;
  font-size: 12px;
  color:#6b7280;
}
.dc-dot{
  width:22px; height:22px;
  border-radius:999px;
  display:grid; place-items:center;
  border:1px solid #e5e7eb;
  background:#fff;
  font-weight:700;
}
.dc-step.is-active{ border-color: rgba(42,160,162,.45); color:#0f172a; }
.dc-step.is-active .dc-dot{ border-color: rgba(42,160,162,.65); background: rgba(42,160,162,.10); color:#0f172a; }
.dc-step.is-done{ border-color: rgba(42,160,162,.25); color:#0f172a; opacity:.9; }
.dc-step.is-done .dc-dot{ background: rgba(42,160,162,.12); border-color: rgba(42,160,162,.35); }

.dc-actions{ margin-top: 14px; display:flex; justify-content:center; gap:10px; flex-wrap:wrap; }
.dc-actions-2{ justify-content:space-between; }
.dc-btn{
  appearance:none;
  border:1px solid #e5e7eb;
  background:#fff;
  color:#111827;
  border-radius: 12px;
  padding: 12px 16px;
  font-weight: 700;
  cursor:pointer;
  min-width: 160px;
  text-align:center;
}
.dc-btn:disabled{ opacity:.6; cursor:not-allowed; }
.dc-btn-primary{
  background: var(--dc-primary);
  border-color: var(--dc-primary);
  color:#fff;
}
.dc-btn-secondary{ background:#fff; }
.dc-btn-outline{
  background:#fff;
  border-color: rgba(42,160,162,.55);
  color: var(--dc-primary);
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}

.dc-error{
  margin-top: 10px;
  color:#b91c1c;
  font-size: 13px;
  min-height: 18px;
  text-align:center;
}
.dc-success{
  margin-top: 12px;
  border: 1px solid rgba(34,197,94,.35);
  background: rgba(34,197,94,.08);
  border-radius: 12px;
  padding: 12px 14px;
  color:#065f46;
  font-size: 13px;
}

/* Fields */
.dc-field{ margin: 12px 0; }
.dc-field label{
  display:block;
  font-weight: 800;
  font-size: 13px;
  margin-bottom: 6px;
  color:#111827;
}
.dc-field input, .dc-field select, .dc-field textarea{
  width:100%;
  border:1px solid #e5e7eb;
  border-radius: 12px;
  padding: 12px 12px;
  font-size: 14px;
  background:#fff;
  color:#111827;
}
.dc-field textarea{ resize: vertical; }

.dc-hint{ margin-top:6px; color:#6b7280; font-size: 12px; }

/* Profile cards row */
.dc-profile-row{
  display:flex;
  justify-content:center;
  gap:14px;
  flex-wrap:wrap;
  margin: 12px 0 8px;
}

/* Toggle cards (used in Profile + Request + Channels + Timeline) */
.dc-toggle-card{
  width: 320px;
  max-width: 100%;
  border:1px solid #e5e7eb;
  border-radius: 14px;
  padding: 14px 14px;
  background:#fff;
  display:flex;
  align-items:center;
  gap:12px;
  cursor:pointer;
  text-align:left;
}
.dc-toggle-card .dc-tc-ic{
  width:34px; height:34px;
  border-radius: 12px;
  display:grid; place-items:center;
  background: rgba(245,158,11,.10);
  border: 1px solid rgba(245,158,11,.25);
}
.dc-toggle-card .dc-tc-ic svg{ width:22px; height:22px; }
.dc-toggle-card .dc-tc-txt{ display:flex; flex-direction:column; gap:4px; }
.dc-toggle-card strong{ font-size: 14px; color:#111827; }
.dc-toggle-card span{ font-size: 12px; color:#6b7280; }
.dc-toggle-card .dc-tc-badge{
  margin-left:auto;
  width:24px; height:24px;
  border-radius: 999px;
  border: 1px solid #e5e7eb;
  display:grid; place-items:center;
  color:#fff;
  background: transparent;
  font-weight: 900;
}
.dc-toggle-card.is-selected{
  border-color: rgba(42,160,162,.65);
  background: rgba(42,160,162,.08);
}
.dc-toggle-card.is-selected .dc-tc-badge{
  background: var(--dc-primary);
  border-color: var(--dc-primary);
}

/* Panel */
.dc-panel{
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  background:#fff;
  padding: 14px;
  margin: 12px 0;
}
.dc-panel-title{
  font-weight: 900;
  font-size: 13px;
  color:#111827;
  margin-bottom: 10px;
}

/* Multi card grids */
.dc-card-grid{
  display:grid;
  gap:12px;
}
.dc-card-grid-3{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
.dc-card-grid-4{ grid-template-columns: repeat(4, minmax(0, 1fr)); }
@media (max-width: 900px){
  .dc-card-grid-4{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .dc-card-grid-3{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 520px){
  .dc-card-grid-4, .dc-card-grid-3{ grid-template-columns: 1fr; }
}

/* Project cards grid */
.dc-grid{ display:grid; gap:12px; }
.dc-grid-4{ grid-template-columns: repeat(4, minmax(0, 1fr)); }
@media (max-width: 900px){
  .dc-grid-4{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 520px){
  .dc-grid-4{ grid-template-columns: 1fr; }
}

.dc-card{
  border:1px solid #e5e7eb;
  border-radius: 14px;
  padding: 12px;
  background:#fff;
  cursor:pointer;
}
.dc-card.is-selected{
  border-color: rgba(42,160,162,.65);
  background: rgba(42,160,162,.08);
}
.dc-card-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
}
.dc-card-left{ display:flex; gap:10px; align-items:center; }
.dc-icon{
  width:34px; height:34px;
  border-radius: 12px;
  display:grid; place-items:center;
  background: rgba(245,158,11,.10);
  border: 1px solid rgba(245,158,11,.25);
}
.dc-icon svg{ width:22px; height:22px; }
.dc-card-label{ font-weight: 900; font-size: 13px; color:#111827; }
.dc-card-sub{ font-size: 12px; color:#6b7280; }
.dc-card-badge{
  width:26px; height:26px;
  border-radius: 999px;
  border:1px solid #e5e7eb;
  display:grid; place-items:center;
  font-weight: 900;
  color:#111827;
  background:#fff;
}
.dc-card.is-selected .dc-card-badge{
  background: var(--dc-primary);
  border-color: var(--dc-primary);
  color:#fff;
}

/* Controls inside card */
.dc-card-controls{ margin-top: 10px; }
.dc-controls-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.dc-controls-left{
  font-weight: 800;
  font-size: 12px;
  color:#111827;
}
.dc-controls-right{
  display:flex;
  align-items:center;
  gap:8px;
}
.dc-qty-big{
  display:flex;
  align-items:baseline;
  gap:6px;
}
.dc-qty-num{ font-size: 18px; font-weight: 1000; color:#111827; }
.dc-qty-unit{ font-size: 12px; color:#6b7280; font-weight: 800; }

.dc-qty-arrows{
  display:flex;
  gap:6px;
}
.dc-arrow{
  width:28px;
  height:28px;
  border-radius: 10px;
  border: 1px solid rgba(42,160,162,.45);
  background: #fff;
  color: var(--dc-primary);
  cursor:pointer;
  font-weight: 900;
  display:grid;
  place-items:center;
  line-height: 1;
}

.dc-manual{
  display:flex;
  gap:8px;
  align-items:center;
  margin: 10px 0 10px;
}
.dc-manual-input{
  width: 110px !important;
  max-width: 45%;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 10px 10px;
  font-weight: 900;
  color:#111827;
  background:#fff;
}
.dc-manual-unit{ font-size: 12px; font-weight: 800; color:#6b7280; }

.dc-range{
  width:100%;
  accent-color: var(--dc-primary);
}

/* Photos */
.dc-photos{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top: 10px;
}
.dc-photo{
  position:relative;
  width: 110px;
  height: 90px;
  border-radius: 12px;
  overflow:hidden;
  border: 1px solid #e5e7eb;
  background:#fff;
}
.dc-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.dc-x{
  position:absolute;
  top:6px;
  right:6px;
  width:24px; height:24px;
  border-radius: 999px;
  border:1px solid rgba(0,0,0,.15);
  background: rgba(255,255,255,.95);
  cursor:pointer;
  font-weight: 900;
}

/* Honeypot */
.dc-hp{
  position:absolute !important;
  left:-9999px !important;
  width:1px !important;
  height:1px !important;
  opacity:0 !important;
}

/* RGPD */
.dc-rgpd{
  display:flex;
  gap:10px;
  align-items:flex-start;
  font-size: 12px;
  color:#374151;
}
.dc-rgpd input{ margin-top: 2px; }

/* Result */
.dc-result{
  border: 1px solid rgba(42,160,162,.35);
  background: rgba(42,160,162,.06);
  border-radius: 14px;
  padding: 14px;
  text-align:center;
  margin: 12px 0;
}
.dc-result-title{ font-weight: 1000; font-size: 13px; color:#0f172a; }
.dc-result-price{ font-weight: 1000; font-size: 26px; color:#0f172a; margin-top: 6px; }
.dc-result-sub{ font-size: 12px; color:#374151; margin-top: 6px; }

.dc-break{ display:flex; flex-direction:column; gap:10px; }
.dc-break-row{
  display:flex;
  justify-content:space-between;
  gap:12px;
  border:1px solid #eef2f7;
  background:#fff;
  padding: 10px 12px;
  border-radius: 12px;
}
.dc-break-row span{ color:#111827; font-size: 13px; }
.dc-break-row em{ color:#6b7280; font-style: normal; font-size: 12px; }
.dc-break-row strong{ color:#0f172a; }
.dc-break-row.dc-total{
  border-color: rgba(42,160,162,.35);
  background: rgba(42,160,162,.06);
}

/* Advantages 2 columns */
.dc-adv-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:12px;
}
@media (max-width: 700px){
  .dc-adv-grid{ grid-template-columns: 1fr; }
}
.dc-adv-card{
  border:1px solid #e5e7eb;
  border-radius: 14px;
  background:#fff;
  padding: 12px;
  display:grid;
  grid-template-columns: 28px 1fr;
  gap:10px;
  align-items:start;
}
.dc-adv-ic{
  width:28px;
  height:28px;
  border-radius: 12px;
  display:grid;
  place-items:center;
  background: rgba(34,197,94,.10);
  border: 1px solid rgba(34,197,94,.25);
  color:#16a34a;
  font-weight: 1000;
  font-size: 14px;
}
.dc-adv-t{ font-weight: 1000; font-size: 13px; color:#111827; }
.dc-adv-d{ font-size: 12px; color:#4b5563; margin-top: 4px; }

/* === V3.1.3 PATCH — Correctifs ciblés (UI + lisibilité) === */

/* (A) Step 1 — Pro: Société / Métier sur 2 colonnes */
.dc-pro-fields{
  display:grid;
  grid-template-columns: 1fr 1.6fr;
  gap:14px;
}
@media (max-width: 720px){
  .dc-pro-fields{ grid-template-columns: 1fr; }
}

/* (B) Métier: éviter le tronquage visuel */
.dc-pro-fields select{
  width:100%;
  max-width:100%;
  min-width:0;
}
.dc-pro-fields select{
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}

/* (C) Sélection visible (toutes les cards) — renforce le contraste */
.dc-toggle-card.is-selected,
.dc-card.is-selected{
  border-color: rgba(42,160,162,.9);
  background: rgba(42,160,162,.10);
  box-shadow: 0 0 0 2px rgba(42,160,162,.18) inset;
}
.dc-toggle-card.is-selected .dc-tc-badge{
  background: var(--dc-primary);
  border-color: var(--dc-primary);
}

/* (D) Projet: garantir une grille stable (si thème injecte des styles) */
.dc-grid, .dc-card-grid{
  box-sizing: border-box;
}
.dc-grid .dc-card, .dc-card-grid .dc-toggle-card{
  height: 100%;
}

/* (E) Accessibilité: focus visible sans casser le design */
.dc-toggle-card:focus-visible,
.dc-card:focus-visible,
.dc-btn:focus-visible,
.dc-arrow:focus-visible,
.dc-field input:focus-visible,
.dc-field select:focus-visible,
.dc-field textarea:focus-visible{
  outline: 3px solid rgba(42,160,162,.35);
  outline-offset: 2px;
}

/* === FINAL PATCH (selective) ===
   Scope: Step 3 coordinate fields grid + Step 4 advantage cards formatting + select readability.
   No changes to Step 1/2 structure or card grids.
*/

/* Step 3 — Coordonnées: 2→3 colonnes (responsive), sans toucher aux cards (Votre demande / Canaux / Délai) */
.dc-form-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap:14px;
  margin-top: 8px;
}
@media (min-width: 720px){
  .dc-form-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 1100px){
  .dc-form-grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
.dc-field.dc-span-all{ grid-column: 1 / -1; }

/* Step 1 — Métier: éviter l’effet “tronqué” */
.dc-field{ min-width: 0; }
.dc-field select{ min-width: 0; width: 100%; }
.dc-field select option{ white-space: normal; }

/* Step 4 — Avantages: le texte doit être en colonne 2 (sinon il se compresse à 28px) */
.dc-adv-t{ grid-column: 2; grid-row: 1; }
.dc-adv-d{ grid-column: 2; grid-row: 2; color:#4b5563; font-size: 13px; line-height: 1.35; }

/* === FIX: éviter recouvrement par footer / bandeaux sticky (mobile/tablette/desktop) === */
#dc-sim-app {
  padding-bottom: 120px; /* espace de sécurité */
}

@media (max-width: 768px) {
  #dc-sim-app {
    padding-bottom: 160px; /* plus large sur mobile */
  }
}