/* sections.css — styles propres a chaque section */

section{padding:48px 0;}
@media(min-width:768px){section{padding:80px 0;}}
.section-eyebrow{
  font-family:var(--ff-ui);text-transform:uppercase;letter-spacing:.18em;
  font-size:.74rem;color:var(--accent);font-weight:600;
  display:inline-flex;align-items:center;gap:10px;margin-bottom:14px;
}
.section-eyebrow::before{content:"";width:24px;height:1px;background:var(--accent);}
.section-title{
  font-family:var(--ff-display);
  font-size:clamp(1.85rem,4.4vw,2.8rem);
  line-height:1.12;margin:0 0 14px;
}
.section-title em{font-style:italic;color:var(--accent);}
.section-lead{
  font-size:clamp(1rem,1.6vw,1.12rem);
  max-width:60ch;color:var(--text-2);margin-bottom:36px;
}

/* HERO IMMERSIF (override HERO-SVG → photos rule non-negociable) */
.hero{
  position:relative;
  min-height:88vh;
  display:flex;align-items:flex-end;
  padding:calc(var(--header-h-mobile) + 24px) 20px 36px;
  overflow:hidden;
}
.hero__bg{position:absolute;inset:0;z-index:0;}
.hero__bg img{width:100%;height:100%;object-fit:cover;display:block;}
.hero::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg,rgba(31,51,40,.10) 0%,rgba(31,51,40,.70) 92%),
    radial-gradient(60% 60% at 22% 18%,color-mix(in oklab,var(--accent) 22%,transparent) 0%,transparent 60%);
}
.hero__inner{position:relative;z-index:2;max-width:760px;color:#fff;width:100%;}
.hero__top{
  display:flex;align-items:center;flex-wrap:wrap;gap:10px;
  margin-bottom:18px;
}
.hero__title{
  font-family:var(--ff-display);
  font-size:clamp(2.1rem,7vw,4.6rem);
  line-height:1.04;color:#fff;
  margin:0 0 16px;font-weight:500;
}
.hero__title em{font-style:italic;color:#E4D7A8;font-weight:500;}
.hero__sub{
  font-family:var(--ff-body);
  font-size:clamp(1rem,1.7vw,1.18rem);
  color:rgba(255,255,255,.92);
  margin:0 0 26px;max-width:50ch;
}
.hero__zone{
  font-size:.92rem;color:rgba(255,255,255,.82);
  margin-bottom:22px;display:flex;align-items:center;gap:8px;
}
.hero__zone svg{width:16px;height:16px;flex-shrink:0;}
@media(min-width:768px){
  .hero{padding:calc(var(--header-h) + 40px) 32px 56px;min-height:90vh;}
}

/* STATS strip */
.stats-strip{
  background:var(--surface);
  padding:36px 0;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.stats-grid{
  display:grid;grid-template-columns:1fr;gap:24px;text-align:center;
}
@media(min-width:600px){.stats-grid{grid-template-columns:repeat(3,1fr);}}
.stat-item{
  display:flex;flex-direction:column;gap:6px;
  padding:6px 12px;
}
.stat-item:not(:last-child){
  position:relative;
}
@media(min-width:600px){
  .stat-item:not(:last-child)::after{
    content:"";position:absolute;right:0;top:18%;bottom:18%;
    width:1px;background:var(--border);
  }
}
.stat-number{
  font-family:var(--ff-display);
  font-size:clamp(2rem,4.5vw,2.6rem);
  color:var(--accent);font-weight:500;line-height:1;
}
.stat-number sup{font-size:.6em;}
.stat-label{
  font-family:var(--ff-ui);font-size:.76rem;
  text-transform:uppercase;letter-spacing:.14em;
  color:var(--text-mute);
}

/* PROCESS (section inversee — fond fonce, texte clair PIEGE PROD #10) */
.process{
  background:var(--surface-deep);
  color:var(--text-on-dark);
  position:relative;overflow:hidden;
}
.process .section-title,
.process .section-lead,
.process h3,
.process p,
.process li,
.process span{color:var(--text-on-dark);}
.process .section-title em{color:#A4D9A8;}
.process .section-lead{color:var(--text-on-dark-2);}
.process .section-eyebrow{color:#A4D9A8;}
.process .section-eyebrow::before{background:#A4D9A8;}
.process-grid{
  display:grid;grid-template-columns:1fr;gap:24px;
  counter-reset:proc;
}
@media(min-width:768px){.process-grid{grid-template-columns:repeat(3,1fr);gap:36px;}}
.process-step{
  position:relative;
  padding:24px 0 24px 0;
  border-top:1px solid rgba(242,234,215,.18);
}
@media(min-width:768px){
  .process-step{padding:28px 24px;border-top:none;border-left:1px solid rgba(242,234,215,.18);}
  .process-step:first-child{border-left:none;padding-left:0;}
}
.process-step__num{
  font-family:var(--ff-display);font-style:italic;
  font-size:2rem;color:#A4D9A8;display:block;line-height:1;
  margin-bottom:14px;
}
.process-step h3{
  font-family:var(--ff-display);font-size:1.3rem;
  margin-bottom:10px;color:var(--text-on-dark);font-weight:500;
}
.process-step p{color:var(--text-on-dark-2);margin-bottom:0;font-size:.96rem;}

/* APROPOS */
.apropos{background:var(--bg);}
.apropos-grid{
  display:grid;grid-template-columns:1fr;gap:32px;align-items:center;
}
@media(min-width:768px){.apropos-grid{grid-template-columns:1.05fr .95fr;gap:64px;}}
.apropos-text p{font-size:1rem;}
.apropos-text p:first-of-type::first-letter{
  font-family:var(--ff-display);font-style:italic;
  font-size:3.2em;line-height:.85;float:left;
  margin:6px 10px 0 0;color:var(--accent);
}
.apropos-sign{
  font-family:var(--ff-display);font-style:italic;color:var(--accent);
  margin-top:14px;display:block;font-size:1.05rem;
}
.apropos-media{
  position:relative;width:100%;aspect-ratio:4/5;
  border-radius:18px;overflow:hidden;
}
.apropos-media img{width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 1s ease;}
.apropos-media:hover img{transform:scale(1.04);}
.apropos-badge{
  position:absolute;left:14px;bottom:14px;
  background:rgba(245,241,234,.94);
  padding:10px 14px;border-radius:12px;
  font-family:var(--ff-ui);font-size:.82rem;
  display:flex;align-items:center;gap:10px;
  backdrop-filter:blur(6px);
}
.apropos-badge strong{font-family:var(--ff-display);color:var(--accent);font-size:1.04rem;}
@media (prefers-reduced-motion:reduce){.apropos-media img{transition:none;}}

/* SERVICES (LAY-1 grid-3 + cards line) */
.services{background:var(--bg-alt);}
.svc-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(16px,2vw,22px);
}
@media(max-width:900px){.svc-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.svc-grid{grid-template-columns:1fr;}}
.svc-card{display:flex;flex-direction:column;gap:12px;}
.svc-card__icon{
  width:46px;height:46px;border-radius:12px;
  background:color-mix(in srgb,var(--accent) 14%,var(--bg));
  color:var(--accent);
  display:grid;place-items:center;
}
.svc-card__icon svg{width:24px;height:24px;}
.svc-card h3{font-family:var(--ff-display);font-size:1.18rem;font-weight:500;}
.svc-card p{color:var(--text-2);font-size:.94rem;margin-bottom:10px;}
.svc-card__tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto;}
.svc-card__tags span{
  font-family:var(--ff-ui);font-size:.72rem;font-weight:500;
  color:var(--text-mute);text-transform:uppercase;letter-spacing:.08em;
  padding:4px 9px;border-radius:999px;
  border:1px solid var(--border);
}

/* REALISATIONS — galerie grid (LAY-1) + lien page */
.realisations{background:var(--bg);}
.realisations__head{
  display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;
  gap:18px;margin-bottom:36px;
}
.gal-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;
}
.gal-grid figure{
  cursor:pointer;border-radius:12px;overflow:hidden;position:relative;
  aspect-ratio:1/1;width:100%;
  transition:transform var(--t-med);
}
.gal-grid figure:hover{transform:translateY(-2px);}
.gal-grid img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .7s ease;
}
.gal-grid figure:hover img{transform:scale(1.05);}
@media(max-width:560px){.gal-grid{grid-template-columns:repeat(2,1fr);gap:10px;}}
@media (prefers-reduced-motion:reduce){
  .gal-grid figure,.gal-grid img{transition:none;}
  .gal-grid figure:hover{transform:none;}.gal-grid figure:hover img{transform:none;}
}
.realisations__cta{
  margin-top:32px;display:flex;justify-content:center;
}

/* AVIS (LAY-1 cols-2) */
.avis{background:var(--bg-alt);}
.avis-cols{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
}
@media(max-width:700px){.avis-cols{grid-template-columns:1fr;}}
.avis-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:16px;padding:26px 24px;
  display:flex;flex-direction:column;gap:14px;
}
.avis-stars{display:inline-flex;gap:2px;color:var(--gold);}
.avis-stars svg{width:16px;height:16px;}
.avis-card blockquote{
  margin:0;font-family:var(--ff-body);font-size:1rem;
  color:var(--text);line-height:1.55;font-style:normal;
}
.avis-card blockquote::before{content:"";}
.avis-author{
  display:flex;justify-content:space-between;align-items:center;
  font-size:.84rem;color:var(--text-mute);
  margin-top:auto;padding-top:8px;border-top:1px solid var(--border);
}
.avis-author strong{color:var(--text);font-family:var(--ff-display);font-weight:500;font-size:.95rem;}
.badge-google{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.72rem;color:var(--text-mute);
}
.badge-google svg{width:14px;height:14px;}
.avis-foot{text-align:center;margin-top:30px;}
.avis-foot a{
  font-family:var(--ff-ui);font-size:.92rem;font-weight:500;
  display:inline-flex;align-items:center;gap:8px;
  color:var(--accent);
}

/* ZONE */
.zone{background:var(--bg);}
.zone-grid{
  display:grid;grid-template-columns:1fr;gap:32px;
}
@media(min-width:768px){.zone-grid{grid-template-columns:1fr 1fr;gap:48px;}}
.zone-info h3{font-family:var(--ff-display);font-size:1.2rem;font-weight:500;margin:0 0 10px;}
.zone-list{
  display:flex;flex-wrap:wrap;gap:8px;list-style:none;padding:0;margin:0 0 28px;
}
.zone-list li{
  font-family:var(--ff-ui);font-size:.88rem;
  padding:7px 14px;border-radius:999px;
  background:color-mix(in srgb,var(--accent) 9%,var(--bg));
  color:var(--text);
  border:1px solid var(--border);
}
.zone-dispo{
  background:var(--surface);border:1px solid var(--border);
  border-radius:14px;padding:18px 20px;
}
.zone-dispo h4{font-family:var(--ff-display);font-size:1rem;font-weight:500;margin:0 0 8px;color:var(--text);}
.zone-dispo p{font-size:.92rem;color:var(--text-2);margin-bottom:8px;}
.dispo-dot{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--ff-ui);font-size:.86rem;color:var(--accent);font-weight:600;
}
.dispo-dot::before{
  content:"";width:8px;height:8px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 22%,transparent);
  animation:pulse 2.2s ease-out infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--accent) 38%,transparent);}
  70%{box-shadow:0 0 0 8px color-mix(in srgb,var(--accent) 0%,transparent);}
  100%{box-shadow:0 0 0 0 color-mix(in srgb,var(--accent) 0%,transparent);}
}
@media (prefers-reduced-motion:reduce){.dispo-dot::before{animation:none;}}
.map-wrap{
  position:relative;width:100%;
  padding-top:62%;
  border-radius:14px;overflow:hidden;
  border:1px solid var(--border);
}
.map-wrap iframe{
  position:absolute;inset:0;width:100%;height:100%;border:0;
}

/* CONTACT */
.contact{
  background:var(--bg-alt);
}
.contact-grid{
  display:grid;grid-template-columns:1fr;gap:36px;
}
@media(min-width:768px){.contact-grid{grid-template-columns:.9fr 1.1fr;gap:60px;}}
.contact-info p{font-size:1rem;}
.contact-row{
  display:flex;align-items:center;gap:14px;
  padding:14px 0;border-top:1px solid var(--border);
}
.contact-row:last-of-type{border-bottom:1px solid var(--border);}
.contact-row__icon{
  width:38px;height:38px;border-radius:10px;
  background:color-mix(in srgb,var(--accent) 12%,var(--bg));color:var(--accent);
  display:grid;place-items:center;flex-shrink:0;
}
.contact-row__icon svg{width:18px;height:18px;}
.contact-row__txt{display:flex;flex-direction:column;line-height:1.3;min-width:0;}
.contact-row__txt strong{font-family:var(--ff-display);color:var(--text);font-weight:500;}
.contact-row__txt a,.contact-row__txt span{color:var(--text-2);font-size:.94rem;}
.contact-cta{display:flex;flex-direction:column;gap:10px;margin-top:24px;}
@media(min-width:480px){.contact-cta{flex-direction:row;}}
.contact-cta .btn{flex:1;}

.form-wrap{
  background:var(--surface);border:1px solid var(--border);
  border-radius:18px;padding:26px 22px;
}
@media(min-width:768px){.form-wrap{padding:32px 30px;}}
.form-wrap h3{font-family:var(--ff-display);font-size:1.3rem;margin-bottom:6px;font-weight:500;}
.form-wrap > p{margin-bottom:18px;font-size:.94rem;}

/* TEXTURE — TEX-6 degrade OKLCH discret sur fond */
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(60% 50% at 12% 8%, color-mix(in oklab,var(--accent) 8%,transparent) 0%, transparent 55%),
    radial-gradient(50% 40% at 92% 90%, color-mix(in oklab,var(--accent) 6%,transparent) 0%, transparent 60%);
}
