/* Section paddings */
section{
  padding:48px 0;
  position:relative;
}
@media(min-width:768px){
  section{padding:80px 0;}
}
section.tight{padding-top:32px;}

.section-head{
  margin-bottom:32px;
  max-width:780px;
}
.section-head h2{
  margin-bottom:14px;
  font-weight:500;
}
.section-head p{font-size:1.02rem;color:var(--text-2);max-width:60ch;}

/* ===== HERO (override HERO-SVG -> HERO-SPLIT photo, per regle photos) ===== */
.hero{
  padding-top:calc(var(--header-h-mobile) + 32px);
  padding-bottom:48px;
}
@media(min-width:768px){
  .hero{
    padding-top:calc(var(--header-h) + 56px);
    padding-bottom:80px;
  }
}
.hero-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:32px;
  align-items:center;
}
@media(min-width:900px){
  .hero-grid{
    grid-template-columns:1.1fr .9fr;
    gap:clamp(32px, 5vw, 64px);
  }
}
.hero-title{
  font-size:var(--fs-h1);
  font-weight:500;
  line-height:1.08;
  margin:8px 0 18px;
  letter-spacing:-0.012em;
}
.hero-title em{
  font-style:italic;
  font-weight:500;
  position:relative;
  display:inline-block;
  color:var(--accent);
}
.hero-title em::after{
  content:"";
  position:absolute;
  left:0;right:0;
  bottom:.02em;
  height:.22em;
  background:color-mix(in srgb, var(--accent) 16%, transparent);
  z-index:-1;
}
.hero-sub{
  font-family:var(--ff-body);
  font-size:1.05rem;
  color:var(--text-2);
  line-height:1.55;
  margin-bottom:26px;
  max-width:46ch;
}
.hero-cta{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-bottom:22px;
}
.hero-cta .btn{width:100%;}
@media(min-width:480px){
  .hero-cta{flex-direction:row;flex-wrap:wrap;}
  .hero-cta .btn{width:auto;flex:1;min-width:160px;}
}
.hero-trust{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:14px 22px;
  font-family:var(--ff-ui);
  font-size:0.86rem;
  color:var(--text-mute);
}
.hero-trust span{display:inline-flex;align-items:center;gap:6px;}
.hero-trust svg{width:14px;height:14px;color:var(--accent);}

/* Hero illustration SVG (HERO-SVG per DA vector) */
.hero-art{
  position:relative;
  width:100%;
  max-width:440px;
  margin:0 auto;
  aspect-ratio:1/1.05;
  background:
    radial-gradient(circle at 30% 30%, color-mix(in srgb, var(--accent) 14%, var(--bg)) 0%, transparent 55%),
    color-mix(in srgb, var(--accent) 5%, var(--bg));
  border:1px solid color-mix(in srgb, var(--accent) 14%, transparent);
  border-radius:var(--r-xl);
  display:grid;
  place-items:center;
  padding:36px;
  color:var(--accent);
  overflow:hidden;
}
.hero-art::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(color-mix(in srgb, var(--accent) 12%, transparent) 1px, transparent 1px),
    linear-gradient(90deg, color-mix(in srgb, var(--accent) 12%, transparent) 1px, transparent 1px);
  background-size: 24px 24px;
  opacity:.35;
  mask-image: radial-gradient(circle at 50% 50%, black 30%, transparent 75%);
  -webkit-mask-image: radial-gradient(circle at 50% 50%, black 30%, transparent 75%);
}
.hero-art svg{
  position:relative;
  width:100%;
  max-width:280px;
  height:auto;
  filter: drop-shadow(0 12px 24px rgba(31,58,95,0.18));
}
.hero-art__chip{
  position:absolute;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:50px;
  padding:8px 14px 8px 10px;
  font-family:var(--ff-ui);
  font-size:0.78rem;
  color:var(--text);
  display:inline-flex;
  align-items:center;
  gap:8px;
  box-shadow:0 6px 18px rgba(0,0,0,0.08);
  white-space:nowrap;
  font-weight:500;
}
.hero-art__chip svg{width:14px;height:14px;color:var(--accent);max-width:none;filter:none;}
.hero-art__chip--tl{top:14px;left:14px;}
.hero-art__chip--br{bottom:14px;right:14px;}
@media(max-width:560px){
  .hero-art{max-width:320px;padding:28px;}
  .hero-art svg{max-width:200px;}
  .hero-art__chip{font-size:0.72rem;padding:6px 11px 6px 8px;}
}

/* ===== STATS STRIP ===== */
.stats-strip{
  padding:0;
}
.stats-strip .container{
  background:color-mix(in srgb, var(--accent) 6%, var(--bg));
  border:1px solid color-mix(in srgb, var(--accent) 16%, transparent);
  border-radius:var(--r-lg);
  padding:24px 20px;
}
.stats-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:24px 28px;
}
@media(min-width:560px){
  .stats-grid{grid-template-columns:repeat(3,1fr);}
}
.stat-item{
  display:flex;
  flex-direction:column;
  gap:6px;
  text-align:center;
  position:relative;
}
@media(min-width:560px){
  .stat-item + .stat-item::before{
    content:"";
    position:absolute;
    top:8px;bottom:8px;left:0;
    width:1px;
    background:color-mix(in srgb, var(--accent) 18%, transparent);
  }
}
.stat-number{
  font-family:var(--ff-display);
  font-size:clamp(1.9rem, 4vw, 2.6rem);
  font-weight:500;
  color:var(--accent);
  line-height:1.05;
}
.stat-label{
  font-family:var(--ff-ui);
  font-size:0.82rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--text-2);
  font-weight:500;
}

/* ===== PROCESS (COMP-4) ===== */
.process{
  background:transparent;
}
.process-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:18px;
}
@media(min-width:760px){
  .process-grid{
    grid-template-columns:repeat(3,1fr);
    gap:24px;
  }
}
.process-step{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:24px 22px;
  position:relative;
  transition:transform var(--t-base), box-shadow var(--t-base);
}
.process-step:hover{
  transform:translateY(-3px);
  box-shadow:0 10px 30px rgba(31,58,95,0.08);
}
.process-step__num{
  font-family:var(--ff-display);
  font-style:italic;
  font-size:2.3rem;
  color:var(--accent);
  line-height:1;
  margin-bottom:14px;
  font-weight:500;
}
.process-step h3{
  font-size:1.15rem;
  font-weight:500;
  margin-bottom:8px;
}
.process-step p{font-size:0.95rem;line-height:1.55;}

/* ===== SERVICES (LAY-4 list-sep) ===== */
.svc-list{
  display:flex;
  flex-direction:column;
}
.svc-list__item{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:18px 22px;
  align-items:flex-start;
  padding:24px 0;
  border-top:1px solid var(--border);
  transition:background var(--t-fast);
}
.svc-list__item:last-child{border-bottom:1px solid var(--border);}
.svc-list__item:hover{background:color-mix(in srgb, var(--accent) 3%, transparent);}
.svc-list__num{
  font-family:var(--ff-display);
  color:var(--accent);
  font-style:italic;
  font-size:1.15rem;
  font-weight:500;
  padding-top:2px;
  min-width:32px;
}
.svc-list__title{
  font-family:var(--ff-display);
  font-size:clamp(1.15rem, 2vw, 1.4rem);
  font-weight:500;
  color:var(--text);
  margin-bottom:4px;
  letter-spacing:-0.005em;
}
.svc-list__desc{
  font-size:0.95rem;
  color:var(--text-2);
  line-height:1.5;
}
.svc-list__cta{
  align-self:center;
  white-space:nowrap;
}
@media(max-width:560px){
  .svc-list__item{
    grid-template-columns:auto 1fr;
    column-gap:16px;
    row-gap:8px;
  }
  .svc-list__num{font-size:1rem;padding-top:1px;min-width:28px;}
  .svc-list__cta{grid-column:1/-1;justify-self:start;font-size:0.88rem;}
}

/* ===== REALISATIONS (cards texte substitut, photos stock inutilisables) ===== */
.real-intro{
  display:flex;
  align-items:center;
  gap:10px;
  font-family:var(--ff-ui);
  font-size:0.82rem;
  color:var(--text-mute);
  margin-bottom:24px;
  padding:12px 16px;
  background:color-mix(in srgb, var(--accent) 5%, var(--bg));
  border:1px solid color-mix(in srgb, var(--accent) 14%, transparent);
  border-radius:var(--r-md);
}
.real-intro svg{width:16px;height:16px;color:var(--accent);flex-shrink:0;}
.real-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:16px;
}
@media(min-width:680px){
  .real-grid{grid-template-columns:repeat(2,1fr);gap:18px;}
}
@media(min-width:980px){
  .real-grid{grid-template-columns:repeat(3,1fr);}
}
.real-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:24px 22px;
  display:flex;
  flex-direction:column;
  gap:10px;
  transition:transform var(--t-base), box-shadow var(--t-base);
  position:relative;
  overflow:hidden;
}
.real-card::before{
  content:"";
  position:absolute;
  top:0;left:0;
  width:42px;height:3px;
  background:var(--accent);
  border-radius:0 0 3px 3px;
}
.real-card:hover{transform:translateY(-3px);box-shadow:0 14px 32px rgba(31,58,95,0.10);}
.real-card__date{
  font-family:var(--ff-ui);
  font-size:0.74rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--text-mute);
  font-weight:500;
}
.real-card h3{
  font-family:var(--ff-display);
  font-size:1.15rem;
  font-weight:500;
  letter-spacing:-0.005em;
  margin:4px 0;
}
.real-card p{
  font-size:0.92rem;
  color:var(--text-2);
  line-height:1.55;
}
.real-card__client{
  margin-top:auto;
  padding-top:12px;
  border-top:1px dashed var(--border);
  font-family:var(--ff-display);
  font-style:italic;
  font-size:0.86rem;
  color:var(--text-2);
}
.real-foot{
  margin-top:28px;
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  font-family:var(--ff-ui);
  font-size:0.88rem;
  color:var(--text-mute);
}

/* ===== AVIS (LAY-4 carousel) ===== */
.avis-section{
  background:color-mix(in srgb, var(--accent) 4%, var(--bg));
}
.avis-head{
  display:flex;
  flex-direction:column;
  gap:16px;
  margin-bottom:30px;
}
@media(min-width:768px){
  .avis-head{flex-direction:row;align-items:flex-end;justify-content:space-between;gap:32px;}
}
.avis-rating-line{
  display:inline-flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px 14px;
  font-family:var(--ff-ui);
  color:var(--text-2);
  font-size:0.95rem;
}
.avis-rating-line strong{
  color:var(--text);
  font-family:var(--ff-display);
  font-size:1.6rem;
  font-weight:500;
  white-space:nowrap;
}
.avis-rating-line .stars{display:inline-flex;gap:2px;color:#E8A33D;}
.avis-rating-line .stars svg{width:18px;height:18px;}

.avis-carousel{
  display:flex;
  gap:14px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  padding:8px 4px 24px;
  margin:0 -4px;
  -webkit-overflow-scrolling:touch;
}
.avis-carousel::-webkit-scrollbar{height:6px;}
.avis-carousel::-webkit-scrollbar-thumb{background:color-mix(in srgb, var(--accent) 40%, transparent);border-radius:3px;}

.avis-card{
  scroll-snap-align:start;
  flex:0 0 auto;
  width:min(86vw, 380px);
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:24px 22px;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.avis-card__stars{
  display:inline-flex;
  gap:2px;
  color:#E8A33D;
}
.avis-card__stars svg{width:16px;height:16px;}
.avis-card blockquote{
  font-family:var(--ff-display);
  font-style:italic;
  font-size:1.02rem;
  line-height:1.55;
  color:var(--text);
  font-weight:400;
  position:relative;
  padding-left:0;
}
.avis-card__foot{
  margin-top:auto;
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  gap:8px 12px;
  padding-top:12px;
  border-top:1px solid var(--border);
  font-family:var(--ff-ui);
  font-size:0.82rem;
}
.avis-card__author{display:flex;flex-direction:column;gap:2px;}
.avis-card__author strong{color:var(--text);font-weight:500;font-size:0.9rem;}
.avis-card__author span{color:var(--text-mute);}
.badge-google{
  display:inline-flex;
  align-items:center;
  gap:6px;
  color:var(--text-mute);
  font-size:0.78rem;
}
.badge-google svg{width:14px;height:14px;}
.avis-foot{
  display:flex;
  justify-content:center;
  margin-top:8px;
}

/* ===== ZONE / CONTACT ===== */
.zone-cols{
  display:grid;
  grid-template-columns:1fr;
  gap:32px;
}
@media(min-width:880px){
  .zone-cols{grid-template-columns:1fr 1fr;gap:48px;}
}
.zone-info p{font-size:1rem;line-height:1.6;margin-bottom:16px;}
.zone-chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:14px 0 24px;
}
.zone-chip{
  display:inline-block;
  padding:6px 14px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:50px;
  font-family:var(--ff-ui);
  font-size:0.85rem;
  color:var(--text-2);
}
.horaires{
  margin-top:14px;
  border:1px solid var(--border);
  border-radius:var(--r-md);
  overflow:hidden;
  background:var(--surface);
}
.horaires h3{
  font-family:var(--ff-ui);
  font-size:0.78rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--text-mute);
  font-weight:600;
  padding:14px 16px 0;
  margin-bottom:6px;
}
.horaires table{width:100%;border-collapse:collapse;}
.horaires td{
  padding:12px 16px;
  border-top:1px solid var(--border);
  font-family:var(--ff-ui);
  font-size:0.92rem;
  color:var(--text-2);
}
.horaires tr:first-child td{border-top:none;}
.horaires td:first-child{color:var(--text);font-weight:500;text-transform:capitalize;}
.horaires td:last-child{text-align:right;}
.horaires tr.is-today td{
  background:color-mix(in srgb, var(--accent) 8%, transparent);
  color:var(--text);
}
.horaires tr.is-today td:first-child{color:var(--accent);font-weight:600;}
.horaires tr.is-closed td{color:var(--text-mute);}

.map-wrap{
  position:relative;
  width:100%;
  padding-top:75%;
  border-radius:var(--r-lg);
  overflow:hidden;
  border:1px solid var(--border);
  background:var(--bg-alt);
}
@media(min-width:880px){
  .map-wrap{padding-top:0;height:100%;min-height:380px;}
}
.map-wrap iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
}

.contact-section{
  background:var(--surface);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.contact-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:36px;
  align-items:start;
}
@media(min-width:880px){
  .contact-grid{grid-template-columns:1fr 1fr;gap:56px;}
}
.contact-info h2{margin-bottom:14px;font-weight:500;}
.contact-info p{font-size:1.02rem;margin-bottom:24px;line-height:1.55;}
.contact-coords{
  list-style:none;
  margin:24px 0 0;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.contact-coords li{
  display:flex;
  align-items:center;
  gap:14px;
}
.contact-coords li svg{
  width:20px;height:20px;
  color:var(--accent);
  flex-shrink:0;
}
.contact-coords li a{color:var(--text);font-family:var(--ff-ui);font-size:0.98rem;}
.contact-coords li a:hover{color:var(--accent);}
.contact-coords li strong{font-weight:500;color:var(--text);}
.contact-direct-ctas{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top:26px;
}
@media(min-width:560px){
  .contact-direct-ctas{flex-direction:row;}
  .contact-direct-ctas .btn{flex:1;}
}

/* About */
.about-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:36px;
  align-items:start;
}
@media(min-width:880px){
  .about-grid{grid-template-columns:.92fr 1.08fr;gap:56px;}
}
.about-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:28px 26px;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.about-card h3{
  font-family:var(--ff-ui);
  font-size:0.76rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--text-mute);
  font-weight:600;
}
.about-meta{display:flex;flex-direction:column;gap:14px;margin-top:8px;}
.about-meta li{
  display:flex;
  gap:14px;
  align-items:flex-start;
  font-family:var(--ff-ui);
  font-size:0.94rem;
}
.about-meta li svg{width:22px;height:22px;color:var(--accent);flex-shrink:0;margin-top:2px;}
.about-meta li strong{display:block;color:var(--text);font-weight:500;}
.about-meta li span{color:var(--text-mute);font-size:0.84rem;}
.about-body h2{
  margin-bottom:18px;
  font-weight:500;
  line-height:1.12;
}
.about-body p{
  font-size:1.02rem;
  line-height:1.65;
  margin-bottom:16px;
}
.about-body p:first-of-type::first-letter{
  font-family:var(--ff-display);
  font-style:italic;
  font-size:3.2rem;
  line-height:.9;
  float:left;
  margin:6px 12px 0 0;
  color:var(--accent);
  font-weight:500;
}
.about-sign{
  margin-top:24px;
  display:flex;
  align-items:center;
  gap:14px;
  font-family:var(--ff-display);
  font-style:italic;
  color:var(--text-2);
  font-size:1rem;
}
.about-sign::before{
  content:"";
  display:block;
  width:36px;height:1px;
  background:var(--accent);
}

/* FAQ */
.faq-list{
  display:flex;
  flex-direction:column;
  border-top:1px solid var(--border);
}
.faq-item{border-bottom:1px solid var(--border);}
.faq-trigger{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:20px 4px;
  text-align:left;
  font-family:var(--ff-display);
  font-size:1.08rem;
  font-weight:500;
  color:var(--text);
  background:transparent;
  border:none;
  cursor:pointer;
}
.faq-trigger:hover{color:var(--accent);}
.faq-chevron{
  width:18px;height:18px;
  flex-shrink:0;
  position:relative;
  transition:transform var(--t-base);
}
.faq-chevron::before,
.faq-chevron::after{
  content:"";
  position:absolute;
  top:50%;left:50%;
  background:var(--accent);
  border-radius:2px;
}
.faq-chevron::before{width:12px;height:2px;transform:translate(-50%,-50%);}
.faq-chevron::after{width:2px;height:12px;transform:translate(-50%,-50%);transition:transform var(--t-base);}
.faq-trigger[aria-expanded="true"] .faq-chevron::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0;}
.faq-answer{
  padding:0 4px 22px;
  font-size:0.96rem;
  line-height:1.6;
  color:var(--text-2);
}
.faq-answer p + p{margin-top:10px;}

/* Section title flourish */
.section-head .eyebrow{margin-bottom:14px;}
