/* Sections */
section{padding:var(--section-py-mobile) 0;}
@media (min-width:880px){section{padding:var(--section-py-desktop) 0;}}

/* HERO-SVG : split texte + illustration arbre / grimpeur */
.hero-svg{
  display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(24px,4vw,56px);align-items:center;
  max-width:1240px;margin:0 auto;
  padding:clamp(44px,6vw,86px) 24px;
}
.hero-svg__eyebrow{display:inline-flex;align-items:center;gap:10px;margin-bottom:18px;}
.hero-svg__eyebrow::before{content:"";width:36px;height:1.5px;background:var(--accent);}
.hero-svg__title{
  font-family:var(--ff-display);
  font-size:clamp(2.3rem,5.2vw,3.8rem);
  line-height:1.04;color:var(--text);font-weight:500;
  margin:0 0 .5em;
}
.hero-svg__title em{font-style:italic;color:var(--accent);font-weight:500;position:relative;display:inline-block;}
.hero-svg__title em::after{
  content:"";position:absolute;left:-2px;right:-2px;bottom:.06em;height:.36em;
  background:color-mix(in srgb,var(--accent) 22%,transparent);
  border-radius:3px;z-index:-1;transform:skewX(-6deg);
}
.hero-svg__sub{
  font-family:var(--ff-body);font-size:clamp(1rem,1.6vw,1.16rem);
  color:var(--text-2);margin:0 0 28px;max-width:48ch;line-height:1.6;
}
.hero-svg__rating{
  display:inline-flex;align-items:center;gap:10px;margin-bottom:24px;
  padding:8px 14px;background:rgba(255,255,255,.65);
  border:1px solid var(--border);border-radius:999px;
  font-family:var(--ff-ui);font-size:.92rem;color:var(--text);
  text-decoration:none;font-weight:500;
}
.hero-svg__rating .stars{display:inline-flex;gap:1px;color:#E0A516;}
.hero-svg__rating .stars svg{width:14px;height:14px;}
.hero-svg__rating strong{font-weight:700;color:var(--text);}
.hero-svg__cta{display:flex;flex-wrap:wrap;gap:12px;}
.hero-svg__usps{
  display:flex;flex-wrap:wrap;gap:10px;margin-top:26px;
}
.hero-svg__usp{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--ff-ui);font-size:.86rem;color:var(--text);
  background:color-mix(in srgb,var(--accent) 8%,var(--bg));
  border:1px solid color-mix(in srgb,var(--accent) 16%,transparent);
  padding:6px 12px;border-radius:999px;
}
.hero-svg__usp svg{width:14px;height:14px;color:var(--accent);}
.hero-svg__art{
  width:100%;max-width:480px;margin:0 auto;
  position:relative;color:var(--accent);
}
.hero-svg__art svg{width:100%;height:auto;display:block;}
@media (max-width:879px){
  .hero-svg{grid-template-columns:1fr;gap:24px;padding:calc(var(--header-h-mobile) + 18px) 20px 32px;}
  .hero-svg__art{max-width:300px;order:-1;}
  .hero-svg__cta .btn{flex:0 0 100%;}
}

/* Realisations (LAY-5 gallery masonry) */
.realisations{background:var(--surface);}
.realisations .section-head{text-align:center;margin-bottom:36px;}
.realisations h2{margin-bottom:8px;}
.realisations .section-head p{max-width:54ch;margin:0 auto;color:var(--text-2);}

.gal-masonry{column-count:3;column-gap:14px;}
.gal-masonry .gal-item{
  width:100%;margin:0 0 14px;border-radius:12px;display:block;break-inside:avoid;
  overflow:hidden;position:relative;cursor:zoom-in;background:var(--bg-alt);
}
.gal-masonry .gal-item img{
  width:100%;height:auto;display:block;
  transition:transform var(--t-mid),filter var(--t-mid);
  filter:saturate(1.04) contrast(1.02);
}
.gal-masonry .gal-item:hover img{transform:scale(1.04);}
.gal-masonry .gal-tag{
  position:absolute;left:12px;bottom:12px;
  background:rgba(31,53,49,.72);color:#fff;
  font-family:var(--ff-ui);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;
  padding:5px 11px;border-radius:999px;backdrop-filter:blur(4px);
}
@media (max-width:900px){.gal-masonry{column-count:2;}}
@media (max-width:520px){.gal-masonry{column-count:1;}}

/* Services (LAY-5 services grid-3 + card stripe) */
.services .section-head{max-width:760px;margin-bottom:36px;}
.services .section-head p{color:var(--text-2);font-size:1.05rem;}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
@media (max-width:900px){.svc-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.svc-grid{grid-template-columns:1fr;}}

/* Avis (LAY-5 avis cards + card stripe) */
.avis{background:var(--bg-alt);}
.avis .section-head{text-align:center;margin-bottom:40px;}
.avis-rating-strip{
  display:inline-flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:10px;
  margin:0 auto 12px;padding:8px 18px;background:var(--bg);
  border:1px solid var(--border);border-radius:999px;
  font-family:var(--ff-ui);
}
.avis-rating-strip strong,.avis-rating-strip span{white-space:nowrap;}
.avis-rating-strip .stars{display:inline-flex;gap:1px;color:#E0A516;}
.avis-rating-strip .stars svg{width:15px;height:15px;}
.avis-rating-strip a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;font-weight:600;}
.avis-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
@media (max-width:900px){.avis-cards{grid-template-columns:1fr;}}
.avis-card{
  border-left:4px solid var(--accent);
  background:var(--bg);
  border-radius:0 14px 14px 0;
  padding:22px 24px;
  display:flex;flex-direction:column;gap:10px;
}
.avis-card .stars{display:inline-flex;gap:1px;color:#E0A516;}
.avis-card .stars svg{width:14px;height:14px;}
.avis-card blockquote{
  margin:0;font-family:var(--ff-display);font-style:italic;
  font-size:1.02rem;line-height:1.55;color:var(--text);
}
.avis-card .meta{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  font-family:var(--ff-ui);font-size:.85rem;color:var(--text-mute);
  border-top:1px solid var(--border);padding-top:10px;margin-top:6px;
}
.avis-card .meta strong{color:var(--text);font-weight:600;}
.badge-google{display:inline-flex;align-items:center;gap:5px;font-size:.78rem;}
.badge-google svg{width:13px;height:13px;}

/* Stats */
.stats{background:var(--accent);color:#fff;}
.stats .stats-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  max-width:1000px;margin:0 auto;text-align:center;
}
.stats .stat-item{padding:8px 0;}
.stats .stat-num{
  display:block;font-family:var(--ff-display);
  font-size:clamp(2rem,4.5vw,3rem);font-weight:500;color:#fff;line-height:1;margin-bottom:8px;
}
.stats .stat-label{
  font-family:var(--ff-ui);font-size:.85rem;letter-spacing:.10em;text-transform:uppercase;
  color:rgba(255,255,255,.85);
}
@media (max-width:560px){
  .stats .stats-grid{grid-template-columns:1fr;gap:18px;}
  .stats .stat-item{padding:12px 0;border-bottom:1px solid rgba(255,255,255,.18);}
  .stats .stat-item:last-child{border-bottom:none;}
}

/* FAQ */
.faq{background:var(--surface);}
.faq .container{max-width:820px;}
.faq .section-head{text-align:center;margin-bottom:36px;}
.faq-list{display:flex;flex-direction:column;gap:10px;margin:0;padding:0;}
.faq-item{background:var(--bg);border:1px solid var(--border);border-radius:12px;overflow:hidden;}
.faq-item dt{margin:0;}
.faq-trigger{
  width:100%;text-align:left;background:transparent;border:none;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:18px 22px;font-family:var(--ff-display);font-size:1.06rem;
  color:var(--text);cursor:pointer;font-weight:500;line-height:1.35;
}
.faq-trigger:hover{background:var(--accent-soft);}
.faq-chevron{
  width:22px;height:22px;border-radius:50%;display:grid;place-items:center;
  background:var(--accent-soft);color:var(--accent-strong);flex-shrink:0;
  transition:transform var(--t-fast);
  position:relative;
}
.faq-chevron::before,.faq-chevron::after{
  content:"";position:absolute;background:currentColor;border-radius:1px;
}
.faq-chevron::before{width:10px;height:2px;}
.faq-chevron::after{width:2px;height:10px;transition:transform var(--t-fast);}
.faq-trigger[aria-expanded="true"] .faq-chevron::after{transform:rotate(90deg);}
.faq-answer{margin:0;padding:0 22px 18px;}
.faq-answer p{margin:0;color:var(--text-2);font-size:.96rem;line-height:1.6;}
.faq-answer[hidden]{display:none;}

/* Contact (incl. zone + carte) */
.contact{background:var(--text);color:#E8F0EC;}
.contact h2{color:#fff;}
.contact .eyebrow{color:var(--accent-2);}
.contact-grid{
  display:grid;grid-template-columns:1.1fr .9fr;gap:42px;align-items:start;
  max-width:var(--container);margin:0 auto;
}
.contact-info p{color:#C5D2CD;}
.tel-big{
  font-family:var(--ff-display);font-style:italic;
  font-size:clamp(1.8rem,4vw,2.6rem);color:#fff;
  text-decoration:none;display:inline-block;margin:8px 0 18px;
  border-bottom:1.5px solid var(--accent-2);padding-bottom:4px;
}
.tel-big:hover{color:var(--accent-2);}
.contact-actions{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:22px;}
.contact-actions .btn-line{color:#E8F0EC;border-color:#E8F0EC;}
.contact-actions .btn-line:hover{background:#E8F0EC;color:var(--text);}
.horaires-list{list-style:none;padding:0;margin:18px 0 0;display:flex;flex-direction:column;gap:6px;}
.horaires-list li{
  display:flex;justify-content:space-between;gap:14px;
  font-family:var(--ff-ui);font-size:.94rem;color:#C5D2CD;
  padding:8px 12px;border-radius:8px;
}
.horaires-list li.is-today{background:rgba(74,139,127,.22);color:#fff;}
.horaires-list li.is-today strong{color:var(--accent-2);}
.horaires-list li.is-closed{opacity:.65;}
.horaires-list strong{font-weight:600;color:#fff;}
.zone-chips{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 8px;}
.zone-chip{
  display:inline-flex;align-items:center;
  background:rgba(255,255,255,.10);color:#fff;
  padding:6px 12px;border-radius:999px;
  font-family:var(--ff-ui);font-size:.84rem;
  border:1px solid rgba(255,255,255,.16);
}
.zone-chip-pri{background:var(--accent);border-color:var(--accent);}
.map-wrap{
  position:relative;width:100%;padding-top:60%;border-radius:14px;overflow:hidden;
  background:#0F1C19;
}
.map-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0;}
.contact-form-card{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);
  border-radius:16px;padding:24px;backdrop-filter:blur(4px);
}
.contact-form-card h3{color:#fff;margin:0 0 14px;}
.contact-form-card label{color:#E8F0EC;}
.contact-form-card input,.contact-form-card textarea{
  background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.18);color:#fff;
}
.contact-form-card input::placeholder,.contact-form-card textarea::placeholder{color:#9CABA6;}
.contact-form-card input:focus,.contact-form-card textarea:focus{
  border-color:var(--accent-2);box-shadow:0 0 0 3px rgba(111,168,157,.22);
}
@media (max-width:880px){
  .contact-grid{grid-template-columns:1fr;gap:32px;}
  .tel-big{font-size:2rem;}
}

/* Section head generale */
.section-head{margin-bottom:36px;}
.section-head .eyebrow{display:inline-block;margin-bottom:10px;}
