/* ============================================================
   Serrurerie du Caire — feuille de style (mobile-first, responsive)
   ============================================================ */
:root{
  --brand:#0a4d7a;
  --brand-dark:#063352;
  --accent:#d4a017;
  --accent-light:#f0c94a;
  --emergency:#dc2626;
  --emergency-dark:#991b1b;
  --success:#16a34a;
  --bg:#ffffff;
  --bg-soft:#f5f8fb;
  --text:#0f172a;
  --text-soft:#475569;
  --text-light:#64748b;
  --border:#e2e8f0;
  --shadow:0 1px 3px rgba(0,0,0,.07);
  --shadow-lg:0 12px 28px -8px rgba(0,0,0,.14);
  --radius:14px;
  --radius-sm:9px;
  --maxw:1180px;
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font);
  font-size:16px;
  line-height:1.65;
  color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{margin:0 0 .55em;line-height:1.25;font-weight:800;color:var(--text);letter-spacing:-.01em}
h1{font-size:1.7rem}
h2{font-size:1.45rem}
h3{font-size:1.15rem}
p{margin:0 0 1em}
ul{margin:0 0 1em}
:focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:4px}

/* ---------- LAYOUT ---------- */
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 18px}
section{padding:40px 0}
.bg-soft{background:var(--bg-soft)}
.text-center{text-align:center}

/* ---------- TOP BAR ---------- */
.topbar{background:var(--emergency);color:#fff;padding:9px 14px;font-size:.84rem;text-align:center;line-height:1.5}
.topbar a{color:#fff;font-weight:700;text-decoration:underline;white-space:nowrap}
.topbar .pulse{display:inline-block;width:8px;height:8px;margin-right:6px;background:#fff;border-radius:50%;vertical-align:middle;animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}

/* ---------- HEADER ---------- */
header.site{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid var(--border);box-shadow:var(--shadow)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;max-width:var(--maxw);margin:0 auto;padding:11px 18px}
.logo{display:flex;align-items:center;gap:11px;color:var(--brand-dark);font-weight:800}
.logo:hover{text-decoration:none}
.logo-img{height:48px;width:auto;display:block}
.logo span{display:flex;flex-direction:column;font-size:1rem;line-height:1.25}
.logo small{font-size:.7rem;font-weight:500;color:var(--text-soft);letter-spacing:.01em}
.nav-cta{display:flex;align-items:center;gap:8px}
.nav-call,.nav-wa{padding:10px 15px;border-radius:30px;font-weight:700;font-size:.9rem;color:#fff;white-space:nowrap}
.nav-call{background:var(--emergency)}
.nav-call:hover{background:var(--emergency-dark);text-decoration:none}
.nav-wa{background:#25d366}
.nav-wa:hover{background:#1da851;text-decoration:none}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 24px;border:none;border-radius:12px;
  font-size:1rem;font-weight:700;cursor:pointer;text-align:center;
  transition:transform .15s,background .15s;
}
.btn:hover{text-decoration:none;transform:translateY(-2px)}
.btn-emergency{background:var(--emergency);color:#fff;box-shadow:0 6px 16px rgba(220,38,38,.32)}
.btn-emergency:hover{background:var(--emergency-dark)}
.btn-wa{background:#25d366;color:#fff;box-shadow:0 6px 16px rgba(37,211,102,.3)}
.btn-wa:hover{background:#1da851}
.btn-ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.45)}
.btn-ghost:hover{background:rgba(255,255,255,.12)}

/* ---------- HERO (accueil) ---------- */
.hero{background:linear-gradient(135deg,#063352 0%,#0a4d7a 62%,#1565a0 100%);color:#fff;padding:42px 0 48px}
.hero h1{color:#fff;margin-bottom:14px}
.hero-inner{display:flex;flex-direction:column;gap:30px}
.hero .lead{font-size:1.05rem;color:#dbeafe;margin-bottom:22px}
.hero-badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:22px}
.badge{background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.22);padding:6px 12px;border-radius:20px;font-size:.82rem;color:#fff}
.badge.gold{background:var(--accent);border-color:var(--accent);color:#1a1a1a;font-weight:700}
.hero-cta{display:flex;flex-wrap:wrap;gap:11px;margin-bottom:24px}
.hero-cta .btn{flex:1 1 auto;min-width:200px}
.hero-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.stat{background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.14);padding:14px 10px;border-radius:var(--radius-sm);text-align:center}
.stat-num{display:block;font-size:1.5rem;font-weight:800;color:var(--accent-light)}
.stat-lbl{font-size:.72rem;color:#cbd5e1;text-transform:uppercase;letter-spacing:.04em}

/* hero card (tarifs) */
.hero-card{background:#fff;color:var(--text);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-lg)}
.hero-card h3{color:var(--brand-dark);margin-bottom:4px}
.hero-card .sub{color:var(--text-soft);font-size:.86rem;margin-bottom:14px}
.price-row{display:flex;justify-content:space-between;align-items:baseline;gap:12px;padding:9px 0;border-bottom:1px solid var(--border);font-size:.92rem}
.price-row:last-of-type{border-bottom:none}
.price-row .lbl{color:var(--text-soft)}
.price-row .val{font-weight:800;color:var(--brand-dark);white-space:nowrap}
.price-row .val small{display:block;font-weight:400;font-size:.74rem;color:var(--text-light)}

/* ---------- SECTION HEADINGS ---------- */
.section-head{text-align:center;max-width:680px;margin:0 auto 32px}
.section-head .eyebrow{display:inline-block;background:#fff;border:1px solid var(--border);color:var(--brand);font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;padding:6px 14px;border-radius:20px;margin-bottom:12px}
.bg-soft .section-head .eyebrow{background:var(--bg)}
.section-head h2{margin-bottom:10px}
.section-head p{color:var(--text-soft);font-size:1rem;margin:0}

/* ---------- SERVICES GRID ---------- */
.services{display:grid;grid-template-columns:1fr;gap:18px}
.service-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:24px}
.service-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);transition:transform .2s,box-shadow .2s}
.service-icon{font-size:2rem;margin-bottom:10px}
.service-card h3{color:var(--brand-dark);margin-bottom:8px}
.service-card .desc{color:var(--text-soft);font-size:.94rem;margin-bottom:14px}
.service-card ul{list-style:none;padding:0;margin:0 0 16px;color:var(--text-soft);font-size:.9rem}
.service-card li{position:relative;padding:5px 0 5px 24px}
.service-card li::before{content:"✓";position:absolute;left:0;color:var(--success);font-weight:800}
.service-card .price{margin-top:auto;padding-top:14px;border-top:1px solid var(--border);font-weight:800;color:var(--brand);font-size:1.02rem}
.service-card .price small{display:block;font-weight:400;font-size:.76rem;color:var(--text-light);margin-top:2px}
.service-card .cta-link{display:inline-block;margin-top:12px;color:var(--emergency);font-weight:700;font-size:.92rem}

/* ---------- BRANDS ---------- */
.brands{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:30px}
.brand{flex:0 1 140px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;text-align:center}
.brand .b-name{font-weight:800;color:var(--brand-dark)}
.brand .b-tag{font-size:.76rem;color:var(--text-light);margin-top:2px}

/* ---------- PRICING ---------- */
.pricing{display:grid;grid-template-columns:1fr;gap:16px}
.price-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:24px}
.price-card h3{color:var(--brand-dark);margin-bottom:14px}
.price-card .note{margin-top:14px;padding-top:13px;border-top:1px solid var(--border);font-size:.8rem;font-weight:600;color:var(--success);line-height:1.6}

/* ---------- STEPS ---------- */
.steps{display:grid;grid-template-columns:1fr;gap:24px;counter-reset:step;margin-top:14px}
.step{position:relative;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:22px}
.step::before{counter-increment:step;content:counter(step);position:absolute;top:-16px;left:22px;display:flex;align-items:center;justify-content:center;width:34px;height:34px;background:var(--accent);color:var(--brand-dark);font-weight:800;border-radius:50%;box-shadow:var(--shadow)}
.step h3{color:var(--brand-dark);font-size:1.05rem;margin:6px 0 5px}
.step p{margin:0;color:var(--text-soft);font-size:.92rem}

/* ---------- REVIEWS ---------- */
.reviews-head{display:flex;justify-content:center;margin-bottom:26px}
.rating-big{text-align:center}
.rating-big .num{font-size:3rem;font-weight:800;color:var(--brand-dark);line-height:1}
.rating-big .stars{color:var(--accent);font-size:1.25rem;letter-spacing:2px}
.rating-big .meta{color:var(--text-soft);font-size:.9rem;margin-top:4px}
.reviews{display:grid;grid-template-columns:1fr;gap:16px}
.review{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px}
.review-head{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.avatar{flex:0 0 auto;width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:var(--brand);color:#fff;font-weight:700;border-radius:50%}
.review .name{font-weight:700}
.review .date{font-size:.78rem;color:var(--text-light)}
.review .stars{color:var(--accent);letter-spacing:1px;margin-bottom:7px}
.review p{margin:0;font-size:.92rem;font-style:italic;color:var(--text-soft)}

/* ---------- GALERIE PHOTOS (accueil) ---------- */
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.gallery-item{margin:0;display:flex;flex-direction:column;background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.gallery-item:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);transition:transform .2s,box-shadow .2s}
.gallery-item img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;background:var(--bg-soft)}
.gallery-item .cap{padding:11px 13px;font-size:.86rem;font-weight:700;color:var(--brand-dark);line-height:1.4}
.gallery-item .cap span{display:block;margin-top:3px;font-weight:400;font-size:.78rem;color:var(--text-light)}

/* ---------- ZONE / ARRONDISSEMENTS ---------- */
.arr-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.arr-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 10px;text-align:center;font-weight:700;color:var(--brand-dark);font-size:.92rem}
.arr-card:hover{background:var(--brand);border-color:var(--brand);color:#fff;text-decoration:none}
.arr-card small{display:block;margin-top:3px;font-weight:400;font-size:.72rem;color:var(--text-light)}
.arr-card:hover small{color:#cbd5e1}

/* ---------- LOCAL INFO (pages arrondissement) ---------- */
.local-info{display:grid;grid-template-columns:1fr;gap:18px;margin-top:26px}
.info-box{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:22px}
.info-box h3{color:var(--brand-dark);font-size:1.08rem;margin-bottom:12px}
.info-box ul{list-style:none;padding:0;margin:0;font-size:.93rem;color:var(--text-soft)}
.info-box li{position:relative;padding:7px 0 7px 26px;border-bottom:1px solid var(--border)}
.info-box li:last-child{border-bottom:none}
.info-box li::before{content:"📍";position:absolute;left:0}
.info-box.metros li::before{content:"Ⓜ️"}
.info-box.streets li::before{content:"🛣️"}
.info-box.landmarks li::before{content:"🏛️"}

/* ---------- IMAGE D'ILLUSTRATION (pages arr/quartier) ---------- */
.boutique-img{width:100%;height:auto;border-radius:var(--radius);box-shadow:var(--shadow-lg);margin:22px 0;display:block}

/* ---------- HISTOIRE (accueil) ---------- */
.histoire-grid{display:grid;grid-template-columns:1fr;gap:24px;align-items:center}
.histoire-grid .boutique-img{margin:0}
.check-list{list-style:none;padding:0;margin:0}
.check-list li{position:relative;padding:8px 0 8px 30px;color:var(--text-soft)}
.check-list li::before{content:"✓";position:absolute;left:0;color:var(--success);font-weight:800;font-size:1.1rem}

/* ---------- CTA STRIP ---------- */
.cta-strip{background:linear-gradient(135deg,var(--emergency),#ef4444);color:#fff;text-align:center;padding:34px 22px;border-radius:var(--radius);box-shadow:var(--shadow-lg)}
.cta-strip h2{color:#fff;margin-bottom:8px}
.cta-strip p{color:#fee2e2;font-size:.95rem;margin-bottom:20px}
.cta-strip .btn{margin:5px}
.cta-strip .btn-emergency,.cta-strip .btn:not(.btn-wa){background:#fff;color:var(--emergency)}
.cta-strip .btn-wa{background:#1da851;color:#fff}

/* ---------- TRUST BAR ---------- */
.trust{background:#fff;border-bottom:1px solid var(--border);padding:22px 0}
.trust-inner{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.trust-item{display:flex;flex-direction:column;align-items:center;gap:3px;text-align:center;font-size:.84rem;color:var(--text-soft)}
.trust-item strong{color:var(--brand-dark);font-size:.92rem}

/* ---------- CRUMBS ---------- */
.crumbs{background:var(--bg-soft);border-bottom:1px solid var(--border);font-size:.86rem;color:var(--text-light);padding:11px 0}
.crumbs .container{display:flex;flex-wrap:wrap;gap:6px;align-items:center}

/* ---------- LOCAL HERO (pages internes) ---------- */
.local-hero{background:linear-gradient(135deg,#063352,#0a4d7a);color:#fff;padding:38px 0 42px}
.local-hero h1{color:#fff}
.local-hero .lead{color:#dbeafe;font-size:1.02rem;margin-bottom:20px}
.arr-tag{display:inline-block;background:var(--accent);color:var(--brand-dark);font-weight:700;font-size:.82rem;padding:6px 13px;border-radius:20px;margin-bottom:14px}

/* ---------- FAQ ---------- */
.faq{max-width:780px;margin:0 auto}
.faq details{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:10px;overflow:hidden}
.faq summary{padding:16px 18px;font-weight:700;color:var(--brand-dark);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px;font-size:.98rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;font-weight:400;color:var(--brand);line-height:1;flex:0 0 auto}
.faq details[open] summary::after{content:"–"}
.faq details[open] summary{border-bottom:1px solid var(--border)}
.faq details p{margin:0;padding:15px 18px;color:var(--text-soft);font-size:.93rem}

/* ---------- FOOTER ---------- */
footer.site{background:var(--brand-dark);color:#cbd5e1;padding:44px 0 26px;margin-top:50px}
footer.site .container{display:grid;grid-template-columns:1fr;gap:30px}
footer.site h4{color:#fff;font-size:.95rem;text-transform:uppercase;letter-spacing:.04em;margin-bottom:13px}
footer.site ul{list-style:none;padding:0;margin:0}
footer.site li{padding:4px 0}
footer.site a{color:#cbd5e1;font-size:.9rem}
footer.site a:hover{color:var(--accent-light)}
footer.site .desc{font-size:.9rem;color:#94a3b8;margin-bottom:12px;line-height:1.6}
footer.site .contact-line{margin:6px 0;font-size:.9rem}
.copyright{border-top:1px solid #1e3a5f;margin-top:26px;padding-top:22px;text-align:center;font-size:.82rem;color:#94a3b8}

/* ---------- FLOATING CTA (mobile) ---------- */
.floating-cta{position:fixed;left:0;right:0;bottom:0;z-index:99;display:none;background:#fff;border-top:1px solid var(--border);box-shadow:0 -4px 14px rgba(0,0,0,.08);padding:9px}
.floating-cta-inner{display:grid;grid-template-columns:1fr 1fr;gap:8px;max-width:480px;margin:0 auto}
.floating-cta a{padding:13px;border-radius:11px;text-align:center;font-weight:700;font-size:.95rem;color:#fff}
.floating-cta a:hover{text-decoration:none}
.floating-cta .call{background:var(--emergency)}
.floating-cta .wa{background:#25d366}

/* ---------- ACCESSIBILITÉ ---------- */
.sr-only{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ============================================================
   RESPONSIVE — petits écrans (téléphone)
   ============================================================ */
@media(max-width:700px){
  .floating-cta{display:block}
  body{padding-bottom:74px}
  .nav{padding:10px 14px}
  .logo span{font-size:.92rem}
  .logo-img{height:42px}
  .nav-cta{gap:6px}
  .nav-call,.nav-wa{padding:9px 12px;font-size:.82rem}
  section{padding:32px 0}
  .hero{padding:34px 0 40px}
}
@media(max-width:380px){
  .gallery,.arr-grid,.trust-inner{grid-template-columns:1fr}
  .hero-stats{grid-template-columns:repeat(2,1fr)}
  .nav-wa{display:none}
}

/* ============================================================
   RESPONSIVE — tablette
   ============================================================ */
@media(min-width:600px){
  .container{padding:0 22px}
  h1{font-size:2rem}
  h2{font-size:1.7rem}
  .hero h1{font-size:2.1rem}
  .hero-stats{grid-template-columns:repeat(4,1fr)}
  .services{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(3,1fr);gap:16px}
  .reviews{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .arr-grid{grid-template-columns:repeat(3,1fr)}
  .trust-inner{grid-template-columns:repeat(4,1fr)}
  .local-info{grid-template-columns:1fr 1fr}
  .hero-cta .btn{flex:0 1 auto}
}

/* ============================================================
   RESPONSIVE — ordinateur
   ============================================================ */
@media(min-width:900px){
  section{padding:56px 0}
  h1{font-size:2.4rem}
  .hero h1{font-size:2.6rem}
  h2{font-size:2rem}
  .hero{padding:58px 0 64px}
  .hero-inner{flex-direction:row;align-items:center}
  .hero-inner>div:first-child{flex:1 1 58%}
  .hero-card{flex:1 1 42%}
  .hero .lead{font-size:1.15rem}
  .services{grid-template-columns:repeat(3,1fr);gap:22px}
  .gallery{grid-template-columns:repeat(4,1fr);gap:18px}
  .pricing{grid-template-columns:repeat(3,1fr);gap:20px}
  .reviews{grid-template-columns:repeat(3,1fr);gap:18px}
  .steps{grid-template-columns:repeat(4,1fr);gap:20px}
  .arr-grid{grid-template-columns:repeat(5,1fr)}
  .histoire-grid{grid-template-columns:1.05fr .95fr;gap:34px}
  footer.site .container{grid-template-columns:1.5fr 1fr 1fr 1fr;gap:34px}
}
@media(min-width:1100px){
  .local-hero{padding:48px 0 54px}
}

/* ============================================================
   CORRECTIONS BANDEAU MOBILE (header + topbar)
   ============================================================ */
@media(max-width:560px){
  .topbar{font-size:.78rem;padding:7px 10px;line-height:1.45}
  .topbar strong{white-space:nowrap}
  .topbar a{display:inline-block;margin-top:2px;white-space:nowrap}
  .nav{padding:9px 12px;gap:8px;flex-wrap:nowrap;align-items:center}
  .logo{gap:9px;min-width:0;flex:1 1 auto}
  .logo-img{height:38px;flex:0 0 auto}
  .logo span{font-size:.88rem;line-height:1.2;min-width:0;overflow:hidden;text-overflow:ellipsis}
  .logo small{display:none}
  .nav-cta{gap:6px;flex-shrink:0}
  .nav-call{padding:9px 13px;font-size:.82rem;white-space:nowrap}
  .nav-wa{padding:9px 11px;font-size:.82rem;white-space:nowrap}
  .hero{padding:30px 0 36px}
  .hero h1{font-size:1.55rem}
  .hero .lead{font-size:.98rem}
  .hero-cta .btn{flex:1 1 100%;padding:14px 18px}
  .hero-card{padding:20px}
  .section-head{margin-bottom:24px}
  .section-head p{font-size:.95rem}
  h2{font-size:1.4rem}
  .cta-strip{padding:28px 18px}
  .cta-strip h2{font-size:1.25rem}
  .btn{padding:13px 20px}
}
@media(max-width:420px){
  .logo span{display:none}
  .nav-wa{display:none}                /* WhatsApp accessible via la barre flottante en bas */
  .nav{justify-content:space-between}
  .nav-call{padding:11px 18px;font-size:.9rem;font-weight:800;letter-spacing:.01em}
  .topbar{padding:6px 10px;font-size:.74rem}
  .topbar strong{font-weight:700}
  .crumbs{font-size:.78rem;padding:9px 0}
  .crumbs .container{gap:4px}
  .local-hero{padding:28px 0 34px}
  .local-hero h1{font-size:1.55rem}
  .arr-tag{font-size:.76rem;padding:5px 11px}
}
@media(max-width:360px){
  .logo-img{height:34px}
  .nav-call{padding:10px 15px;font-size:.85rem}
  .nav{padding:8px 11px;gap:6px}
  .container{padding:0 14px}
  .topbar{padding:5px 8px;font-size:.7rem}
}
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     
/* ============================================================
   FORMULAIRE DE CONTACT
   ============================================================ */
.contact-form{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}
@media(min-width:600px){.contact-form{padding:30px}}
.contact-form .field{margin-bottom:16px}
.contact-form label{display:block;margin-bottom:6px;font-weight:700;color:var(--brand-dark);font-size:.92rem}
.contact-form input,.contact-form textarea{
  width:100%;padding:13px 14px;
  border:1.5px solid var(--border);border-radius:var(--radius-sm);
  font-family:inherit;font-size:1rem;color:var(--text);background:#fff;
  transition:border-color .15s,box-shadow .15s
}
.contact-form input:focus,.contact-form textarea:focus{
  outline:none;border-color:var(--brand);
  box-shadow:0 0 0 3px rgba(10,77,122,.15)
}
.contact-form textarea{resize:vertical;min-height:120px;font-size:.97rem;line-height:1.55}
.contact-form .row{display:grid;grid-template-columns:1fr;gap:0}
@media(min-width:560px){.contact-form .row{grid-template-columns:1fr 1fr;gap:14px}}
.contact-form .form-submit{width:100%;margin-top:6px;padding:16px;font-size:1.05rem}
.contact-form .req{color:var(--emergency);font-weight:700}
.contact-form .hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-wa{margin-top:22px;padding-top:18px;border-top:1px dashed var(--border);text-align:center}
.form-wa p{margin:0 0 11px;color:var(--text-soft);font-size:.92rem}
.form-wa .btn{padding:13px 22px;font-size:.97rem}

/* ============================================================
   FORMULAIRE V2 — 2 colonnes, dropdown, upload photo, RGPD, carte
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1fr;gap:24px;max-width:1080px;margin:0 auto}
@media(min-width:900px){.contact-grid{grid-template-columns:1.45fr 1fr;gap:30px;align-items:start}}

/* Formulaire (carte blanche à gauche) */
.contact-form{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}
@media(min-width:600px){.contact-form{padding:30px}}
.contact-form .field{margin-bottom:16px}
.contact-form label{display:block;margin-bottom:6px;font-weight:700;color:var(--brand-dark);font-size:.92rem}
.contact-form input,
.contact-form select,
.contact-form textarea{
  width:100%;padding:13px 14px;
  border:1.5px solid var(--border);border-radius:var(--radius-sm);
  font-family:inherit;font-size:1rem;color:var(--text);background:#fff;
  transition:border-color .15s,box-shadow .15s;
  -webkit-appearance:none;appearance:none
}
.contact-form select{
  background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%230a4d7a'%3e%3cpath d='M7 10l5 5 5-5z'/%3e%3c/svg%3e");
  background-repeat:no-repeat;background-position:right 10px center;background-size:22px;
  padding-right:42px;cursor:pointer
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(10,77,122,.15)}
.contact-form input[type="file"]{padding:10px 14px;background:var(--bg-soft);cursor:pointer;font-size:.9rem}
.contact-form input[type="file"]::file-selector-button{
  padding:8px 14px;margin-right:12px;background:var(--brand);color:#fff;
  border:none;border-radius:7px;font-weight:700;cursor:pointer;font-size:.88rem
}
.contact-form input[type="file"]::file-selector-button:hover{background:var(--brand-dark)}
.contact-form textarea{resize:vertical;min-height:120px;font-size:.97rem;line-height:1.55}
.contact-form .row{display:grid;grid-template-columns:1fr;gap:0}
@media(min-width:560px){.contact-form .row{grid-template-columns:1fr 1fr;gap:14px}}
.contact-form .form-submit{width:100%;margin-top:6px;padding:16px;font-size:1.05rem}
.contact-form .req{color:var(--emergency);font-weight:700}
.contact-form .hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.contact-form .consent{
  display:flex;gap:10px;align-items:flex-start;margin:14px 0 18px;
  font-weight:400;color:var(--text-soft);font-size:.85rem;line-height:1.5;cursor:pointer
}
.contact-form .consent input{width:auto;flex:0 0 auto;margin-top:3px;cursor:pointer;-webkit-appearance:checkbox;appearance:checkbox}
.contact-form .consent span{flex:1 1 auto}
.form-wa{margin-top:22px;padding-top:18px;border-top:1px dashed var(--border);text-align:center}
.form-wa p{margin:0 0 11px;color:var(--text-soft);font-size:.92rem}
.form-wa .btn{padding:13px 22px;font-size:.97rem}

/* Colonne info contact (sombre, à droite) */
.contact-info{
  background:linear-gradient(160deg,var(--brand-dark),var(--brand));
  color:#fff;border-radius:var(--radius);padding:26px;box-shadow:var(--shadow)
}
.contact-info h3{
  margin:0 0 8px;text-transform:uppercase;letter-spacing:.05em;
  font-size:.74rem;font-weight:700;color:#fde68a
}
.contact-info h3:not(:first-child){margin-top:22px}
.contact-info p{margin:0 0 6px;font-size:.95rem;color:#e0eaf5;line-height:1.55}
.contact-info a{color:#fff;text-decoration:none}
.contact-info a:hover{color:#fde68a;text-decoration:underline}
.contact-info .contact-phone{font-size:1.4rem;font-weight:800;letter-spacing:.02em;color:#fff;display:inline-block;margin-bottom:6px}
.contact-info ul.check-list{margin:0;padding:0;list-style:none}
.contact-info .check-list li{color:#e0eaf5;font-size:.92rem;padding:6px 0 6px 26px;position:relative}
.contact-info .check-list li::before{content:"✓";color:#86efac;position:absolute;left:0;font-weight:800}
.contact-info strong{color:#fff}
.contact-map{margin-top:22px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid rgba(255,255,255,.18);height:200px;background:#0a1929}
.contact-map iframe{width:100%;height:100%;border:0;display:block}
