/* ─────────────────────────────────────────────────────────────
   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;}
.diag-regl-hint{
  display:none;
  position:absolute;
  left:0;bottom:calc(100% + 5px);
  background:#5c4300;color:#fff;
  font-size:.68rem;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 {
  opacity: 0.4;
  cursor: help;
}
.diag-price {
  font-size: .75rem;
  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;}
.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;opacity:.65;}
@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;padding:0 18px;display:flex;align-items:center;justify-content:center;gap:18px;overflow-x:auto;font-size:12.5px;flex-wrap:wrap;}
.slots-bar-label{font-weight:700;color:#136c38;flex-shrink:0;}
.slot-chip{display:inline-block;background:#fff;border:1px solid #136c38;color:#136c38;border-radius:20px;padding:8px 14px;font-size:13px;white-space:nowrap;margin:0 2px;min-height:40px;display:inline-flex;align-items:center;}
@media(max-width:600px){.slots-bar{flex-direction:column;gap:6px;padding:8px 12px;}.slots-bar-label{margin-bottom:2px;}#slotsBarContent{display:flex;flex-wrap:wrap;justify-content:center;gap:4px;}}
@media(max-width:600px){#main-fields-grid{grid-template-columns:1fr!important;}}

/* ── 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:#94a3b8;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:.71rem;color:#136c38;font-weight:700;margin-top:2px;}
.avis-stars{color:#f59e0b;font-size:15px;letter-spacing:1.5px;margin-bottom:6px;line-height:1;}
.avis-date{font-size:.74rem;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 0;max-width:420px;min-width:200px;}
.city-gallery img{width:100%;height:260px;object-fit:cover;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 img{height:130px;}.city-gallery figure{min-width:120px;}}
.city-diagnostics-links{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;}

/* === 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;}
.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;}
.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:11px;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;}
}
