/* spacer pour header sticky */
main{padding-top:var(--header-h-mobile);}
@media (min-width:769px){main{padding-top:var(--header-h);}}

/* ===== HERO-EDITORIAL-CENTRE ===== */
.hero{
  max-width:1100px;margin:0 auto;
  text-align:center;
  padding:clamp(36px,8vw,80px) 24px clamp(24px,4vw,36px);
  position:relative;z-index:1;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--ff-body);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.74rem;
  color:var(--accent);
  margin-bottom:18px;
  font-weight:500;
}
.hero-eyebrow::before,
.hero-eyebrow::after{content:"";width:22px;height:1px;background:var(--accent);}
.hero-title{
  font-family:var(--ff-display);
  font-weight:400;
  font-size:clamp(2.2rem,6vw,4.6rem);
  line-height:1.04;
  letter-spacing:-.015em;
  color:var(--text);
  margin:0 0 18px;
}
.hero-title em{
  font-style:italic;
  color:var(--accent);
  font-weight:500;
}
.hero-sub{
  font-family:var(--ff-body);
  font-size:clamp(1rem,1.7vw,1.18rem);
  color:var(--text-2);
  max-width:54ch;
  margin:0 auto 30px;
  line-height:1.55;
}
.hero-cta{
  display:flex;flex-direction:column;gap:12px;
  align-items:stretch;
  max-width:360px;margin:0 auto;
}
.hero-cta .btn{width:100%;}
@media (min-width:560px){
  .hero-cta{flex-direction:row;justify-content:center;flex-wrap:wrap;max-width:none;}
  .hero-cta .btn{width:auto;min-width:200px;}
}

.hero-pills{
  display:flex;flex-wrap:wrap;gap:8px;justify-content:center;
  margin-top:24px;
}

/* Bande "photo" remplacee par composition SVG architectural */
.hero-band{
  width:100%;
  max-width:1100px;
  margin:clamp(28px,5vw,56px) auto 0;
  aspect-ratio:21/9;
  border-radius:var(--r-lg);
  overflow:hidden;
  background:linear-gradient(135deg,#E5DAC5 0%, #D9CAB0 100%);
  position:relative;
  box-shadow:0 12px 40px rgba(42,33,26,.10);
}
.hero-band svg{
  position:absolute;inset:0;width:100%;height:100%;
  display:block;
}
@media (max-width:560px){
  .hero-band{aspect-ratio:16/10;}
}

/* ===== SERVICES — LAY-2 alt-rows ===== */
.services-section{background:transparent;}
.svc-alt{display:flex;flex-direction:column;gap:clamp(40px,6vw,72px);}
.svc-alt__row{
  display:grid;
  grid-template-columns:1fr;
  gap:24px;
  align-items:center;
}
@media (min-width:900px){
  .svc-alt__row{grid-template-columns:1fr 1fr;gap:56px;}
  .svc-alt__row:nth-child(even) .svc-alt__media{order:-1;}
}
.svc-alt__num{
  font-family:var(--ff-display);
  font-style:italic;
  font-size:1rem;
  color:var(--accent);
  letter-spacing:.06em;
  margin-bottom:10px;
}
.svc-alt__title{
  font-family:var(--ff-display);
  font-weight:400;
  font-size:clamp(1.5rem,3.2vw,2.1rem);
  line-height:1.15;
  margin-bottom:14px;
  color:var(--text);
}
.svc-alt__body{
  font-size:1rem;color:var(--text-2);
  line-height:1.6;
  max-width:46ch;
  margin-bottom:18px;
}
.svc-alt__list{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:8px;
}
.svc-alt__list li{
  font-family:var(--ff-body);
  font-size:.92rem;color:var(--text-2);
  padding-left:18px;position:relative;
}
.svc-alt__list li::before{
  content:"";position:absolute;
  left:0;top:.7em;
  width:8px;height:1px;background:var(--accent);
}

/* Media SVG visuelle */
.svc-alt__media{
  width:100%;
  aspect-ratio:4/3;
  border-radius:var(--r-lg);
  background:var(--bg-alt);
  position:relative;
  overflow:hidden;
  display:grid;place-items:center;
  border:1px solid var(--border);
}
.svc-alt__media svg{width:80%;height:80%;display:block;color:var(--text);}
.svc-alt__media--dark{background:var(--dark);border-color:transparent;}
.svc-alt__media--dark svg{color:#D9B27A;}

/* ===== REALISATIONS — Matieres + showroom (no-photo strategy) ===== */
.matieres-intro{margin-bottom:36px;}
.swatches{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
}
@media (min-width:768px){.swatches{grid-template-columns:repeat(4,1fr);gap:18px;}}
.swatch{
  display:flex;flex-direction:column;
  border-radius:var(--r-lg);
  overflow:hidden;
  background:var(--surface);
  border:1px solid var(--border);
}
.swatch__visual{
  aspect-ratio:4/3;
  position:relative;
}
.swatch__visual--noyer{
  background:
    repeating-linear-gradient(90deg, #4D3322 0px, #5C3D2A 2px, #432A1B 4px, #553527 7px),
    linear-gradient(180deg,#5C3D2A,#3D2A1C);
}
.swatch__visual--chene{
  background:
    repeating-linear-gradient(95deg, #C49567 0px, #B38758 3px, #A87C50 5px, #BD8E62 9px),
    linear-gradient(180deg,#BD8E62,#A47346);
}
.swatch__visual--laque{
  background:
    radial-gradient(80% 50% at 30% 30%, rgba(255,255,255,.12), transparent 70%),
    linear-gradient(135deg,#1E1812 0%, #2A211A 60%, #1E1812 100%);
}
.swatch__visual--granit{
  background:
    radial-gradient(2px 2px at 20% 30%, rgba(255,255,255,.5), transparent 60%),
    radial-gradient(1.5px 1.5px at 60% 70%, rgba(255,255,255,.4), transparent 60%),
    radial-gradient(1.5px 1.5px at 80% 20%, rgba(255,255,255,.35), transparent 60%),
    radial-gradient(1px 1px at 35% 80%, rgba(255,255,255,.3), transparent 60%),
    linear-gradient(135deg,#6E6B62 0%, #57544D 50%, #45433D 100%);
}
.swatch__body{padding:16px 18px 18px;}
.swatch__title{
  font-family:var(--ff-display);
  font-size:1.1rem;
  font-weight:500;
  color:var(--text);
  margin:0 0 6px;
}
.swatch__caption{
  font-size:.82rem;color:var(--text-mute);margin:0;line-height:1.45;
}

.showroom-card{
  margin-top:36px;
  background:var(--dark);color:#E7DCC9;
  border-radius:var(--r-xl);
  padding:32px 24px;
  display:grid;
  gap:18px;
  align-items:center;
  position:relative;
  overflow:hidden;
}
@media (min-width:768px){.showroom-card{padding:44px 48px;grid-template-columns:1.5fr auto;gap:28px;}}
.showroom-card::before{
  content:"";position:absolute;
  right:-80px;bottom:-80px;
  width:280px;height:280px;
  background:radial-gradient(circle, color-mix(in srgb,var(--accent-2) 40%,transparent), transparent 70%);
  pointer-events:none;
}
.showroom-card__title{
  font-family:var(--ff-display);
  font-size:clamp(1.35rem,3vw,1.8rem);
  color:#fff;
  margin:0 0 10px;
  line-height:1.2;
}
.showroom-card__body{color:#C9BCA5;font-size:.96rem;line-height:1.55;margin:0;max-width:48ch;}
.showroom-card .btn{position:relative;z-index:1;}

/* ===== STATS STRIP ===== */
.stats-section{padding-top:24px;padding-bottom:24px;}
@media (min-width:768px){.stats-section{padding-top:36px;padding-bottom:36px;}}
.stats-strip{
  display:grid;
  grid-template-columns:1fr;
  gap:6px;
  background:color-mix(in srgb,var(--text) 4%, var(--bg));
  border-radius:var(--r-lg);
  padding:24px;
  border:1px solid var(--border);
}
@media (min-width:640px){.stats-strip{grid-template-columns:repeat(3,1fr);padding:28px 24px;}}
.stat-item{
  text-align:center;
  padding:14px 8px;
  position:relative;
}
@media (min-width:640px){
  .stat-item + .stat-item{
    border-left:1px solid var(--border);
  }
}
.stat-num{
  font-family:var(--ff-display);
  font-weight:500;
  font-size:clamp(1.8rem,5vw,2.6rem);
  line-height:1;
  color:var(--accent);
  display:inline-block;margin-bottom:6px;
}
.stat-label{
  display:block;
  font-size:.78rem;
  color:var(--text-2);
  text-transform:uppercase;
  letter-spacing:.12em;
  font-weight:500;
}

/* ===== AVIS — LAY-2 single ===== */
.avis-section{background:var(--bg-alt);position:relative;z-index:1;}
.avis-single{
  max-width:780px;margin:0 auto;
  text-align:center;
}
.avis-single__quote{
  font-family:var(--ff-display);
  font-style:italic;
  font-weight:400;
  font-size:clamp(1.25rem,2.8vw,1.7rem);
  line-height:1.4;
  color:var(--text);
  margin:0 0 22px;
  position:relative;
  padding:0 8px;
}
.avis-single__quote::before{
  content:"\201C";
  display:block;
  font-family:var(--ff-display);
  font-size:4rem;line-height:.4;
  color:var(--accent);
  margin-bottom:14px;
}
.avis-single__stars{
  display:inline-flex;gap:3px;justify-content:center;
  margin-bottom:14px;
  color:var(--accent);
}
.avis-single__stars svg{width:18px;height:18px;}
.avis-single__author{
  display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:8px 14px;
  font-size:.9rem;color:var(--text-2);
  margin-bottom:20px;
}
.avis-single__author strong{color:var(--text);font-weight:600;}
.avis-google-badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 11px;
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:999px;
  font-size:.75rem;color:var(--text-mute);
}
.avis-google-badge svg{width:11px;height:11px;}
.avis-note{
  font-size:.85rem;color:var(--text-mute);
  max-width:54ch;margin:0 auto;
  line-height:1.55;
}
.avis-note a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;}

/* ===== FAQ accordion ===== */
.faq-list{
  display:flex;flex-direction:column;
  max-width:780px;margin:0 auto;
}
.faq-item{
  border-top:1px solid var(--border);
}
.faq-item:last-child{border-bottom:1px solid var(--border);}
.faq-trigger{
  width:100%;
  display:flex;justify-content:space-between;align-items:center;gap:18px;
  background:transparent;border:none;
  padding:22px 0;
  font-family:var(--ff-display);
  font-weight:400;
  font-size:clamp(1.05rem,2.2vw,1.25rem);
  line-height:1.3;
  color:var(--text);
  text-align:left;
  cursor:pointer;
  transition:color .2s;
}
.faq-trigger:hover{color:var(--accent);}
.faq-chevron{
  flex-shrink:0;width:14px;height:14px;
  position:relative;
  transition:transform .25s ease;
}
.faq-chevron::before,
.faq-chevron::after{
  content:"";position:absolute;left:50%;top:50%;
  width:14px;height:1.5px;background:var(--accent);
  transform:translate(-50%,-50%);
}
.faq-chevron::after{transform:translate(-50%,-50%) rotate(90deg);transition:transform .25s ease;}
.faq-trigger[aria-expanded="true"] .faq-chevron::after{transform:translate(-50%,-50%) rotate(0deg);}
.faq-answer{
  padding:0 0 22px;
  font-size:.96rem;color:var(--text-2);line-height:1.6;
  max-width:60ch;
}
.faq-answer p{margin:0 0 8px;}

/* ===== ZONE + CARTE ===== */
.zone-wrap{
  display:grid;
  grid-template-columns:1fr;
  gap:32px;
  align-items:start;
}
@media (min-width:900px){.zone-wrap{grid-template-columns:1fr 1.1fr;gap:48px;}}

.zone-info h3{
  font-family:var(--ff-body);
  font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);
  margin:24px 0 12px;font-weight:500;
}
.zone-info h3:first-child{margin-top:0;}
.zone-chips{display:flex;flex-wrap:wrap;gap:8px;margin:0;padding:0;list-style:none;}
.zone-chips li{
  background:var(--surface);
  border:1px solid var(--border);
  padding:6px 13px;border-radius:999px;
  font-size:.85rem;color:var(--text);
  margin:0;
}

.horaires-table{margin:0;width:100%;border-collapse:collapse;}
.horaires-table tr{border-top:1px solid var(--border);}
.horaires-table tr:last-child{border-bottom:1px solid var(--border);}
.horaires-table td{
  padding:10px 0;
  font-size:.92rem;
  color:var(--text-2);
}
.horaires-table td:first-child{text-transform:capitalize;color:var(--text);font-weight:500;width:38%;}
.horaires-table td:last-child{text-align:right;}
.horaires-table tr.is-today td{color:var(--accent);}
.horaires-table tr.is-today td:first-child::before{
  content:"";display:inline-block;
  width:6px;height:6px;border-radius:50%;
  background:var(--wa-green);
  margin-right:7px;vertical-align:middle;
  box-shadow:0 0 0 0 rgba(37,211,102,.5);
  animation:pulse-dot 2s infinite;
}
@keyframes pulse-dot{
  0%{box-shadow:0 0 0 0 rgba(37,211,102,.5);}
  70%{box-shadow:0 0 0 8px rgba(37,211,102,0);}
  100%{box-shadow:0 0 0 0 rgba(37,211,102,0);}
}
.open-now{
  display:inline-flex;align-items:center;gap:8px;
  margin-top:14px;
  font-size:.85rem;
  padding:6px 12px;border-radius:999px;
  background:color-mix(in srgb,var(--wa-green) 14%, var(--bg));
  color:#0F6B2C;
  font-weight:500;
}
.open-now.closed{background:color-mix(in srgb, #B85149 14%, var(--bg));color:#7A1E1E;}
.open-now::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--wa-green);}
.open-now.closed::before{background:#B85149;}

.map-wrapper{
  width:100%;
  border-radius:var(--r-lg);
  overflow:hidden;
  border:1px solid var(--border);
  position:relative;
  aspect-ratio:4/3;
  min-height:300px;
  background:var(--bg-alt);
}
@media (min-width:900px){.map-wrapper{aspect-ratio:1/1;min-height:380px;}}
.map-wrapper iframe{
  position:absolute;inset:0;
  width:100%;height:100%;border:0;
}

/* ===== CONTACT ===== */
.contact-section{background:var(--bg-alt);position:relative;z-index:1;padding-bottom:80px;}
@media (max-width:767px){.contact-section{padding-bottom:120px;}}
.contact-wrap{
  display:grid;
  grid-template-columns:1fr;
  gap:32px;
  align-items:start;
}
@media (min-width:900px){.contact-wrap{grid-template-columns:1fr 1.05fr;gap:48px;}}
.contact-wrap > *{min-width:0;}

.contact-info{
  background:var(--dark);
  color:#E7DCC9;
  border-radius:var(--r-xl);
  padding:32px 26px;
}
@media (min-width:768px){.contact-info{padding:40px 36px;}}
.contact-info h2{color:#fff;margin-bottom:14px;}
.contact-info p{color:#B5A892;margin-bottom:22px;}
.contact-info .tel-big{
  display:block;
  font-family:var(--ff-display);
  font-style:italic;
  font-size:clamp(1.5rem,4vw,2rem);
  color:#D9B27A;
  text-decoration:none;
  margin:18px 0 8px;
}
.contact-info .meta-line{
  display:flex;align-items:center;gap:10px;
  font-size:.9rem;color:#B5A892;
  margin-bottom:10px;
  line-height:1.4;
}
.contact-info .meta-line svg{width:14px;height:14px;color:#D9B27A;flex-shrink:0;}
.contact-info .cta-row{
  display:flex;flex-direction:column;gap:10px;
  margin-top:24px;
}
@media (min-width:480px){.contact-info .cta-row{flex-direction:row;flex-wrap:wrap;}}
.contact-info .cta-row .btn{flex:1;min-width:0;}

.contact-form-wrap{
  background:var(--surface);
  border-radius:var(--r-xl);
  padding:28px 24px;
  border:1px solid var(--border);
}
@media (min-width:768px){.contact-form-wrap{padding:36px 32px;}}
.contact-form-wrap h3{font-family:var(--ff-display);font-size:1.3rem;margin:0 0 18px;}
