/* ============ SECTIONS ============ */

/* ==== Hero IMMERSIF (override HERO-SVG impose : 7 photos dispo) ==== */
.hero-immersif {
  position: relative;
  min-height: 84dvh;
  display: flex;
  align-items: flex-end;
  padding: calc(var(--header-h-mobile) + 16px) 20px 32px;
  border-radius: 0 0 18px 18px;
  overflow: hidden;
}
@media (min-width:768px) {
  .hero-immersif { padding: clamp(40px, 8vh, 88px) 32px clamp(48px, 9vh, 108px); min-height: 88dvh; }
}
.hero-immersif__bg {
  position: absolute; inset: 0; z-index: 0;
  overflow: hidden;
}
.hero-immersif__bg img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transform: scale(1.04);
  animation: heroZoom 22s ease-in-out infinite alternate;
}
@keyframes heroZoom {
  to { transform: scale(1.10); }
}
@media (prefers-reduced-motion: reduce) {
  .hero-immersif__bg img { animation: none; transform: none; }
}
.hero-immersif::before {
  content: ""; position: absolute; inset: 0; z-index: 1;
  background:
    radial-gradient(120% 80% at 25% 100%, rgba(46,40,32,.78) 0%, rgba(46,40,32,0) 60%),
    linear-gradient(180deg, rgba(46,40,32,.15) 0%, rgba(46,40,32,.65) 100%);
}
.hero-immersif::after {
  content: ""; position: absolute; inset: 0; z-index: 1;
  background-image: radial-gradient(rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 22px 22px;
  opacity: .35;
}
.hero-immersif__inner {
  position: relative; z-index: 2;
  max-width: 760px;
  color: #fff;
  width: 100%;
}
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: .55em;
  font-family: var(--ff-ui); text-transform: uppercase; letter-spacing: .22em;
  font-size: .72rem; color: rgba(255,255,255,.86); font-weight: 600;
  margin-bottom: 16px;
}
.hero-eyebrow::before { content:""; display:inline-block; width: 28px; height: 1px; background: rgba(255,255,255,.6); }
.hero-immersif h1 {
  font-family: var(--ff-display);
  font-size: clamp(2rem, 7vw, 4.4rem);
  line-height: 1.08;
  font-weight: 500;
  color: #fff;
  letter-spacing: -.01em;
  margin: 0 0 14px;
  max-width: 18ch;
}
.hero-immersif h1 em {
  font-style: italic;
  color: var(--accent-soft);
}
.hero-immersif__sub {
  font-size: clamp(.96rem, 1.7vw, 1.15rem);
  color: rgba(255,255,255,.92);
  max-width: 50ch;
  margin: 0 0 18px;
  line-height: 1.5;
}
.hero-usp {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-bottom: 18px;
}
.hero-usp .chip {
  background: rgba(255,255,255,.12);
  color: #fff;
  border-color: rgba(255,255,255,.28);
  -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px);
}
.hero-meta {
  position: absolute;
  left: 20px; right: 20px;
  bottom: 16px;
  display: flex; flex-wrap: wrap; gap: 14px; align-items: center; justify-content: space-between;
  font-family: var(--ff-ui);
  font-size: .82rem;
  color: rgba(255,255,255,.78);
  z-index: 2;
  pointer-events: none;
}
.hero-meta .dot-live {
  display: inline-flex; align-items: center; gap: 8px;
  pointer-events: auto;
}
.hero-meta .dot-live::before {
  content:""; width: 8px; height: 8px; border-radius: 50%;
  background: var(--wa-green);
  box-shadow: 0 0 0 0 rgba(37,211,102,.6);
  animation: pulse 2.2s ease-out infinite;
}
@keyframes pulse {
  0% { box-shadow: 0 0 0 0 rgba(37,211,102,.6); }
  70% { box-shadow: 0 0 0 10px rgba(37,211,102,0); }
  100% { box-shadow: 0 0 0 0 rgba(37,211,102,0); }
}
@media (prefers-reduced-motion: reduce) {
  .hero-meta .dot-live::before { animation: none; }
}
@media (max-width: 540px) {
  .hero-meta { position: static; margin-top: 22px; }
}

/* ==== Intro strip apres hero ==== */
.intro-strip {
  background: var(--bg-alt);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 22px 0;
}
.intro-strip__inner {
  display: flex; align-items: center; gap: 16px;
  flex-wrap: wrap;
}
.intro-strip__quote {
  font-family: var(--ff-display);
  font-style: italic;
  font-size: clamp(1.05rem, 2vw, 1.3rem);
  color: var(--text);
  flex: 1;
  min-width: 220px;
  line-height: 1.4;
}
.intro-strip__quote::before { content: "« "; color: var(--accent); }
.intro-strip__quote::after { content: " »"; color: var(--accent); }
.intro-strip__author {
  font-family: var(--ff-ui);
  font-size: .8rem;
  color: var(--text-mute);
  letter-spacing: .08em;
  text-transform: uppercase;
  white-space: nowrap;
}

/* ==== Services grid-3 (LAY-5) ==== */
.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; } }

/* ==== A propos ==== */
.about {
  display: grid;
  grid-template-columns: 1fr;
  gap: 36px;
  align-items: center;
}
@media (min-width: 880px) {
  .about { grid-template-columns: 1fr 1fr; gap: clamp(40px, 5vw, 72px); }
}
.about-body p { font-size: 1.04rem; color: var(--text-2); line-height: 1.7; }
.about-body p:first-of-type { font-size: 1.1rem; color: var(--text); }
.about-tags { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 24px; }
.about-photo {
  width: 100%;
  aspect-ratio: 4 / 5;
  border-radius: 16px;
  overflow: hidden;
  position: relative;
  box-shadow: 0 18px 40px rgba(46,40,32,.12);
}
.about-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.about-photo__caption {
  position: absolute;
  left: 16px; bottom: 16px;
  background: rgba(46,40,32,.7);
  color: #fff;
  font-family: var(--ff-ui);
  font-size: .78rem;
  padding: 6px 12px;
  border-radius: 999px;
  letter-spacing: .04em;
  backdrop-filter: blur(4px);
}

/* ==== Stats strip ==== */
.stats {
  background: color-mix(in srgb, var(--accent) 8%, var(--bg));
  border-top: 1px solid color-mix(in srgb, var(--accent) 18%, transparent);
  border-bottom: 1px solid color-mix(in srgb, var(--accent) 18%, transparent);
  padding: 36px 0;
}
.stats-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
  text-align: center;
}
@media (min-width: 640px) { .stats-grid { grid-template-columns: repeat(3, 1fr); position: relative; } }
.stat-item {
  position: relative;
  padding: 0 8px;
}
@media (min-width: 640px) {
  .stat-item + .stat-item::before {
    content: "";
    position: absolute;
    left: 0; top: 12%;
    height: 76%;
    width: 1px;
    background: color-mix(in srgb, var(--accent) 24%, transparent);
  }
}
.stat-num {
  font-family: var(--ff-display);
  font-style: italic;
  font-size: clamp(2.1rem, 4.4vw, 2.8rem);
  font-weight: 500;
  color: var(--accent-deep);
  line-height: 1;
  display: block;
  margin-bottom: 6px;
}
.stat-label {
  font-family: var(--ff-ui);
  font-size: .82rem;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--text-2);
}

/* ==== Galerie masonry ==== */
.gal-masonry {
  column-count: 3;
  column-gap: 14px;
}
.gal-item {
  position: relative;
  margin: 0 0 14px;
  break-inside: avoid;
  cursor: zoom-in;
  border-radius: 12px;
  overflow: hidden;
}
.gal-item img {
  width: 100%;
  display: block;
  transition: transform .6s ease;
}
.gal-item:hover img { transform: scale(1.04); }
.gal-item__tag {
  position: absolute;
  bottom: 12px; left: 12px;
  background: rgba(255,255,255,.92);
  color: var(--text);
  font-family: var(--ff-ui);
  font-size: .7rem;
  letter-spacing: .12em;
  font-weight: 600;
  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: 560px) { .gal-masonry { column-count: 1; } .gal-item { margin-bottom: 12px; } }

/* ==== Avis cards (LAY-5) ==== */
.avis-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
}
@media (max-width: 760px) { .avis-cards { grid-template-columns: 1fr; gap: 18px; } }
.avis-card {
  position: relative;
  padding: 28px 26px 22px;
  background: var(--surface);
  border-left: 4px solid var(--accent);
  border-radius: 0 14px 14px 0;
}
.avis-card__quote {
  font-family: var(--ff-display);
  font-style: italic;
  font-size: 1.18rem;
  line-height: 1.45;
  color: var(--text);
  margin: 0 0 16px;
  quotes: "« " " »";
}
.avis-card__quote::before { content: "« "; color: var(--accent); font-style: normal; }
.avis-card__quote::after { content: " »"; color: var(--accent); font-style: normal; }
.avis-card__foot {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
  font-family: var(--ff-ui);
  margin-top: 12px;
}
.avis-card__author {
  font-weight: 600;
  font-size: .92rem;
  color: var(--text);
}
.avis-card__date {
  font-size: .78rem;
  color: var(--text-mute);
  display: block;
  font-weight: 400;
  margin-top: 1px;
}
.avis-card--meta {
  background: var(--bg-alt);
  border-left-color: var(--accent-2);
}
.avis-card--meta .avis-card__quote {
  font-style: normal;
  font-family: var(--ff-body);
  font-size: 1rem;
  color: var(--text-2);
  line-height: 1.55;
}
.avis-card--meta .avis-card__quote::before,
.avis-card--meta .avis-card__quote::after { content: none; }
.avis-link {
  display: inline-flex;
  align-items: center; gap: 8px;
  margin-top: 24px;
  font-family: var(--ff-ui);
  font-size: .92rem;
  color: var(--accent-deep);
  text-decoration: none;
  border-bottom: 1.5px solid var(--accent);
  padding-bottom: 2px;
  transition: color .2s;
}
.avis-link:hover { color: var(--accent); }

/* ==== FAQ accordion ==== */
.faq-list { display: flex; flex-direction: column; gap: 4px; }
.faq-item {
  border-bottom: 1px solid var(--border);
}
.faq-item:first-child { border-top: 1px solid var(--border); }
.faq-trigger {
  width: 100%;
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px;
  padding: 20px 4px;
  background: transparent;
  border: 0;
  text-align: left;
  font-family: var(--ff-display);
  font-size: clamp(1.05rem, 2vw, 1.25rem);
  font-weight: 500;
  color: var(--text);
  cursor: pointer;
  line-height: 1.3;
}
.faq-chevron {
  flex-shrink: 0;
  width: 28px; height: 28px;
  border: 1.5px solid var(--accent);
  border-radius: 50%;
  position: relative;
  transition: transform .35s ease, background .25s ease;
}
.faq-chevron::before, .faq-chevron::after {
  content: ""; position: absolute;
  background: var(--accent);
  border-radius: 1px;
  transition: transform .25s ease;
}
.faq-chevron::before { left: 7px; right: 7px; top: 50%; height: 1.6px; transform: translateY(-50%); }
.faq-chevron::after { top: 7px; bottom: 7px; left: 50%; width: 1.6px; transform: translateX(-50%); }
.faq-trigger[aria-expanded="true"] .faq-chevron::after { transform: translateX(-50%) scaleY(0); }
.faq-trigger[aria-expanded="true"] .faq-chevron { background: var(--accent-soft); }
.faq-answer {
  padding: 0 4px 22px;
  color: var(--text-2);
  font-size: 1rem;
  line-height: 1.65;
  max-width: 70ch;
}
.faq-answer p { margin: 0 0 .8em; }
.faq-answer strong { color: var(--text); font-weight: 600; }

/* ==== Zone ==== */
.zone {
  display: grid; grid-template-columns: 1fr;
  gap: 32px;
}
@media (min-width: 880px) { .zone { grid-template-columns: 1fr 1.1fr; gap: 48px; } }
.zone-info h3 {
  font-size: 1.1rem; font-weight: 600; font-family: var(--ff-ui);
  text-transform: uppercase; letter-spacing: .14em; margin: 0 0 14px;
  color: var(--text-2);
}
.communes { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 28px; }
.commune {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 6px 12px;
  background: var(--bg-alt);
  border: 1px solid var(--border);
  border-radius: 999px;
  font-size: .86rem;
  color: var(--text-2);
}
.commune svg { width: 12px; height: 12px; color: var(--accent); }

.hours-table {
  width: 100%;
  border-collapse: collapse;
}
.hours-table tr {
  border-top: 1px solid var(--border);
}
.hours-table tr:last-child { border-bottom: 1px solid var(--border); }
.hours-table td {
  padding: 11px 4px;
  font-size: .96rem;
  vertical-align: middle;
}
.hours-table td:first-child {
  font-weight: 500;
  text-transform: capitalize;
}
.hours-table td:last-child {
  text-align: right;
  color: var(--text-2);
  font-variant-numeric: tabular-nums;
}
.hours-table .is-today {
  background: color-mix(in srgb, var(--accent) 8%, var(--bg));
}
.hours-table .is-today td:first-child { color: var(--accent-deep); }
.hours-table .is-closed td:last-child { color: var(--text-mute); font-style: italic; }
.open-badge {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 13px;
  background: color-mix(in srgb, var(--wa-green) 12%, var(--bg));
  border: 1px solid color-mix(in srgb, var(--wa-green) 35%, transparent);
  border-radius: 999px;
  font-family: var(--ff-ui); font-size: .82rem; font-weight: 600;
  color: var(--wa-deep);
  margin-bottom: 20px;
}
.open-badge.is-closed {
  background: color-mix(in srgb, #c44 12%, var(--bg));
  border-color: color-mix(in srgb, #c44 35%, transparent);
  color: #8a2c2c;
}
.open-badge::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%;
  background: var(--wa-green);
  box-shadow: 0 0 0 0 rgba(37,211,102,.5);
  animation: pulse 2.2s ease-out infinite;
}
.open-badge.is-closed::before { background: #c44; animation: none; }
@media (prefers-reduced-motion: reduce) { .open-badge::before { animation: none; } }

.map-wrap {
  position: relative;
  width: 100%;
  padding-top: 75%;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 14px 32px rgba(46,40,32,.12);
}
.map-wrap iframe {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  border: 0;
}

/* ==== Contact ==== */
.contact {
  background: var(--surface-deep);
  color: var(--text-inverse);
  padding: 64px 0;
}
.contact :where(h1,h2,h3,h4,p,a,span,li,strong,small) { color: var(--text-inverse); }
.contact .section-head h2 em { color: var(--accent-soft); }
.contact .section-head p { color: color-mix(in srgb, var(--text-inverse) 82%, transparent); }
.contact-grid {
  display: grid; grid-template-columns: 1fr;
  gap: 32px;
}
@media (min-width: 900px) { .contact-grid { grid-template-columns: 1fr 1.05fr; gap: 56px; } }
.contact-info { display: flex; flex-direction: column; gap: 22px; }
.contact-row {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 16px;
  align-items: center;
}
.contact-row__icon {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--accent) 22%, var(--surface-deep));
  display: grid; place-items: center;
  color: var(--accent-soft);
}
.contact-row__icon svg { width: 20px; height: 20px; }
.contact-row__label {
  font-family: var(--ff-ui); font-size: .76rem;
  text-transform: uppercase; letter-spacing: .18em;
  color: color-mix(in srgb, var(--text-inverse) 68%, transparent);
  margin: 0 0 2px;
}
.contact-row__value {
  font-family: var(--ff-display); font-size: 1.18rem; font-weight: 500;
  text-decoration: none;
  color: var(--text-inverse);
}
.contact-row__value:hover { color: var(--accent-soft); }
.contact-row__hours { display: flex; flex-direction: column; gap: 1px; font-family: var(--ff-ui); font-size: .92rem; }

.contact-form {
  background: color-mix(in srgb, var(--text-inverse) 8%, var(--surface-deep));
  padding: 28px 24px;
  border-radius: 16px;
  border: 1px solid color-mix(in srgb, var(--text-inverse) 14%, transparent);
}
.contact-form h3 {
  font-family: var(--ff-display); font-style: italic;
  font-size: 1.35rem; margin: 0 0 16px;
}
.contact-form .field label {
  color: color-mix(in srgb, var(--text-inverse) 78%, transparent);
}
.contact-form .field input,
.contact-form .field textarea,
.contact-form .field select {
  background: color-mix(in srgb, var(--text-inverse) 8%, transparent);
  border-color: color-mix(in srgb, var(--text-inverse) 24%, transparent);
  color: var(--text-inverse);
}
.contact-form .field input:focus,
.contact-form .field textarea:focus,
.contact-form .field select:focus {
  border-color: var(--accent-soft);
  background: color-mix(in srgb, var(--text-inverse) 14%, transparent);
}
.contact-form .field input::placeholder,
.contact-form .field textarea::placeholder {
  color: color-mix(in srgb, var(--text-inverse) 50%, transparent);
}
.contact-form .btn-wa { width: 100%; margin-top: 6px; }
.contact-form__hint { font-size: .82rem; color: color-mix(in srgb, var(--text-inverse) 65%, transparent); margin-top: 12px; line-height: 1.45; }
