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

/* ========== HERO-IMMERSIF (impose) ========== */
.hero-immersif{
  position:relative;
  min-height:clamp(520px,82vh,760px);
  display:flex;align-items:flex-end;
  padding:clamp(28px,6vw,72px) 24px;
  border-radius:0 0 18px 18px;
  overflow:hidden;
  margin-top:0;
}
.hero-immersif__bg{position:absolute;inset:0;z-index:0;}
.hero-immersif__bg img{width:100%;height:100%;object-fit:cover;display:block;}
.hero-immersif::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(20,12,4,.18) 0%,rgba(20,12,4,.62) 100%);
}
.hero-immersif__inner{position:relative;z-index:2;max-width:820px;width:100%;}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--ff-ui);
  font-size:.72rem;
  letter-spacing:.20em;
  text-transform:uppercase;
  color:#fff;
  font-weight:600;
  opacity:.92;
  margin-bottom:16px;
}
.hero-eyebrow::before{
  content:"";width:30px;height:1.5px;background:#fff;opacity:.7;
}
.hero-immersif__title{
  font-family:var(--ff-display);
  font-size:clamp(2.3rem,6vw,4.4rem);
  line-height:1.04;
  letter-spacing:-.012em;
  color:#fff;
  font-weight:500;
  margin:0;
}
.hero-immersif__title em{
  font-style:italic;
  color:var(--accent-soft);
}
.hero-immersif__sub{
  font-family:var(--ff-body);
  font-size:clamp(1rem,1.6vw,1.18rem);
  color:rgba(255,255,255,.92);
  margin:18px 0 22px;
  max-width:50ch;
  line-height:1.55;
}
.hero-immersif__cta{
  display:flex;flex-direction:column;gap:10px;
}
.hero-immersif__cta .btn{width:100%;}
@media (min-width:600px){
  .hero-immersif__cta{flex-direction:row;flex-wrap:wrap;}
  .hero-immersif__cta .btn{width:auto;}
}
@media (max-width:768px){
  .hero-immersif{
    min-height:78vh;
    padding:calc(var(--header-h-mobile) + 32px) 20px 36px;
  }
}

/* ========== REALISATIONS (galerie masonry — LAY-2) ========== */
.realisations{padding:48px 0;}
@media (min-width:768px){.realisations{padding:88px 0;}}
.gal-masonry{
  column-count:1;
  column-gap:14px;
}
@media (min-width:600px){.gal-masonry{column-count:2;}}
@media (min-width:900px){.gal-masonry{column-count:3;}}
.gal-item{
  width:100%;
  margin:0 0 14px;
  border-radius:var(--r-lg);
  overflow:hidden;
  display:block;
  break-inside:avoid;
  cursor:zoom-in;
  border:1px solid var(--border);
  transition:transform var(--t-med),box-shadow var(--t-med);
}
.gal-item img{
  width:100%;
  height:auto;
  display:block;
  transition:transform .8s cubic-bezier(.2,.7,.2,1);
}
.gal-item:hover{
  box-shadow:0 14px 36px rgba(42,32,24,.18);
}
.gal-item:hover img{transform:scale(1.03);}
.real-head-cta{
  margin-top:32px;
  text-align:center;
}
.real-head-cta a{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--ff-ui);font-size:.95rem;font-weight:600;
  color:var(--accent-dark);
  border-bottom:1.5px solid var(--accent);
  padding-bottom:3px;
}
.real-head-cta a:hover{color:var(--accent);}

/* ========== SERVICES (alt-rows — LAY-2) ========== */
.svc-alt{display:flex;flex-direction:column;gap:clamp(36px,5vw,72px);}
.svc-alt__row{
  display:grid;
  grid-template-columns:1fr;
  gap:20px;
  align-items:center;
}
@media (min-width:768px){
  .svc-alt__row{grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);}
  .svc-alt__row:nth-child(even) .svc-alt__media{order:-1;}
}
.svc-alt__media{
  width:100%;
  aspect-ratio:4/3;
  border-radius:var(--r-lg);
  overflow:hidden;
  background:color-mix(in srgb,var(--accent) 10%,var(--bg));
  display:grid;place-items:center;
  color:var(--accent);
  border:1px solid var(--border);
}
.svc-alt__media svg{width:64%;height:auto;opacity:.45;}
.svc-alt__num{
  font-family:var(--ff-display);
  font-style:italic;
  font-size:1.15rem;
  color:var(--accent);
  font-weight:500;
  display:inline-flex;align-items:center;gap:10px;
  margin-bottom:10px;
}
.svc-alt__num::after{
  content:"";width:26px;height:1px;background:var(--accent);
}
.svc-alt__title{
  font-family:var(--ff-display);
  font-size:clamp(1.55rem,3vw,2.1rem);
  line-height:1.12;
  margin:0 0 10px;
  letter-spacing:-.005em;
}
.svc-alt__title em{font-style:italic;color:var(--accent);}
.svc-alt__text{
  font-family:var(--ff-body);
  font-size:1rem;
  color:var(--text-2);
  margin:0 0 14px;
  line-height:1.6;
}
.svc-alt__tags{display:flex;flex-wrap:wrap;gap:6px;}
.svc-alt__tags .chip{font-size:.74rem;}

/* ========== AVIS (single — LAY-2) + 2 mini ========== */
.avis-section{background:color-mix(in srgb,var(--bg-alt) 60%,var(--bg));}
.avis-single{max-width:780px;margin:0 auto;text-align:center;position:relative;padding:0 8px;}
.avis-single__stars{
  display:inline-flex;gap:3px;justify-content:center;margin-bottom:18px;
}
.avis-single__stars svg{width:22px;height:22px;color:#D4A04C;}
.avis-single__quote{
  font-family:var(--ff-display);
  font-style:italic;
  font-size:clamp(1.3rem,2.8vw,1.9rem);
  line-height:1.4;
  color:var(--text);
  margin:0 0 22px;
  position:relative;
}
.avis-single__quote::before{
  content:"\201C";
  display:block;
  font-family:var(--ff-display);
  font-size:5rem;
  line-height:.6;
  color:var(--accent);
  opacity:.3;
  margin-bottom:-12px;
}
.avis-single__author{
  font-family:var(--ff-ui);
  font-size:.92rem;
  color:var(--text-2);
  display:inline-flex;align-items:center;gap:10px;
  flex-wrap:wrap;justify-content:center;
}
.avis-single__author strong{color:var(--text);font-weight:600;}
.avis-single__date{color:var(--text-mute);font-size:.85rem;}
.avis-badge-google{
  display:inline-flex;align-items:center;gap:5px;
  font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;
  color:var(--text-mute);font-weight:600;
  padding:3px 9px;border:1px solid var(--border);border-radius:999px;background:var(--surface);
}
.avis-badge-google svg{width:11px;height:11px;}

.avis-mini-grid{
  margin-top:40px;
  display:grid;grid-template-columns:1fr;gap:18px;
}
@media (min-width:768px){.avis-mini-grid{grid-template-columns:1fr 1fr;}}
.avis-mini{padding:22px 22px 18px;}
.avis-mini .stars{display:inline-flex;gap:2px;margin-bottom:10px;}
.avis-mini .stars svg{width:14px;height:14px;color:#D4A04C;}
.avis-mini blockquote{
  font-family:var(--ff-body);
  font-size:.95rem;color:var(--text-2);
  margin:0 0 12px;line-height:1.55;font-style:italic;
}
.avis-mini__foot{
  font-family:var(--ff-ui);
  font-size:.82rem;
  color:var(--text-mute);
  display:flex;justify-content:space-between;gap:10px;
}
.avis-mini__foot strong{color:var(--text-2);font-weight:600;}

.avis-google-link{
  margin-top:32px;text-align:center;
}
.avis-google-link a{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--ff-ui);font-size:.9rem;font-weight:600;
  color:var(--accent-dark);
  border-bottom:1.5px solid var(--accent);
  padding-bottom:2px;
}
.avis-google-link a:hover{color:var(--accent);}

/* ========== STATS strip ========== */
.stats-strip{
  background:var(--surface-deep);
  color:var(--text-on-dark);
  padding:40px 0;
}
.stats-strip :where(h1,h2,h3,h4,p,span,small){color:var(--text-on-dark);}
.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{padding:8px 12px;position:relative;}
@media (min-width:600px){
  .stat-item:not(:last-child)::after{
    content:"";
    position:absolute;top:18%;bottom:18%;right:0;
    width:1px;background:rgba(244,236,222,.16);
  }
}
.stat-num{
  display:block;
  font-family:var(--ff-display);
  font-size:clamp(2.4rem,4.5vw,3rem);
  font-weight:500;
  color:var(--text-on-dark);
  line-height:1;
}
.stat-num em{font-style:italic;color:var(--accent-2);}
.stat-label{
  display:block;
  font-family:var(--ff-ui);
  font-size:.74rem;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:var(--text-on-dark-2);
  margin-top:10px;
}

/* ========== FAQ accordion ========== */
.faq-list{margin:0;padding:0;display:flex;flex-direction:column;gap:0;}
.faq-item{
  border-top:1px solid var(--border);
}
.faq-item:last-child{border-bottom:1px solid var(--border);}
.faq-trigger{
  width:100%;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:20px 6px;
  text-align:left;
  font-family:var(--ff-display);
  font-size:clamp(1.05rem,1.8vw,1.3rem);
  color:var(--text);
  background:transparent;border:0;cursor:pointer;
  font-weight:500;
}
.faq-trigger:hover{color:var(--accent-dark);}
.faq-chevron{
  flex-shrink:0;
  width:22px;height:22px;
  position:relative;
}
.faq-chevron::before,
.faq-chevron::after{
  content:"";position:absolute;left:50%;top:50%;
  background:var(--accent);
  transition:transform var(--t-med);
}
.faq-chevron::before{width:12px;height:1.5px;transform:translate(-50%,-50%);}
.faq-chevron::after{width:1.5px;height:12px;transform:translate(-50%,-50%);}
.faq-trigger[aria-expanded="true"] .faq-chevron::after{transform:translate(-50%,-50%) scaleY(0);}
.faq-answer{padding:0 6px 22px;}
.faq-answer p{margin:0;color:var(--text-2);font-size:.98rem;line-height:1.6;}

/* ========== CONTACT ========== */
.contact-grid{
  display:grid;grid-template-columns:1fr;gap:30px;
}
@media (min-width:900px){
  .contact-grid{grid-template-columns:1.05fr .95fr;gap:48px;}
}
.contact-coord{display:flex;flex-direction:column;gap:18px;margin-bottom:24px;}
.contact-coord__item{
  display:flex;align-items:center;gap:14px;
}
.contact-coord__icon{
  width:42px;height:42px;
  border-radius:var(--r-md);
  background:color-mix(in srgb,var(--accent) 12%,var(--bg));
  color:var(--accent);
  display:grid;place-items:center;
  flex-shrink:0;
}
.contact-coord__icon svg{width:20px;height:20px;}
.contact-coord__body{display:flex;flex-direction:column;gap:2px;min-width:0;}
.contact-coord__label{
  font-family:var(--ff-ui);
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:var(--text-mute);
}
.contact-coord__value{
  font-family:var(--ff-display);
  font-size:1.15rem;
  color:var(--text);
  line-height:1.3;
}
.contact-coord__value a{color:var(--text);text-decoration:none;border-bottom:1px solid var(--accent);padding-bottom:1px;}
.contact-coord__value a:hover{color:var(--accent);}

.contact-cta-row{display:flex;flex-direction:column;gap:10px;margin-bottom:18px;}
@media (min-width:500px){.contact-cta-row{flex-direction:row;}.contact-cta-row .btn{flex:1;}}

.dispo-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 14px;
  border-radius:999px;
  background:color-mix(in srgb,#3FA664 15%,var(--bg));
  color:#2A6038;
  font-family:var(--ff-ui);
  font-size:.84rem;
  font-weight:600;
  border:1px solid color-mix(in srgb,#3FA664 25%,transparent);
  margin-bottom:14px;
}
.dispo-pill__dot{
  width:8px;height:8px;border-radius:50%;background:#3FA664;
  animation:pulse 2s ease-in-out infinite;
}
.dispo-pill.is-closed{
  background:color-mix(in srgb,#B07B4F 15%,var(--bg));
  color:#7A4D24;
  border-color:color-mix(in srgb,#B07B4F 25%,transparent);
}
.dispo-pill.is-closed .dispo-pill__dot{background:#B07B4F;animation:none;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.4;}}

.contact-form-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  padding:30px 26px;
}
.contact-form-card h3{margin-top:0;font-size:1.4rem;}
.contact-form-card .form-grid{margin-top:18px;}
.contact-form-card .btn{margin-top:14px;width:100%;}

/* Zone communes chips */
.zone-chips{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 22px;}
.zone-chips .chip{font-size:.82rem;padding:7px 13px;}

/* Map */
.map-wrap{
  width:100%;
  border-radius:var(--r-lg);
  overflow:hidden;
  border:1px solid var(--border);
  margin-top:20px;
  background:var(--surface);
}
.map-wrap iframe{display:block;width:100%;height:280px;border:0;}
@media (min-width:768px){.map-wrap iframe{height:320px;}}

/* ========== ABOUT (intercale) ========== */
.about-grid{
  display:grid;grid-template-columns:1fr;gap:36px;align-items:center;
}
@media (min-width:900px){
  .about-grid{grid-template-columns:1fr 1.05fr;gap:64px;}
}
.about-media{
  width:100%;
  aspect-ratio:4/5;
  border-radius:var(--r-lg);
  overflow:hidden;
  border:1px solid var(--border);
}
.about-media img{width:100%;height:100%;object-fit:cover;display:block;}
.about-body p{
  font-family:var(--ff-body);
  font-size:1.04rem;
  color:var(--text-2);
  line-height:1.7;
  margin:0 0 16px;
}
.about-body p:first-of-type::first-letter{
  font-family:var(--ff-display);
  font-size:3.2em;
  float:left;
  line-height:.9;
  margin:.06em .08em 0 0;
  color:var(--accent);
  font-weight:500;
}
.about-signature{
  margin-top:18px;
  font-family:var(--ff-display);
  font-style:italic;
  font-size:1.05rem;
  color:var(--accent-dark);
}
