/* ====================================================================
   NEATIK AIRBNB SIMULATOR - SENTIONE STYLE
   Inspired by https://sentione.com/resources/tools/chatbot-roi-calculator
   ==================================================================== */

:root {
  --sim-bg-primary: #0a0e27;
  --sim-bg-secondary: #101435;
  --sim-bg-card: #1a1f45;
  --sim-accent: #6366f1;
  --sim-accent-hover: #4f46e5;
  --sim-text-primary: #ffffff;
  --sim-text-secondary: #a5b4fc;
  --sim-text-muted: #6b7280;
  --sim-border: rgba(99, 102, 241, 0.2);
  --sim-shadow: 0 20px 60px rgba(0, 0, 0, 0.4);
  --sim-radius: 16px;
  --sim-transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.sim-background-wrapper .left-lines {
    position: absolute;
    top: 368px;
    left: -216px;
    transform: translateZ(0);
}
.sim-background-wrapper .right-line {
    position: absolute;
    top: 70px;
    right: -73px;
    transform: translateZ(0);
}
.bottom-line {
    position: absolute;
    top: 753px;
    left: -100px;
    transform: translateX(-26px);
    width: 405px;
    height: 159px;
    background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI0MDUiIGhlaWdodD0iMTU5Ij48ZGVmcz48cmFkaWFsR3JhZGllbnQgaWQ9ImEiIGN4PSI2OS43MyUiIGN5PSIxNy43NDUlIiByPSIyNDUuNjAyJSIgZng9IjY5LjczJSIgZnk9IjE3Ljc0NSUiIGdyYWRpZW50VHJhbnNmb3JtPSJtYXRyaXgoMCAxIC0uMzMzMzMgMCAuNzU2IC0uNTIpIj48c3RvcCBvZmZzZXQ9IjAlIiBzdG9wLWNvbG9yPSIjN0M2REZEIi8+PHN0b3Agb2Zmc2V0PSIxMDAlIiBzdG9wLWNvbG9yPSIjN0M2REZEIiBzdG9wLW9wYWNpdHk9IjAiLz48L3JhZGlhbEdyYWRpZW50PjwvZGVmcz48ZyBmaWxsPSJub25lIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDAgNSkiPjxjaXJjbGUgY3g9IjQiIGN5PSIxNTAiIHI9IjQiIGZpbGw9IiM3QzZERkQiLz48cGF0aCBmaWxsPSJ1cmwoI2EpIiBmaWxsLXJ1bGU9Im5vbnplcm8iIGQ9Ik00LjUgMTI5djNoLTF2LTNoMVptMC02djNoLTF2LTNoMVptMC02djNoLTF2LTNoMVptMC02djNoLTF2LTNoMVptMC02djNoLTF2LTNoMVptMC02djNoLTF2LTNoMVptMC02djNoLTF2LTNoMVptMC02djNoLTF2LTNoMVptMC02djNoLTF2LTNoMVptMC02djNoLTF2LTNoMVptMC02djNoLTF2LTNoMVptLS4zNjctNi4wOTcuOTUzLjMwNGMtLjI5MS45MTQtLjQ3NiAxLjg2Mi0uNTUgMi44MzFsLS45OTctLjA3NWMuMDgtMS4wNDcuMjgtMi4wNzIuNTk0LTMuMDZaTTcuMzIgNTcuNTlsLjcxNy42OTdhMTIuNTUyIDEyLjU1MiAwIDAgMC0xLjc2IDIuMjg2bC0uODU3LS41MTVhMTMuNTUyIDEzLjU1MiAwIDAgMSAxLjktMi40NjhabTUuMzE4LTMuMzcuMzIzLjk0N2MtLjkxNC4zMTItMS43ODcuNzI5LTIuNjAzIDEuMjQybC0uNTMyLS44NDdhMTMuNDQzIDEzLjQ0MyAwIDAgMSAyLjgxMi0xLjM0MlptNi4wNy0uNzJ2MWgtMS43M2MtLjQxNyAwLS44My4wMjItMS4yNDEuMDYzbC0uMS0uOTk1Yy40NDMtLjA0NC44OS0uMDY3IDEuMzQtLjA2OGgxLjczMVptMTU2IDB2MWgtM3YtMWgzWm0xMiAwdjFoLTN2LTFoM1ptLTE2MiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptNiAwdjFoLTN2LTFoM1ptMjE2IDB2MWgtM3YtMWgzWm0tMjA0IDB2MWgtM3YtMWgzWm0xOTggMHYxaC0zdi0xaDNabS0xODYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTYgMHYxaC0zdi0xaDNabTE3LjgxNi0uNTA0LjI4Mi45NmMtLjk5NC4yOTItMi4wMjMuNDY4LTMuMDcyLjUyNGwtLjA1NC0uOTk4YTEyLjQ2NyAxMi40NjcgMCAwIDAgMi44NDQtLjQ4NlptNS4wMjUtMi44NzcuNjg1LjczYy0uNzYuNzEyLTEuNiAxLjMzNS0yLjUwMiAxLjg1NWwtLjUtLjg2NmExMi41NDUgMTIuNTQ1IDAgMCAwIDIuMzE3LTEuNzE5Wm0zLjE4OC00LjgwNy45MzguMzQ1Yy0uMzYuOTc5LS44MzIgMS45MTEtMS40MDYgMi43OGwtLjgzNS0uNTUyYy41MzItLjgwNC45Ny0xLjY2NyAxLjMwMy0yLjU3M1ptMS43NjMtNS43Mjh2MS40NDRjLS4wMDEuNTUyLS4wMzUgMS4xLS4xMDIgMS42NDFsLS45OTMtLjEyMmMuMDYyLS41MDIuMDk0LTEuMDEuMDk1LTEuNTJ2LTEuNDQzaDFabTAtNnYzaC0xdi0zaDFabTAtNnYzaC0xdi0zaDFabTAtNnYzaC0xdi0zaDFabTAtNnYzaC0xdi0zaDFabTAtNnYzaC0xdi0zaDFaTTQwMC00LjVhNC41IDQuNSAwIDAgMSAuNSA4Ljk3MnYyLjExMmgtMVY0LjQ3M0E0LjUgNC41IDAgMCAxIDQwMC00LjVabTAgMWEzLjUgMy41IDAgMSAwIDAgNyAzLjUgMy41IDAgMCAwIDAtN1oiLz48L2c+PC9zdmc+);
}
/* Reset et base */
#neatik-simulateur-airbnb * {
  box-sizing: border-box;
}

#neatik-simulateur-airbnb {
  background: linear-gradient(180deg, var(--sim-bg-primary) 0%, var(--sim-bg-secondary) 100%);
  min-height: 100vh;
}

/* Container */
.sim-calculator-section, .sim-results-section {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}
/* ====================================================================
   SECTION 1 : SIMULATEUR (LAYOUT SENTIONE)
   ==================================================================== */
.sim-calculator-section {
  padding-top: 50px;
}

.sim-calculator-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 200px !important;
  align-items: center;
}

/* ====================================================================
   COLONNE GAUCHE : Wrapper (NO BACKGROUND)
   ==================================================================== */
.sim-form-wrapper {
  max-width: 600px;
}

/* Badge discret */
.sim-form-wrapper .sim-hero-badge {
  display: inline-block;
  padding: 6px 14px;
  background: rgba(99, 102, 241, 0.1);
  border: 1px solid var(--sim-border);
  border-radius: 999px;
  color: var(--sim-accent);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  margin-bottom: 24px;
  margin-top: 0;
  opacity: 0.8;
}

/* Titre H1 intégré */
.sim-form-wrapper .sim-hero-title {
  font-size: clamp(36px, 4.5vw, 52px);
  font-weight: 800;
  color: var(--sim-text-primary);
  margin: 0 0 20px;
  line-height: 1.15;
  max-width: 500px;
}

/* Description */
.sim-form-wrapper .sim-hero-subtitle {
  font-size: 17px;
  color: var(--sim-text-secondary);
  max-width: 520px;
  margin: 0 0 48px;
  line-height: 1.65;
  opacity: 0.85;
}

/* Formulaire (NO CARD - texte direct sur fond) */
.sim-form {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

/* Supprimer complètement .sim-form-card */
/* (ou laisser vide si référencé ailleurs) */
.sim-form-card {
  /* VIDE - ne plus utiliser */
}

/* ====================================================================
   SECTION 1 : SIMULATEUR
   ==================================================================== */


.sim-calculator-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 200px;
  align-items: center;
}

/* Carte formulaire */
.sim-form-card {
  background: var(--sim-bg-card);
  border: 1px solid var(--sim-border);
  border-radius: var(--sim-radius);
  padding: 32px;
  box-shadow: var(--sim-shadow);
}

.sim-form {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.sim-field {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.sim-field-group {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 16px;
}

.sim-label {
  font-size: 14px;
  font-weight: 600;
  color: var(--sim-text-primary);
  display: block;
  margin-bottom: 2px;
}

.sim-input {
  width: 100%;
  padding: 14px 16px;
  background: rgba(255, 255, 255);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 12px;
  color: #20334f;
  font-size: 16px;
  transition: var(--sim-transition);
  outline: none;
	height: 70px;
}

.sim-input:focus {
  border-color: var(--sim-accent);
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15);
}

.sim-input::placeholder {
  color: var(--sim-text-muted);
}

/* Boutons pills (type de logement) */
.sim-button-group {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}

.sim-btn-pill {
  padding: 10px 16px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 10px;
  color: var(--sim-text-secondary);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: var(--sim-transition);
  text-align: center;
}

.sim-btn-pill:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.2);
}

.sim-btn-pill-active {
  background: var(--sim-accent);
  border-color: var(--sim-accent);
  color: white;
}

/* Slider */
.sim-slider-container {
  position: relative;
}

.sim-slider {
  width: 100%;
  background: rgba(255, 255, 255, 0.1);
	height: 6px !important;
  border-radius: 10px;
  outline: none;
  appearance: none;
  cursor: pointer;
	bottom: 30px;
    margin: auto;
    width: 95%;
    background: linear-gradient(to right, rgb(182, 174, 255) 0%, rgb(124, 109, 253) 46.8421%, rgba(255, 255, 255, 0.1) 46.8421%, rgba(255, 255, 255, 0.1) 100%);
}
.sim-slider + svg {
	bottom: 33px;
    margin: auto;
    width: 95%;
	position:relative;
	
}
/* ====================================================================
   BACKGROUND SVG EFFECTS (Style Sentione)
   ==================================================================== */

/* Wrapper pour tous les éléments de fond */
.sim-preview-card {
  position: relative;
}

.sim-background-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
}

/* Grid checkered background */
.sim-checkered-background {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 150%;
  height: 150%;
  opacity: 0.12;
}

/* Squares overlay */
.sim-squares {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0.25;
}

/* Oval glow effect */
.sim-oval {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 500px;
  height: 500px;
  background: radial-gradient(circle, rgba(124, 109, 253, 0.25) 0%, transparent 70%);
  border-radius: 50%;
  filter: blur(80px);
}

/* Vignette effect */
.sim-vignette {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: radial-gradient(
    ellipse at center, 
    transparent 0%, 
    transparent 40%, 
    rgba(10, 14, 39, 0.3) 70%,
    rgba(10, 14, 39, 0.5) 100%
  );
  pointer-events: none;
}

/* Left decorative lines */
.sim-left-lines {
  position: absolute;
  left: -30px;
  top: 15%;
  width: 216px;
  height: auto;
  opacity: 0.5;
}

/* Right decorative line */
.sim-right-line {
  position: absolute;
  right: -20px;
  top: 25%;
  width: 73px;
  height: auto;
  opacity: 0.5;
}

/* S'assurer que le contenu est au-dessus */
.sim-preview-header-section,
.sim-preview-result {
  position: relative;
  z-index: 1;
}
.sim-slider::-webkit-slider-thumb {
  appearance: none;
  width: 20px;
  height: 20px;
  background: var(--sim-accent);
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(99, 102, 241, 0.4);
  transition: var(--sim-transition);
}

.sim-slider::-webkit-slider-thumb:hover {
  transform: scale(1.1);
  box-shadow: 0 4px 12px rgba(99, 102, 241, 0.6);
}

.sim-slider::-moz-range-thumb {
  width: 20px;
  height: 20px;
  background: var(--sim-accent);
  border-radius: 50%;
  cursor: pointer;
  border: none;
  box-shadow: 0 2px 8px rgba(99, 102, 241, 0.4);
  transition: var(--sim-transition);
}

.sim-slider-value {
  margin-top: 12px;
  padding: 12px 18px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 10px;
  color: var(--sim-text-primary);
  font-size: 18px;
  font-weight: 700;
  text-align: center;
}

/* Boutons profil */
.sim-profile-group {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.sim-profile-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 16px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 12px;
  color: var(--sim-text-secondary);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: var(--sim-transition);
}

.sim-profile-icon {
  font-size: 28px;
}

.sim-profile-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.2);
  transform: translateY(-2px);
}

.sim-profile-btn-active {
  background: linear-gradient(135deg, var(--sim-accent), var(--sim-accent-hover));
  border-color: var(--sim-accent);
  color: white;
  box-shadow: 0 8px 20px rgba(99, 102, 241, 0.3);
}

/* ====================================================================
   CARTE PRÉVISUALISATION (DROITE)
   ==================================================================== */
.sim-preview-card {
  background: linear-gradient(135deg, #2d3561 0%, #1e2347 100%);
  border: 1px solid var(--sim-border);
  border-radius: var(--sim-radius);
  padding: 32px;
  box-shadow: var(--sim-shadow);
  position: sticky;
  top: 20px;
  position: relative;
}

.sim-preview-header {
  margin-bottom: 24px;
}

.sim-preview-subtitle {
  font-size: 14px;
  color: var(--sim-text-secondary);
  margin: 0 0 12px;
  font-weight: 600;
	z-index: 0;
}

/* Onglets objectifs */
.sim-objective-tabs {
  display: flex;
  gap: 8px;
  background: rgba(0, 0, 0, 0.2);
  padding: 6px;
  border-radius: 12px;
}
.sim-tab-indicator {
  position: absolute;
  bottom: -3px;
  left: 0;
  height: 6px;
  width: 52px; /* Largeur initiale (1/3 si 3 onglets) */
  background-image: linear-gradient(270deg, #7c6dfd, #b6aeff);
  border-radius: 12px;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 0 12px rgba(124, 109, 253, 0.6);
  pointer-events: none; /* Ne pas interférer avec les clics */
}
.sim-tab {
  flex: 1;
  padding: 10px 12px;
  background: transparent;
  border: none;
  border-radius: 8px;
  color: var(--sim-text-secondary);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: var(--sim-transition);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
}

.sim-tab-active {
  background: var(--sim-accent);
  color: white;
}

.sim-tab-info {
  opacity: 0.6;
  font-size: 11px;
}

/* Résultat preview */
.sim-preview-result {
  text-align: center;
  padding: 12px 0;
}

.sim-result-label {
  font-size: 14px;
  color: var(--sim-text-secondary);
  margin-bottom: 8px;
}

.sim-result-value {
  font-size: 48px;
  font-weight: 800;
  color: var(--sim-text-primary);
  line-height: 1;
  margin-bottom: 28px;
  letter-spacing: -0.02em;
}

.sim-result-currency {
  font-size: 24px;
  opacity: 0.6;
  font-weight: 400;
}

.sim-result-secondary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 12px;
  margin-bottom: 24px;
}

.sim-result-item {
  display: flex;
  align-items: center;
  gap: 8px;
}

.sim-result-icon {
  font-size: 20px;
}

.sim-result-text {
  font-size: 13px;
  color: var(--sim-text-secondary);
}

.sim-result-badge {
  font-size: 28px;
  font-weight: 700;
  color: var(--sim-text-primary);
}

/* Bouton CTA principal */
.sim-cta-button {
  	padding: 18px 24px;
    background: linear-gradient(135deg, var(--sim-accent), var(--sim-accent-hover));
    border: none;
    border-radius: 44px;
    color: white;
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
    transition: var(--sim-transition);
    box-shadow: 0 8px 20px rgba(99, 102, 241, 0.3);
    width: max-content;
}

.sim-cta-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(99, 102, 241, 0.4);
}

/* ====================================================================
   SECTION 2 : RÉSULTATS
   ==================================================================== */
.sim-results-section {
  margin-top: 80px;
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 32px;
  opacity: 0;
  animation: fadeInUp 0.6s ease forwards;
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.sim-results-card {
  background: var(--sim-bg-card);
  border: 1px solid var(--sim-border);
  border-radius: var(--sim-radius);
  padding: 32px;
  box-shadow: var(--sim-shadow);
}

.sim-results-title {
  font-size: 20px;
  font-weight: 700;
  color: var(--sim-text-primary);
  margin: 0 0 24px;
}

/* Graphique */
.sim-results-chart-card {
  position: relative;
}

.sim-chart-wrapper {
  height: 380px;
  position: relative;
}

/* Teaser Mode Expert */
.sim-expert-teaser {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 200px;
  background: linear-gradient(to top, var(--sim-bg-card), transparent);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 32px;
}

.sim-teaser-content {
  background: rgba(99, 102, 241, 0.1);
  border: 2px solid var(--sim-accent);
  border-radius: 16px;
  padding: 24px;
  text-align: center;
  max-width: 500px;
  backdrop-filter: blur(10px);
}

.sim-teaser-icon {
  font-size: 32px;
  margin-bottom: 12px;
}

.sim-teaser-title {
  font-size: 18px;
  font-weight: 700;
  color: var(--sim-text-primary);
  margin: 0 0 8px;
}

.sim-teaser-text {
  font-size: 14px;
  color: var(--sim-text-secondary);
  margin: 0 0 16px;
  line-height: 1.5;
}

.sim-teaser-btn {
  padding: 12px 24px;
  background: var(--sim-accent);
  border: none;
  border-radius: 10px;
  color: white;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: var(--sim-transition);
}

.sim-teaser-btn:hover {
  background: var(--sim-accent-hover);
  transform: translateY(-2px);
}

.sim-teaser-note {
  font-size: 12px;
  color: var(--sim-text-muted);
  margin: 12px 0 0;
}

/* Métriques */
.sim-metrics-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.sim-metric {
  padding: 20px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  transition: var(--sim-transition);
}

.sim-metric:hover {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(255, 255, 255, 0.15);
  transform: translateY(-2px);
}

.sim-metric-label {
  font-size: 13px;
  color: var(--sim-text-secondary);
  margin-bottom: 8px;
}

.sim-metric-value {
  font-size: 28px;
  font-weight: 700;
  color: var(--sim-text-primary);
}

/* ====================================================================
   SECTION 3 : COMMENT ÇA MARCHE
   ==================================================================== */
.sim-info-section {
  margin-top: 80px;
}

.sim-info-card {
  background: var(--sim-bg-card);
  border: 1px solid var(--sim-border);
  border-radius: var(--sim-radius);
  padding: 40px;
  box-shadow: var(--sim-shadow);
}

.sim-info-title {
  font-size: 28px;
  font-weight: 700;
  color: var(--sim-text-primary);
  margin: 0 0 32px;
  border-left: 4px solid var(--sim-accent);
  padding-left: 16px;
}

.sim-info-subtitle {
  font-size: 20px;
  font-weight: 600;
  color: var(--sim-text-primary);
  margin: 40px 0 24px;
}

/* Features grid */
.sim-features-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 40px;
}

.sim-feature {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  transition: var(--sim-transition);
}

.sim-feature:hover {
  background: rgba(255, 255, 255, 0.05);
  transform: translateX(4px);
}

.sim-feature-icon {
  font-size: 24px;
  flex-shrink: 0;
}

.sim-feature-text {
  font-size: 14px;
  color: var(--sim-text-secondary);
  line-height: 1.4;
}

/* Tableau comparatif */
.sim-comparison-table {
  overflow: hidden;
  border-radius: 12px;
  border: 1px solid var(--sim-border);
}

.sim-table-header {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  background: rgba(99, 102, 241, 0.1);
  border-bottom: 1px solid var(--sim-border);
}

.sim-table-header .sim-table-cell {
  font-weight: 700;
  color: var(--sim-text-primary);
}

.sim-table-row {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  transition: var(--sim-transition);
}

.sim-table-row:hover {
  background: rgba(255, 255, 255, 0.03);
}

.sim-table-row:last-child {
  border-bottom: none;
}

.sim-table-cell {
  padding: 16px 20px;
  font-size: 14px;
  color: var(--sim-text-secondary);
  display: flex;
  align-items: center;
  gap: 8px;
}

.sim-table-expert {
  color: var(--sim-accent);
  font-weight: 600;
}

.sim-table-icon {
  font-size: 16px;
}

/* ====================================================================
   SECTION UNLOCK
   ==================================================================== */
.sim-unlock-section {
  margin-top: 60px;
}

.sim-unlock-card {
  background: var(--sim-bg-card);
  border: 1px solid var(--sim-border);
  border-radius: var(--sim-radius);
  padding: 40px;
  box-shadow: var(--sim-shadow);
  text-align: center;
}

.sim-unlock-title {
  font-size: 24px;
  font-weight: 700;
  color: var(--sim-text-primary);
  margin: 0 0 24px;
}

.sim-unlock-input-wrapper {
  display: flex;
  gap: 12px;
  max-width: 400px;
  margin: 0 auto 16px;
}

.sim-unlock-input {
  flex: 1;
  padding: 14px 20px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 12px;
  color: var(--sim-text-primary);
  font-size: 18px;
  font-weight: 600;
  text-align: center;
  letter-spacing: 2px;
  text-transform: uppercase;
  outline: none;
  transition: var(--sim-transition);
}

.sim-unlock-input:focus {
  border-color: var(--sim-accent);
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1);
}

.sim-unlock-btn {
  padding: 14px 32px;
  background: var(--sim-accent);
  border: none;
  border-radius: 12px;
  color: white;
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
  transition: var(--sim-transition);
}

.sim-unlock-btn:hover {
  background: var(--sim-accent-hover);
  transform: translateY(-2px);
}

.sim-unlock-badge {
  padding: 12px 24px;
  background: rgba(34, 197, 94, 0.1);
  border: 1px solid rgba(34, 197, 94, 0.3);
  border-radius: 10px;
  color: #22c55e;
  font-size: 14px;
  font-weight: 600;
  display: inline-block;
}

/* ====================================================================
   TÉMOIGNAGES
   ==================================================================== */
.sim-testimonials-section {
  margin-top: 80px;
}

.sim-section-title {
  font-size: 28px;
  font-weight: 700;
  color: var(--sim-text-primary);
  text-align: center;
  margin: 0 0 40px;
}

.sim-testimonials-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}

.sim-testimonial-card {
  background: var(--sim-bg-card);
  border: 1px solid var(--sim-border);
  border-radius: var(--sim-radius);
  padding: 28px;
  box-shadow: var(--sim-shadow);
  transition: var(--sim-transition);
}

.sim-testimonial-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 72px rgba(0, 0, 0, 0.5);
}

.sim-testimonial-stars {
  color: #fbbf24;
  font-size: 18px;
  margin-bottom: 16px;
}

.sim-testimonial-quote {
  font-size: 16px;
  color: var(--sim-text-secondary);
  line-height: 1.6;
  margin: 0 0 20px;
  font-style: italic;
}

.sim-testimonial-author {
  font-size: 14px;
  color: var(--sim-text-primary);
  font-weight: 600;
  margin-bottom: 8px;
}

.sim-testimonial-result {
  display: inline-block;
  padding: 6px 12px;
  background: rgba(34, 197, 94, 0.1);
  border: 1px solid rgba(34, 197, 94, 0.3);
  border-radius: 8px;
  color: #22c55e;
  font-size: 13px;
  font-weight: 700;
}

/* ====================================================================
   FAQ
   ==================================================================== */
.sim-faq-section {
  margin-top: 60px;
}

.sim-faq-list {
  max-width: 800px;
  margin: 0 auto;
}

.sim-faq-item {
  background: var(--sim-bg-card);
  border: 1px solid var(--sim-border);
  border-radius: 12px;
  margin-bottom: 16px;
  overflow: hidden;
  transition: var(--sim-transition);
}

.sim-faq-item:hover {
  border-color: var(--sim-accent);
}

.sim-faq-question {
  width: 100%;
  padding: 20px 24px;
  background: transparent;
  border: none;
  color: var(--sim-text-primary);
  font-size: 16px;
  font-weight: 600;
  text-align: left;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: var(--sim-transition);
}

.sim-faq-question:hover {
  color: var(--sim-accent);
}

.sim-faq-icon {
  font-size: 24px;
  transition: transform 0.3s ease;
}

.sim-faq-item.open .sim-faq-icon {
  transform: rotate(45deg);
}

.sim-faq-answer {
  padding: 0 24px;
  max-height: 0;
  overflow: hidden;
  color: var(--sim-text-secondary);
  font-size: 14px;
  line-height: 1.6;
  transition: all 0.3s ease;
}

.sim-faq-item.open .sim-faq-answer {
  padding: 0 24px 20px;
  max-height: 500px;
}

/* ====================================================================
   CTA FINAL
   ==================================================================== */
.sim-cta-final-section {
  margin-top: 80px;
}

.sim-cta-final-card {
  background: linear-gradient(135deg, var(--sim-accent), var(--sim-accent-hover));
  border-radius: var(--sim-radius);
  padding: 60px 40px;
  text-align: center;
  box-shadow: 0 24px 72px rgba(99, 102, 241, 0.3);
}

.sim-cta-final-title {
  font-size: 32px;
  font-weight: 800;
  color: white;
  margin: 0 0 32px;
}

.sim-cta-final-buttons {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}

.sim-btn-primary,
.sim-btn-secondary {
  padding: 16px 32px;
  border-radius: 12px;
  font-size: 16px;
  font-weight: 700;
  text-decoration: none;
  transition: var(--sim-transition);
  display: inline-block;
}

.sim-btn-primary {
  background: white;
  color: var(--sim-accent);
  border: 2px solid white;
}

.sim-btn-primary:hover {
  background: transparent;
  color: white;
  transform: translateY(-2px);
}

.sim-btn-secondary {
  background: transparent;
  color: white;
  border: 2px solid white;
}

.sim-btn-secondary:hover {
  background: white;
  color: var(--sim-accent);
  transform: translateY(-2px);
}

/* ====================================================================
   RESPONSIVE
   ==================================================================== */
@media (max-width: 1024px) {
  .sim-calculator-grid {
    grid-template-columns: 1fr;
	gap: 60px;
    padding-top: 60px;
  }
  .sim-form-wrapper {
    text-align: center; /* centrer sur mobile */
    max-width: 100%;
  }
  .sim-preview-card {
    position: relative;
    top: 0;
  }
  
  .sim-results-section {
    grid-template-columns: 1fr;
  }
  
  .sim-features-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .sim-hero {
    padding: 40px 0 30px;
  }
  
  .sim-button-group {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .sim-profile-group {
    grid-template-columns: 1fr;
  }
  
  .sim-field-group {
    grid-template-columns: 1fr;
  }
  
  .sim-objective-tabs {
    flex-direction: column;
  }
  
  .sim-result-value {
    font-size: 36px;
  }
  
  .sim-metrics-grid {
    grid-template-columns: 1fr;
  }
  
  .sim-table-header,
  .sim-table-row {
    grid-template-columns: 1.5fr 1fr 1fr;
  }
  
  .sim-table-cell {
    padding: 12px;
    font-size: 12px;
  }
  
  .sim-testimonials-grid {
    grid-template-columns: 1fr;
  }
  
  .sim-cta-final-buttons {
    flex-direction: column;
  }
  
  .sim-unlock-input-wrapper {
    flex-direction: column;
  }
}
/* ====================================================================
   INPUT TEXT + RANGE SYNCHRONISÉS (Style Sentione)
   ==================================================================== */

/* Input text pour les sliders */
.sim-input-range-text {
  width: 100%;
  padding: 14px 18px;
  background: rgba(255, 255, 255);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 12px;
  color: #34354b;
  font-size: 24px;
  font-weight: 600;
  transition: var(--sim-transition);
  outline: none;
  margin-bottom: 12px;
	height: 70px;
}

.sim-input-range-text:focus {
      border: 2px solid #7c6dfd;
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15);
}

.sim-input-range-text:hover {
  color: #7c6dfd;
}

/* Message d'erreur */
.sim-input-error {
  color: #ef4444;
  font-size: 12px;
  margin-top: -8px;
  margin-bottom: 8px;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.sim-input-error.show {
  opacity: 1;
}

/* Slider amélioré */
.sim-slider {
  width: 100%;
  height: 8px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 5px;
  outline: none;
  appearance: none;
  cursor: pointer;
  margin-bottom: 8px;
  position: relative;
  transition: var(--sim-transition);
}
@media (min-width: 1024px) {
  .concon {
    max-width: 504px;
	  width:504px;
    margin: 0 auto; /* facultatif, pour centrer le bloc */
  }
}


.sim-slider::-webkit-slider-thumb {
  appearance: none;
  width: 25px;
  height: 25px;
	border-radius:5px;
  background: 
    radial-gradient(circle at center, white 0%, white 25%, transparent 25%),
    linear-gradient(135deg, #b6aeff, #7c6dfd);
  cursor: grab;
  transform: rotate(45deg);
  box-shadow: 0 3px 12px rgba(124, 109, 253, 0.5);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.sim-slider::-webkit-slider-thumb:hover {
  transform: rotate(0deg) scale(1.1);
	width:40px;
  border-radius: 4px;
  background: linear-gradient(135deg, #b6aeff, #7c6dfd);
  box-shadow: 0 4px 16px rgba(124, 109, 253, 0.7);
}

.sim-slider::-webkit-slider-thumb:active {
  cursor: grabbing;
  transform: rotate(0deg) scale(1);
  box-shadow: 0 2px 8px rgba(124, 109, 253, 0.6);
}

/* Pour Firefox */
.sim-slider::-moz-range-thumb {
  width: 25px;
  height: 25px;
  background: 
    radial-gradient(circle at center, white 0%, white 25%, transparent 25%),
    linear-gradient(135deg, #b6aeff, #7c6dfd);
  border: none;
  border-radius: 5px;
  cursor: grab;
  transform: rotate(45deg);
  box-shadow: 0 3px 12px rgba(124, 109, 253, 0.5);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.sim-slider::-moz-range-thumb:hover {
  transform: rotate(0deg) scale(1.1);
	width:40px;
  border-radius: 4px;
  background: linear-gradient(135deg, #b6aeff, #7c6dfd);
  box-shadow: 0 4px 16px rgba(124, 109, 253, 0.7);
}

.sim-slider::-moz-range-thumb:active {
  cursor: grabbing;
  transform: rotate(0deg) scale(1);
  box-shadow: 0 2px 8px rgba(124, 109, 253, 0.6);
}
/* SVG Scale sous le slider */
.sim-slider-scale {
  width: 100%;
  height: 13px;
  opacity: 0.45;
  margin-top: 4px;
  pointer-events: none;
}

/* Supprimer l'ancien .sim-slider-value */
.sim-slider-value {
  display: none;
}

/* ====================================================================
   TYPE DE LOGEMENT (Nouveau style)
   ==================================================================== */

.sim-button-group {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  padding: 8px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 14px;
}

.sim-btn-pill {
  padding: 14px 20px;
  background: transparent;
  border: none;
  border-radius: 10px;
  color: var(--sim-text-secondary);
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  transition: var(--sim-transition);
  text-align: center;
}

.sim-btn-pill:hover {
  color: var(--sim-text-primary);
  background: rgba(255, 255, 255, 0.05);
}

.sim-btn-pill-active {
  background: linear-gradient(135deg, #b6aeff 0%, #7c6dfd 100%) !important;
  color: white !important;
  box-shadow: 0 4px 12px rgba(124, 109, 253, 0.3);
}

/* ====================================================================
   PREVIEW CARD - BLOCS SÉPARÉS
   ==================================================================== */

.sim-preview-card {
  background: linear-gradient(135deg, #2d3561 0%, #1e2347 100%);
  border: 1px solid var(--sim-border);
  border-radius: var(--sim-radius);
  padding: 0; /* Enlever le padding global */
  box-shadow: var(--sim-shadow);
  position: sticky;
  top: 20px;
}

/* BLOC 1 : Header + Objectifs */
.sim-preview-header-section {
  padding: 28px 32px;
  background: rgba(0, 0, 0, 0.15);
}

.sim-preview-subtitle {
  font-size: 14px;
  color: var(--sim-text-secondary);
  margin: 0 0 16px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.sim-objective-tabs {
  display: flex;
  gap: 8px;
  background: rgba(0, 0, 0, 0.2);
  padding: 6px;
  border-radius: 12px;
}

/* Séparateur */
.sim-preview-divider {
  height: 1px;
  background: rgba(255, 255, 255, 0.08);
}

/* BLOC 2 : Résultats */
.sim-preview-result {
  padding: 12px;
  text-align: center;
}

.sim-result-label {
  font-size: 14px;
  color: #D1CFDD;
  margin-bottom: 12px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.sim-result-value {
  font-size: 52px;
  font-weight: 800;
  color: var(--sim-text-primary);
  line-height: 1;
  margin-bottom: 84px;
  letter-spacing: -0.02em;
}

.sim-result-currency {
  font-size: 33px;
  opacity: 0.6;
  font-weight: 400;
}

.sim-result-secondary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 20px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  margin-bottom: 28px;
}

.sim-result-item {
  display: flex;
  align-items: center;
  gap: 10px;
}

.sim-result-icon {
  font-size: 22px;
}

.sim-result-text {
  font-size: 13px;
  color: var(--sim-text-secondary);
  text-align: left;
}

.sim-result-badge {
  font-size: 32px;
  font-weight: 700;
  color: var(--sim-text-primary);
}

.sim-cta-button {
  padding: 18px 24px;
  background: linear-gradient(135deg, var(--sim-accent), var(--sim-accent-hover));
  border: none;
  color: white;
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
  transition: var(--sim-transition);
  box-shadow: 0 8px 20px rgba(99, 102, 241, 0.3);
}

.sim-cta-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(99, 102, 241, 0.4);
}



/* Onglets objectifs - Style Sentione */
.sim-objective-tabs {
  display: flex;
  gap: 0;
  background: transparent;
  padding: 0;
  border-radius: 0;
}

.sim-tab {
  flex: 1;
  padding: 16px 20px;
  background: transparent;
  border: none;
  border-radius: 0;
  color: var(--sim-text-secondary);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  position: relative;
}
.hf {
	height:611px;
	padding: 104px 20px;
}


.sim-tab-active {
  background: #090F31;
background: linear-gradient(90deg,rgba(9, 15, 49, 1) 0%, rgba(21, 14, 78, 1) 50%, rgba(9, 15, 49, 1) 100%);border-radius: 12px;
  color: white;
  font-weight: 700;
}

.sim-tab-info {
  opacity: 0.7;
  font-size: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.1);
  transition: all 0.3s ease;
}



/* Tooltip au survol */
.sim-tab::before {
  content: attr(data-tooltip);
  position: absolute;
  bottom: calc(100% + 12px);
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  background: rgba(20, 23, 50);
  color: white;
  padding: 10px 16px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 500;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
  z-index: 100;
  border: 1px solid rgba(124, 109, 253, 0.3);
}

.sim-tab::after {
  content: '';
  position: absolute;
  bottom: calc(100% + 4px);
  left: 50%;
  transform: translateX(-50%) translateY(4px);
  width: 0;
  height: 0;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-top: 6px solid rgba(20, 23, 50, 0.98);
  opacity: 0;
  pointer-events: none;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 100;
}

.sim-tab:hover::before,
.sim-tab:hover::after {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* ====================================================================
   SECTION : COMMENT ÇA MARCHE (fond blanc, texte centré, bord arrondi)
   ==================================================================== */

.sim-how-section {
  background: #ffffff;
  border-top-left-radius: 100px;
  border-top-right-radius: 100px;
  padding: 80px 20px;
  text-align: center;
  color: #000000;
  margin-top: 120px;
  box-shadow: 0 -6px 40px rgba(0, 0, 0, 0.05);
}

.sim-how-container {
  max-width: 1000px;
  margin: 0 auto;
}

.sim-how-title {
  font-size: clamp(28px, 4vw, 42px);
  font-weight: 800;
  margin-bottom: 40px;
  color: #000000;
}

.sim-how-steps {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 40px;
  margin-top: 60px;
}

.sim-how-step {
  background: #f9fafb;
  border: 1px solid #e5e7eb;
  border-radius: 20px;
  padding: 32px 24px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.03);
  transition: all 0.3s ease;
}
input[type="range"] {
  position: relative;
  bottom: 30px;
  margin: auto;
  width: 95%;
  background: linear-gradient(
    to right,
    rgb(182, 174, 255) 0%,
    rgb(124, 109, 253) 46.8421%,
    rgba(255, 255, 255, 0.1) 46.8421%,
    rgba(255, 255, 255, 0.1) 100%
  );
  height: 6px;
  border-radius: 10px;
  outline: none;
  appearance: none;
}
.sim-how-step:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.08);
}

.sim-how-icon {
  width: 60px;
  height: 60px;
  background: linear-gradient(135deg, #7c6dfd, #b6aeff);
  border-radius: 50%;
  margin: 0 auto 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-size: 26px;
  font-weight: bold;
  box-shadow: 0 6px 16px rgba(124, 109, 253, 0.3);
}

.sim-how-step h3 {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 12px;
  color: #000000;
}

.sim-how-step p {
  font-size: 15px;
  line-height: 1.6;
  color: #374151;
  opacity: 0.85;
}
.spef {
	padding: 16px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 12px;
	grid-column: 1 / -1;
}
/* Wrapper pour input + préfixe */
.sim-input-wrapper {
  position: relative;
}

/* Préfixe m² fixe */
.sim-input-prefix {
  position: absolute;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  color: #A3B3C9;
  font-size: 24px;
  font-weight: 600;
  pointer-events: none;
  z-index: 1;
}

/* Modifier le padding de l'input pour laisser la place au préfixe */
.sim-input-range-text {
  padding-left: 58px; /* Ajuster selon la largeur de "m²" */
}
.sim-input-prefix {
  position: absolute;
  left: 18px;
  top: 43%;
  transform: translateY(-50%);
  color: #A3B3C9;
  font-size: 24px;
  font-weight: 600;
  pointer-events: none;
  z-index: 1;
  opacity: 0.8;
  letter-spacing: -0.5px;
}

/* État invalide : halo #EC6E8D */
.sim-input.is-invalid {
  border-color: #EC6E8D !important;
  box-shadow: 0 0 0 3px rgba(236, 110, 141, 0.25);
}

/* Le conteneur du champ doit être positionné (si ce n'est pas déjà le cas) */
.sim-field { position: relative; }

/* Champ invalide : bordure/halo rouge */
#location[aria-invalid="true"] {
  border-color: #EC6E8D !important;
  box-shadow: 0 0 0 4px rgba(236,110,141,0.18) !important;
}

/* états de visibilité */
#loc-tip[hidden] { display: none !important; }

/* Bordure/halo du champ invalide */
#location[aria-invalid="true"] {
  box-shadow: 0 0 0 2px rgba(236,110,141,.35) inset, 0 0 0 3px rgba(236,110,141,.45);
  border-color: #EC6E8D;
}

/* Le conteneur du champ permet à la bulle de déborder proprement */
.sim-field {
  position: relative;
  overflow: visible;
}

/* Champ invalide : bordure/halo */
#location[aria-invalid="true"] {
  border-color: #EC6E8D !important;
  box-shadow:
    0 0 0 3px rgba(236,110,141,0.35),
    0 0 0 1px #EC6E8D inset;
}

/* Bulle centrée AU-DESSUS du champ */
.sim-tip {
  position: absolute;
  left: 70%;
  top: -16px; /* ajuste +/- 4–8px selon la hauteur du champ */
  transform: translateX(-50%) translateY(-6px);
  background: #EC6E8D;           /* fond plein rouge */
  color: #fff;
  padding: 10px 14px;
  border-radius: 12px;
  font-size: 14px;
  line-height: 1.2;
  white-space: nowrap;
  z-index: 5;

  opacity: 0;
  pointer-events: none;
  transition: opacity .18s ease, transform .18s ease;

  box-shadow: 0 10px 25px rgba(236,110,141,.35); /* halo élégant */
}

/* Flèche qui pointe vers le CHAMP */
.sim-tip::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -8px;
  transform: translateX(-50%);
  border-width: 8px 9px 0 9px;      /* triangle vers le bas */
  border-style: solid;
  border-color: #EC6E8D transparent transparent transparent;
}

/* État visible (géré en JS: .classList.add('show')) */
.sim-tip.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* Accessibilité: caché = retiré du flux */
#loc-tip[hidden] { display: none !important; }

/* Petits écrans: évite la sortie d’écran */
@media (max-width: 480px) {
  .sim-tip {
    top: -52px;
    max-width: calc(100vw - 32px);
    white-space: normal;
    text-align: center;
    padding: 10px 12px;
  }
}

/* légende juste sous le KPI */
.sim-result-caption {
  margin-top: 6px;             /* réduit l’espace sous la valeur */
  margin-bottom: 36px;         /* petit écart avant le bouton */
  font-size: 13px;
  line-height: 1.4;
  text-align: center;
  color: #cbd5ff;              /* bleu doux du thème */
  opacity: 0.95;
  max-width: 90%;
  margin-left: auto;
  margin-right: auto;
  transition: opacity 0.25s ease, transform 0.25s ease;
}

.sim-result-caption[hidden] {
  opacity: 0;
  transform: translateY(-4px);
  pointer-events: none;
}

/* conteneur du bloc résultats */
.sim-preview-result{
  display: flex;
  flex-direction: column;
  height: 100%;
}

/* le bouton reste toujours en bas du bloc */
.sim-preview-result .sim-cta-button{
  margin-top: auto;          /* pousse vers le bas */
  align-self: center;        /* centré horizontalement */
}

/* ====== Carte graphique (détaillée) ====== */
.sim-results-card.sim-results-chart-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 16px;
  padding: 20px 20px 16px;
  backdrop-filter: blur(4px);
}

/* Titre */
.sim-results-card.sim-results-chart-card .sim-results-title {
  font-size: 18px;
  font-weight: 600;
  margin: 0 0 8px;
}

/* Légende au-dessus du canvas */
.sim-chart-legend {
  display: flex;
  gap: 16px;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 8px;
}

.sim-chart-legend .lg {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  opacity: 0.9;
}

.sim-chart-legend .lg::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 50%;
  display: inline-block;
}

/* Couleurs de courbes (harmonisées avec le thème sombre/violet) */
.lg-gross::before      { background: #7aa8ff; box-shadow: 0 0 10px rgba(122,168,255,.6); }
.lg-costs::before      { background: #ff7a7a; box-shadow: 0 0 10px rgba(255,122,122,.45); }
.lg-breakeven::before  { background: #9b9b9b; }

/* Wrapper du canvas + halo */
.sim-chart-wrapper {
  position: relative;
  border-radius: 12px;
  overflow: hidden;
  background: radial-gradient(120% 120% at 50% 0%, rgba(124, 147, 255, 0.08) 0%, rgba(124, 147, 255, 0.02) 40%, transparent 70%);
  padding: 6px;
}

.sim-chart-wrapper::after {
  /* léger halo bleu global derrière la courbe principale */
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(60% 50% at 50% 40%, rgba(124,147,255,0.10) 0%, rgba(124,147,255,0.00) 70%);
  filter: blur(12px);
}

/* Canvas */
#detail-chart {
  width: 100%;
  height: 320px;
  display: block;
}

/* Caption */
.sim-caption {
  margin: 10px 2px 0;
  font-size: 13px;
  line-height: 1.4;
  opacity: 0.85;
}

/* ====== CTA Neatik AI (teaser) ====== */
.sim-expert-cta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  margin-top: 16px;
  padding: 14px 16px;
  border: 1px dashed rgba(255,255,255,0.12);
  border-radius: 12px;
  background: rgba(124,147,255,0.06);
}

.sim-expert-cta__content h4 {
  margin: 0 0 4px;
  font-size: 16px;
  font-weight: 600;
}

.sim-expert-cta__content p {
  margin: 0;
  font-size: 13px;
  opacity: 0.9;
}

.sim-btn.sim-btn--primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  border-radius: 10px;
  font-weight: 600;
  background: linear-gradient(180deg, #7a87ff 0%, #5562ff 100%);
  color: #fff;
  box-shadow: 0 6px 18px rgba(85,98,255,.35);
  transition: transform .12s ease, box-shadow .12s ease, opacity .12s ease;
  text-decoration: none;
  white-space: nowrap;
}
.sim-btn.sim-btn--primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 22px rgba(85,98,255,.42);
  opacity: .96;
}

/* ====== States utiles pour les métriques ====== */
.sim-metric-value.is-negative {
  color: #ff8f8f; /* charges visuellement identifiées */
}

/* (optionnel) badges unitaires pour les valeurs si besoin */
.sim-metric-value[data-unit="euro"]::after   { content:" €"; }
.sim-metric-value[data-unit="percent"]::after{ content:" %"; }
.sim-metric-value[data-unit="years"]::after  { content:" ans"; }

/* ——— SECTION DÉTAILLÉE : conteneur ——— */
#results-section {
  /* tu l’avais déjà en grid ; on verrouille la largeur de la carte métriques */
  display: grid;
  grid-template-columns: 1fr 340px; /* 340px = largeur visuelle du bloc métriques */
  gap: 24px;
}

/* ——— Carte graphique ——— */
.sim-results-card.sim-results-chart-card {
  position: relative;
  border-radius: 24px;
  overflow: hidden;              /* IMPORTANT: recouple les coins du bas */
  background: rgba(255,255,255,0.02);
  box-shadow: 0 0 0 1px rgba(255,255,255,0.06) inset;
}

/* Bandeau légende en haut-gauche (évite le "texte fantôme") */
.sim-chart-legend {
  position: absolute;
  top: 12px;
  left: 16px;
  display: flex;
  gap: 16px;
  font-size: 12px;
  opacity: .65;                  /* discret mais lisible */
  pointer-events: none;
}

/* Le canvas doit aussi clipper */
.sim-chart-wrapper {
  position: relative;
  padding: 0;                    /* s’assure qu’on colle bien aux bords */
  border-radius: inherit;
  overflow: hidden;
  min-height: 320px;             /* garde une hauteur sympa même à blanc */
}

/* Caption sous le canvas : marge et lisibilité */
#detail-caption.sim-caption {
  margin: 12px 16px 0 16px;
  opacity: .7;
  font-size: 13px;
}

/* ——— Teaser “Mode Expert” collé au bas de la carte ——— */
#expert-teaser.sim-expert-teaser {
  position: absolute;
  left: 16px;
  right: 16px;
  bottom: 16px;
  border-radius: 16px;
  background: linear-gradient(to top, rgba(0,120,255,.10), rgba(0,120,255,.04));
  border: 1px solid rgba(100,150,255,.25);
  backdrop-filter: blur(2px);
}

/* ——— Carte métriques ——— */
.sim-results-card {               /* celle qui entoure TON grid de métriques */
  border-radius: 24px;
  background: rgba(255,255,255,0.02);
  box-shadow: 0 0 0 1px rgba(255,255,255,0.06) inset;
  padding: 18px 18px 14px;
}

.sim-results-card .sim-results-title {
  margin: 2px 0 14px;
}

.sim-metrics-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;        /* 2 colonnes fixes */
  gap: 14px;
}

.sim-metric {
  min-height: 102px;
  border-radius: 18px;
  background: rgba(255,255,255,0.03);
  box-shadow: 0 0 0 1px rgba(255,255,255,0.06) inset;
  padding: 14px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.sim-metric-label {
  font-size: 12px;
  line-height: 1.25;
  opacity: .75;
  min-height: 2.4em;       /* évite que le label passe sur 3 lignes et pousse le chiffre */
}

.sim-metric-value {
  font-size: 26px;
  font-weight: 800;
  line-height: 1.1;
  letter-spacing: .2px;
  white-space: nowrap;      /* garde la valeur sur une seule ligne */
}

/* Variante “cashflow” avec €/ligne dessous comme tu l’as visuellement : */
#metric-cashflow {
  display: flex;
  flex-direction: column;
}

/* Petite sécurité responsive (si la colonne métriques passe sous le chart) */
@media (max-width: 1100px) {
  #results-section {
    grid-template-columns: 1fr;
  }
}

/* ===== 1) Métriques clés : remplir la colonne sans vide ===== */
.sim-results-card {                 /* la carte "Métriques clés" elle-même */
  display: flex;
  flex-direction: column;
  height: 100%;
}

.sim-results-card .sim-metrics-grid {
  flex: 1;                          /* prend toute la hauteur sous le titre */
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-auto-rows: 1fr;              /* chaque case a la même hauteur */
  gap: 18px;
}

.sim-metric {
  display: flex;
  flex-direction: column;
  justify-content: space-between;   /* titre en haut, valeur en bas */
  padding: 22px 24px;
  border-radius: 16px;
  background: rgba(255,255,255,0.03);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.06);
}

.sim-metric-label { opacity: .78; line-height: 1.2; }
.sim-metric-value { font-size: 34px; font-weight: 800; line-height: 1; }

/* (Option utile si la colonne entière est contenue dans un parent flex) */
.sim-results-section { align-items: stretch; }   /* au cas où le parent était en grid/flex */

/* ===== 2) Légende du graphe : sous le titre, plus d’overlap ===== */
.sim-results-chart-card { position: relative; }

.sim-results-title {
  position: relative;
  z-index: 2;
  margin: 0 0 18px 0;               /* un peu d’air sous le titre */
}

/* repasser la légende en flux normal + marge sous le titre */
.sim-chart-legend {
  position: relative;               /* (plus de position:absolute) */
  display: flex;
  gap: 22px;
  margin: 4px 0 12px 0;             /* espace au-dessus du canvas */
  opacity: .9;
}

/* pastilles de la légende (si pas déjà stylées) */
.sim-chart-legend span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
}

/* Lisibilité et espacement de la légende */
.sim-chart-legend span::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 999px;
  display: inline-block;
  margin-right: 8px;              /* petit espace entre la pastille et le texte */
  vertical-align: middle;
}

.sim-chart-legend span {
  color: rgba(255,255,255,.92);   /* texte clair */
  font-weight: 700;
  text-shadow: 0 1px 6px rgba(0,0,0,.35); /* halo discret */
  opacity: 1;
}

.sim-chart-legend .lg-gross::before      { background:#6CA8FF; box-shadow:0 0 10px rgba(108,168,255,.6); }
.sim-chart-legend .lg-costs::before      { background:#FF7575; box-shadow:0 0 10px rgba(255,117,117,.5); }
.sim-chart-legend .lg-breakeven::before  { background:#C9D1FF; box-shadow:0 0 10px rgba(201,209,255,.45); }

/* Chaque card devient un “container” pour pouvoir auto-scaler le texte */
.sim-metric{
  container-type: inline-size;   /* Chrome/Edge/Safari récents */
}

/* Taille qui s’adapte à la largeur de la card, avec bornes min/max */
.sim-metric-value{
  /* fallback si container queries absentes */
  font-size: clamp(28px, 2.2vw, 34px);
  line-height: 1.05;
  white-space: nowrap;           /* la valeur tient sur une ligne */
}

/* Si container queries dispo, on affine (prend la main sur la règle ci-dessus) */
@container (min-width: 0){
  .sim-metric-value{
    font-size: clamp(26px, 7cqw, 34px);  /*  cqw = % de la largeur de la card  */
  }
}

.sim-chart-caption{
  margin-top: 8px;
  font-size: 14px;
  line-height: 1.4;
  color: rgba(255,255,255,.75);
}

/* ===== CTA container ===== */
#neatik-cta {
  position: relative;
  padding: 56px 0 80px;
}

.cta-wrap {
  display: grid;
  place-items: center;
}

.cta-card {
  width: min(1180px, 92vw);
  background: radial-gradient(120% 160% at 20% 0%, rgba(120,95,255,.18) 0%, rgba(18,23,52,.85) 45%, rgba(12,16,40,.95) 100%);
  border-radius: 28px;
  padding: clamp(28px, 4vw, 48px);
  position: relative;
  box-shadow: 0 20px 60px rgba(0,0,0,.35), inset 0 0 0 1px rgba(148,163,255,.15);
}

/* liseré externe doux */
.cta-card::before {
  content: "";
  position: absolute; inset: 0;
  border-radius: 28px;
  padding: 2px;
  background: linear-gradient(90deg, #b9a9ff, #7d6cff, #b9a9ff);
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  animation: hue 8s linear infinite;
  opacity: .55;
}

@keyframes hue { to { filter: hue-rotate(360deg); } }

.cta-content { text-align: left; }

.cta-title{
  font-size: clamp(28px, 4.2vw, 44px);
  line-height: 1.15;
  font-weight: 700;
  color: #e9eaff;
  letter-spacing: .2px;
  margin: 4px 0 12px;
}

.cta-sub{
  max-width: 920px;
  color: #c7ccff;
  font-size: clamp(16px, 1.9vw, 20px);
  line-height: 1.55;
  margin: 0 0 28px;
  opacity: .92;
}



/* ===== Bouton avec doubles anneaux tournants ===== */

.cta-wrap{ position: relative; display:inline-block; }

/* le SVG animé autour du bouton */
.cta-orbit{
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width:  calc(100% + 44px);     /* espace autour du bouton */
  height: calc(100% + 44px);
  pointer-events: none;
  z-index: 0;
  filter: drop-shadow(0 0 8px rgba(167,139,250,.35));
}

/* ajuste le SVG à la taille du conteneur */
.cta-orbit svg{ width:100%; height:100%; display:block; }

/* bouton principal */
.cta-btn{
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .6rem;
  padding: 18px 28px;
  border-radius: 48px;
  background: #7c6cff;
  color: #fff;
  font-weight: 700;
  font-size: clamp(16px, 1.6vw, 18px);
  text-decoration: none;
  box-shadow: 0 10px 40px rgba(124,108,255,.35);
  overflow: visible;
}

/* l’anneau animé */
.orbit-double{
  fill: none;
  stroke: #a78bfa;
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-dasharray: 120 380 120 380;
  animation: orbit-spin 3.4s linear infinite;
}

@keyframes orbit-spin{
  to { stroke-dashoffset: -1000; }
}

@media (max-width: 720px){
  .cta-content{ text-align: center; }
}

/* Centre toute la section CTA */
#neatik-cta {
  width: 100%;
  display: flex;
  justify-content: center;   /* centre horizontalement */
  margin: 60px 0;
}

/* La carte (fond violet arrondi) */
#neatik-cta .cta-card {
  max-width: 1100px;         /* largeur max lisible */
  width: 90%;
  margin: 0 auto;
  text-align: left;
}

/* Contenu textuel */
#neatik-cta .cta-content {
  text-align: left;
  margin-bottom: 24px;
}

/* Centre uniquement le bouton à l'intérieur */
#neatik-cta .cta-btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  position: relative;
  margin-inline: auto;        /* garde le bouton centré */
}

/* Pour mobiles : tout au centre */
@media (max-width: 720px) {
  #neatik-cta .cta-content {
    text-align: center;
  }
  #neatik-cta .cta-btn {
    margin: 0 auto;
  }
}

/* Empêche tout scroll horizontal */
html, body { width:100%; overflow-x:hidden; }

/* Neutralise les débordements accidentels */
.sim-page, .sim-container, .sim-chart-wrapper,
.cta-wrap, #neatik-cta, .cta-card, .cta-inner {
  max-width: 100%;
  overflow-x: hidden;
}

/* Les rangées/grilles prennent toute la largeur, centrées */
.sim-row { width:100%; margin:0 auto; }

/* Boutons / cartes ne doivent pas pousser en largeur */
.sim-card, .sim-profile-btn, .sim-tab, .kpi-tile {
  max-width:100%;
  box-sizing:border-box;
}

/* Canvas responsive */
#detail-chart, canvas#detail-chart {
  display:block;
  width:100% !important;
  height:auto !important; /* la hauteur est gérée en JS mais on évite la casse */
}

.sim-profile-group {
  display:grid; gap:14px;
}
.sim-profile-btn {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  user-select: none;
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  background: rgba(255,255,255,.03);
  transition: transform .06s ease, box-shadow .2s ease, background .2s;
}
.sim-profile-btn[aria-checked="true"],
/* actif = compat .is-active OU ancienne classe .sim-profile-btn-active */
.sim-profile-btn.is-active,
.sim-profile-btn-active {
  background: radial-gradient(120px 60px at 20% 0%, rgba(124,108,255,.22), transparent 60%),
              rgba(124,108,255,.18);
  border-color: rgba(124,108,255,.45);
  box-shadow: 0 10px 28px rgba(124,108,255,.22) inset, 0 10px 30px rgba(124,108,255,.18);
}
.sim-profile-btn:active { transform: scale(.995); }




.sim-tabs{
  position:relative;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  background: rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  padding:6px;
  gap:6px;
}
.sim-tab{
  position:relative;
  z-index:1;
  border:none;
  background:transparent;
  color:#c7d2fe;
  padding:12px 10px;
  border-radius:12px;
  font-weight:600;
  -webkit-tap-highlight-color: transparent;
}
.sim-tab[aria-selected="true"]{ color:#fff; }
.sim-tabs-indicator{
  position:absolute;
  top:6px; bottom:6px;
  width: calc((100% - 12px)/3);
  background: radial-gradient(120px 60px at 20% 0%, rgba(124,108,255,.22), transparent 60%),
              rgba(124,108,255,.22);
  border-radius:12px;
  box-shadow: 0 10px 28px rgba(124,108,255,.24) inset, 0 10px 30px rgba(124,108,255,.18);
  transition: transform .25s ease;
}

.arg-section{
  padding: clamp(28px, 4vw, 48px) 0 80px;
  background: var(--page-bg, #0f1324); /* ta couleur de fond globale */
}
.arg-card{
  max-width: 1100px;
  margin: 0 auto;
  background: #fff;
  color: #111827;
  border-radius: 22px;
  box-shadow:
    0 20px 60px rgba(30, 41, 59, .25),
    0 2px 0 1px rgba(30, 41, 59, .04) inset;
  padding: clamp(22px, 3.5vw, 40px);
}
.arg-title{
  font-size: clamp(28px, 4vw, 40px);
  line-height: 1.15;
  margin: 0 0 18px 0;
}
.arg-intro{
  font-size: clamp(16px, 2vw, 18px);
  color: #374151;
  margin: 0 0 24px 0;
}
.arg-block{ margin: 26px 0; }
.arg-h3{
  position: relative;
  font-size: clamp(18px, 2.2vw, 22px);
  margin: 0 0 8px 0;
  padding-bottom: 8px;
}
.arg-h3::after{
  content:'';
  position:absolute;
  left:0; bottom:0;
  width: 120px; height: 3px;
  background: #7c6cff; /* souligné violet/bleu, comme les mentions */
  border-radius: 3px;
  box-shadow: 0 2px 0 rgba(124,108,255,.25);
}
.arg-card p{ margin: 8px 0 0 0; }

.sim-container, .sim-profile-group, .sim-tabs, .kpi-grid {
  touch-action: pan-y;
}

@media (max-width: 640px){
  .kpi-grid{ gap: 10px; }
  .sim-profile-btn{ padding: 14px; }
  .cta-card{ padding: 18px 16px; }
}

/* ===== Objectifs (mobile & desktop) ===== */
.sim-objective-tabs{
  position: relative;                /* pour l'indicateur absolu */
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  align-items: stretch;
}

.sim-tab{
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 56px;
  padding: 14px 10px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  color: #cfd5ff;
  font-weight: 600;
  line-height: 1;
  transition: background .2s ease, box-shadow .2s ease, color .2s;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

/* actif : on couvre .sim-tab-active ET .is-active */
.sim-tab.sim-tab-active,
.sim-tab.is-active{
  background: radial-gradient(120px 60px at 20% 0%, rgba(124,108,255,.22), transparent 60%),
              rgba(124,108,255,.12);
  border-color: rgba(124,108,255,.45);
  color: #fff;
  box-shadow: 0 10px 26px rgba(124,108,255,.20) inset,
              0 10px 28px rgba(124,108,255,.22);
}

/* l'indicateur glissant */
.sim-tab-indicator{
  position: absolute;
  bottom: -6px;                      /* petit débord sous les boutons */
  height: 4px;
  border-radius: 4px;
  background: linear-gradient(90deg,#a78bfa, #6ca8ff);
  left: 0; width: 0;
  transition: left .25s ease, width .25s ease;
}

/* très petits écrans, on compacte un peu */
@media (max-width: 360px){
  .sim-tab{ min-height: 50px; padding: 12px 8px; font-size: 14px; }
}

.sim-when[hidden]{ display:none !important; }


/* Make every slider and its ticks span the full available width */
.sim-field .sim-slider{ width:100%; }

/* If you use a separate ticks row, stretch it edge to edge */
.sim-field .sim-range-ticks,
.sim-field .sim-ticks{ left:0; right:0; width:100%; position:absolute; }

/* Nuke any accidental inline left offsets from older markup */
#rent.sim-slider,
#taux-interet.sim-slider { margin-left:0 !important; }

/* Allow the tabs row to show floating tooltip content */
.sim-objective-tabs{ overflow: visible; }

/* Mobile-friendly tooltip from data-tooltip */
.sim-tab[data-tooltip]{
  position: relative;
}
.sim-tab[data-tooltip]::after{
  content: attr(data-tooltip);
  position: absolute;
  left: 50%;
  bottom: calc(100% + 10px);
  transform: translateX(-50%);
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(0,0,0,.85);
  color: #fff;
  font-size: 13px;
  line-height: 1.35;
  white-space: normal;           /* wrap lines */
  max-width: min(320px, calc(100vw - 32px)); /* keep inside viewport */
  box-shadow: 0 6px 20px rgba(0,0,0,.25);
  opacity: 0;
  pointer-events: none;
  transition: opacity .15s ease;
}

/* Show on focus or when a helper class is set */
.sim-tab:focus-visible::after,
.sim-tab.tip-open::after { opacity: 1; }

/* Carte du graphe : supprimer min-height en mobile */
@media (max-width: 768px){
  .sim-preview-card,
  .sim-chart-wrap,
  .sim-chart-host{
    min-height: 0 !important;
    height: auto !important;
  }

  /* le canvas lui-même */
  #detail-chart,
  canvas#detail-chart{
    height: auto !important;
    max-height: none !important;
    /* tu peux ajouter une ratio si tu veux un cadre stable : */
    /* aspect-ratio: 16/9; */
  }
}

@media (max-width: 768px){
  .sim-field .sim-input-wrapper{
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .sim-field .sim-slider{
    display: block;
    width: 100% !important;
    margin-left: 0 !important;
    box-sizing: border-box;
  }
  .sim-field .sim-ruler,
  .sim-field .sim-track,
  .sim-field .sim-ticks{
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    transform: none !important;
  }
}

/* ===== SECTION ARGUMENTAIRE (fond blanc full width + coins arrondis) ===== */
.argu-section{
  background:#fff;
  /* coins moins arrondis que la version actuelle */
  border-top-left-radius: 36px;
  border-top-right-radius: 36px;
  /* respiration verticale autour du bloc central */
  padding: clamp(24px,4vw,48px) 0 clamp(56px,6vw,96px);
  /* colle la section après la hero du simulateur sans créer de marge bizarre */
  margin-top: clamp(24px,4vw,56px);
  /* évite toute débordement horizontal résiduel ici */
  overflow: hidden;
}

/* Mobile : coins plus doux et paddings adaptés */
@media (max-width:768px){
  .argu-section{
    border-top-left-radius: 20px;
    border-top-right-radius: 20px;
    padding: 20px 0 48px;
    margin-top: 16px;
  }
}

/* ====== Cadre central "conditions" REPRIS, mais SCOPÉ sous .argu-section ====== */
.argu-section .conditions-content * { box-sizing: border-box; }

.argu-section {
  background:#fff;
  border-top-left-radius:36px;
  border-top-right-radius:36px;
  padding:clamp(24px,4vw,48px) 0 clamp(56px,6vw,96px);
  margin-top:clamp(24px,4vw,56px);
  overflow:hidden;

  /* 🔹 Hérite de la police principale du site */
  font-family: inherit !important;
}

/* Desktop */
@media (min-width:769px){
  .argu-section .conditions-content{
    max-width: 900px;
    margin: 0 auto;              /* centré dans la zone blanche */
    padding: 0 60px;
    background:transparent;       /* inutile d’ajouter un fond ici, le fond est celui de la section */
  }

  .argu-section .conditions-wrapper{
    background:#fff;
    padding:60px;
    border-radius:12px;
    box-shadow:0 4px 20px rgba(0,0,0,.08);
    /* assure un rendu net sur fond blanc */
    color:#333;
  }

  /* Typo / titres / listes (copie “conditions”, scannée) */
  .argu-section .conditions-wrapper,
  .argu-section .conditions-content{
    font-size:16px !important;
    color:#333 !important;
    text-align:left !important;
  }

  .argu-section .conditions-wrapper h1{
    font-size:2.8rem; font-weight:700; margin-bottom:50px; line-height:1.2; color:#333;
  }
  .argu-section .conditions-wrapper h2{
    display:block; font-size:2rem; font-weight:600; margin:60px 0 30px;
    color:#333; border-bottom:3px solid #4B31ED; padding-bottom:15px; clear:both; width:100%;
  }
  .argu-section .conditions-wrapper h3{
    display:block; font-size:1.5rem; font-weight:600; margin:45px 0 25px; color:#444; clear:both; width:100%;
  }
  .argu-section .conditions-wrapper h4{
    display:block; font-size:1.3rem; font-weight:600; margin:35px 0 20px; color:#555; clear:both; width:100%;
  }
  .argu-section .conditions-wrapper p{
    margin-bottom:25px; line-height:1.8; color:#666; text-align:justify; font-size:1rem;
  }
  .argu-section .conditions-wrapper ul,
  .argu-section .conditions-wrapper ol{ margin:25px 0; padding-left:35px; }
  .argu-section .conditions-wrapper li{ margin-bottom:12px; color:#666; line-height:1.7; }
  .argu-section .conditions-wrapper strong{ font-weight:600; color:#333; }
}

/* Mobile */
@media (max-width:768px){
  .argu-section .conditions-content{
    margin:0 auto !important;
    padding: 0 15px !important;
    max-width:95% !important; width:95% !important;
    overflow-x:hidden !important;
    background:transparent !important;
  }
  .argu-section .conditions-wrapper{
    padding:20px !important; margin:0 !important;
    border-radius:8px !important;
    box-shadow:0 2px 10px rgba(0,0,0,.1) !important;
    width:100% !important; max-width:100% !important;
    overflow-x:hidden !important; background:#fff !important; color:#333 !important;
  }
  .argu-section .conditions-wrapper h1{
    font-size:2rem !important; margin-bottom:30px !important; line-height:1.2 !important;
    word-wrap:break-word !important;
  }
  .argu-section .conditions-wrapper h2{
    font-size:1.5rem !important; margin:40px 0 20px !important;
    border-bottom:2px solid #4B31ED !important; padding-bottom:10px !important; clear:both !important; width:100% !important;
  }
  .argu-section .conditions-wrapper h3{ font-size:1.3rem !important; margin:30px 0 15px !important; clear:both !important; width:100% !important; }
  .argu-section .conditions-wrapper h4{ font-size:1.1rem !important; margin:25px 0 10px !important; clear:both !important; width:100% !important; }
  .argu-section .conditions-wrapper p{
    margin-bottom:20px !important; line-height:1.6 !important; color:#666 !important;
    text-align:left !important; font-size:.95rem !important; word-wrap:break-word !important; overflow-wrap:break-word !important;
  }
  .argu-section .conditions-wrapper ul,
  .argu-section .conditions-wrapper ol{
    margin:20px 0 !important; padding-left:25px !important; overflow-x:hidden !important;
  }
  .argu-section .conditions-wrapper li{
    margin-bottom:10px !important; color:#666 !important; line-height:1.6 !important;
    word-wrap:break-word !important; overflow-wrap:break-word !important;
  }
  .argu-section .conditions-wrapper strong{ font-weight:600 !important; color:#333 !important; }
}

/* ====== ARGUMENTAIRE : images pleine largeur + style propre ====== */

/* Conteneurs images (Gutenberg / HTML simple) */
.argu-section .conditions-wrapper figure,
.argu-section .conditions-wrapper .wp-block-image,
.argu-section .conditions-wrapper .content figure {
  display: block;
  width: 100%;
  max-width: 100%;
  margin: 24px 0;            /* marge top/bottom identique */
  border-radius: 12px;        /* coins arrondis visibles grâce à overflow */
  overflow: hidden;
}

/* Images */
.argu-section .conditions-wrapper img {
  display: block;             /* empêche le texte de se coller à côté */
  width: 100%;                /* pleine largeur du conteneur */
  max-width: 100%;            /* pas plus large que le conteneur */
  height: auto;               /* conserve les proportions */
  border-radius: 12px;        /* coins arrondis */
  margin: 24px 0;             /* si <img> n'est pas dans un <figure> */
}

/* Si l'image est dans un bloc Gutenberg, on hérite le rayon */
.argu-section .conditions-wrapper .wp-block-image img,
.argu-section .conditions-wrapper figure img {
  border-radius: inherit;
  margin: 0;                  /* géré par le conteneur figure/wp-block-image */
}

/* Légendes */
.argu-section .conditions-wrapper .wp-block-image figcaption,
.argu-section .conditions-wrapper figure figcaption {
  font-size: 0.95rem;
  color: #666;
  text-align: center;
  padding: 10px 8px;
  background: #f8f9fb;        /* léger fond pour bien détacher */
  border-top: 1px solid rgba(0,0,0,0.05);
}

/* Espacements harmonisés autour des titres et listes après une image */
.argu-section .conditions-wrapper img + h2,
.argu-section .conditions-wrapper img + h3,
.argu-section .conditions-wrapper img + h4,
.argu-section .conditions-wrapper figure + h2,
.argu-section .conditions-wrapper figure + h3,
.argu-section .conditions-wrapper figure + h4 {
  margin-top: 28px;
}

/* Compat classes Gutenberg d’alignement : on force en pleine largeur ici.
   (Si un jour tu veux re-supporter alignleft/alignright en 50%, dis-le moi) */
.argu-section .conditions-wrapper .wp-block-image.alignleft,
.argu-section .conditions-wrapper .wp-block-image.alignright,
.argu-section .conditions-wrapper .wp-block-image.aligncenter {
  float: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  text-align: initial !important;
  width: 100% !important;
}

/* Mobile – rien de spécial, on garde 100% et les mêmes marges */
@media (max-width: 768px) {
  .argu-section .conditions-wrapper figure,
  .argu-section .conditions-wrapper .wp-block-image,
  .argu-section .conditions-wrapper img {
    margin: 20px 0;
    border-radius: 10px;
  }
}

/* ====== TYPO ARGUMENTAIRE : paragraphes, listes, titres ====== */
.argu-section .conditions-wrapper p {
  display: block;
  margin: 0 0 20px !important;    /* espace dessous */
  line-height: 1.7 !important;    /* lisibilité */
  word-break: normal;
}

/* Un petit écart au-dessus de chaque élément (sauf le 1er) pour aérer */
.argu-section .conditions-wrapper > * + * {
  margin-top: 8px;
}

/* Titres */
.argu-section .conditions-wrapper h2 {
  margin: 48px 0 16px !important;
  line-height: 1.25;
}
.argu-section .conditions-wrapper h3 {
  margin: 28px 0 12px !important;
  line-height: 1.3;
}
.argu-section .conditions-wrapper h4 {
  margin: 22px 0 10px !important;
}

/* Listes */
.argu-section .conditions-wrapper ul,
.argu-section .conditions-wrapper ol {
  margin: 0 0 20px 1.25rem !important;   /* espace dessous + indentation */
  padding-left: 0;                        /* on laisse l’indentation au margin */
}
.argu-section .conditions-wrapper li {
  margin: 6px 0;
  line-height: 1.6;
}

/* Images incluses dans le contenu */
.argu-section .conditions-wrapper img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 12px;
  margin: 20px 0 !important;  /* espace identique haut/bas */
}

/* Séparateurs éventuels */
.argu-section .conditions-wrapper hr {
  margin: 32px 0;
  border: 0;
  border-top: 1px solid rgba(0,0,0,.08);
}

