/* ─────────────────────────────────────────────────────────────
   index.css — Styles spécifiques à public/index.php
   Les styles globaux (header, footer, nav, pre-header…) sont
   dans style.css qui est chargé avant ce fichier.
───────────────────────────────────────────────────────────── */
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;z-index:9999;background:#136c38;color:#fff;padding:8px 14px;border-radius:0 0 6px 6px;font-weight:700;text-decoration:none;}
.skip-link:focus{left:0;width:auto;height:auto;}
.header-left .logo{width:154px;margin-bottom:2px;}
@media(max-width:768px){.header-left .logo{width:110px;}}
#main-content > .content{width:calc(100% + 56px);margin-left:-28px;margin-right:-28px;padding-left:0;padding-right:0;}
#main-content > .content > .hero{border-radius:0;}
#main-content > .diagnostics-carousel{border:2px solid transparent;border-radius:38px;background:linear-gradient(#e6eeeb,#e6eeeb) padding-box,linear-gradient(90deg,#136c38,#2361a7) border-box;}
.home-why-list li{white-space:nowrap;}
.infos-complementaires-grid > div{min-width:0;}
.infos-complementaires-grid select,
.infos-complementaires-grid input,
.infos-complementaires-grid textarea{font:inherit;}
@media(max-width:700px){
  #main-content > .content{width:calc(100% + 24px);margin-left:-12px;margin-right:-12px;}
}
@media(max-width:700px){
  .home-why-section{padding-left:16px!important;padding-right:16px!important;}
  .home-why-list{grid-template-columns:1fr!important;}
  .home-why-list li{white-space:normal;}
  .infos-complementaires-grid{grid-template-columns:1fr!important;}
  .infos-complementaires-grid > div{grid-column:auto!important;}
}
.diag-regl-hint{
  display:none;
  position:absolute;
  left:0;bottom:calc(100% + 5px);
  background:#5c4300;color:#fff;
  font-size:.75rem;font-style:normal;font-weight:500;
  white-space:pre-line;
  max-width:220px;
  padding:3px 9px;
  border-radius:5px;
  box-shadow:0 2px 8px rgba(0,0,0,.25);
  z-index:20;
  pointer-events:none;
  line-height:1.4;
}
.diag-regl-hint::after{
  content:'';
  position:absolute;
  top:100%;left:14px;
  border:5px solid transparent;
  border-top-color:#5c4300;
}
.diag-item:hover .diag-regl-hint{display:block;}

/* === Diagnostics : états obligatoire / grisé / prix === */
.diag-item{position:relative;}
.diag-item.diag-obligatoire {
  background: #e8f5e9;
  border-radius: 4px;
  padding: 2px 6px;
  cursor: help;
}
.diag-item.diag-obligatoire input[type=checkbox] + * { color: #2e7d32; font-weight: 600; }
.diag-item.diag-grise {
  cursor: help;
}
.diag-item.diag-grise::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0.62);
  z-index: 2;
  pointer-events: none;
}
.diag-item.diag-grise .diag-regl-hint {
  z-index: 25;
}
.diag-price {
  font-size: 12px;
  color: #475569;
  font-weight: 600;
  white-space: nowrap;
  line-height: 1;
}

/* === Panneau RDV public === */
.public-rdv-panel{display:none;margin-top:18px;padding:18px;border:1px solid #d7e3f4;border-radius:14px;background:linear-gradient(180deg,#f8fbff 0%,#eef5ff 100%);}
.public-rdv-panel.open{display:block;}
.public-rdv-panel h3{margin:0 0 8px;color:#0d4e91;}
.public-rdv-panel p{margin:8px 0;color:#334155;}
.public-rdv-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.public-rdv-header-links{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:.95rem;color:#475569;}
.public-rdv-header-links a{color:#0d4e91;text-decoration:underline;font-weight:600;}
.public-rdv-steps{display:flex;gap:10px;flex-wrap:wrap;margin:14px 0 18px;}
.public-rdv-step{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:#dbe7f5;color:#52606d;font-size:.88rem;font-weight:700;}
.public-rdv-step-number{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:#fff;color:#0d4e91;}
.public-rdv-step.active{background:#0d4e91;color:#fff;}
.public-rdv-step.active .public-rdv-step-number{color:#0d4e91;}
.public-rdv-step.done{background:#dff3e8;color:#166534;}
.public-rdv-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:14px;}
.public-rdv-grid .full{grid-column:1/-1;}
.public-rdv-grid label{display:block;margin-bottom:4px;font-size:.88rem;color:#334155;font-weight:600;}
.public-rdv-grid input{width:100%;padding:10px 12px;border:1px solid #cbd5e1;border-radius:8px;box-sizing:border-box;background:#fff;}
.address-copy-row{grid-column:1/-1;}
.address-copy-check{display:inline-flex!important;align-items:center;gap:8px;margin:2px 0 0!important;width:auto;max-width:100%;line-height:1.35;cursor:pointer;color:#334155;font-size:.9rem;font-weight:650;}
.address-copy-check input[type="checkbox"]{width:16px!important;height:16px;margin:0!important;padding:0!important;flex:0 0 16px;border:1px solid #94a3b8;border-radius:3px;box-shadow:none;accent-color:#136c38;}
.address-autocomplete-host{position:relative;}
.address-suggestions{position:absolute;z-index:40;left:0;right:0;top:calc(100% + 3px);margin:0;padding:0;list-style:none;background:#fff;border:1px solid #cbd5e1;border-radius:8px;box-shadow:0 10px 24px rgba(15,23,42,.14);max-height:230px;overflow:auto;}
.address-suggestions[hidden]{display:none;}
.address-suggestions li{padding:9px 12px;cursor:pointer;font-size:.86rem;line-height:1.35;color:#22324a;border-bottom:1px solid #edf2f7;background:#fff;}
.address-suggestions li:last-child{border-bottom:0;}
.address-suggestions li:hover,.address-suggestions li:focus{background:#edf6ff;outline:none;}
.public-rdv-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:16px;}
.public-payment-options{display:flex;gap:12px;flex-wrap:wrap;margin-top:12px;}
.public-payment-options label{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid #cbd5e1;border-radius:8px;background:#fff;cursor:pointer;}
.payment-brand-line{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;vertical-align:middle;}
.payment-brand-paypal{display:inline-flex;align-items:center;padding:2px 8px;border-radius:5px;background:#fff;color:#003087;border:1px solid #c7d7f3;font-weight:800;letter-spacing:-.02em;line-height:1.25;}
.payment-brand-4x{display:inline-flex;align-items:center;padding:2px 7px;border-radius:5px;background:#ffc439;color:#003087;border:1px solid #f4b000;font-weight:800;font-size:.82rem;line-height:1.25;}
.payment-brand-stripe{height:20px;width:auto;display:inline-block;object-fit:contain;vertical-align:middle;}
.public-rdv-note{font-size:.92rem;color:#0d4e91;font-weight:600;}
.public-rdv-inline-msg{margin-top:12px;padding:12px 14px;border-radius:8px;display:none;}
.public-rdv-inline-msg.error{display:block;background:#fdecec;color:#9f1239;border:1px solid #f5c2c7;}
.public-rdv-inline-msg.success{display:block;background:#e9f8ef;color:#166534;border:1px solid #b7e4c7;}
.public-payment-next{margin-top:12px;}
.public-rdv-stage{display:none;}
.public-rdv-stage.active{display:block;}
.public-rdv-summary{padding:12px 14px;border:1px solid #cbd5e1;border-radius:10px;background:#fff;margin-top:12px;}
.public-rdv-summary strong{color:#0f172a;}
@media(max-width:700px){.public-rdv-grid{grid-template-columns:1fr;}}

/* === Encart conformité / consentement === */
.public-compliance-box{margin:14px 0;padding:14px 16px;border:1px solid #cfe3d7;border-radius:12px;background:linear-gradient(180deg,#f7fcf8 0%,#eef8f1 100%);font-style:italic;font-size:.82rem;}
.public-compliance-box h4{margin:0 0 8px;color:#136c38;font-size:.9rem;}
.public-compliance-box p{margin:6px 0;color:#334155;line-height:1.5;}
.public-compliance-box ul{margin:8px 0 0 18px;padding:0;color:#334155;line-height:1.5;}
.public-compliance-box .pricing-note{margin-top:10px;padding:10px 12px;border-radius:10px;background:#fff;border:1px dashed #b7c8db;color:#475569;line-height:1.5;}
.public-compliance-box .consent-checklist{display:grid;gap:8px;margin-top:12px;}
.public-compliance-box .consent-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border:1px solid #d7e3f4;border-radius:10px;background:#fff;font-style:normal;}
.public-compliance-box .consent-item input[type=checkbox]{margin-top:3px;flex-shrink:0;accent-color:#136c38;}
.public-compliance-box .consent-item label{cursor:pointer;line-height:1.4;color:#22324a;}

/* === Modale RDV iframe === */
.rdv-modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.65);display:none;align-items:center;justify-content:center;z-index:5000;padding:18px;}
.rdv-modal-overlay.open{display:flex;}
.rdv-modal{width:min(1100px,96vw);height:min(88vh,900px);background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 18px 50px rgba(2,6,23,.35);position:relative;}
.rdv-modal-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid #e5e7eb;background:#f8fafc;}
.rdv-modal-title{margin:0;font-size:15px;font-weight:700;color:#0f172a;}
.rdv-modal-close{border:0;border-radius:8px;background:#e2e8f0;color:#111827;font-weight:700;padding:8px 10px;cursor:pointer;}
.rdv-modal-close:hover{background:#cbd5e1;}
.rdv-modal-frame{width:100%;height:calc(100% - 48px);border:0;background:#fff;}

/* === WIZARD Diagnostics Existants === */
.wiz-oui-non{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap;}
.wiz-btn{padding:7px 0;flex:1 1 0;min-width:0;text-align:center;border-radius:12px;border:2px solid var(--border);background:#fff;color:var(--text);font-size:.93rem;font-weight:600;cursor:pointer;transition:.2s ease;}
.wiz-btn:hover{border-color:var(--accent);}
.wiz-btn.active.wiz-btn-non{border-color:#64748b;background:#64748b;color:#fff;}
.wiz-btn.active.wiz-btn-oui{border-color:var(--accent-green);background:var(--accent-green);color:#fff;}
@media(max-width:480px){.wiz-btn{flex:1 1 100%;}}
.wiz-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(195px,1fr));gap:12px;margin-top:12px;}
.wiz-bloc{background:#f7faff;border:1px solid #d0dce8;border-radius:10px;padding:12px 13px;display:flex;flex-direction:column;gap:5px;}
.wiz-bloc-head{font-size:.88rem;font-weight:700;color:#2361a7;margin-bottom:4px;padding-bottom:5px;border-bottom:1px solid #dce8f8;}
.wiz-lbl{display:flex;align-items:flex-start;gap:7px;font-size:.84rem;color:#334155;cursor:pointer;line-height:1.35;margin:0;}
.wiz-lbl input[type=checkbox]{margin-top:2px;flex-shrink:0;accent-color:#136c38;cursor:pointer;}
.wiz-sub{display:none;margin-top:4px;padding-left:2px;}
.wiz-sub.open{display:block;}
.wiz-select{width:100%;padding:5px 8px;border-radius:6px;border:1px solid #aac4e0;font-size:.82rem;background:#fff;color:#1e293b;}
.wiz-note{font-size:.78rem;color:#b45309;font-style:italic;margin:0;}
.wiz-result-bar{display:none;margin-top:12px;padding:9px 14px;background:#e8f5e9;border:1px solid #a5d6a7;border-radius:8px;font-size:.85rem;color:#166534;line-height:1.7;}
.wiz-badge{display:inline-block;margin-left:6px;padding:1px 7px;border-radius:999px;font-size:.7rem;font-weight:700;vertical-align:middle;}
.wiz-badge.valide{background:#e8f5e9;color:#136c38;border:1px solid #a5d6a7;}
.wiz-badge.expire{background:#fdecea;color:#c0392b;border:1px solid #f5c2c7;}
.diag-item.wiz-valide{background:#f0faf4;border-radius:4px;}
.diag-item.wiz-valide::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,0.35);z-index:3;pointer-events:none;}
.diag-item.wiz-valide .diag-regl-hint{z-index:26;}
.wiz-lbl.is-disabled{position:relative;color:#64748b;cursor:not-allowed;}
.wiz-lbl.is-disabled::before{content:'';position:absolute;inset:0;background:rgba(255,255,255,0.32);border-radius:6px;pointer-events:none;}
.wiz-no-install-step{margin-top:12px;}
.wiz-grid.wiz-grid-install-age{grid-template-columns:repeat(2,minmax(0,1fr));max-width:620px;margin-left:auto;margin-right:auto;}
.wiz-grid.wiz-grid-existing-diags{grid-template-columns:repeat(4,minmax(0,1fr));}
@media(max-width:1100px){.wiz-grid.wiz-grid-existing-diags{grid-template-columns:repeat(3,minmax(0,1fr));}}
@media(max-width:700px){.wiz-grid.wiz-grid-existing-diags{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media(max-width:600px){.wiz-grid.wiz-grid-install-age{grid-template-columns:1fr;}}
@media(max-width:440px){.wiz-grid.wiz-grid-existing-diags{grid-template-columns:1fr;}}
@media(max-width:700px){.wiz-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:440px){.wiz-grid{grid-template-columns:1fr;}.wiz-btn{flex:1 1 140px;}}

/* Bouton "Prendre RDV" dans le pre-header (spécifique index.php) */
#btnPrendreRdv.btn.btn-ghost{background:#136c38;color:#ffffff;border:1px solid #136c38;}

/* === Créneaux disponibles widget === */
.creneaux-widget{margin:14px 0 8px;}
.creneaux-widget-title{font-size:.87rem;font-weight:700;color:#0d4e91;margin-bottom:8px;}
.creneaux-list{display:flex;flex-wrap:wrap;gap:8px;min-height:40px;}
.creneaux-card{flex:1 1 0;min-width:140px;max-width:210px;padding:9px 10px;background:#f0f7ff;border:2px solid #bbd6f7;border-radius:10px;text-align:center;font-size:.83rem;color:#0d4e91;font-weight:600;line-height:1.4;}
.creneaux-card .cr-dur{display:block;font-size:.75rem;font-weight:400;margin-top:2px;opacity:.8;}
.creneaux-loading{font-size:.8rem;color:#6b7280;padding:4px 0;}
.creneaux-error{font-size:.8rem;color:#dc2626;padding:4px 0;}
.creneaux-hint{font-size:.78rem;color:#6b7280;margin:5px 0 0;}
@media(max-width:500px){.creneaux-card{min-width:100%;max-width:100%;}}

/* ── Barre créneaux disponibles ── */
.slots-bar{background:#ffffff;height:44px;min-height:44px;padding:0 18px;display:flex;align-items:center;justify-content:center;gap:18px;overflow:hidden;font-size:12.5px;flex-wrap:nowrap;}
.slots-bar-label{font-weight:700;color:#136c38;flex-shrink:0;}
#slotsBarContent{min-width:0;min-height:24px;display:inline-flex;align-items:center;justify-content:center;gap:4px;flex:0 1 auto;max-width:100%;overflow-x:auto;overflow-y:hidden;flex-wrap:nowrap;white-space:nowrap;scrollbar-width:thin;}
.slot-chip{display:inline-block;background:#fff;border:1px solid #136c38;color:#136c38;border-radius:16px;padding:1px 9px;font-size:12.8px;line-height:1.15;white-space:nowrap;margin:0 2px;display:inline-flex;align-items:center;flex:0 0 auto;}
.slot-empty{font-size:12px;color:#6b7280;}
@media(max-width:1024px) and (min-width:601px){.slots-bar{height:70px;min-height:70px;flex-direction:column;align-items:stretch;justify-content:center;gap:5px;padding:7px 14px;font-size:12px;}.slots-bar-label{text-align:center;margin-bottom:0;}#slotsBarContent{width:100%;max-width:100%;flex:0 1 auto;justify-content:center;flex-wrap:wrap;white-space:normal;overflow:hidden;gap:5px 4px;}.slot-chip{margin:0;padding:2px 8px;font-size:12.2px;}}
@media(max-width:600px){.slots-bar{height:82px;min-height:82px;flex-direction:column;gap:6px;padding:8px 12px;}.slots-bar-label{margin-bottom:2px;text-align:center;}#slotsBarContent{width:100%;flex:0 1 auto;justify-content:center;}}
@media(max-width:600px){#main-fields-grid{grid-template-columns:1fr!important;}}

/* ── CTA pages villes ── */
.city-quote-cta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:14px 0 22px;align-items:stretch;}
.city-quote-cta-card{box-sizing:border-box;display:flex;flex-direction:column;justify-content:center;gap:6px;min-height:116px;padding:16px 18px;border-radius:8px;text-decoration:none;line-height:1.35;box-shadow:0 5px 16px rgba(16,35,58,.08);transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease;}
.city-quote-cta-card:hover,.city-quote-cta-card:focus-visible{transform:translateY(-1px);box-shadow:0 9px 22px rgba(35,97,167,.15);outline:none;}
.city-quote-cta-primary{background:#0d4e91;border:1px solid #0d4e91;color:#fff;}
.city-quote-cta-secondary{background:#136c38;border:1px solid #136c38;color:#fff;}
.city-quote-cta-title{display:block;font-size:1rem;font-weight:800;text-align:center;}
.city-quote-cta-text{display:block;font-size:.88rem;font-weight:500;}
.city-quote-cta-primary .city-quote-cta-text{color:rgba(255,255,255,.92);}
.city-quote-cta-secondary .city-quote-cta-title{color:#fff;}
.city-quote-cta-secondary .city-quote-cta-text{color:rgba(255,255,255,.92);}
@media(max-width:680px){.city-quote-cta{grid-template-columns:1fr;}.city-quote-cta-card{min-height:auto;padding:15px 16px;}}
.diagnostic-quote-cta{display:flex;justify-content:center;margin:10px 0 22px;}
.diagnostic-quote-button{display:inline-flex;align-items:center;justify-content:center;min-height:44px;max-width:100%;box-sizing:border-box;padding:12px 24px;border:1px solid #0d4e91;border-radius:8px;background:#0d4e91;color:#fff;text-decoration:none;font-weight:800;font-size:.98rem;line-height:1.2;text-align:center;box-shadow:0 5px 16px rgba(16,35,58,.10);transition:transform .18s ease,background-color .18s ease,box-shadow .18s ease;}
.diagnostic-quote-button:hover,.diagnostic-quote-button:focus-visible{background:#0a447f;color:#fff;transform:translateY(-1px);box-shadow:0 9px 22px rgba(35,97,167,.16);outline:none;}
@media(max-width:480px){.diagnostic-quote-button{width:100%;padding:12px 18px;}}

/* ── Barre accès rapide (index.php) ── */
.quick-access-bar{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;width:100%;box-sizing:border-box;padding:6px 12px;background:#f8fafc;border-bottom:1px solid #e2e8f0;}
.quick-access-link{display:inline-flex;align-items:center;justify-content:center;gap:6px;flex:1 1 180px;min-width:0;padding:5px 8px;background:#fff;border-radius:8px;font-weight:600;font-size:.86rem;line-height:1.1;text-decoration:none;box-sizing:border-box;}
.quick-access-link-client{border:1.5px solid #136c38;color:#136c38;}
.quick-access-link-pro{border:1.5px solid #2361a7;color:#2361a7;}

/* ── Hero accueil (index.php) ── */
.hero-home{background:linear-gradient(90deg,#136c38 0%,#2361a7 100%);border-bottom:1px solid #dce8fb;}
.hero-home-title{text-align:center;color:#ffffff;font-size:1.6rem;}
.hero-home-lead-wrap{background:#e6eeeb;border-radius:12px;}
.devis-launcher{display:flex;flex-direction:column;align-items:center;gap:16px;max-width:900px;margin:22px auto 18px;padding:30px 28px;text-align:center;background:url('/img/devis-card-bg-light-1000.webp') center center/cover no-repeat;border:1px solid #d7e3f4;border-radius:8px;box-shadow:0 6px 18px rgba(35,97,167,.08);}
.devis-launcher-hidden{display:none;}
.devis-launcher-copy{max-width:820px;padding:18px 22px;background:rgba(230,238,235,.70);border-radius:8px;}
.devis-launcher-copy h1{margin:0 0 10px;color:#10233a;font-size:calc(1.5rem + 3px);font-weight:700;line-height:1.25;text-shadow:none;}
.devis-launcher-copy p{margin:0;color:#111;font-size:1rem;font-weight:600;line-height:1.65;text-shadow:none;}
.devis-launcher .btn{flex:0 1 auto;}
.devis-launcher-btn{min-width:220px;padding:12px 24px;border-radius:8px;font-size:1rem;}
.devis-contact-options{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-auto-rows:96px;align-items:stretch;gap:12px;width:100%;max-width:820px;}
.devis-contact-options[hidden]{display:none;}
.devis-contact-card{box-sizing:border-box;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;width:100%;height:100%;margin:0;padding:14px 16px;border:1px solid rgba(35,97,167,.22);border-radius:8px;background:rgba(255,255,255,.94);color:#22324a;text-align:center;text-decoration:none;line-height:1.25;box-shadow:0 4px 12px rgba(16,35,58,.08);transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease;}
.devis-contact-card:hover,.devis-contact-card:focus-visible{transform:translateY(-1px);border-color:#2361a7;box-shadow:0 8px 20px rgba(35,97,167,.14);outline:none;}
.devis-contact-card-title{display:block;width:100%;font-weight:700;color:#10233a;}
.devis-contact-card-text{display:block;width:100%;font-size:.92rem;line-height:1.35;color:#475569;}
.devis-contact-card-button{appearance:none;font:inherit;cursor:pointer;}
.devis-email-gate,.devis-contact-gate{width:100%;max-width:560px;padding:16px 18px;border:1px solid rgba(35,97,167,.22);border-radius:8px;background:rgba(255,255,255,.96);box-shadow:0 4px 14px rgba(16,35,58,.1);text-align:left;}
.devis-email-gate[hidden],.devis-contact-gate[hidden]{display:none;}
.devis-email-gate label,.devis-contact-gate label{display:block;margin:0 0 8px;font-weight:700;color:#10233a;}
.devis-email-gate-row,.devis-contact-gate-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;}
.devis-email-gate input,.devis-contact-gate input,.devis-contact-gate select{box-sizing:border-box;width:100%;min-height:44px;padding:10px 12px;border:1px solid #cbd5e1;border-radius:8px;font:inherit;color:#10233a;background:#fff;}
.devis-email-gate input:focus,.devis-contact-gate input:focus,.devis-contact-gate select:focus{border-color:#2361a7;box-shadow:0 0 0 3px rgba(35,97,167,.14);outline:none;}
.devis-email-gate .btn,.devis-contact-gate .btn{min-height:44px;white-space:nowrap;}
.devis-email-gate-note,.devis-contact-gate-note{margin:10px 0 0;color:#475569;font-size:.84rem;line-height:1.45;}
.devis-email-gate-note a,.devis-contact-gate-note a{color:#2361a7;font-weight:700;}
.devis-email-gate-msg,.devis-contact-gate-msg{min-height:18px;margin:8px 0 0;font-size:.86rem;font-weight:700;}
.devis-email-gate-msg.error,.devis-contact-gate-msg.error{color:#b91c1c;}
.devis-email-gate-msg.success,.devis-contact-gate-msg.success{color:#136c38;}
.devis-phone-call-btn{box-sizing:border-box;width:100%;justify-content:center;margin-bottom:14px;text-decoration:none;}
.devis-phone-callback-title{margin:0 0 10px;text-align:center;color:#475569;font-size:.92rem;font-weight:700;}
.devis-phone-callback-form{margin:0;}
.devis-contact-gate-row + label{margin-top:12px;}
.devis-section-hidden{display:none;}
.devis-panel-hidden{display:none;}
@media(max-width:760px){.devis-contact-options{grid-template-columns:1fr;grid-auto-rows:104px;max-width:420px;}.devis-launcher{padding:22px 14px;background:linear-gradient(180deg,#f8fbff 0%,#eaf3ff 100%);}.devis-launcher-copy{padding:16px 14px;background:rgba(255,255,255,.9);}.devis-launcher-copy h1{font-size:1.45rem;line-height:1.22;}.devis-launcher-copy p{font-size:.98rem;line-height:1.55;}.devis-contact-card{padding:14px 18px;}.devis-email-gate-row,.devis-contact-gate-row{grid-template-columns:1fr;}.devis-email-gate .btn,.devis-contact-gate .btn{width:100%;}}
@media(min-width:761px){.devis-launcher-copy{background:rgba(230,238,235,.71);}}

/* ── Formulaire devis : styles sortis de index.php ── */
#main-fields-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.devis-progress-step{position:relative;transition:background-color 1.55s ease;}
.devis-progress-step::after{content:'';position:absolute;inset:-1px;background:#f5f9ff;border:1px solid #e6f0ff;border-radius:14px;pointer-events:none;z-index:8;opacity:0;transition:opacity 1.55s ease;will-change:opacity;}
.devis-progress-step-main{margin-bottom:16px;}
.devis-progress-step.is-progress-locked{opacity:1;filter:none;background:#f5f9ff;border-radius:14px;pointer-events:none;overflow:hidden;}
.devis-progress-step.is-progress-locked::after{opacity:1;}
.devis-progress-step.is-progress-unlocking{background:#f5f9ff;border-radius:14px;overflow:hidden;}
.devis-progress-step.is-progress-unlocking::after{opacity:1;}
.devis-progress-step.is-progress-complete:not(.is-progress-locked)::before{content:'✓';position:absolute;top:10px;right:12px;width:22px;height:22px;border-radius:999px;background:#136c38;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:800;}
.devis-step-requirement{margin:4px 0 10px;padding:6px 10px;border-left:3px solid #2361a7;border-radius:6px;background:#f2f7fc;color:#334155;font-size:.8rem;font-weight:650;line-height:1.35;}
#devis-step-main .devis-step-requirement{text-align:center;border-left:0;}
.devis-optional-label{font-size:.72rem;font-weight:600;color:#64748b;}
.diagnostics-required-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px;margin:10px 0 12px;}
.diagnostics-required-summary.is-empty{display:block;padding:10px 12px;border-radius:8px;background:#f8fafc;border:1px dashed #cbd5e1;color:#64748b;font-size:.84rem;}
.diagnostics-required-card{padding:9px 11px;border-radius:8px;background:#edf7f0;border:1px solid #b8ddc4;color:#14532d;font-size:.84rem;font-weight:750;}
.diagnostics-required-card small{display:block;margin-top:2px;color:#475569;font-size:.72rem;font-weight:500;line-height:1.3;}
.diagnostics-extra-block{margin-top:12px;padding:10px 12px;border-radius:10px;background:#f8fafc;border:1px solid #e2e8f0;}
.diagnostics-extra-title{margin:0 0 8px;color:#334155;font-size:.88rem;font-weight:750;}
#typeBien,
#cadre,
#surface{padding:5px 8px;}
#coproSelect{padding:5px 8px;border-radius:6px;border:1px solid #ccc;font-size:.9rem;width:100%;}
#anneeConstruction{width:175px;padding:6px;border-radius:6px;border:1px solid #ccc;color:#22324a;-webkit-text-fill-color:#22324a;background:#fff;}
.wizard-owner-note{margin:6px 0 0;font-size:.8rem;color:#b45309;font-style:italic;}
.wiz-lbl.wiz-lbl-offset{margin-top:4px;}
#wiz-plomb-date-sub,
#wiz-surfaces-hint{margin-top:6px;}
.infos-complementaires-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;align-items:end;}
.infos-complementaires-grid > div{min-width:0;}
.infos-complementaires-grid .infos-complementaires-full{grid-column:1 / -1;}
.infos-complementaires-grid label{display:block;font-size:.82rem;font-weight:600;color:#334155;margin-bottom:3px;}
.infos-complementaires-grid select,
.infos-complementaires-grid input{width:100%;padding:6px;border-radius:6px;border:1px solid #ccc;box-sizing:border-box;text-align:center;}
.infos-complementaires-grid textarea{width:100%;padding:8px 10px;border-radius:6px;border:1px solid #ccc;resize:vertical;box-sizing:border-box;}
.diag-required-star{color:#e53e3e;font-weight:700;}
.diag-inline-note{font-size:12px;color:#555;}
.option-modifier{font-size:.75rem;color:#475569;font-weight:600;}
#travaux-info-msg{margin-top:8px;padding:12px 14px;background:#fff8e1;border:1px solid #ffe082;border-radius:8px;font-size:.85rem;color:#5d4037;line-height:1.6;}
#travaux-info-msg a{color:#0d4e91;font-weight:700;}
#zone-checker{margin-top:8px;padding:10px 12px;background:#f0f5fb;border-radius:8px;border:1px solid #d0dbd7;position:relative;}
.zone-checker-title{font-size:12.5px;font-weight:600;color:#2361a7;margin-bottom:6px;}
.zone-checker-row{display:flex;gap:8px;align-items:flex-start;position:relative;}
.zone-checker-input-wrap{flex:1;position:relative;}
#zone-adresse-input{width:100%;padding:7px 10px;border:1px solid #aac4e0;border-radius:6px;font-size:13px;box-sizing:border-box;}
#zone-suggestions{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #aac4e0;border-top:none;border-radius:0 0 6px 6px;list-style:none;margin:0;padding:0;z-index:200;box-shadow:0 4px 12px rgba(0,0,0,.12);}
#zone-btn-verif{padding:7px 14px;background:#2361a7;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap;flex-shrink:0;}
.zone-results{display:flex;gap:16px;flex-wrap:wrap;margin-top:8px;}
#zone-result-termites,
#zone-result-peb{flex:1;min-width:200px;font-size:13px;font-weight:600;}
.zone-checker-note{margin:6px 0 0;font-size:.8rem;color:#b45309;font-style:italic;}
#urgence-notice{margin:4px 0 6px;padding:11px 14px;background:#fff8e1;border:1px solid #f59e0b;border-radius:12px;font-size:.87rem;color:#7c4a00;line-height:1.5;}
#urgence-notice a{color:#b45309;font-weight:700;white-space:nowrap;}
#km-supplement-item{background:#fff3e0;border-radius:4px;padding:4px 8px;}
.price-note{font-size:.75rem;color:#64748b;margin-bottom:6px;line-height:1.4;}
.price-rounding-note{font-size:.72rem;color:#c62828;margin-top:2px;line-height:1.25;}
#erpEnsaNotice{margin-top:10px;padding:12px 16px;background:#e8f5e9;border:1px solid #a5d6a7;border-radius:6px;font-size:.88rem;color:#2e7d32;line-height:1.5;}
.public-rdv-intro{margin-top:8px;font-size:.8rem;color:#0d4e91;}
#surface-error{color:#b00020;margin-top:10px;font-weight:600;}
#calendar-container{margin-top:20px;}

/* ── Bannière packs promotionnels (index.php) ── */
.promo-packs-banner{background:linear-gradient(135deg,#1a3f70 0%,#2361a7 60%,#136c38 100%);padding:36px 24px;margin:0;border-radius:16px;overflow:hidden;}
.promo-packs-inner{max-width:860px;margin:0 auto;display:flex;flex-wrap:wrap;align-items:center;gap:20px;}
.promo-packs-icon{font-size:2.8rem;flex-shrink:0;}
.promo-packs-text{flex:1;min-width:260px;color:#fff;}
.promo-packs-title{font-size:1.35rem;font-weight:700;margin:0 0 8px;color:#fff;}
.promo-packs-title strong{color:#f0e96e;}
.promo-packs-lead{font-size:.95rem;margin:0 0 10px;line-height:1.55;opacity:.92;}
.promo-packs-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:5px;}
.promo-packs-list li{font-size:.88rem;opacity:.9;}
.promo-packs-fidelite{margin-top:4px;padding-top:8px;border-top:1px solid rgba(255,255,255,.25);opacity:1!important;}
.promo-packs-cta{display:flex;flex-direction:column;align-items:center;gap:10px;flex-shrink:0;}
.promo-packs-btn,
.promo-packs-btn.btn-primary{padding:12px 22px;border-radius:8px;font-size:.97rem;font-weight:700;white-space:nowrap;text-decoration:none;display:inline-block;background:#ffffff;color:#1a3f70;border:1px solid rgba(255,255,255,.78);box-shadow:0 6px 18px rgba(0,0,0,.14);}
.promo-packs-btn:hover,
.promo-packs-btn.btn-primary:hover{background:#eef6ff;color:#136c38;border-color:#ffffff;}
.promo-packs-login{color:rgba(255,255,255,.8);font-size:.85rem;text-decoration:none;text-align:center;}
.promo-packs-login span{color:#fff;text-decoration:underline;}
.promo-packs-login:hover span{color:#f0e96e;}
@media(max-width:600px){.promo-packs-inner{flex-direction:column;text-align:center;}.promo-packs-list{align-items:flex-start;}}

.home-why-section{max-width:960px;margin:32px auto;padding:16px 24px;border:2px solid transparent;border-radius:10px;background:linear-gradient(#fff,#fff) padding-box,linear-gradient(90deg,#2361a7,#136c38) border-box;}
.home-why-section h2{font-size:1.2rem;color:#334155;margin-bottom:8px;}
.home-why-list{list-style-type:disc;padding-left:20px;color:#334155;display:grid;grid-template-columns:1fr 1fr;gap:6px 18px;margin:0;line-height:1.45;}
.home-blog-section{max-width:960px;margin:32px auto;}
.home-blog-section h2{font-size:1.2rem;color:#0d4e91;margin-bottom:16px;}
.home-blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;}
.home-blog-card{display:flex;flex-direction:column;gap:8px;padding:18px 20px;border:1px solid #e0ecff;border-radius:10px;background:#fff;text-decoration:none;color:inherit;transition:box-shadow .15s,border-color .15s;}
.home-blog-card:hover{box-shadow:0 4px 16px rgba(35,97,167,.13);border-color:#2361a7;}
.home-blog-card strong{font-size:.97rem;color:#0d4e91;line-height:1.35;}
.home-blog-card p{margin:0;font-size:.85rem;color:#475569;line-height:1.55;}
.home-blog-tag{background:#e0ecff;color:#0d4e91;font-size:.72rem;font-weight:700;padding:2px 10px;border-radius:20px;align-self:flex-start;}
.home-blog-link{font-size:.82rem;color:#2361a7;font-weight:600;margin-top:4px;}
.home-blog-more{text-align:right;margin-top:12px;}
.home-blog-more a{font-size:.85rem;color:#2361a7;text-decoration:none;font-weight:600;}
@media(max-width:760px){
  .home-blog-section{margin:24px auto;}
  .home-blog-grid{grid-template-columns:1fr;gap:12px;}
  .home-blog-card{padding:14px 16px;}
  .home-blog-card:nth-child(n+4){display:none;}
  .home-blog-more{text-align:left;}
}

.home-why-section,
.home-blog-section,
.city-diagnostics-links{
  content-visibility:auto;
  contain-intrinsic-size:520px;
}

/* ── Bannière campagne promotionnelle ── */
.promo-campaign-strip{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:10px;padding:10px 20px;background:linear-gradient(90deg,#b45309,#d97706);color:#fff;font-size:.92rem;font-weight:600;text-align:center;}
.promo-campaign-strip .promo-campaign-msg{flex:1;min-width:200px;}
.promo-campaign-copy{flex-shrink:0;background:#fff;color:#b45309;border:none;border-radius:6px;padding:6px 14px;font-size:.82rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s;}
.promo-campaign-copy:hover{background:#fef3c7;color:#92400e;}
/* Strip intégré dans la bannière packs (fond sombre) */
.promo-packs-banner .promo-campaign-strip{background:rgba(0,0,0,.22);border-radius:8px;margin-top:14px;padding:10px 16px;}
.promo-packs-banner .promo-campaign-copy{background:#f0e96e;color:#1a3f70;}
.promo-packs-banner .promo-campaign-copy:hover{background:#fffde6;}
/* Champ code promo sur recapitulatif */
.promo-code-zone{margin:16px 0;padding:14px 18px;background:#fffbeb;border:1px solid #f59e0b;border-radius:8px;}
.promo-code-zone label{display:block;font-size:.85rem;font-weight:700;color:#92400e;margin-bottom:6px;}
.promo-code-row{display:flex;gap:8px;flex-wrap:wrap;}
.promo-code-row input{flex:1;min-width:140px;border:1px solid #d97706;border-radius:6px;padding:8px 10px;font-size:.9rem;text-transform:uppercase;}
.promo-code-row button{background:#d97706;color:#fff;border:none;border-radius:6px;padding:8px 16px;font-size:.88rem;font-weight:700;cursor:pointer;white-space:nowrap;}
.promo-code-row button:hover{background:#b45309;}
.promo-code-row button:disabled{opacity:.5;cursor:not-allowed;}
.promo-code-feedback{margin-top:6px;font-size:.85rem;}
.promo-code-feedback.ok{color:#166534;}
.promo-code-feedback.err{color:#dc2626;}
.promo-applied-line{display:flex;align-items:center;gap:8px;margin-top:6px;font-size:.88rem;color:#166534;font-weight:600;}
.promo-applied-line button{background:none;border:1px solid #dc2626;color:#dc2626;border-radius:4px;padding:2px 8px;font-size:.78rem;cursor:pointer;}
#home-promo-zone,
#home-promo-line{position:relative;z-index:9;}
#devis-step-actions.is-progress-locked #home-promo-zone,
#devis-step-actions.is-progress-locked #home-promo-line{pointer-events:auto;}
#home-promo-zone{display:inline-block;width:auto;max-width:100%;margin:8px auto 6px;padding:8px 10px;background:#fff;border:1px solid #d7e0ea;border-radius:6px;text-align:left;}
#home-promo-zone label{font-size:.78rem;color:#475569;margin-bottom:4px;}
#home-promo-zone .promo-code-row{gap:6px;flex-wrap:nowrap;align-items:center;}
#homePromoCodeInput{width:190px;min-width:0;flex:0 0 190px;border-color:#cbd5e1;padding:8px 10px;font-size:.9rem;}
#homePromoCodeInput::placeholder{font-size:.86rem;}
#homePromoApplyBtn{background:#0d4e91;padding:7px 10px;font-size:.82rem;border-radius:6px;}
#homePromoApplyBtn:hover{background:#2361a7;}
#homePromoRemoveBtn{padding:7px 10px;font-size:.82rem;border-radius:6px;}
#home-promo-feedback,
#home-promo-applied{margin-top:4px;font-size:.78rem;max-width:260px;text-align:right;}
#home-promo-line{justify-content:center;margin-top:4px;font-size:.82rem;}
@media(max-width:480px){
  #home-promo-zone{display:block;width:100%;max-width:320px;}
  #home-promo-zone .promo-code-row{flex-wrap:wrap;}
  #homePromoCodeInput{width:100%;flex:1 1 100%;min-width:0;}
  #home-promo-feedback,
  #home-promo-applied{max-width:none;text-align:left;}
}

/* ── Widget Avis clients vérifiés ── */
.avis-section{background:transparent;padding:32px 0 24px;overflow:hidden;}
.avis-header{text-align:center;padding:0 24px 28px;}
.avis-google-badge{display:inline-flex;align-items:center;gap:12px;background:#fff;border:1px solid #deeae3;border-radius:12px;padding:10px 18px;margin-bottom:20px;box-shadow:0 1px 6px rgba(0,0,0,.06);}
.ag-stars{color:#f59e0b;font-size:16px;letter-spacing:1px;line-height:1;}
.ag-label{font-size:.82rem;font-weight:700;color:var(--text);margin-top:2px;}
.ag-sub{font-size:.76rem;color:#475569;margin-top:1px;}
.avis-header h2{font-size:1.65rem;font-weight:800;color:var(--text);margin:0 0 8px;}
.avis-header p{font-size:.92rem;color:var(--muted);margin:0;}
.avis-marquee-outer{position:relative;overflow:hidden;}
.avis-marquee-outer::before,.avis-marquee-outer::after{content:'';position:absolute;top:0;bottom:0;width:90px;z-index:2;pointer-events:none;}
.avis-marquee-outer::before{left:0;background:linear-gradient(to right,#f0f7f2,transparent);}
.avis-marquee-outer::after{right:0;background:linear-gradient(to left,#edf3fb,transparent);}
.avis-marquee{display:flex;gap:16px;padding:4px 24px 16px;width:max-content;will-change:transform;animation:avisScroll 50s linear infinite;}
.avis-marquee:hover{animation-play-state:paused;}
@keyframes avisScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.avis-card{flex-shrink:0;width:248px;background:#fff;border-radius:14px;padding:18px 20px 14px;box-shadow:0 2px 12px rgba(19,108,56,.08),0 1px 3px rgba(0,0,0,.04);border:1px solid #deeae3;}
.avis-card-top{display:flex;align-items:center;gap:11px;margin-bottom:10px;}
.avis-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#136c38 0%,#2361a7 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.88rem;flex-shrink:0;letter-spacing:.5px;}
.avis-name{font-weight:700;font-size:.9rem;color:var(--text);line-height:1.2;}
.avis-verified{font-size:.75rem;color:#136c38;font-weight:700;margin-top:2px;display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:#e8f5e9;border-radius:4px;}
.avis-verified.badge-google{background:#e3f2fd;color:#1565c0;}
.avis-verified.badge-google-verified{background:#e8f5e9;color:#136c38;}
.avis-verified.badge-internal{background:#f3e5f5;color:#6a1b9a;}
.avis-stars{color:#f59e0b;font-size:15px;letter-spacing:1.5px;margin-bottom:6px;line-height:1;}
.avis-text{font-size:.82rem;line-height:1.45;color:#334155;margin:4px 0 6px;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;}
.avis-date{font-size:.75rem;color:#94a3b8;margin-top:4px;font-weight:500;}
.avis-cta{text-align:center;margin-top:28px;padding:0 20px;}
.avis-cta a{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(90deg,#136c38 0%,#2361a7 100%);color:#fff;border-radius:999px;padding:11px 28px;text-decoration:none;font-size:.88rem;font-weight:700;box-shadow:0 2px 10px rgba(19,108,56,.22);transition:opacity .2s,transform .12s;}
.avis-cta a:hover{opacity:.88;transform:translateY(-1px);}
@media(max-width:600px){.avis-section{padding:36px 0 30px;max-width:100%;margin-bottom:20px;}.avis-marquee-outer::before,.avis-marquee-outer::after{width:40px;}.avis-card{width:218px;padding:14px 15px 12px;}}

/* === Hors périmètre === */
#horsPerimetreMsg{display:none;margin-top:10px;padding:12px 16px;background:#fff3cd;border:1px solid #ffc107;border-radius:8px;font-size:.88rem;color:#6d4c00;line-height:1.6;}
#horsPerimetreMsg strong{color:#5a3e00;}
#horsPerimetreMsg a{color:#0d4e91;font-weight:700;}

/* === Champs requis === */
._req-err,._req-err select,._req-err input{outline:2px solid #e53e3e!important;border-color:#e53e3e!important;background:#fff8f8!important;border-radius:6px;}
._req-err-section{outline:2px solid #e53e3e;border-radius:8px;padding:2px;}
label .req,span.req{color:#e53e3e;font-weight:700;margin-left:1px;}

/* ─────────────────────────────────────────────────────────────
   Styles partagés — recapitulatif.php
───────────────────────────────────────────────────────────── */

/* === Bloc récapitulatif principal === */
.container-recap{background:#fff;max-width:900px;width:100%;padding:30px;border-radius:16px;box-shadow:0 6px 30px rgba(0,0,0,.08);margin:30px auto;}
.container-recap h2{text-align:center;margin-bottom:25px;}
.section-recapitulatif{margin-bottom:20px;padding:15px;background:#f9f9f9;border-radius:8px;}
.section-recapitulatif h4{margin-bottom:10px;color:#333;}
.section-recapitulatif .diag-line{display:flex;justify-content:space-between;padding:4px 0;border-bottom:1px solid #eee;}
.section-recapitulatif .diag-line:last-child{border-bottom:none;}
.total-recap{font-size:1.8rem;font-weight:700;color:var(--accent,#0d4e91);text-align:center;margin:20px 0;padding:15px;background:#e8f0fe;border-radius:8px;}

/* === Boutons récapitulatif === */
.btn-recap{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:25px;}
.btn-recap .btn{padding:12px 22px;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;text-decoration:none;display:inline-block;text-align:center;}
.btn-recap .btn.primary{background:var(--accent,#0d4e91);color:#fff;border:none;}
.btn-recap .btn.ghost{background:#136c38;color:#ffffff;border:2px solid #136c38;}
.btn-recap .btn.success{background:#28a745;color:#fff;border:none;}

/* === Formulaire coordonnées === */
.form-coordonnees{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:10px;}
.form-coordonnees .full{grid-column:1/-1;}
.form-coordonnees label{font-size:.85rem;color:#555;margin-bottom:3px;display:block;}
.form-coordonnees input,.form-coordonnees select{width:100%;padding:8px 10px;border:1px solid #ccc;border-radius:6px;box-sizing:border-box;}
@media(max-width:600px){.form-coordonnees{grid-template-columns:1fr;}.form-coordonnees .full{grid-column:1;}}

/* === Messages feedback === */
.msg-success{padding:12px 18px;background:#d4edda;color:#155724;border:1px solid #c3e6cb;border-radius:6px;margin:15px 0;text-align:center;}
.msg-error{padding:12px 18px;background:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:6px;margin:15px 0;text-align:center;}
.badge-statut{font-size:.8rem;padding:3px 8px;border-radius:4px;background:#ffc107;color:#333;}

/* === Panneau RDV (récapitulatif) === */
.public-rdv-box{display:none;margin-top:20px;padding:18px;border:1px solid #d6e4ff;border-radius:12px;background:#f7fbff;}
.public-rdv-box.open{display:block;}
.public-rdv-box h4{margin:0 0 10px;}
.public-rdv-box p{margin:8px 0;color:#334155;}

/* === Encart conformité (récapitulatif) === */
.compliance-box{margin:18px 0;padding:14px 16px;border:1px solid #cfe3d7;border-radius:12px;background:linear-gradient(180deg,#f7fcf8 0%,#eef8f1 100%);font-style:italic;font-size:.82rem;}
.compliance-box h4{margin:0 0 8px;color:#136c38;font-size:.9rem;}
.compliance-box p{margin:6px 0;color:#334155;line-height:1.5;}
.compliance-list{margin:8px 0 0 18px;padding:0;color:#334155;line-height:1.5;}
.consent-checklist{display:grid;gap:8px;margin-top:12px;}
.consent-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border:1px solid #d7e3f4;border-radius:10px;background:#fff;}
.consent-item input[type=checkbox]{margin-top:3px;flex-shrink:0;accent-color:#136c38;}
.consent-item label{cursor:pointer;line-height:1.4;color:#22324a;}
.pricing-note{margin-top:10px;padding:10px 12px;border-radius:10px;background:#fff;border:1px dashed #b7c8db;color:#475569;line-height:1.5;}
.public-rdv-hint{font-size:.92rem;color:#0d4e91;font-weight:600;}

/* === Backgrounds pages diagnostics (utilisé via class="dpe-container bg-xxx") === */
.bg-dpe{background:url('/img/DPE.png') center/cover no-repeat;}
.bg-elec{background:url('/img/Elec.png') center/cover no-repeat;}
.bg-gaz{background:url('/img/gaz.png') center/cover no-repeat;}
.bg-amiante{background:url('/img/Amiante.png') center/cover no-repeat;}
.bg-crep{background:url('/img/crep.png') center/cover no-repeat;}
.bg-erp{background:url('/img/ERP.png') top center / 100% auto no-repeat; background-color:#dfc07a;}
.bg-termites{background:url('/img/Termites.png') center/cover no-repeat;}
.bg-surfaces{background:url('/img/Surfaces.png') center/cover no-repeat;}
.bg-mentions{background:url('/img/legal.png') center/cover no-repeat;}
.bg-rgpd{background:url('/img/RGPD.png') center/cover no-repeat;}
.bg-paiement{background:url('/img/paiement.png') center/cover no-repeat;}

/* === Pages villes diagnostics === */
.city-local-block{margin:0 auto 24px;padding:18px 20px;}
.city-local-block>p{margin:0 0 12px;font-size:1.05rem;text-align:center;}
.city-gallery{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:14px;}
.city-gallery figure{margin:0;flex:1 1 260px;max-width:420px;min-width:200px;}
.city-gallery img{width:100%;height:auto;object-fit:contain;border-radius:12px;display:block;}
.city-gallery figcaption{font-size:.78rem;color:#6b7280;text-align:center;margin-top:4px;}
.retour-pilier-links{text-align:center;font-size:.92rem;}
.retour-pilier-links a{color:#2361a7;text-decoration:underline;}
@media(max-width:600px){.city-gallery figure{min-width:120px;}}
.city-diagnostics-links{max-width:960px;margin:24px auto 32px;padding:30px 20px;text-align:center;}
.city-diagnostics-links h2{font-size:1.25rem;margin-bottom:16px;color:#22324a;}
.city-diagnostics-links ul{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:10px;justify-content:center;}
.city-diagnostics-links li{margin:0;}
.city-diagnostics-links a{display:inline-block;padding:10px 18px;border:1px solid #d1d5db;border-radius:8px;text-decoration:none;color:#22324a;font-size:.92rem;transition:all .2s;}
.city-diagnostics-links a:hover{background:#2361a7;color:#fff;border-color:#2361a7;}
.city-diagnostics-links li a strong{color:#2361a7;}
.city-diagnostics-links li a:hover strong{color:#fff;}
.popular-diagnostics-links{margin:18px auto 0;padding:18px 20px;max-width:900px;text-align:left;background:#eef6ff;border:1px solid #cfe3f8;border-radius:8px;}
.popular-diagnostics-links h3{margin:0 0 12px;text-align:center;font-size:1.08rem;color:#111827;font-weight:800;}
.popular-diagnostics-links ul{display:block;margin:0;padding:0;list-style:none;text-align:center;line-height:1.9;}
.popular-diagnostics-links li{display:inline;margin:0;}
.popular-diagnostics-links li:not(:last-child)::after{content:" · ";color:#94a3b8;margin:0 6px;}
.popular-diagnostics-links a{display:inline;padding:0;border:0;border-radius:0;background:transparent;color:#2361a7;text-align:left;line-height:1.35;text-decoration:underline;text-underline-offset:3px;font-size:.88rem;}
.popular-diagnostics-links a:hover{background:transparent;border:0;color:#136c38;}
@media(max-width:640px){.popular-diagnostics-links ul{text-align:left;line-height:1.8;}.popular-diagnostics-links a{font-size:.9rem;}}

/* === Contact === */
.contact-wrapper{max-width:700px;margin:32px auto;background:#fff;border-radius:14px;padding:32px 28px;box-shadow:0 8px 30px rgba(0,0,0,.08);}
@media(max-width:600px){.contact-wrapper{padding:20px 14px;}}
.contact-info{display:flex;flex-wrap:wrap;gap:18px;margin-bottom:28px;padding:18px;background:#f0f7ff;border-radius:10px;}
.contact-info-item{display:flex;align-items:center;gap:10px;font-size:.97rem;color:#1a3a5c;}
.contact-info-item a{color:#0d4e91;font-weight:700;text-decoration:none;}
.contact-info-item a:hover{text-decoration:underline;}
.form-group{margin-bottom:16px;}
.form-group label{display:block;margin-bottom:6px;font-weight:600;color:#334155;}
.form-group input,.form-group textarea{width:100%;box-sizing:border-box;border:1px solid #c9d3df;border-radius:8px;padding:10px 12px;font-size:.97rem;font-family:inherit;}
.form-group textarea{min-height:160px;resize:vertical;font-size:.9rem;line-height:1.45;}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#0d4e91;box-shadow:0 0 0 2px #cce0ff;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
@media(max-width:540px){.form-row{grid-template-columns:1fr;}}
.btn-send{background:#0d4e91;color:#fff;border:none;border-radius:8px;padding:12px 28px;font-size:1rem;font-weight:700;cursor:pointer;}
.btn-send:hover{background:#0a3d72;}
.msg-ok{background:#e8f5e9;color:#1b5e20;border:1px solid #c8e6c9;border-radius:8px;padding:12px;margin-bottom:16px;}
.msg-ko{background:#ffebee;color:#b71c1c;border:1px solid #ffcdd2;border-radius:8px;padding:12px;margin-bottom:16px;}

/* === Auth forms (connexion / inscription / mot de passe) === */
.auth-form .form-group{display:flex;align-items:center;margin-bottom:15px;}
.auth-form .form-group label{width:160px;margin-right:10px;text-align:right;white-space:nowrap;}
.auth-form .form-group input,.auth-form .form-group select{flex:1;padding:8px;border:1px solid #ccc;border-radius:4px;}
.auth-form .button-group{display:flex;justify-content:center;margin-top:20px;}
.auth-form button{padding:10px 20px;border:none;border-radius:4px;background-color:#007bff;color:#fff;cursor:pointer;}
.center-text{text-align:center;margin-top:15px;font-size:1rem;}
@media(max-width:500px){
  .auth-form .form-group{flex-direction:column;align-items:flex-start;}
  .auth-form .form-group label{width:auto;text-align:left;margin-bottom:5px;}
  .auth-form .button-group{width:100%;}
}
/* .form-row en contexte auth (inscription) — flex, diffère du grid contact */
.auth-form .form-row{display:flex;gap:15px;margin-bottom:15px;}
.auth-form .form-row .form-group{flex:1;display:flex;flex-direction:column;}
.auth-form .form-row label{margin-bottom:5px;font-weight:500;width:auto;text-align:left;white-space:normal;line-height:1.25;overflow-wrap:anywhere;}
.auth-form .form-row input,.auth-form .form-row select{width:100%;}
@media(max-width:700px){.auth-form .form-row{flex-direction:column;}}

/* === Paiement === */
.payment-cards{display:flex;flex-wrap:wrap;gap:20px;margin:24px 0;}
.payment-card{flex:1 1 260px;border:1px solid #d1d5db;border-radius:10px;padding:20px 24px;background:#f8fafc;}
.payment-card h3{margin:0 0 10px;color:#22324a;font-size:1.05rem;}
.payment-card p{margin:0;font-size:.92rem;color:#374151;line-height:1.5;}
.payment-card .amount{display:inline-block;margin-top:10px;padding:4px 12px;border-radius:999px;background:#2361a7;color:#fff;font-weight:700;font-size:.88rem;}

/* === Confirmation === */
.confirmation-box{max-width:640px;margin:40px auto;padding:36px 40px;border:1px solid #d1d5db;border-radius:14px;background:#f8fafc;text-align:center;}
.confirmation-icon{width:72px;height:72px;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#e7f7ed;}
.confirmation-icon svg{width:40px;height:40px;color:#1a8a42;}
.confirmation-box h1{font-size:1.5rem;color:#22324a;margin:0 0 12px;}
.confirmation-box .sub{color:#4b5563;font-size:.97rem;line-height:1.6;margin:0 0 24px;}
.confirmation-steps{text-align:left;margin:24px 0;padding:20px 24px;background:#fff;border:1px solid #e5e7eb;border-radius:10px;}
.confirmation-steps h2{font-size:1rem;color:#22324a;margin:0 0 14px;}
.confirmation-steps ol{margin:0;padding-left:20px;color:#374151;font-size:.92rem;line-height:1.8;}
.confirmation-ref{display:inline-block;margin:0 0 24px;padding:6px 16px;border-radius:999px;background:#2361a7;color:#fff;font-size:.88rem;font-weight:600;}
.confirmation-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}
.confirmation-actions a{display:inline-block;padding:10px 22px;border-radius:8px;font-size:.92rem;font-weight:600;text-decoration:none;}
.btn-primary{background:#2361a7;color:#fff;}
.btn-secondary{background:#f3f4f6;color:#22324a;border:1px solid #d1d5db;}

/* === ERP commander === */
.erp-hero{max-width:960px;margin:18px auto 0;background:linear-gradient(135deg,#136c38 0%,#2361a7 100%);color:#fff;padding:36px 20px;text-align:center;border-radius:18px;box-shadow:0 10px 26px rgba(19,108,56,.16);overflow:hidden;}
.erp-hero h1{margin:0 0 8px;font-size:2rem;font-weight:800;color:#fff;}
.erp-hero p{margin:0;opacity:.9;font-size:1rem;color:#fff;}
.erp-wrap{max-width:760px;margin:0 auto;padding:28px 16px 48px;}
.erp-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:28px 28px 24px;box-shadow:0 2px 12px rgba(0,0,0,.06);margin-bottom:20px;}
.erp-card h2{margin:0 0 18px;font-size:1.15rem;color:#22324a;}
.erp-field{margin-bottom:16px;}
.erp-field label{display:block;margin-bottom:6px;font-size:.88rem;font-weight:600;color:#374151;}
.erp-field input{width:100%;box-sizing:border-box;padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;color:#111;outline:none;transition:border .15s;}
.erp-field input:focus{border-color:#2361a7;box-shadow:0 0 0 3px rgba(35,97,167,.12);}
.erp-autocomplete{position:relative;}
.erp-suggestions{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #d1d5db;border-top:none;border-radius:0 0 8px 8px;z-index:999;max-height:240px;overflow-y:auto;box-shadow:0 4px 16px rgba(0,0,0,.08);}
.erp-suggestions li{padding:10px 14px;cursor:pointer;font-size:.9rem;color:#22324a;border-bottom:1px solid #f3f4f6;list-style:none;}
.erp-suggestions li:hover,.erp-suggestions li.active{background:#eef4ff;color:#2361a7;}
.erp-suggestions li:last-child{border-bottom:none;}
.erp-preview{margin-top:22px;}
.erp-preview-loading{text-align:center;padding:22px;color:#6b7280;font-size:.92rem;}
.erp-preview-title{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#6b7280;margin-bottom:10px;}
.risk-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:10px;}
.risk-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;font-size:.85rem;font-weight:500;}
.risk-item.present{background:#fee2e2;color:#991b1b;}
.risk-item.absent{background:#f0fdf4;color:#166534;}
.risk-item.unknown{background:#f3f4f6;color:#6b7280;}
.risk-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.risk-item.present .risk-dot{background:#dc2626;}
.risk-item.absent .risk-dot{background:#16a34a;}
.risk-item.unknown .risk-dot{background:#9ca3af;}
.erp-error{background:#fee2e2;color:#991b1b;padding:12px 16px;border-radius:8px;font-size:.9rem;margin-top:14px;}
.erp-recap{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:12px;padding:18px 20px;margin-top:20px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;}
.erp-recap-info{font-size:.9rem;color:#166534;}
.erp-recap-info strong{font-size:1.3rem;color:#136c38;display:block;margin-top:2px;}
.erp-recap-info small{display:block;color:#4b7a5e;font-size:.78rem;margin-top:2px;}
.btn-erp-order{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:#136c38;color:#fff;border:none;border-radius:999px;font-size:.97rem;font-weight:700;cursor:pointer;text-decoration:none;transition:background .18s;}
.btn-erp-order:hover{background:#0e5229;}
.btn-erp-order:disabled{opacity:.5;cursor:not-allowed;}
.erp-payment-choice{display:flex;align-items:center;gap:8px;font-size:.88rem;color:#22324a;cursor:pointer;flex-wrap:wrap;}
.erp-legal{font-size:.78rem;color:#6b7280;margin-top:14px;line-height:1.5;}
.erp-legal a{color:#2361a7;}
.erp-docs{margin-top:16px;display:grid;gap:10px;}
.erp-doc{border:1px solid #e5e7eb;border-radius:10px;background:#fafcff;overflow:hidden;}
.erp-doc summary{cursor:pointer;padding:10px 12px;font-size:.86rem;font-weight:700;color:#22324a;list-style:none;}
.erp-doc summary::-webkit-details-marker{display:none;}
.erp-doc summary::after{content:'+';float:right;color:#64748b;}
.erp-doc[open] summary::after{content:'−';}
.erp-doc-content{padding:0 12px 12px;font-size:.78rem;line-height:1.55;color:#4b5563;white-space:pre-line;}
.erp-accept{margin-top:12px;display:flex;flex-direction:column;gap:8px;}
.erp-accept label{display:flex;align-items:flex-start;gap:9px;cursor:pointer;padding:10px 12px;border-radius:10px;font-size:.82rem;line-height:1.5;}
.erp-accept label.cgv-label{border:1px solid #dbeafe;background:#eff6ff;color:#1e3a8a;}
.erp-accept label.retract-label{border:1px solid #fde68a;background:#fffbeb;color:#92400e;}
.erp-accept input[type=checkbox]{margin-top:2px;flex-shrink:0;width:16px;height:16px;}
#erp-cad-map{height:320px;border-radius:8px;overflow:hidden;border:1px solid #e5e7eb;}
.erp-cad-tooltip{background:rgba(255,255,255,.9);border:1px solid #ef4444;color:#111827;font-weight:700;font-size:12px;padding:1px 4px;box-shadow:none;}
.erp-cad-loading{text-align:center;padding:28px;color:#6b7280;font-size:.92rem;}
#erp-gen-overlay{position:fixed;inset:0;background:rgba(255,255,255,.93);z-index:9999;flex-direction:column;align-items:center;justify-content:center;gap:18px;display:none;}
#erp-gen-overlay .erp-ov-msg{font-size:1.1rem;font-weight:700;color:#22324a;text-align:center;}
#erp-gen-overlay .erp-ov-sub{font-size:.82rem;color:#6b7280;text-align:center;}
#erp-gen-overlay .erp-ov-bar-wrap{width:320px;max-width:90vw;height:10px;background:#e5e7eb;border-radius:999px;overflow:hidden;}
#erp-gen-progress-bar{height:100%;width:18%;background:#136c38;transition:width .35s ease;}
#erp-geo-loading{display:none;margin-top:10px;padding:10px 14px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;font-size:.88rem;color:#1e3a8a;align-items:center;gap:8px;}
#erp-geo-loading .erp-geo-spinner{width:16px;height:16px;border:2px solid #bfdbfe;border-top-color:#2361a7;border-radius:50%;animation:erp-spin .7s linear infinite;flex-shrink:0;}
@keyframes erp-spin{to{transform:rotate(360deg);}}
@media(max-width:600px){
  .erp-hero{margin:12px 12px 0;border-radius:14px;padding:28px 16px;}
  .erp-hero h1{font-size:1.5rem;}
  .erp-card{padding:20px 16px;}
  .erp-recap{flex-direction:column;align-items:stretch;}
  .btn-erp-order{justify-content:center;}
}
