/* =========================================================
   MINDSET — Simulateur de devis (moteur configurable)
   Mobile-first, boutons tactiles ≥ 48px, une question/écran.
   ========================================================= */

.ms-sim {
  max-width: 720px;
  margin-inline: auto;
  background: var(--wp--preset--color--white);
  border: 1px solid var(--ms-line);
  border-radius: var(--ms-radius-lg);
  box-shadow: var(--ms-shadow-soft);
  padding: clamp(1.4rem, 4vw, 2.6rem);
}

/* ---------- Progress ---------- */
.ms-sim__progress { margin-bottom: 1.6rem; }
.ms-sim__progress-label {
  display: block;
  font-size: .8rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
  color: var(--wp--preset--color--accent);
  margin-bottom: .5rem;
}
.ms-sim__progress progress {
  width: 100%; height: 6px;
  -webkit-appearance: none; appearance: none;
  border: none; border-radius: 99px; overflow: hidden;
  background: var(--wp--preset--color--bg-alt);
}
.ms-sim__progress progress::-webkit-progress-bar { background: var(--wp--preset--color--bg-alt); }
.ms-sim__progress progress::-webkit-progress-value {
  background: var(--wp--preset--color--accent);
  transition: width .4s var(--ms-ease);
}
.ms-sim__progress progress::-moz-progress-bar { background: var(--wp--preset--color--accent); }

/* ---------- Étapes ---------- */
.ms-sim__step { border: 0; padding: 0; margin: 0; }
.ms-sim__question {
  font-family: var(--wp--preset--font-family--display);
  font-size: clamp(1.25rem, 1rem + 1.2vw, 1.7rem);
  font-weight: 700;
  color: var(--wp--preset--color--primary);
  margin-bottom: 1.4rem;
  padding: 0;
}

.ms-sim__options {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: .8rem;
}
.ms-sim__option {
  min-height: 48px;
  display: flex; flex-direction: column; align-items: flex-start; gap: .3rem;
  padding: 1rem 1.1rem;
  background: var(--wp--preset--color--bg);
  border: 2px solid var(--ms-line);
  border-radius: var(--ms-radius);
  text-align: left;
  cursor: pointer;
  transition: border-color .25s var(--ms-ease), transform .25s var(--ms-ease), box-shadow .25s var(--ms-ease);
}
.ms-sim__option:hover {
  border-color: var(--wp--preset--color--accent);
  transform: translateY(-2px);
  box-shadow: var(--ms-shadow-soft);
}
.ms-sim__option.is-selected {
  border-color: var(--wp--preset--color--accent);
  background: color-mix(in srgb, var(--wp--preset--color--accent) 6%, var(--wp--preset--color--white));
}
.ms-sim__option-icon { color: var(--wp--preset--color--accent); }
.ms-sim__option-icon svg {
  width: 26px; height: 26px;
  fill: none; stroke: currentColor; stroke-width: 2;
  stroke-linecap: round; stroke-linejoin: round;
}
.ms-sim__option-label { font-weight: 700; color: var(--wp--preset--color--primary); }
.ms-sim__option-hint { font-size: .82rem; color: var(--wp--preset--color--muted); }

/* ---------- Slider ---------- */
.ms-sim__slider { margin-bottom: 1.4rem; }
.ms-sim__slider-value {
  font-family: var(--wp--preset--font-family--display);
  font-size: 2rem; font-weight: 700;
  color: var(--wp--preset--color--accent);
  margin-bottom: 1rem;
}
.ms-sim__slider input[type="range"] {
  width: 100%; height: 48px;
  accent-color: var(--wp--preset--color--accent);
  cursor: pointer;
}
.ms-sim__next { min-height: 48px; }

/* ---------- Estimation sticky ---------- */
.ms-sim__estimate {
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  margin-top: 1.6rem;
  padding: .9rem 1.2rem;
  background: var(--wp--preset--color--primary-dark);
  color: rgba(255,255,255,.8);
  border-radius: var(--ms-radius);
  font-size: .92rem;
}
.ms-sim__estimate strong {
  color: #fff;
  font-family: var(--wp--preset--font-family--display);
  font-size: 1.15rem;
  white-space: nowrap;
}

/* ---------- Navigation ---------- */
.ms-sim__nav { margin-top: 1.4rem; }
.ms-sim__prev { min-height: 44px; padding: .6rem 1.2rem; font-size: .88rem; }

/* ---------- Résultat ---------- */
.ms-sim__result-intro { color: var(--wp--preset--color--muted); margin-bottom: .6rem; }
.ms-sim__result-range {
  font-family: var(--wp--preset--font-family--display);
  font-size: clamp(1.8rem, 1.2rem + 2.4vw, 2.8rem);
  font-weight: 700;
  color: var(--wp--preset--color--primary);
  margin-bottom: .8rem;
}
.ms-sim__result-aide {
  background: color-mix(in srgb, #2e7d32 8%, var(--wp--preset--color--white));
  border: 1px solid color-mix(in srgb, #2e7d32 25%, transparent);
  color: #1b5e20;
  border-radius: var(--ms-radius);
  padding: .8rem 1rem;
  font-size: .9rem;
  margin-bottom: 1.2rem;
}

/* ---------- Formulaire de capture ---------- */
.ms-sim__form { margin-top: 1.4rem; display: grid; gap: 1rem; }
.ms-sim__form-title { font-weight: 700; color: var(--wp--preset--color--primary); }
.ms-sim__form .ms-form__field label {
  display: block; font-weight: 600; font-size: .9rem;
  color: var(--wp--preset--color--primary);
  margin-bottom: .35rem;
}
.ms-sim__form input[type="text"],
.ms-sim__form input[type="email"],
.ms-sim__form input[type="tel"] {
  width: 100%; min-height: 48px;
  padding: .7rem .9rem;
  border: 1.5px solid var(--ms-line);
  border-radius: 12px;
  font-family: inherit; font-size: 1rem;
  background: var(--wp--preset--color--bg);
}
.ms-sim__form input:focus {
  outline: 2px solid var(--wp--preset--color--accent);
  outline-offset: 1px;
  border-color: transparent;
}
.ms-sim__hp { position: absolute; left: -9999px; opacity: 0; height: 0; overflow: hidden; }
.ms-sim__consent {
  display: flex; gap: .6rem; align-items: flex-start;
  font-size: .88rem; color: var(--wp--preset--color--muted);
}
.ms-sim__consent input { margin-top: .2rem; min-width: 18px; min-height: 18px; }
.ms-sim__status { color: #b32d2e; font-size: .9rem; min-height: 1.2em; }

.ms-sim__done {
  text-align: center;
  padding: 2rem 1rem;
}
.ms-sim__done-title {
  font-family: var(--wp--preset--font-family--display);
  font-size: 1.5rem; font-weight: 700;
  color: #1b5e20;
  margin-bottom: .5rem;
}

/* ---------- Mentions ---------- */
.ms-sim__disclaimer {
  margin-top: 1.4rem;
  font-size: .78rem;
  color: var(--wp--preset--color--muted);
}
.ms-rgpd-notice {
  font-size: .75rem;
  color: var(--wp--preset--color--muted);
  margin-top: .5rem;
}
.ms-sim__alt {
  text-align: center;
  margin-top: 2rem;
  color: var(--wp--preset--color--muted);
}
.ms-sim__alt .ms-btn { margin-top: .6rem; }

/* ---------- Mobile ---------- */
@media (max-width: 560px) {
  .ms-sim__options { grid-template-columns: 1fr; }
  .ms-sim__estimate {
    position: sticky; bottom: .8rem; z-index: 50;
    box-shadow: var(--ms-shadow);
  }
}
@media (prefers-reduced-motion: reduce) {
  .ms-sim__option, .ms-sim__progress progress::-webkit-progress-value { transition: none !important; }
}
