.page-wrap { padding-top: var(--nav-h, 64px); }

/* ══ HERO ════════════════════════════════════════════════ */
.contact-hero { display: grid; grid-template-columns: 1fr 1fr; min-height: 52vh; border-bottom: 1px solid var(--border); }
.contact-hero-left { padding: 5rem 6rem; border-right: 1px solid var(--border); display: flex; flex-direction: column; justify-content: center; }
.contact-hero-tag { display: inline-flex; align-items: center; gap: .6rem; background: rgba(33,150,243,.08); border: 1px solid rgba(33,150,243,.2); border-radius: 100px; padding: .35rem .9rem .35rem .5rem; margin-bottom: 1.8rem; }
.contact-hero-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--blue); animation: pulse 2s ease-in-out infinite; }
.contact-hero-tag span { font-family: var(--font-display); font-size: .62rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; color: var(--blue-light); }
.contact-hero-title { font-family: var(--font-display); font-weight: 800; font-size: clamp(2.8rem, 5vw, 5rem); line-height: .92; text-transform: uppercase; letter-spacing: -.02em; margin-bottom: 1.2rem; }
.contact-hero-title em { font-style: italic; font-weight: 300; color: var(--blue-light); display: block; }
.contact-hero-desc { font-size: .95rem; color: var(--muted); line-height: 1.7; margin-bottom: 2rem; max-width: 440px; }
.contact-reassurance { display: flex; flex-direction: column; gap: .55rem; }
.reassurance-item { display: flex; align-items: center; gap: .7rem; font-size: .85rem; color: var(--text2); }
.reassurance-icon { width: 1.3rem; height: 1.3rem; min-width: 1.3rem; background: rgba(52,211,153,.12); border: 1px solid rgba(52,211,153,.25); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: .6rem; font-weight: 700; color: var(--green); }
.contact-hero-right { background: var(--surface); padding: 4rem; display: flex; flex-direction: column; gap: 2.5rem; justify-content: center; }
.contact-how { background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.8rem; }
.contact-how-title { font-family: var(--font-display); font-weight: 700; font-size: .72rem; letter-spacing: .2em; text-transform: uppercase; color: var(--blue); margin-bottom: 1.4rem; }
.contact-how-steps { display: flex; flex-direction: column; gap: 1.1rem; }
.contact-how-step { display: flex; align-items: flex-start; gap: 1rem; }
.contact-how-num { width: 1.6rem; height: 1.6rem; min-width: 1.6rem; border: 1px solid var(--blue); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 700; font-size: .72rem; color: var(--blue); margin-top: .1rem; }
.contact-how-step-title { font-size: .88rem; font-weight: 500; color: var(--text); line-height: 1.3; }
.contact-how-step-sub { font-size: .78rem; color: var(--muted); margin-top: .15rem; }
.contact-direct-wrap { display: flex; flex-direction: column; gap: .7rem; }
.contact-direct-label { font-family: var(--font-display); font-size: .62rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--muted2); }
.contact-tel-btn { display: flex; align-items: center; gap: 1rem; background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius); padding: .9rem 1.2rem; text-decoration: none; transition: border-color .2s; }
.contact-tel-btn:hover { border-color: var(--blue); }
.contact-tel-icon { font-size: 1.2rem; }
.contact-tel-btn strong { display: block; font-family: var(--font-display); font-weight: 700; font-size: 1rem; color: var(--text); }
.contact-tel-btn small { display: block; font-size: .72rem; color: var(--muted); margin-top: .1rem; }
.contact-wa-btn { display: flex; align-items: center; justify-content: center; gap: .7rem; background: #25D366; border-radius: var(--radius); padding: .85rem 1.2rem; text-decoration: none; font-family: var(--font-display); font-weight: 700; font-size: .85rem; letter-spacing: .08em; text-transform: uppercase; color: #fff; transition: background .2s; }
.contact-wa-btn:hover { background: #1ebe5a; }

/* ══ BODY ════════════════════════════════════════════════ */
.contact-body { display: grid; grid-template-columns: 1fr 360px; }
.contact-form-wrap { padding: 4rem 5rem; border-right: 1px solid var(--border); }

/* Progression */
.form-progress { margin-bottom: 2.5rem; }
.form-progress-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: .5rem; }
.form-progress-label { font-family: var(--font-display); font-size: .6rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--muted2); }
.form-progress-pct { font-family: var(--font-display); font-size: .6rem; font-weight: 700; color: var(--blue); }
.form-progress-track { height: 3px; background: var(--border); border-radius: 2px; overflow: hidden; margin-bottom: .8rem; }
.form-progress-bar { height: 100%; background: var(--blue); border-radius: 2px; transition: width .4s ease; }
.form-progress-steps { display: flex; gap: 1.5rem; flex-wrap: wrap; }
.form-progress-step { font-family: var(--font-display); font-size: .58rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--muted2); transition: color .3s; }
.form-progress-step.active { color: var(--blue); }

/* Section headers */
.form-section-header { display: flex; align-items: center; gap: .9rem; margin-bottom: 1.4rem; margin-top: 2.2rem; padding-bottom: .8rem; border-bottom: 1px solid var(--border); }
.form-section-header:first-of-type { margin-top: 0; }
.form-section-num { width: 1.6rem; height: 1.6rem; min-width: 1.6rem; background: var(--blue); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 800; font-size: .7rem; color: #fff; }
.form-section-label { font-family: var(--font-display); font-weight: 700; font-size: 1rem; text-transform: uppercase; letter-spacing: .04em; color: var(--text); }

/* Form elements */
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }
.form-row-3 { grid-template-columns: 1fr 1fr 1fr; }
.form-group { display: flex; flex-direction: column; gap: .4rem; margin-bottom: 1rem; }
.form-label { font-family: var(--font-display); font-size: .62rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--muted); }
.form-label-opt { font-weight: 300; color: var(--muted2); text-transform: none; letter-spacing: 0; font-family: var(--font-body); font-size: .72rem; }
.required { color: var(--blue); }
.form-error-msg { display: none; font-size: .72rem; color: var(--red); }
.form-error-msg.visible { display: block; }
.form-input, .form-select, .form-textarea { background: var(--surface); border: 1px solid var(--border); border-radius: 4px; color: var(--text); font-family: var(--font-body); font-size: .9rem; font-weight: 300; padding: .8rem 1rem; transition: border-color .2s; width: 100%; appearance: none; }
.form-input:focus, .form-select:focus, .form-textarea:focus { outline: none; border-color: var(--blue); }
.form-input.error { border-color: var(--red); }
.form-textarea { min-height: 110px; resize: vertical; }
.select-wrap { position: relative; }
.select-wrap::after { content: '▾'; position: absolute; right: 1rem; top: 50%; transform: translateY(-50%); color: var(--muted); pointer-events: none; font-size: .8rem; }

/* Prestations */
.prestation-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: .6rem; }
.prestation-check { display: flex; flex-direction: column; gap: .5rem; padding: .9rem; border: 1px solid var(--border); border-radius: var(--radius); cursor: pointer; transition: border-color .2s, background .2s; }
.prestation-check:hover { border-color: var(--blue); }
.prestation-check input { display: none; }
.prestation-check.checked { border-color: var(--blue); background: var(--blue-dim); }
.prestation-check-box { width: 1rem; height: 1rem; border: 1px solid var(--border2); border-radius: 2px; display: flex; align-items: center; justify-content: center; font-size: .6rem; color: transparent; transition: all .15s; }
.prestation-check.checked .prestation-check-box { background: var(--blue); border-color: var(--blue); color: #fff; }
.prestation-check-content { display: flex; flex-direction: column; gap: .15rem; }
.prestation-check-label { font-size: .78rem; font-weight: 500; color: var(--text2); line-height: 1.2; transition: color .2s; }
.prestation-check.checked .prestation-check-label { color: var(--text); }
.prestation-check-sub { font-size: .68rem; color: var(--muted2); line-height: 1.2; }
.prestation-check.checked .prestation-check-sub { color: var(--blue-light); }

/* RGPD */
.form-rgpd { font-size: .75rem; color: var(--muted2); line-height: 1.6; padding: .9rem 1rem; background: var(--surface); border: 1px solid var(--border); border-radius: 4px; margin: .5rem 0 1.4rem; }
.form-rgpd a { color: var(--blue); text-decoration: none; }
.form-rgpd a:hover { text-decoration: underline; }

/* Actions */
.form-actions { display: flex; flex-direction: column; gap: .9rem; }
.btn-submit { width: 100%; padding: 1.1rem; font-family: var(--font-display); font-weight: 800; font-size: 1.05rem; letter-spacing: .12em; text-transform: uppercase; background: var(--blue); color: #fff; border: none; border-radius: 4px; cursor: pointer; transition: background .2s, box-shadow .2s; }
.btn-submit:hover { background: #1565C0; box-shadow: 0 0 32px var(--blue-glow); }
.btn-submit:disabled { opacity: .55; cursor: not-allowed; }
.form-submit-reassurance { display: flex; align-items: center; justify-content: center; gap: .6rem; font-size: .75rem; color: var(--muted2); flex-wrap: wrap; }
.dot-sep { color: var(--border2); }
.or-divider { display: flex; align-items: center; gap: 1rem; color: var(--muted2); font-size: .7rem; letter-spacing: .1em; text-transform: uppercase; }
.or-divider::before, .or-divider::after { content: ''; flex: 1; height: 1px; background: var(--border); }
.btn-whatsapp { width: 100%; padding: 1rem; font-family: var(--font-display); font-weight: 700; font-size: .9rem; letter-spacing: .1em; text-transform: uppercase; background: #25D366; color: #fff; border: none; border-radius: 4px; cursor: pointer; transition: background .2s; display: flex; align-items: center; justify-content: center; gap: .6rem; text-decoration: none; }
.btn-whatsapp:hover { background: #1ebe5a; }

/* Success */
.form-success { display: none; text-align: center; padding: 4rem 2rem; }
.form-success.visible { display: block; }
.form-success-check { width: 4rem; height: 4rem; border-radius: 50%; background: rgba(52,211,153,.12); border: 2px solid var(--green); display: flex; align-items: center; justify-content: center; font-size: 1.4rem; color: var(--green); font-weight: 700; margin: 0 auto 1.5rem; }
.form-success-title { font-family: var(--font-display); font-weight: 800; font-size: 2.5rem; text-transform: uppercase; color: var(--text); margin-bottom: .8rem; }
.form-success-title em { color: var(--green); font-style: italic; font-weight: 300; }
.form-success p { color: var(--muted); line-height: 1.7; margin-bottom: 1.5rem; }
.form-success-steps { display: flex; flex-direction: column; gap: .5rem; max-width: 340px; margin: 0 auto; }
.form-success-step { padding: .7rem 1rem; border-radius: 4px; font-size: .82rem; text-align: left; border: 1px solid var(--border); }
.form-success-step.done { background: rgba(52,211,153,.08); border-color: rgba(52,211,153,.2); color: var(--green); }
.form-success-step.active { background: rgba(33,150,243,.08); border-color: rgba(33,150,243,.2); color: var(--blue-light); }
.form-success-step.pending { color: var(--muted2); }

/* ══ SIDEBAR ═════════════════════════════════════════════ */
.contact-sidebar { background: var(--surface); padding: 3rem 2.5rem; display: flex; flex-direction: column; gap: 2.5rem; }
.sidebar-block { display: flex; flex-direction: column; }
.sidebar-block-title { font-family: var(--font-display); font-size: .62rem; font-weight: 700; letter-spacing: .22em; text-transform: uppercase; color: var(--blue); margin-bottom: 1rem; display: flex; align-items: center; gap: .5rem; }
.sidebar-block-title::before { content: ''; display: block; width: 1rem; height: 1px; background: var(--blue); }
.sidebar-p { font-size: .82rem; color: var(--muted); line-height: 1.6; margin-bottom: 1rem; }
.response-box { border: 1px solid var(--border); border-radius: 4px; padding: 1.5rem; text-align: center; }
.response-val { font-family: var(--font-display); font-weight: 800; font-size: 2.8rem; color: var(--blue); line-height: 1; }
.response-label { font-size: .72rem; color: var(--muted); margin-top: .3rem; letter-spacing: .1em; text-transform: uppercase; }
.response-hours { font-size: .7rem; color: var(--muted2); margin-top: .2rem; }
.guarantee-list { display: flex; flex-direction: column; gap: .9rem; }
.guarantee-item { display: flex; align-items: flex-start; gap: .9rem; }
.guarantee-icon { width: 2rem; height: 2rem; min-width: 2rem; background: var(--surface2); border: 1px solid var(--border); border-radius: 4px; display: flex; align-items: center; justify-content: center; font-size: .9rem; }
.guarantee-name { font-size: .85rem; font-weight: 500; color: var(--text); line-height: 1.2; }
.guarantee-sub { font-size: .75rem; color: var(--muted); margin-top: .1rem; }
.zone-list { display: flex; flex-direction: column; gap: .4rem; }
.zone-pill { display: flex; align-items: center; gap: .8rem; padding: .6rem .8rem; border: 1px solid var(--border); border-radius: 4px; font-size: .82rem; color: var(--muted); text-decoration: none; transition: border-color .2s, color .2s; }
.zone-pill:hover { border-color: var(--blue); color: var(--text); }
.zone-pill-num { font-family: var(--font-display); font-weight: 800; font-size: .9rem; color: var(--blue); min-width: 2rem; }
.sidebar-cta { display: block; text-align: center; }
.faq-link { display: flex; align-items: center; justify-content: space-between; padding: .7rem .6rem; font-size: .82rem; color: var(--muted); border-bottom: 1px solid var(--border); text-decoration: none; transition: color .2s; }
.faq-link.last { border-bottom: none; color: var(--blue); }
.faq-link:hover { color: var(--text); }
.faq-link span { color: var(--blue); font-size: .7rem; }

/* ══ RESPONSIVE ══════════════════════════════════════════ */
@media (max-width: 1100px) { .prestation-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 900px) {
  .contact-hero, .contact-body { grid-template-columns: 1fr; }
  .contact-hero-left { padding: 4rem 1.5rem; border-right: none; border-bottom: 1px solid var(--border); }
  .contact-hero-right { padding: 2.5rem 1.5rem; }
  .contact-form-wrap { padding: 3rem 1.5rem; border-right: none; }
  .form-row, .form-row-3 { grid-template-columns: 1fr; }
  .contact-sidebar { padding: 3rem 1.5rem; }
  .prestation-grid { grid-template-columns: repeat(2,1fr); }
  .form-progress-steps { gap: 1rem; }
}
@media (max-width: 480px) {
  .prestation-grid { grid-template-columns: 1fr 1fr; }
  .contact-hero-title { font-size: 2.6rem; }
}
