/* ============================================================
   SIMULATEUR — wizard (E1+E2+E3)
   DA : navy #1E2D3F / orange #F5A623 / off-white #FAF9F6
   ============================================================ */

.sim-page{background:#FAF9F6;min-height:70vh}
.sim-app{max-width:760px;margin:0 auto;padding:40px 20px 80px;font-family:'IBM Plex Sans',sans-serif;color:#1E2D3F}

/* --- Progression --- */
.sim-progress{margin-bottom:36px}
.sim-progress-bar{height:3px;background:rgba(30,45,63,.10);border-radius:2px;overflow:hidden}
.sim-progress-fill{display:block;height:100%;background:#F5A623;border-radius:2px;transition:width .4s ease}
.sim-progress-label{margin:10px 0 0;font-size:13px;color:#6B7888;letter-spacing:.02em}
.sim-progress-num{color:#1E2D3F;font-weight:600}

/* --- Steps --- */
.sim-step{display:none}
.sim-step.is-active{display:block;animation:simFadeIn .35s ease both}
@keyframes simFadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.sim-kicker{margin:0 0 14px;font-size:14px;font-weight:600;color:#C26A00;letter-spacing:.04em;text-transform:uppercase}
.sim-title{margin:0 0 14px;font-size:34px;line-height:1.15;font-weight:700}
.sim-title-step{margin:0 0 10px;font-size:26px;line-height:1.2;font-weight:700}
.sim-sub{margin:0 0 28px;font-size:17px;line-height:1.5;color:#6B7888}
.sim-sub-step{margin:0 0 24px;font-size:15px;line-height:1.5;color:#6B7888}
.sim-hint{margin:14px 0 0;font-size:13px;color:#6B7888}

.hl{background-image:linear-gradient(rgba(245,166,35,.30),rgba(245,166,35,.30));background-repeat:no-repeat;background-size:100% .42em;background-position:0 88%;border-radius:2px;display:inline}

/* --- Zones --- */
.sim-field-zone,.sim-map-zone,.sim-analyse-zone,.sim-choices,.sim-gate-zone{min-height:40px}
.sim-map-zone{border:1px solid rgba(30,45,63,.12);border-radius:8px;overflow:hidden;position:relative}

/* --- Choix tapables (S4/S5) --- */
.sim-choices{display:grid;gap:12px}
@media (min-width:600px){.sim-choices{grid-template-columns:repeat(2,1fr)}}

/* --- Navigation --- */
.sim-nav{margin-top:32px;padding-top:20px;border-top:1px solid rgba(30,45,63,.10)}
.sim-back{padding:8px 0;font-family:inherit;font-size:14px;color:#6B7888;cursor:pointer}
.sim-back:hover{color:#1E2D3F}

.sim-results[hidden]{display:none}
.sim-noscript{padding:20px;border:1px solid rgba(30,45,63,.15);border-radius:8px;font-size:15px}

@media (max-width:599px){
	.sim-app{padding:28px 16px 64px}
	.sim-title{font-size:27px}
	.sim-title-step{font-size:22px}
}

@media (prefers-reduced-motion:reduce){
	.sim-step.is-active{animation:none}
	.sim-progress-fill{transition:none}
	.sim-cta::after{transition:none}
}

/* ============================================================
   S1 — Adresse (E2)
   ============================================================ */
.sim-sr{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);border:0}

.sim-adresse-wrap{display:flex;flex-direction:column;gap:10px;position:relative}
@media (min-width:600px){.sim-adresse-wrap{flex-direction:row}}


.sim-cta{display:inline-flex;align-items:center;justify-content:center;gap:9px;height:56px;padding:0 24px;font-family:inherit;font-size:15.5px;font-weight:600;letter-spacing:.01em;color:#1E2D3F !important;background-color:#F5A623 !important;border:none;border-radius:8px;cursor:pointer;transition:background-color .15s ease}
.sim-cta::after{content:"\2192";font-size:17px;line-height:1;transition:transform .18s ease}
.sim-cta:hover,.sim-cta:focus{background-color:#FF8A00 !important;color:#1E2D3F !important}
.sim-cta:hover::after,.sim-cta:focus::after{transform:translateX(3px)}
.sim-cta:disabled{background-color:rgba(30,45,63,.14) !important;color:#9AA3AE !important;cursor:not-allowed}
.sim-cta:disabled::after{opacity:.5}
.sim-cta:disabled:hover::after{transform:none}

.sim-suggestions{list-style:none;margin:6px 0 0;padding:0;background:#fff;border:1px solid rgba(30,45,63,.15);border-radius:8px;overflow:hidden}
.sim-suggestions li{padding:13px 18px;font-size:15px;cursor:pointer;border-bottom:1px solid rgba(30,45,63,.07)}
.sim-suggestions li:last-child{border-bottom:none}
.sim-suggestions li:hover,.sim-suggestions li.is-focus{background:rgba(245,166,35,.12)}
.sim-suggestions[hidden]{display:none}

.sim-data-badge{margin:26px 0 0;padding:12px 0 0;border-top:1px solid rgba(30,45,63,.10);font-size:13.5px;color:#6B7888}

/* ============================================================
   S2 — Satellite + detection batiment (E3)
   ============================================================ */
#sim-carte{width:100%;height:380px;background:#1E2D3F}
@media (min-width:600px){#sim-carte{height:440px}}

/* Polygone batiment : tracage anime + glow */
.sim-bat-poly{
	filter:drop-shadow(0 0 6px rgba(245,166,35,.9));
	stroke-dasharray:1200;
	stroke-dashoffset:1200;
	animation:simTrace 1s ease forwards;
}
@keyframes simTrace{to{stroke-dashoffset:0}}

.sim-bat-status{margin:16px 0 0;font-size:14px;line-height:1.45;font-weight:500}
.sim-bat-status.is-searching{color:#6B7888}
.sim-bat-status.is-found{color:#1FA868}
.sim-bat-status.is-none{color:#C26A00}

.sim-actions{margin-top:16px}
.sim-cta-confirm{width:100%}
@media (min-width:600px){.sim-cta-confirm{width:auto}}
.sim-hint-carte{margin-top:12px}

.leaflet-container{font-family:'IBM Plex Sans',sans-serif}
.leaflet-control-attribution{font-size:10px;background:rgba(250,249,246,.85) !important;color:#6B7888}
.leaflet-control-attribution a{color:#6B7888}

@media (prefers-reduced-motion:reduce){
	.sim-bat-poly{animation:none;stroke-dashoffset:0}
}

/* ============================================================
   S3 — Analyse toiture (E4) : schema 2 colonnes + 4 pentes
   ============================================================ */
/* Chargement */
.sim-step[data-step="3"].is-loading::before{content:"Analyse de votre toiture en cours\2026";display:block;font-size:16px;color:#6B7888;padding:40px 0 24px;text-align:center}
.sim-step[data-step="3"].is-loading::after{content:"";display:block;width:34px;height:34px;margin:0 auto;border:3px solid rgba(30,45,63,.15);border-top-color:#F5A623;border-radius:50%;animation:simSpin .8s linear infinite}
.sim-step[data-step="3"].is-loading .sim-analyse-zone{display:none !important}
@keyframes simSpin{to{transform:rotate(360deg)}}

/* Schema : visuel + data cote a cote */
.sim-schema{display:flex;flex-direction:column;align-items:center;gap:8px;margin:14px 0 30px;padding:24px;background:#fff;border:1px solid rgba(30,45,63,.10);border-radius:12px}
.sim-schema-img{display:block;width:200px;max-width:70%;height:auto}
.sim-schema-data{width:100%;list-style:none;margin:0;padding:0}

@media (min-width:640px){
	.sim-schema{flex-direction:row;align-items:center;gap:36px;padding:32px 36px}
	.sim-schema-img{width:240px;max-width:none;flex:none}
	.sim-schema-data{flex:1}
}

.sim-co{display:flex;align-items:center;gap:13px;padding:14px 0;border-bottom:1px solid rgba(30,45,63,.09);opacity:0;transform:translateY(6px);transition:opacity .4s ease,transform .4s ease}
.sim-co:last-child{border-bottom:none}
.sim-co.is-in{opacity:1;transform:none}
.sim-co.is-empty{display:none}
.sim-co-check{flex:none;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;background:rgba(31,168,104,.12);color:#1FA868;border-radius:50%;font-size:13px;font-weight:700}
.sim-co-label{flex:1;font-size:14.5px;color:#6B7888}
.sim-co-val{font-size:22px;font-weight:700;color:#1E2D3F;font-variant-numeric:tabular-nums;white-space:nowrap}

.sim-link-modif{display:inline-block;margin-top:18px;padding:6px 0;font-family:inherit;font-size:13.5px;color:#6B7888;text-decoration:underline;text-underline-offset:3px;cursor:pointer}
.sim-link-modif:hover{color:#1E2D3F}

/* Fallback manuel */
.sim-q{margin-bottom:30px}
.sim-q-label{margin:0 0 14px;font-size:16px;font-weight:600;color:#1E2D3F}

.sim-orient-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media (min-width:600px){.sim-orient-grid{grid-template-columns:repeat(3,1fr)}}
.sim-orient-btn{padding:16px 12px;font-family:inherit;font-size:15px;font-weight:600;color:#1E2D3F !important;background:#fff !important;border:1.5px solid rgba(30,45,63,.18) !important;border-radius:8px;cursor:pointer;transition:border-color .15s ease,background .15s ease}
.sim-orient-btn:hover{border-color:#F5A623 !important}
.sim-orient-btn.is-sel{border-color:#F5A623 !important;background:rgba(245,166,35,.10) !important}

.sim-pente-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media (min-width:680px){.sim-pente-grid{grid-template-columns:repeat(4,1fr)}}
.sim-pente-btn{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:4px;padding:20px 12px 16px;font-family:inherit;color:#1E2D3F !important;background:#fff !important;border:1.5px solid rgba(30,45,63,.18) !important;border-radius:10px;cursor:pointer;transition:border-color .15s ease,background .15s ease}
.sim-pente-btn:hover{border-color:#F5A623 !important;background:rgba(245,166,35,.06) !important}
.sim-pente-btn.is-sel{border-color:#F5A623 !important;background:rgba(245,166,35,.10) !important}
.sim-pente-img{width:100%;max-width:130px;height:72px;object-fit:contain;margin-bottom:10px}
.sim-pente-nom{font-size:14.5px;font-weight:600;line-height:1.2;text-align:center}
.sim-pente-deg{font-size:13px;color:#6B7888;font-variant-numeric:tabular-nums}

@media (prefers-reduced-motion:reduce){
	.sim-step[data-step="3"].is-loading::after{animation:none}
	.sim-co{transition:none;opacity:1;transform:none}
}

/* ============================================================
   S3 — corrections : degres sous nom, boussole, surface (E4)
   ============================================================ */
/* Pente : nom et degres empiles, lisibles */
.sim-pente-nom{display:block;font-size:14.5px;font-weight:600;line-height:1.25;text-align:center}
.sim-pente-deg{display:block;margin-top:2px;font-size:13px;color:#6B7888;font-variant-numeric:tabular-nums;text-align:center}

/* Orientation : boussole illustrative + boutons */
.sim-orient-wrap{display:flex;flex-direction:column;align-items:center;gap:18px}
.sim-orient-boussole{width:96px;height:96px;flex:none}
@media (min-width:720px){
	.sim-orient-wrap{flex-direction:row;align-items:center;gap:28px}
	.sim-orient-boussole{width:120px;height:120px}
	.sim-orient-wrap .sim-orient-grid{flex:1}
}

/* Surface */
.sim-q-hint{margin:0 0 14px;font-size:13.5px;color:#6B7888;line-height:1.45}
.sim-surface-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media (min-width:600px){.sim-surface-grid{grid-template-columns:repeat(4,1fr)}}
.sim-surface-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:18px 12px;font-family:inherit;color:#1E2D3F !important;background:#fff !important;border:1.5px solid rgba(30,45,63,.18) !important;border-radius:10px;cursor:pointer;text-align:center;transition:border-color .15s ease,background .15s ease}
.sim-surface-btn:hover{border-color:#F5A623 !important;background:rgba(245,166,35,.06) !important}
.sim-surface-btn.is-sel{border-color:#F5A623 !important;background:rgba(245,166,35,.10) !important}
.sim-surface-val{font-size:15px;font-weight:600;line-height:1.2}
.sim-surface-sub{font-size:12.5px;color:#6B7888}

/* ============================================================
   S3 — fix surface (spans en block) + boussole interactive
   ============================================================ */
.sim-surface-val{display:block;font-size:15px;font-weight:600;line-height:1.25}
.sim-surface-sub{display:block;margin-top:3px;font-size:12.5px;color:#6B7888;line-height:1.2}

/* Boussole interactive : rose des vents cliquable */
.sim-boussole-wrap{position:relative;width:230px;height:230px;margin:0 auto 8px}
.sim-boussole-bg{width:100%;height:100%;display:block;pointer-events:none}
.sim-dir{position:absolute;width:34%;height:34%;border:none;background:transparent;cursor:pointer;border-radius:50%;font-family:inherit;font-size:13px;font-weight:600;color:#1E2D3F;transition:background .15s ease,color .15s ease;padding:0}
.sim-dir:hover{background:rgba(245,166,35,.16)}
.sim-dir.is-sel{background:#F5A623;color:#1E2D3F}
.sim-dir-n{top:2%;left:33%}
.sim-dir-ne{top:14%;right:8%}
.sim-dir-e{top:33%;right:2%}
.sim-dir-se{bottom:14%;right:8%}
.sim-dir-s{bottom:2%;left:33%}
.sim-dir-so{bottom:14%;left:8%}
.sim-dir-o{top:33%;left:2%}
.sim-dir-no{top:14%;left:8%}
.sim-dir-n,.sim-dir-no,.sim-dir-ne{opacity:.4;cursor:default}
.sim-dir-n:hover,.sim-dir-no:hover,.sim-dir-ne:hover{background:transparent}
.sim-boussole-skip{display:block;margin:6px auto 0;padding:6px 0;background:none;border:none;font-family:inherit;font-size:13.5px;color:#6B7888;text-decoration:underline;text-underline-offset:3px;cursor:pointer}
.sim-boussole-skip:hover{color:#1E2D3F}

/* ============================================================
   S3 — boussole interactive hybride (E4 v2)
   ============================================================ */
.sim-orient-hybrid{display:flex;flex-direction:column;align-items:center;gap:24px}
@media (min-width:680px){.sim-orient-hybrid{flex-direction:row;align-items:center;gap:36px}}

.sim-boussole-svg-wrap{flex:none;width:200px}
.sim-boussole-svg{width:100%;height:auto;display:block;overflow:visible}

.sim-branch{fill:#1E2D3F;cursor:pointer;transition:fill .15s ease}
.sim-branch:hover{fill:#C26A00}
.sim-branch.is-sel{fill:#F5A623}
.sim-branch.is-disabled{fill:rgba(30,45,63,.18);cursor:default;pointer-events:none}

.sim-orient-cards{flex:1;display:grid;grid-template-columns:repeat(2,1fr);gap:10px;width:100%}
@media (min-width:680px){.sim-orient-cards{grid-template-columns:repeat(2,1fr)}}
.sim-orient-card{display:flex;flex-direction:column;align-items:center;gap:2px;padding:14px 12px;font-family:inherit;font-size:15px;font-weight:600;color:#1E2D3F !important;background:#fff !important;border:1.5px solid rgba(30,45,63,.18) !important;border-radius:8px;cursor:pointer;transition:border-color .15s ease,background .15s ease}
.sim-orient-card span{font-size:12px;font-weight:500;color:#6B7888}
.sim-orient-card:hover{border-color:#F5A623 !important}
.sim-orient-card.is-sel{border-color:#F5A623 !important;background:rgba(245,166,35,.10) !important}
.sim-orient-card[data-val="?"]{grid-column:1 / -1}

@media (prefers-reduced-motion:reduce){
	.sim-branch{transition:none}
}

/* ============================================================
   S3 — boussole v2 : aiguille + label central (E4 final)
   ============================================================ */
.sim-boussole-stage{display:flex;flex-direction:column;align-items:center;gap:16px;margin:8px 0 6px}
.sim-boussole-svg{width:280px;max-width:88%;height:auto;display:block;overflow:visible}

.sim-bz-ring{fill:none;stroke:rgba(30,45,63,.12);stroke-width:1.5}

/* Branches : trait fin par defaut, remplissage a la selection */
.sim-br{fill:#fff;stroke:#1E2D3F;stroke-width:1.6;stroke-linejoin:round;cursor:pointer;transition:fill .18s ease}
.sim-br:hover{fill:rgba(245,166,35,.20)}
.sim-br.is-sel{fill:#F5A623;stroke:#F5A623}
.sim-br.is-dis{fill:#fff;stroke:rgba(30,45,63,.20);stroke-dasharray:3 3;cursor:default}

/* Pulse d'invite sur les branches Sud au depart */
.sim-boussole-stage.is-hint .sim-br[data-dir="Sud"],
.sim-boussole-stage.is-hint .sim-br[data-dir="Sud-Est"],
.sim-boussole-stage.is-hint .sim-br[data-dir="Sud-Ouest"]{animation:simBrPulse 1.8s ease-in-out infinite}
@keyframes simBrPulse{0%,100%{fill:#fff}50%{fill:rgba(245,166,35,.30)}}

.sim-br-lab{font-family:'IBM Plex Sans',sans-serif;font-size:14px;font-weight:600;fill:#1E2D3F;pointer-events:none}
.sim-br-lab.is-dis{fill:#C3C9D1}

.sim-hit{fill:transparent;cursor:pointer}

/* Aiguille : invisible tant que rien n'est choisi, pivote a la selection */
.sim-needle{transform-origin:130px 130px;transform:rotate(180deg);opacity:0;transition:transform .5s cubic-bezier(.34,1.56,.64,1),opacity .3s ease}
.sim-boussole-stage.is-chosen .sim-needle{opacity:1}

.sim-boussole-readout{margin:0;font-size:20px;font-weight:700;color:#6B7888;letter-spacing:.02em;text-align:center;min-height:26px;transition:color .2s ease}
.sim-boussole-stage.is-chosen .sim-boussole-readout{color:#1E2D3F}

.sim-boussole-skip{display:block;margin:14px auto 0;padding:6px 0;background:none;border:none;font-family:inherit;font-size:13.5px;color:#6B7888;text-decoration:underline;text-underline-offset:3px;cursor:pointer}
.sim-boussole-skip:hover{color:#1E2D3F}

@media (prefers-reduced-motion:reduce){
	.sim-br{transition:none}
	.sim-needle{transition:opacity .2s ease}
	.sim-boussole-stage.is-hint .sim-br{animation:none}
}

/* ============================================================
   S3 — boussole : 8 directions cliquables (nord = faible)
   ============================================================ */
.sim-br-faible{stroke:rgba(30,45,63,.45)}
.sim-br-faible:hover{fill:rgba(245,166,35,.14)}
.sim-br-faible.is-sel{fill:#F5A623;stroke:#F5A623}
/* on neutralise l'ancien etat desactive : tout est cliquable */
.sim-br.is-dis{fill:#fff;stroke:#1E2D3F;stroke-dasharray:none;cursor:pointer;pointer-events:auto}

/* ============================================================
   S4 — Facture slider (E5)
   ============================================================ */
.sim-facture{margin-top:18px;text-align:center}
.sim-facture-readout{display:flex;align-items:baseline;justify-content:center;gap:2px}
.sim-facture-amount{font-size:60px;font-weight:700;color:#1E2D3F;line-height:1;font-variant-numeric:tabular-nums}
.sim-facture-unit{font-size:22px;font-weight:600;color:#6B7888}
.sim-facture-conso{margin:10px 0 30px;font-size:15px;color:#6B7888}
.sim-facture-conso span{font-weight:600;color:#1E2D3F}

.sim-slider-wrap{padding:0 6px}
/* Reset natif + jauge orange via background dynamique (JS pose --pct) */
.sim-slider{-webkit-appearance:none;appearance:none;width:100%;height:8px;border-radius:6px;outline:none;cursor:pointer;
	background:linear-gradient(to right,#F5A623 0%,#F5A623 var(--pct,24%),rgba(30,45,63,.14) var(--pct,24%),rgba(30,45,63,.14) 100%)}
/* Poignee : pastille navy + symbole € (en pseudo via background SVG data-uri) */
.sim-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:38px;height:38px;border-radius:50%;background:#1E2D3F;border:3px solid #fff;box-shadow:0 0 0 1px rgba(30,45,63,.15);cursor:grab;
	background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ctext x='12' y='17' text-anchor='middle' font-family='IBM Plex Sans,sans-serif' font-size='15' font-weight='700' fill='%23F5A623'%3E%E2%82%AC%3C/text%3E%3C/svg%3E");background-size:38px 38px;background-position:center}
.sim-slider::-webkit-slider-thumb:active{cursor:grabbing}
.sim-slider::-moz-range-thumb{width:38px;height:38px;border-radius:50%;background:#1E2D3F;border:3px solid #fff;cursor:grab;
	background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ctext x='12' y='17' text-anchor='middle' font-family='sans-serif' font-size='15' font-weight='700' fill='%23F5A623'%3E%E2%82%AC%3C/text%3E%3C/svg%3E");background-size:38px 38px;background-position:center}
.sim-slider::-moz-range-track{height:8px;border-radius:6px;background:transparent}

.sim-slider-scale{display:flex;justify-content:space-between;margin:12px 4px 0;font-size:12.5px;color:#9AA3AE}
.sim-facture .sim-actions{margin-top:30px}

/* ============================================================
   S5 — Presence (E5)
   ============================================================ */
.sim-presence-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-top:8px}
@media (min-width:680px){.sim-presence-grid{grid-template-columns:repeat(3,1fr)}}
.sim-presence-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px 16px;font-family:inherit;color:#1E2D3F !important;background:#fff !important;border:1.5px solid rgba(30,45,63,.18) !important;border-radius:12px;cursor:pointer;text-align:center;transition:border-color .15s ease,background .15s ease,transform .15s ease}
.sim-presence-btn:hover{border-color:#F5A623 !important;background:rgba(245,166,35,.05) !important}
.sim-presence-btn.is-sel{border-color:#F5A623 !important;background:rgba(245,166,35,.10) !important}
.sim-presence-img{width:84px;height:84px;object-fit:contain;margin-bottom:4px}
.sim-presence-nom{font-size:16px;font-weight:600;line-height:1.2}
.sim-presence-sub{font-size:13px;color:#6B7888;line-height:1.35}

@media (prefers-reduced-motion:reduce){
	.sim-presence-btn{transition:none}
}

/* ============================================================
   S6 — Gate (E6 C1)
   ============================================================ */
.sim-gate{max-width:440px;margin:0 auto}

/* Teaser verrouille */
.sim-gate-teaser{position:relative;background:#fff;border:1px solid rgba(30,45,63,.10);border-radius:14px;padding:22px 24px;margin-bottom:26px;overflow:hidden}
.sim-teaser-row{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px solid rgba(30,45,63,.07)}
.sim-teaser-row:last-of-type{border-bottom:none}
.sim-teaser-lbl{font-size:14px;color:#6B7888}
.sim-teaser-val{font-size:19px;font-weight:700;color:#1E2D3F;font-variant-numeric:tabular-nums}
.sim-teaser-hero .sim-teaser-lbl{font-weight:600;color:#1E2D3F}
.sim-teaser-hero .sim-teaser-val{font-size:26px;color:#C26A00}
.sim-blur{filter:blur(8px);user-select:none}
.sim-teaser-lock{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(250,249,246,.35)}
.sim-lock-ico{width:46px;height:46px;display:flex;align-items:center;justify-content:center;background:#1E2D3F;color:#F5A623;border-radius:50%;font-size:20px}

.sim-gate-title{margin-top:0}

/* Champs label flottant */
.sim-gate-form{margin-top:22px}
.sim-field{position:relative;margin-bottom:16px}
.sim-input{width:100%;height:58px;padding:22px 16px 8px;font-family:inherit;font-size:16px;color:#1E2D3F;background:#fff;border:1.5px solid rgba(30,45,63,.20);border-radius:10px;outline:none;transition:border-color .15s ease}
.sim-input:focus{border-color:#F5A623}
.sim-label{position:absolute;left:16px;top:18px;font-size:16px;color:#9AA3AE;pointer-events:none;transition:transform .15s ease,font-size .15s ease,color .15s ease;transform-origin:left top}
.sim-input:focus + .sim-label,
.sim-input:not(:placeholder-shown) + .sim-label{transform:translateY(-11px) scale(.78);color:#6B7888}
.sim-input.is-valid{border-color:#1FA868}
.sim-input.is-error{border-color:#B43C3C}
.sim-field-help{margin:7px 4px 0;font-size:12.5px;color:#6B7888;line-height:1.4}

.sim-hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}

/* Consentement */
.sim-consent{display:flex;align-items:flex-start;gap:11px;margin:6px 0 22px;cursor:pointer}
.sim-consent input{flex:none;width:20px;height:20px;margin-top:1px;accent-color:#F5A623;cursor:pointer}
.sim-consent-txt{font-size:12.5px;line-height:1.5;color:#6B7888}
.sim-consent.is-error .sim-consent-txt{color:#B43C3C}

/* CTA gate */
.sim-gate-cta{width:100%;justify-content:center}
.sim-gate-cta.is-loading{opacity:.7;pointer-events:none;position:relative;color:transparent}
.sim-gate-cta.is-loading::after{content:"";position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;border:2.5px solid rgba(30,45,63,.3);border-top-color:#1E2D3F;border-radius:50%;animation:simSpin .7s linear infinite}

.sim-gate-error{margin:12px 0 0;font-size:13.5px;color:#B43C3C;text-align:center}

/* Trust bar */
.sim-gate-trust{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 20px;list-style:none;margin:20px 0 0;padding:0}
.sim-gate-trust li{position:relative;font-size:12.5px;color:#6B7888;padding-left:18px}
.sim-gate-trust li::before{content:"";position:absolute;left:0;top:50%;width:11px;height:11px;margin-top:-5px;background:rgba(31,168,104,.18);border-radius:50%}
.sim-gate-trust li::after{content:"";position:absolute;left:3px;top:50%;width:5px;height:3px;margin-top:-2px;border-left:1.5px solid #1FA868;border-bottom:1.5px solid #1FA868;transform:rotate(-45deg)}

@media (prefers-reduced-motion:reduce){
	.sim-gate-cta.is-loading::after{animation:none}
}

/* S5 fix : nom et sous-titre en block (collage) */
.sim-presence-nom{display:block;width:100%}
.sim-presence-sub{display:block;width:100%}

/* ============================================================
   S1 — Champ adresse premium (E6 polish)
   ============================================================ */
.sim-adresse-field{position:relative;flex:1}
.sim-adresse-ico{position:absolute;left:17px;top:50%;transform:translateY(-50%);width:20px;height:20px;pointer-events:none;color:#9AA3AE}
.sim-adresse-ico svg{display:block;width:100%;height:100%}
#sim-adresse-input{width:100%;height:60px;padding:0 18px 0 48px;font-family:inherit;font-size:16px;color:#1E2D3F;background:#fff;border:1.5px solid rgba(30,45,63,.18);border-radius:12px;outline:none;transition:border-color .15s ease,box-shadow .15s ease}
#sim-adresse-input:focus{border-color:#F5A623;box-shadow:0 0 0 4px rgba(245,166,35,.14)}
#sim-adresse-input:focus ~ .sim-adresse-ico{color:#F5A623}
#sim-adresse-input::placeholder{color:#9AA3AE}

.sim-suggestions{position:absolute;left:0;right:0;top:calc(100% + 8px);z-index:20;list-style:none;margin:0;padding:6px;background:#fff;border:1px solid rgba(30,45,63,.12);border-radius:12px;box-shadow:0 12px 30px rgba(30,45,63,.12);overflow:hidden}
.sim-suggestions li{display:flex;align-items:center;gap:11px;padding:12px 12px;font-size:15px;color:#1E2D3F;cursor:pointer;border-radius:8px;border-bottom:none}
.sim-suggestions li::before{content:"";flex:none;width:16px;height:16px;background:rgba(30,45,63,.32);border-radius:50% 50% 50% 0;transform:rotate(-45deg)}
.sim-suggestions li:hover,.sim-suggestions li.is-focus{background:rgba(245,166,35,.10)}
.sim-suggestions li:hover::before,.sim-suggestions li.is-focus::before{background:#F5A623}
.sim-suggestions[hidden]{display:none}

/* ============================================================
   S3 — Scan satellite (E6 option A)
   ============================================================ */
.sim-scan{position:relative;width:100%;aspect-ratio:16/10;border-radius:14px;overflow:hidden;border:1px solid rgba(30,45,63,.12);background:#1E2D3F;margin:6px 0 22px}
.sim-scan-map{position:absolute;inset:0}
/* carte figee : on bloque les interactions */
.sim-scan-map .leaflet-control-container,
.sim-scan-map .leaflet-control-attribution{display:none}
.sim-scan-map{cursor:default}

/* Overlay scan */
.sim-scan-overlay{position:absolute;inset:0;pointer-events:none;z-index:500}
.sim-scan-line{position:absolute;left:0;right:0;top:0;height:3px;background:linear-gradient(90deg,transparent,#F5A623,transparent);box-shadow:0 0 16px 4px rgba(245,166,35,.7)}
.sim-scan.is-scanning .sim-scan-line{animation:simScanLine 2.5s cubic-bezier(.45,.05,.55,.95) forwards}
@keyframes simScanLine{0%{top:0;opacity:0}10%{opacity:1}90%{opacity:1}100%{top:100%;opacity:0}}
.sim-scan.is-done .sim-scan-line{display:none}
.sim-scan-status{position:absolute;left:50%;bottom:12px;transform:translateX(-50%);padding:5px 14px;font-size:12.5px;font-weight:600;color:#fff;background:rgba(30,45,63,.78);border-radius:20px;letter-spacing:.02em}
.sim-scan.is-done .sim-scan-status{display:none}

/* Cartouches data */
.sim-scan-data{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:26px}
@media (min-width:560px){.sim-scan-data{grid-template-columns:repeat(3,1fr)}}
.sim-dcard{display:flex;flex-direction:column;align-items:flex-start;gap:5px;padding:15px 14px;background:#fff;border:1px solid rgba(30,45,63,.10);border-radius:11px;opacity:0;transform:translateY(10px);transition:opacity .45s ease,transform .45s ease}
.sim-dcard.is-in{opacity:1;transform:none}
.sim-dcard-ico{width:28px;height:28px;display:block;margin-bottom:2px}
.sim-dcard-lbl{font-size:12.5px;color:#6B7888;line-height:1.25}
.sim-dcard-val{font-size:20px;font-weight:700;color:#1E2D3F;font-variant-numeric:tabular-nums;line-height:1.1}
.sim-dcard.is-empty{display:none}

@media (prefers-reduced-motion:reduce){
	.sim-scan.is-scanning .sim-scan-line{animation:none;display:none}
	.sim-dcard{transition:opacity .2s ease;transform:none}
}

/* Fix dropdown adresse : ancre sous le champ, pas sous tout le wrap */
.sim-adresse-wrap{position:static}
.sim-adresse-field{position:relative}
.sim-adresse-field .sim-suggestions{top:calc(100% + 8px)}


/* ============================================================
   S3 — Logement (qualification, E6+)
   ============================================================ */
.sim-bien-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.sim-bien-btn{padding:20px 16px;font-family:inherit;font-size:16px;font-weight:600;color:#1E2D3F !important;background:#fff !important;border:1.5px solid rgba(30,45,63,.18) !important;border-radius:12px;cursor:pointer;transition:border-color .15s ease,background .15s ease}
.sim-bien-btn:hover{border-color:#F5A623 !important}
.sim-bien-btn.is-sel{border-color:#F5A623 !important;background:rgba(245,166,35,.10) !important}
.sim-bien-note{margin:20px 0 0;padding:14px 16px;font-size:13.5px;color:#6B7888;background:rgba(30,45,63,.04);border-left:3px solid #F5A623;border-radius:6px;line-height:1.5}

/* S3 logement : boutons avec icone */
/* bouton logement : icone centree au-dessus, texte dessous */
.sim-bien-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-height:140px;padding:22px 16px;text-align:center}
.sim-bien-btn .sim-bien-ico{width:56px;height:56px;display:block;flex:none;margin:0 auto}
.sim-bien-btn span{display:block;width:100%;font-size:16px;font-weight:600;line-height:1.2;text-align:center}

/* ============================================================
   ECRAN RESULTATS — V2 immersif (E6 C2/C3)
   Navy reserve au seul climax. Pleine largeur desktop.
   ============================================================ */
.sim-results{padding:0;max-width:100%}
.sim-r{width:100%}
.sim-r-wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.sim-r [data-anim]{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
.sim-r [data-anim].is-in{opacity:1;transform:none}

/* HERO satellite (clair, photo) */
.sim-r-hero{position:relative;min-height:54vh;display:flex;align-items:flex-end;overflow:hidden}
.sim-r-hero-map{position:absolute;inset:0;background:#1a2738}
.sim-r-hero-map .leaflet-control-container{display:none}
.sim-r-hero-grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(30,45,63,.88) 0%,rgba(30,45,63,.35) 42%,rgba(30,45,63,0) 72%);pointer-events:none;z-index:1}
.sim-r-hero-txt{position:relative;z-index:2;width:100%;max-width:1180px;margin:0 auto;padding:0 24px 48px;color:#fff}
.sim-r-hero-title{margin:0;font-size:clamp(32px,4.5vw,56px);font-weight:700;line-height:1.04;letter-spacing:-.02em;color:#fff;max-width:16ch}
.sim-r-hero-title em{font-style:normal;color:#F5A623}
.sim-r-hero-sub{margin:14px 0 0;font-size:16px;color:rgba(255,255,255,.8)}

/* Sections claires */
.sim-r-sec{padding:72px 0}
.sim-r-sec-t{font-size:clamp(25px,3vw,38px);font-weight:700;letter-spacing:-.015em;line-height:1.08;color:#1E2D3F}
.sim-r-sec-i{font-size:16px;color:#6B7888;margin-top:10px;max-width:48ch}

/* ANALYSE 2 colonnes */
.sim-r-analyse{background:#fff;border-top:1px solid rgba(30,45,63,.10)}
.sim-r-ag{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;margin-top:44px}
.sim-r-avis{border-radius:18px;overflow:hidden;aspect-ratio:4/3;background:#e8e4dc}
.sim-r-avis-map{width:100%;height:100%}
.sim-r-avis-map .leaflet-control-container{display:none}
.sim-r-dg{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.sim-r-dc{padding:20px;border:1px solid rgba(30,45,63,.10);border-radius:14px;background:#FAF9F6}
.sim-r-dc img{width:30px;height:30px;display:block;margin-bottom:10px}
.sim-r-dc-l{font-size:12.5px;color:#6B7888;margin-bottom:3px}
.sim-r-dc-v{font-size:24px;font-weight:700;color:#1E2D3F}
.sim-r-dc.full{grid-column:1/-1;display:flex;align-items:center;gap:14px;background:rgba(245,166,35,.10);border-color:rgba(245,166,35,.38)}
.sim-r-dc.full img{margin:0;width:34px;height:34px}
.sim-r-dc.full .sim-r-dc-v{font-size:19px}

/* INSTALL + stats */
.sim-r-install{background:#FAF9F6}
.sim-r-ih{display:flex;justify-content:space-between;align-items:flex-end;gap:36px;flex-wrap:wrap;margin-bottom:40px}
.sim-r-kwc{display:flex;align-items:baseline;gap:10px;margin-top:8px}
.sim-r-kwc-v{font-size:clamp(56px,7vw,88px);font-weight:700;line-height:.85;letter-spacing:-.03em;color:#1E2D3F}
.sim-r-kwc-u{font-size:28px;font-weight:600;color:#6B7888}
.sim-r-kwc-s{font-size:16px;color:#6B7888;max-width:32ch}
.sim-r-kwc-s strong{color:#1E2D3F}
.sim-r-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.sim-r-st{background:#fff;border:1px solid rgba(30,45,63,.10);border-radius:16px;padding:28px 24px}
.sim-r-st-v{font-size:34px;font-weight:700;letter-spacing:-.02em;line-height:1;color:#1E2D3F;font-variant-numeric:tabular-nums}
.sim-r-st-l{font-size:13.5px;color:#6B7888;margin-top:9px;line-height:1.3}
.sim-r-st.accent .sim-r-st-v{color:#C26A00}

/* SCENARIO profil ajustable */
.sim-r-scenario{background:#fff;border-top:1px solid rgba(30,45,63,.10)}
.sim-r-sg{display:grid;grid-template-columns:.85fr 1.15fr;gap:52px;align-items:center;margin-top:40px}
.sim-r-schema{text-align:center}
.sim-r-schema img{width:78%;max-width:320px}
.sim-r-ptabs{display:flex;gap:10px;margin-bottom:24px;flex-wrap:wrap}
.sim-r-ptab{flex:1;min-width:130px;padding:14px;border:1.5px solid rgba(30,45,63,.18);border-radius:12px;background:#fff;cursor:pointer;font-family:inherit;font-weight:600;font-size:14px;color:#1E2D3F;transition:.15s}
.sim-r-ptab.on{border-color:#F5A623;background:rgba(245,166,35,.10)}
.sim-r-sout{display:flex;gap:40px;flex-wrap:wrap}
.sim-r-so-v{font-size:38px;font-weight:700;color:#C26A00;line-height:1;font-variant-numeric:tabular-nums}
.sim-r-so-l{font-size:13.5px;color:#6B7888;margin-top:6px}

/* COMPARAISON facture */
.sim-r-compare{background:#FAF9F6}
.sim-r-legend{display:flex;gap:24px;margin:18px 0 24px;font-size:13.5px;color:#6B7888}
.sim-r-legend span{display:inline-flex;align-items:center;gap:8px}
.sim-r-legend i{width:14px;height:14px;border-radius:3px;display:inline-block}
.sim-r-bars{display:flex;align-items:flex-end;gap:20px;height:300px;padding:24px 8px 0;border-bottom:1px solid rgba(30,45,63,.12)}
.sim-r-bc{flex:1;display:flex;flex-direction:column;align-items:center;gap:0;height:100%;justify-content:flex-end}
.sim-r-bpair{display:flex;align-items:flex-end;gap:6px;width:100%;justify-content:center;height:100%}
.sim-r-bar{width:34px;border-radius:6px 6px 0 0;position:relative;transition:height .7s cubic-bezier(.4,0,.2,1)}
.sim-r-bar.sans{background:#cdd3da}
.sim-r-bar.avec{background:#F5A623}
.sim-r-bar-v{position:absolute;top:-22px;left:50%;transform:translateX(-50%);font-size:11.5px;font-weight:600;color:#1E2D3F;white-space:nowrap;font-variant-numeric:tabular-nums}
.sim-r-byr{font-size:13px;color:#6B7888;margin-top:10px}

/* CLIMAX — SEUL navy */
.sim-r-climax{background:#1E2D3F;color:#fff;text-align:center}
.sim-r-climax-lead{font-size:18px;color:rgba(255,255,255,.7);margin-bottom:8px}
.sim-r-climax-hero{display:flex;align-items:baseline;justify-content:center;gap:8px;margin-bottom:8px}
.sim-r-climax-v{font-size:clamp(60px,9vw,112px);font-weight:700;color:#F5A623;letter-spacing:-.03em;line-height:.85;font-variant-numeric:tabular-nums}
.sim-r-climax-u{font-size:46px;font-weight:700;color:#F5A623}
.sim-r-curve{margin:40px auto 16px;max-width:920px;position:relative}
.sim-r-curve svg{width:100%;height:300px;overflow:visible;display:block}
.sim-r-cv-area{fill:url(#simgrad)}
.sim-r-cv-line{fill:none;stroke:#F5A623;stroke-width:3.5;stroke-linecap:round}
.sim-r-cv-grid{stroke:rgba(255,255,255,.08)}
.sim-r-cv-zero{stroke:rgba(255,255,255,.25);stroke-dasharray:5 5}
.sim-r-cv-lbl{fill:rgba(255,255,255,.5);font-size:13px}
.sim-r-cv-hit{fill:transparent;cursor:crosshair}
.sim-r-cv-cursor{stroke:rgba(245,166,35,.55);stroke-width:1.5;stroke-dasharray:4 4;opacity:0}
.sim-r-cv-dot{fill:#fff;stroke:#F5A623;stroke-width:3;opacity:0}
.sim-r-cv-eq{fill:#1FA868;stroke:#fff;stroke-width:2.5}
.sim-r-bubble{position:absolute;background:#fff;color:#1E2D3F;padding:8px 13px;border-radius:9px;font-size:13.5px;font-weight:600;pointer-events:none;opacity:0;transform:translate(-50%,-135%);white-space:nowrap;box-shadow:0 8px 24px rgba(0,0,0,.25);transition:opacity .15s}
.sim-r-bubble b{color:#C26A00}
.sim-r-climax-note{font-size:12.5px;color:rgba(255,255,255,.45);max-width:60ch;margin:10px auto 0;line-height:1.5}

/* CTA premium */
.sim-r-cta{background:#fff;border-top:1px solid rgba(30,45,63,.10)}
.sim-r-cta-feats{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:44px}
.sim-r-feat{display:flex;gap:16px;align-items:center;padding:24px;border:1px solid rgba(30,45,63,.10);border-radius:14px;background:#FAF9F6}
.sim-r-feat img{width:48px;height:48px;flex:none}
.sim-r-feat h4{font-size:16.5px;font-weight:700;margin:0 0 3px;color:#1E2D3F}
.sim-r-feat p{font-size:13.5px;color:#6B7888;margin:0}
.sim-r-cta-head{text-align:center;margin-bottom:32px}
.sim-r-cta-head h3{font-size:clamp(24px,3vw,34px);font-weight:700;margin:0 0 10px;color:#1E2D3F}
.sim-r-cta-head p{font-size:16px;color:#6B7888;max-width:50ch;margin:0 auto}
.sim-r-slots{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;max-width:720px;margin:0 auto}
.sim-r-slot{padding:22px 16px;border:1.5px solid rgba(30,45,63,.18);border-radius:14px;background:#fff;cursor:pointer;font-family:inherit;font-size:16px;font-weight:600;color:#1E2D3F !important;transition:.15s;display:flex;flex-direction:column;gap:4px;align-items:center}
.sim-r-slot span{font-size:13px;font-weight:500;color:#6B7888}
.sim-r-slot:hover{border-color:#F5A623;transform:translateY(-2px)}
.sim-r-slot.is-sel{border-color:#F5A623 !important;background:rgba(245,166,35,.12) !important}
.sim-r-slot-done{margin:26px auto 0;max-width:600px;padding:18px 20px;font-size:15px;color:#1FA868;background:rgba(31,168,104,.10);border-radius:12px;line-height:1.5;text-align:center}

@media (max-width:900px){
	.sim-r-ag,.sim-r-sg{grid-template-columns:1fr;gap:32px}
	.sim-r-stats,.sim-r-slots,.sim-r-cta-feats{grid-template-columns:repeat(2,1fr)}
	.sim-r-sec{padding:48px 0}
	.sim-r-bar{width:24px}
}
@media (prefers-reduced-motion:reduce){
	.sim-r [data-anim]{transition:opacity .3s ease;transform:none}
	.sim-r-bar{transition:none}
}

/* FIX : boutons compte-rendu doivent battre le reset global button !important */
.sim-r-ptab{border:1.5px solid rgba(30,45,63,.18) !important;background:#fff !important;color:#1E2D3F !important}
.sim-r-ptab.on{border-color:#F5A623 !important;background:rgba(245,166,35,.10) !important}
.sim-r-slot{border:1.5px solid rgba(30,45,63,.18) !important;background:#fff !important}
.sim-r-slot:hover{border-color:#F5A623 !important;background:#fff !important}
.sim-r-slot.is-sel{border-color:#F5A623 !important;background:rgba(245,166,35,.12) !important}

/* FIX créneaux : structure interne (le reset global casse le span) */
.sim-r-slot{display:flex !important;flex-direction:column !important;align-items:center !important;justify-content:center !important;gap:5px !important;white-space:normal !important;text-align:center;min-height:84px}
.sim-r-slot span{display:block !important;width:100%;font-size:13px;font-weight:500;color:#6B7888 !important}

/* ============================================================
   S5 facture — toggle voiture électrique
   ============================================================ */
.sim-ve{margin:28px 0 4px;padding:20px;background:#fff;border:1px solid rgba(30,45,63,.10);border-radius:14px}
.sim-ve-q{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.sim-ve-ico{width:34px;height:34px;flex:none;display:block}
.sim-ve-q span{font-size:15px;font-weight:600;color:#1E2D3F;line-height:1.3}
.sim-ve-opts{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.sim-ve-btn{padding:13px;font-family:inherit;font-size:15.5px;font-weight:600;color:#1E2D3F !important;background:#fff !important;border:1.5px solid rgba(30,45,63,.18) !important;border-radius:10px;cursor:pointer;transition:border-color .15s ease,background .15s ease;white-space:normal !important}
.sim-ve-btn:hover{border-color:#F5A623 !important}
.sim-ve-btn.is-sel{border-color:#F5A623 !important;background:rgba(245,166,35,.10) !important}

/* Voiture élec : 3 choix + icône agrandie */
.sim-ve-opts{grid-template-columns:repeat(3,1fr)}
.sim-ve-btn{font-size:14px;padding:13px 8px}
.sim-ve-ico{width:100px;height:100px}

/* FIX mobile : features CTA en 1 colonne empilée */
@media (max-width:700px){
	.sim-r-cta-feats{grid-template-columns:1fr;gap:14px}
	.sim-r-feat{padding:18px}
	.sim-r-feat img{width:42px;height:42px}
}
