/* ============ offre.css (simulator + form) ============ */
.ohero{background:var(--navy);color:#fff;text-align:center;padding:60px 24px 54px;position:relative;overflow:hidden}
.ohero::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 120% at 50% -10%,rgba(140,191,68,.4),transparent 55%)}
.ohero h1{position:relative;font-size:clamp(2rem,4.5vw,3rem);font-weight:800;margin:6px 0 10px}
.ohero p{position:relative;color:#D7DBE0;max-width:60ch;margin:0 auto;font-size:1.05rem}

.sim-grid{display:grid;grid-template-columns:1.55fr .95fr;gap:34px;align-items:start}
.sim-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px;margin-bottom:24px}
.sim-card h3{font-size:1.1rem;color:var(--navy);font-weight:800;margin-bottom:4px;display:flex;align-items:center;gap:10px}
.sim-card h3 svg{width:20px;height:20px;color:var(--green-dk)}
.sim-card .hint{font-size:.86rem;color:var(--muted);margin-bottom:16px}

.field{margin-bottom:16px}
.field label{display:block;font-size:.8rem;font-weight:600;color:var(--navy);margin-bottom:6px}
.field input{width:100%;border:1px solid var(--line);border-radius:10px;padding:12px 14px;font-family:inherit;font-size:.95rem;color:var(--ink);transition:border-color .15s}
.field input:focus{outline:none;border-color:var(--green)}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px}

.sim-row{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:14px;padding:12px 0;border-top:1px solid var(--line)}
.sim-row:first-of-type{border-top:0}
.sim-row .nm{font-size:.92rem;color:var(--navy);font-weight:600}
.sim-row .nm small{display:block;font-weight:500;color:var(--muted);font-size:.78rem}
.qty{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:9px;overflow:hidden}
.qty button{width:32px;height:36px;border:0;background:var(--soft);color:var(--navy);font-size:1.1rem;font-weight:700;cursor:pointer;line-height:1}
.qty button:hover{background:var(--greent)}
.qty input{width:46px;height:36px;border:0;border-left:1px solid var(--line);border-right:1px solid var(--line);text-align:center;font-family:inherit;font-size:.95rem;font-weight:600;color:var(--navy);-moz-appearance:textfield}
.qty input::-webkit-outer-spin-button,.qty input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.sim-row .line{font-weight:700;color:var(--green-dk);min-width:96px;text-align:right;font-size:.95rem}

/* summary */
.summary{position:sticky;top:100px;background:var(--navy);color:#fff;border-radius:18px;padding:26px;box-shadow:var(--shadow)}
.summary h3{font-size:1rem;color:#fff;margin-bottom:18px;letter-spacing:.04em}
.sline{display:flex;justify-content:space-between;font-size:.9rem;color:#cdd2da;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.sline b{color:#fff;font-weight:600}
.stotal{display:flex;justify-content:space-between;align-items:baseline;margin-top:16px}
.stotal span{font-size:.85rem;color:#aeb6c1}
.stotal b{font-size:2rem;font-weight:800;color:var(--green);line-height:1}
.syear{font-size:.82rem;color:#aeb6c1;margin-top:4px;text-align:right}
.summary .btn{width:100%;justify-content:center;margin-top:20px}
.summary .smallnote{font-size:.74rem;color:#8b94a1;margin-top:12px;line-height:1.4}
.formok{display:none;background:var(--greent);border:1px solid var(--greent2);color:var(--green-dk);border-radius:10px;padding:12px 14px;font-size:.88rem;font-weight:600;margin-top:14px}

/* contact strip */
.cta{position:relative;background:var(--navy);color:#fff;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;background:radial-gradient(50% 90% at 15% 100%,rgba(140,191,68,.4),transparent 60%)}
.cta .wrap{position:relative;display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;align-items:center;padding:60px 24px}
.cta h2{font-size:clamp(1.7rem,3vw,2.3rem);font-weight:800}
.cta-contacts{display:flex;flex-wrap:wrap;gap:10px 26px;margin-top:10px}
.cta-contacts a,.cta-contacts span{display:flex;align-items:center;gap:10px;color:#D7DBE0;font-weight:500;font-size:.95rem}
.cta-contacts svg{width:18px;height:18px;color:var(--green)}

@media (max-width:880px){.sim-grid{grid-template-columns:1fr}.summary{position:static}}
@media (max-width:520px){.fgrid{grid-template-columns:1fr}.sim-row{grid-template-columns:1fr auto;grid-template-areas:"nm qty" "line line"}.sim-row .nm{grid-area:nm}.qty{grid-area:qty}.sim-row .line{grid-area:line;text-align:left;min-width:0}}

/* ---- sélecteur de pays du simulateur (ajout) ---- */
.sim-row .sel{justify-self:end}
.sim-row .sel select{appearance:none;-webkit-appearance:none;background:var(--soft);border:1px solid var(--line);border-radius:9px;padding:8px 34px 8px 12px;font-family:inherit;font-size:.92rem;font-weight:600;color:var(--navy);cursor:pointer;min-width:170px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235E8A28' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:16px}
.sim-row .sel select:focus{outline:none;border-color:var(--green)}
@media (max-width:520px){.sim-row .sel{justify-self:start}.sim-row .sel select{min-width:0;width:100%}}

/* ---- téléphonie verrouillée tant qu'IMAGINE Connect < 1 ---- */
.tel-locked-note{display:none;align-items:center;gap:8px;font-size:.84rem;font-weight:600;color:#c0392b;background:#fdecea;border:1px solid #f3c5c0;border-radius:9px;padding:9px 12px;margin-bottom:14px}
.tel-locked-note svg{width:16px;height:16px;flex:0 0 auto}
.sim-card.tel-locked .tel-locked-note{display:flex}
.sim-card.tel-locked #tel-hint{opacity:.45}
.sim-row.locked{opacity:.5}
.sim-row.locked .qty button,.sim-row.locked select:disabled,.sim-row.locked input:disabled{cursor:not-allowed}

/* ---- message d'erreur d'envoi du devis ---- */
.formerr{display:block;background:#fdecea;border:1px solid #f3c5c0;color:#c0392b;border-radius:10px;padding:12px 14px;font-size:.88rem;font-weight:600;margin-top:14px}

/* ---- référence de devis (auto-générée, lecture seule) ---- */
.ref-field input[readonly]{background:var(--greent);border:1px solid var(--greent2);border-style:dashed;color:var(--green-dk);font-weight:700;letter-spacing:.05em;cursor:default;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}
.ref-field input[readonly]:focus{outline:none;border-color:var(--green)}
