:root{
  --blue:#1B3A57;
  --blue-accent:#2563EB;
  --text:#0F172A;
  --muted:#64748B;
  --bg:#F5F7FA;
  --white:#ffffff;
  --line:#E5E7EB;
  --radius:14px;
}

/* Reset */
*{ box-sizing:border-box; margin:0; padding:0; }
body{
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  background: var(--bg);
  color: var(--text);
}

/* Layout helpers */
.wrap{ max-width:1200px; margin:0 auto; padding:0 24px; }
.section{ padding:56px 0; }
.section-alt{
  background: var(--white);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.section-head h1,
.section-head h2{ font-size:28px; letter-spacing:-0.3px; }
.section-head p{
  margin-top:10px; color:var(--muted);
  font-size:16px; line-height:1.6; max-width:760px;
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 16px;
  border-radius:10px;
  text-decoration:none;
  font-weight:700;
  font-size:15px;
  border:1px solid transparent;
  cursor:pointer;
}
.btn-primary{ background:var(--blue-accent); color:#fff; }
.btn-primary:hover{ filter:brightness(.95); }
.btn-ghost{
  background:transparent;
  border-color:var(--line);
  color:var(--text);
}
.btn-ghost:hover{ background:#F1F5F9; }

/* Phone button (Apple-style icon) */
.btn-phone, .call-box{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:12px 16px;
  border-radius:10px;
  text-decoration:none;
  font-weight:800;
  background: var(--blue-accent);
  color:#fff;
  border:1px solid transparent;
}
.btn-phone:hover, .call-box:hover{ filter:brightness(.95); }

.phone-ico{
  width:18px;
  height:18px;
  color:#fff;
}

.phone-note{
  margin-top:10px;
  color: var(--muted);
  line-height:1.6;
  max-width:720px;
}

/* ================= HEADER (CLEAN) ================= */
.site-header{
  position: sticky;
  top:0;
  z-index:1000;
  background: var(--white);
  border-bottom:1px solid var(--line);
}

.header-inner{
  max-width:1200px;
  margin:0 auto;
  padding:14px 24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}

/* Logo */
.brand{ display:flex; align-items:center; text-decoration:none; }
.brand img{ height:80px; width:auto; display:block; }

/* Desktop nav */
.nav-links{ display:flex; gap:22px; align-items:center; }
.nav-links a{
  text-decoration:none;
  color: var(--text);
  font-weight:600;
  font-size:15px;
  padding:8px 6px;
}
.nav-links a:hover{ color: var(--blue-accent); }

/* Actions */
.header-actions{ display:flex; align-items:center; gap:12px; }
.email-link{
  text-decoration:none;
  color: var(--muted);
  font-size:14px;
  font-weight:600;
}
.email-link:hover{ color: var(--text); }

/* ===== MENU HAMBURGER QUI MARCHE VRAIMENT ===== */
.burger{
  display:none;
  background:none;
  border:none;
  font-size:32px;
  line-height:1;
  cursor:pointer;
  color:var(--text);
  position:relative;
  z-index:10002;
}

.drawer{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:100vh;
  background:rgba(0,0,0,0.45);
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  z-index:10000;
  transition:opacity .25s ease, visibility .25s ease;
}

.drawer.open{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}

.drawer-panel{
  position:fixed;
  top:0;
  right:0;
  width:320px;
  max-width:85vw;
  height:100vh;
  background:#ffffff;
  border-left:1px solid var(--line);
  box-shadow:-10px 0 30px rgba(0,0,0,0.18);
  padding:20px;
  overflow-y:auto;
  display:flex;
  flex-direction:column;
  gap:16px;
  transform:translateX(100%);
  transition:transform .25s ease;
  z-index:10001;
}

.drawer.open .drawer-panel{
  transform:translateX(0) !important;
}

.drawer-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding-bottom:12px;
  border-bottom:1px solid var(--line);
}

.drawer-logo{
  height:54px;
  width:auto;
  display:block;
}

.close-btn{
  background:none;
  border:none;
  font-size:30px;
  cursor:pointer;
  color:var(--text);
  line-height:1;
}

.drawer-nav{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top:6px;
}

.drawer-nav a{
  display:block;
  text-decoration:none;
  color:var(--text);
  font-weight:700;
  padding:12px;
  border:1px solid var(--line);
  border-radius:10px;
  background:#F8FAFC;
}

.drawer-actions{
  margin-top:auto;
  display:grid;
  gap:10px;
}

@media (max-width:992px){
  .nav-links,
  .header-actions{
    display:none;
  }

  .burger{
    display:block;
  }

  .brand img{
    height:62px;
  }
}

/* ================= HERO (layout only) ================= */
.hero{
  background: var(--white);
  border-bottom:1px solid var(--line);
}
.hero-grid{
  padding:44px 24px;
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:28px;
  align-items:start;
}
.pill{
  display:inline-flex;
  padding:8px 12px;
  border-radius:999px;
  background:#EEF2FF;
  color:var(--blue-accent);
  font-weight:700;
  font-size:13px;
  border:1px solid #E0E7FF;
}
.hero h1{
  margin-top:14px;
  font-size:44px;
  line-height:1.12;
  letter-spacing:-0.6px;
}
.lead{
  margin-top:14px;
  color:var(--muted);
  font-size:16.5px;
  line-height:1.65;
  max-width:680px;
}
.hero-actions{
  margin-top:18px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.search{
  margin-top:16px;
  display:flex;
  gap:10px;
}
.search input{
  flex:1;
  padding:12px 14px;
  border-radius:10px;
  border:1px solid var(--line);
  background:#fff;
  font-size:15px;
  outline:none;
}
.search input:focus{
  border-color:#C7D2FE;
  box-shadow:0 0 0 4px rgba(37,99,235,.12);
}
.search button{
  padding:0 16px;
  border-radius:10px;
  border:1px solid transparent;
  background:var(--blue-accent);
  color:#fff;
  font-weight:700;
  cursor:pointer;
}
.hint{
  margin-top:10px;
  color:var(--muted);
  font-size:14px;
}
.hint a{ color:var(--blue-accent); text-decoration:none; }
.hint a:hover{ text-decoration:underline; }

/* Hero photo (right column) */
.hero-photo{
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--line);
  background:#fff;
}
.hero-photo img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  min-height:380px;
}

/* Simple footer */
.site-footer{
  padding:28px 0;
  border-top:1px solid var(--line);
  background:#fff;
}
.footer-grid{
  display:flex;
  gap:14px;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
}
.footer-grid p{ color:var(--muted); }

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

/* Responsive */
@media (max-width: 992px){
  .nav-links{ display:none; }
  .header-actions{ display:none; }
  .burger{ display:block; }
  .brand img{ height:62px; }
}

@media (max-width: 980px){
  .hero-grid{ grid-template-columns:1fr; }
  .hero h1{ font-size:32px; }
}
/* ===== Cards services ===== */
.cards-4{
  margin-top:18px;
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap:14px;
}

.card-link{
  display:block;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  padding:18px;
  text-decoration:none;
  color:var(--text);
  transition: .15s ease;
}

.card-link:hover{
  border-color:#C7D2FE;
  box-shadow:0 10px 26px rgba(15,23,42,.06);
  transform: translateY(-1px);
}

.card-link h3{
  font-size:16px;
  margin-bottom:8px;
}

.card-link p{
  color:var(--muted);
  line-height:1.6;
}

.card-cta{
  display:inline-block;
  margin-top:12px;
  color:var(--blue-accent);
  font-weight:700;
}

/* ===== Steps ===== */
.steps-3{
  margin-top:18px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:14px;
}

.step-box{
  background: var(--bg);
  border:1px solid var(--line);
  border-radius:16px;
  padding:18px;
}

.step-badge{
  width:34px;
  height:34px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#EEF2FF;
  color:var(--blue-accent);
  font-weight:800;
  margin-bottom:10px;
}

.step-box h3{
  font-size:16px;
  margin-bottom:8px;
}

.step-box p{
  color:var(--muted);
  line-height:1.6;
}

/* ===== City tags ===== */
.city-tags{
  margin-top:18px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.city-tags a{
  text-decoration:none;
  color:var(--text);
  background:#fff;
  border:1px solid var(--line);
  padding:10px 12px;
  border-radius:999px;
  font-weight:600;
}

.city-tags a:hover{
  border-color:#C7D2FE;
  background:#F8FAFC;
}

.city-tags .tag-more{
  color:var(--blue-accent);
  border-color:#E0E7FF;
  background:#EEF2FF;
}

/* ===== CTA band ===== */
.cta-band{
  background:#0B1220;
  color:#fff;
  border-radius:18px;
  padding:22px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}

.cta-band p{
  margin-top:6px;
  color: rgba(255,255,255,.78);
}

.cta-band .btn-phone{
  background: var(--blue-accent);
}

/* Responsive */
@media (max-width: 980px){
  .cards-4{ grid-template-columns: 1fr; }
  .steps-3{ grid-template-columns: 1fr; }
}
/* ===== Comment ça marche (avec SVG) ===== */
.steps-5{
  margin-top:18px;
  display:grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap:14px;
}

.step-card{
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 18px;
}

.step-icon{
  width:44px;
  height:44px;
  border-radius: 12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#EEF2FF;
  color: var(--blue-accent);
  margin-bottom:12px;
  border:1px solid #E0E7FF;
}

.step-icon svg{
  width:22px;
  height:22px;
}

.step-card h3{
  font-size:15px;
  margin-bottom:8px;
  line-height:1.25;
}

.step-card p{
  color: var(--muted);
  line-height:1.6;
  font-size:14px;
}

/* Responsive */
@media (max-width: 1100px){
  .steps-5{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 680px){
  .steps-5{ grid-template-columns: 1fr; }
}
/* ================= SERVICES BUTTONS ================= */

.service-buttons{

display:flex;
flex-wrap:wrap;
gap:12px;
margin-top:25px;
margin-bottom:25px;

}

.service-btn{

background:#ffffff;
border:1px solid var(--line);
padding:12px 18px;
border-radius:10px;

font-size:15px;
font-weight:700;

cursor:pointer;

transition:all 0.2s ease;

}

.service-btn:hover{

border-color:#2563EB;
color:#2563EB;

}

.service-btn.active{

background:#2563EB;
color:white;
border-color:#2563EB;

}


/* ================= ZONES BUTTONS ================= */

.zone-tags{

display:flex;
flex-wrap:wrap;
gap:10px;

margin-top:15px;

}

.zone-tag{

background:#ffffff;

border:1px solid var(--line);

padding:10px 14px;

border-radius:999px;

font-size:14px;
font-weight:600;

cursor:pointer;

transition:all 0.2s ease;

}

.zone-tag:hover{

border-color:#2563EB;

background:#F8FAFC;

transform:translateY(-1px);

}


/* ================= MOBILE ================= */

@media (max-width:768px){

.service-buttons{

gap:8px;

}

.service-btn{

font-size:14px;
padding:10px 14px;

}

.zone-tag{

font-size:13px;
padding:8px 12px;

}

}
/* grid cards */

.grid-3{

display:grid;

grid-template-columns:repeat(3,1fr);

gap:20px;

margin-top:30px;

}

.card{

background:white;

border:1px solid var(--line);

padding:22px;

border-radius:12px;

}

.card h3{

font-size:18px;

margin-bottom:10px;

}

.card p{

font-size:15px;

color:#475569;

}


@media (max-width:900px){

.grid-3{

grid-template-columns:1fr;

}

}
/* ===== Benefits grid ===== */
.benefits-grid{
  margin-top:18px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:14px;
}

.benefit{
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  padding:18px;
}

.benefit-icon{
  width:44px;
  height:44px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#EEF2FF;
  color: var(--blue-accent);
  border:1px solid #E0E7FF;
  margin-bottom:12px;
}

.benefit-icon svg{
  width:22px;
  height:22px;
}

.benefit h3{
  font-size:15px;
  margin-bottom:8px;
}

.benefit p{
  color: var(--muted);
  line-height:1.6;
  font-size:14px;
}

/* CTA inline */
.cta-inline{
  margin-top:18px;
  background:#0B1220;
  color:#fff;
  border-radius:18px;
  padding:18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}

.cta-inline p{
  margin-top:6px;
  color: rgba(255,255,255,.78);
}

/* Responsive */
@media (max-width: 980px){
  .benefits-grid{ grid-template-columns: 1fr; }
}
/* Les zones en liens gardent le style bouton */
.zone-links .zone-tag{
  display:inline-flex;
  text-decoration:none;
  align-items:center;
  justify-content:center;
}
/* FAQ ACCORDEON */

.faq-accordion{

margin-top:30px;

display:flex;
flex-direction:column;

gap:12px;

}


.faq-item{

border:1px solid var(--line);

border-radius:12px;

background:white;

padding:18px;

}


.faq-item summary{

cursor:pointer;

font-weight:700;

font-size:17px;

list-style:none;

}


.faq-item summary::-webkit-details-marker{

display:none;

}


.faq-item p{

margin-top:12px;

color:#475569;

line-height:1.6;

}
/* ================= FOOTER ================= */

.site-footer{
  background:#0B1220;
  color:#fff;
  margin-top:40px;
  padding:40px 0 18px;
}

.footer-grid{
  display:grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap:22px;
}

.footer-logo img{
  height:42px;
  width:auto;
}

.footer-desc{
  margin-top:12px;
  color: rgba(255,255,255,.78);
  line-height:1.6;
  max-width:460px;
}

.footer-contact{
  margin-top:14px;
  display:flex;
  flex-direction:column;
  gap:6px;
}

.footer-phone{
  color:#fff;
  font-weight:800;
  text-decoration:none;
  font-size:16px;
}

.footer-sub{
  font-size:12px;
  color: rgba(255,255,255,.72);
}

.footer-mail{
  color: rgba(255,255,255,.9);
  text-decoration:none;
  font-weight:600;
}

.footer-col h3{
  font-size:14px;
  margin-bottom:10px;
  color:#fff;
}

.footer-col ul{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:8px;
}

.footer-col a{
  color: rgba(255,255,255,.78);
  text-decoration:none;
  font-weight:600;
}

.footer-col a:hover{
  color:#fff;
  text-decoration:underline;
}

.footer-bottom{
  margin-top:22px;
  padding-top:16px;
  border-top:1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.72);
  font-size:13px;
}

/* Responsive */
@media (max-width: 980px){
  .footer-grid{
    grid-template-columns: 1fr;
  }
}
/* ===== Header mobile : logo centré et encore plus grand ===== */

@media (max-width: 900px) {

  .site-header .header-inner{
    position: relative;
  }

  /* Burger et téléphone restent au dessus */
  .site-header .burger,
  .site-header .header-actions{
    position: relative;
    z-index: 3;
  }

  /* Logo centré dans le header */
  .site-header .brand{
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    align-items: center;
    justify-content: center;
  }

  /* Logo encore plus grand */
  .site-header .brand img{
    height: 80px;
    width: auto;
  }

}/* CONTACT */

.contact-line{
display:flex;
align-items:flex-start;
gap:12px;
}

.contact-icon{
width:36px;
height:36px;
display:flex;
align-items:center;
justify-content:center;
border-radius:10px;
background:#eef4ff;
color:#2563eb;
flex-shrink:0;
}

.contact-icon svg{
width:18px;
height:18px;
}
/* ✅ AJOUTE ÇA TOUT EN BAS DE css/style.css */
.btn-ghost-on-dark{
  color:#fff !important;
  border-color:rgba(255,255,255,0.4) !important;
  background:transparent;
}
.btn-ghost-on-dark:hover{
  background:rgba(255,255,255,0.1);
}
/* ===== Texte normal pour les sections serrurerie générées ===== */
.service-text{
  display:flex;
  flex-direction:column;
  gap:18px;
  margin-top:18px;
}

.service-text p{
  margin:0;
  padding:0;
  background:none;
  border:none;
  box-shadow:none;
  border-radius:0;
  color:#1f2937;
  font-size:1rem;
  line-height:1.8;
  font-weight:400;
}

.section-alt .service-text p{
  color:#1f2937;
}

@media (max-width: 768px){
  .service-text{
    gap:14px;
    margin-top:14px;
  }

  .service-text p{
    font-size:0.98rem;
    line-height:1.75;
  }
}