/* ============================================================
   HERO IMMERSIF - photo plein ecran, voile, type editorial
   ============================================================ */
.hero{
  position:relative;
  min-height:100dvh;
  display:flex;
  align-items:flex-end;
  color:var(--on-dark);
  overflow:hidden;
  padding-bottom:64px;
}
.hero-media{
  position:absolute;inset:0;
  z-index:0;
}
.hero-media img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 35%;
  transform:scale(1.06);
  animation:heroZoom 16s var(--ease) forwards;
}
@keyframes heroZoom{to{transform:scale(1)}}
.hero-media::after{
  content:"";
  position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(27,42,32,.55) 0%, rgba(27,42,32,.18) 30%, rgba(27,42,32,.4) 60%, rgba(27,42,32,.86) 100%),
    linear-gradient(90deg, rgba(27,42,32,.55) 0%, rgba(27,42,32,.1) 60%);
}
.hero-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(246,244,235,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(246,244,235,.04) 1px, transparent 1px);
  background-size:64px 64px;
  z-index:1;
  pointer-events:none;
}
.hero-inner{
  position:relative;z-index:2;
  width:100%;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--ff-ui);
  font-size:.78rem;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--on-dark-2);
  margin-bottom:22px;
}
.hero-eyebrow::before{
  content:"";width:36px;height:1px;background:var(--on-dark-2);
}
.hero h1{
  font-size:clamp(2.6rem, 8.5vw, 5.4rem);
  font-weight:400;
  color:var(--on-dark);
  letter-spacing:-.02em;
  line-height:1.04;
  max-width:14ch;
}
.hero h1 em{
  font-style:italic;
  color:var(--on-dark);
  font-weight:300;
}
.hero h1 .underline{
  display:inline-block;
  position:relative;
  font-style:italic;
  font-weight:300;
}
.hero h1 .underline::after{
  content:"";
  position:absolute;
  left:0;right:0;
  bottom:.04em;
  height:1px;
  background:var(--gold);
}
.hero-sub{
  margin-top:24px;
  font-size:1.08rem;
  line-height:1.55;
  color:var(--on-dark-2);
  max-width:46ch;
}
.hero-rating-badge{
  display:inline-flex;align-items:center;gap:10px;
  margin-top:28px;
  padding:9px 16px;
  border-radius:999px;
  background:rgba(246,244,235,.1);
  border:1px solid rgba(246,244,235,.22);
  backdrop-filter:blur(8px);
  font-family:var(--ff-ui);
  font-size:.86rem;
  color:var(--on-dark);
}
.hero-rating-badge strong{font-weight:600}
.hero-rating-badge .stars{color:#F4C265}
.hero-rating-badge .sep{opacity:.4}
.hero-cta{
  margin-top:36px;
  display:flex;flex-direction:column;gap:12px;
}
.hero-cta .btn{width:100%;justify-content:center;padding:16px 22px}
@media (min-width:560px){
  .hero-cta{flex-direction:row;gap:14px}
  .hero-cta .btn{width:auto;flex:none}
}
.hero-meta{
  position:absolute;
  left:24px;right:24px;
  bottom:18px;
  z-index:3;
  display:flex;align-items:center;justify-content:space-between;
  font-family:var(--ff-ui);font-size:.74rem;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--on-dark-mute);
}
.hero-meta .scroll-cue{
  display:inline-flex;align-items:center;gap:8px;
}
.hero-meta .scroll-cue::after{
  content:"";display:block;width:1px;height:40px;
  background:linear-gradient(180deg, var(--on-dark-2), transparent);
  animation:cueDrop 2.4s ease-in-out infinite;
  transform-origin:top;
}
@keyframes cueDrop{
  0%{transform:scaleY(.2)}
  50%{transform:scaleY(1)}
  100%{transform:scaleY(.2)}
}

/* ============================================================
   STATS STRIP
   ============================================================ */
.stats{
  padding:60px 0;
  border-bottom:1px solid var(--border-soft);
  background:var(--surface-warm);
}
.stats-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:36px;
  text-align:left;
}
.stat{
  display:flex;flex-direction:column;gap:8px;
  border-left:1px solid var(--border);
  padding-left:24px;
}
.stat-val{
  font-family:var(--ff-display);
  font-size:clamp(2.4rem, 6vw, 3.6rem);
  font-weight:400;
  color:var(--accent);
  line-height:1;
  letter-spacing:-.02em;
}
.stat-val .small{font-size:.55em;color:var(--text-2);font-style:italic;font-family:var(--ff-display)}
.stat-label{
  font-family:var(--ff-ui);
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--text-2);
}
@media (min-width:768px){
  .stats-grid{grid-template-columns:repeat(3, 1fr);gap:0}
  .stat:first-child{border-left:0;padding-left:0}
}

/* ============================================================
   ABOUT (editorial split)
   ============================================================ */
.about-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:48px;
  align-items:center;
}
.about-media{
  position:relative;
}
.about-media-frame{
  position:relative;
  border-radius:var(--r-lg);
  overflow:hidden;
  aspect-ratio:4/5;
}
.about-media-frame img{width:100%;height:100%;object-fit:cover}
.about-media-tag{
  position:absolute;
  left:-12px;bottom:24px;
  background:var(--surface);
  padding:16px 22px;
  border-radius:var(--r-md);
  box-shadow:var(--sh-2);
  border:1px solid var(--border-soft);
  font-family:var(--ff-display);
  font-size:1.1rem;
  line-height:1.3;
  max-width:240px;
}
.about-media-tag small{
  display:block;
  font-family:var(--ff-ui);
  font-size:.68rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--text-mute);
  margin-bottom:6px;
}
.about-text h2{margin-bottom:22px}
.about-text .lead{
  font-size:1.15rem;
  line-height:1.55;
  color:var(--text);
  font-family:var(--ff-display);
  font-style:italic;
  font-weight:400;
  margin-bottom:24px;
  padding-left:18px;
  border-left:2px solid var(--accent);
}
.about-text p{color:var(--text-2);font-size:1rem;line-height:1.7}
.about-signature{
  margin-top:28px;
  display:flex;align-items:center;gap:16px;
  padding-top:24px;
  border-top:1px solid var(--border-soft);
}
.about-signature .sig-name{
  font-family:var(--ff-display);
  font-size:1.4rem;
  font-style:italic;
}
.about-signature .sig-role{
  font-family:var(--ff-ui);
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--text-mute);
  margin-top:4px;
}
@media (min-width:900px){
  .about-grid{grid-template-columns:1fr 1.3fr;gap:80px}
}

/* ============================================================
   SERVICES - LAY-4 "Liste epuree"
   ============================================================ */
.services{background:var(--bg-alt)}
.services-list{
  display:flex;flex-direction:column;
  border-top:1px solid var(--border);
}
.service-row{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:20px;
  padding:28px 0;
  border-bottom:1px solid var(--border);
  position:relative;
  transition:background .35s var(--ease), padding .35s var(--ease);
}
.service-row::before{
  content:"";
  position:absolute;
  inset:0 -24px;
  background:var(--surface-warm);
  opacity:0;
  transition:opacity .35s var(--ease);
  z-index:-1;
  border-radius:var(--r-md);
}
.service-row:hover::before{opacity:1}
@media (min-width:768px){
  .service-row:hover{padding-left:24px;padding-right:24px}
}
.service-num{
  font-family:var(--ff-display);
  font-size:1rem;
  font-style:italic;
  color:var(--text-mute);
  letter-spacing:.04em;
  min-width:36px;
}
.service-body h3{
  font-family:var(--ff-display);
  font-size:clamp(1.4rem, 3vw, 1.85rem);
  font-weight:500;
  color:var(--text);
  letter-spacing:-.01em;
  margin-bottom:6px;
}
.service-body p{
  font-size:.96rem;
  color:var(--text-2);
  margin:0;
  line-height:1.5;
}
.service-pic{
  width:48px;height:48px;
  border-radius:50%;
  background:var(--surface);
  display:grid;place-items:center;
  flex:none;
  border:1px solid var(--border);
}
.service-pic svg{
  width:24px;height:24px;
  stroke:var(--accent);
  fill:none;
  stroke-width:1.4;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.service-tag{
  display:none;
  font-family:var(--ff-ui);
  font-size:.74rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--accent);
  border:1px solid var(--accent);
  border-radius:999px;
  padding:6px 12px;
}
@media (min-width:768px){
  .service-tag{display:inline-block}
}
.services-footnote{
  margin-top:48px;
  padding:32px;
  border-radius:var(--r-lg);
  background:var(--accent-deep);
  color:var(--on-dark);
  display:flex;flex-direction:column;gap:16px;
  position:relative;
  overflow:hidden;
}
.services-footnote::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(246,244,235,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(246,244,235,.025) 1px, transparent 1px);
  background-size:32px 32px;
}
.services-footnote>*{position:relative}
.services-footnote h3{
  font-family:var(--ff-display);
  font-size:1.5rem;
  color:var(--on-dark);
  max-width:24ch;
}
.services-footnote p{color:var(--on-dark-2);margin:0;max-width:50ch}
.services-footnote .actions{display:flex;gap:12px;flex-wrap:wrap}
@media (min-width:768px){
  .services-footnote{flex-direction:row;align-items:center;justify-content:space-between;padding:40px 48px}
}

/* ============================================================
   GALERIE - LAY-4 slider + lightbox
   ============================================================ */
.gallery-head{
  display:flex;flex-direction:column;gap:12px;
  align-items:flex-start;
  margin-bottom:36px;
}
.gallery-head .actions{display:flex;gap:14px;align-items:center}
.gallery-slider-wrap{
  position:relative;
  margin:0 -24px;
}
.gallery-slider{
  display:flex;
  gap:18px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scrollbar-width:none;
  padding:8px 24px 24px;
  -webkit-overflow-scrolling:touch;
}
.gallery-slider::-webkit-scrollbar{display:none}
.gallery-item{
  flex:0 0 80%;
  scroll-snap-align:center;
  aspect-ratio:4/3;
  border-radius:var(--r-lg);
  overflow:hidden;
  position:relative;
  cursor:pointer;
  background:var(--bg-alt);
  box-shadow:var(--sh-1);
}
.gallery-item img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .5s var(--ease);
}
.gallery-item:hover img{transform:scale(1.04)}
.gallery-item-label{
  position:absolute;
  inset:auto 0 0 0;
  padding:16px 18px;
  background:linear-gradient(180deg, transparent, rgba(27,42,32,.85));
  color:var(--on-dark);
  font-family:var(--ff-ui);
  font-size:.82rem;
  letter-spacing:.04em;
  font-weight:500;
}
.gallery-item-label small{
  display:block;
  font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;
  opacity:.72;margin-bottom:4px;
}
@media (min-width:560px){.gallery-item{flex:0 0 60%}}
@media (min-width:900px){.gallery-item{flex:0 0 40%}}
@media (min-width:1100px){.gallery-item{flex:0 0 32%}}

.slider-nav{
  display:flex;gap:10px;align-items:center;
  margin-top:18px;
  padding:0 24px;
}
.slider-nav button{
  width:46px;height:46px;
  border-radius:50%;
  border:1px solid var(--border);
  background:var(--surface);
  color:var(--text);
  display:grid;place-items:center;
  transition:background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);
}
.slider-nav button:hover{background:var(--accent);color:var(--on-dark);border-color:var(--accent)}
.slider-nav button svg{width:18px;height:18px}
.slider-count{
  font-family:var(--ff-display);
  font-size:1.1rem;
  font-style:italic;
  color:var(--text-2);
  margin-left:8px;
}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;
  background:rgba(27,42,32,.92);
  z-index:var(--z-modal);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;
  transition:opacity .3s var(--ease), visibility 0s linear .3s;
  padding:24px;
}
.lightbox.is-open{opacity:1;visibility:visible;transition:opacity .3s var(--ease)}
.lightbox img{
  max-width:92vw;max-height:88vh;
  object-fit:contain;
  border-radius:var(--r-md);
  box-shadow:var(--sh-3);
}
.lightbox-close,.lightbox-prev,.lightbox-next{
  position:absolute;
  width:48px;height:48px;
  border-radius:50%;
  background:rgba(246,244,235,.12);
  color:var(--on-dark);
  display:grid;place-items:center;
  border:1px solid rgba(246,244,235,.18);
  backdrop-filter:blur(6px);
  transition:background .25s var(--ease);
}
.lightbox-close{top:24px;right:24px}
.lightbox-prev{left:24px;top:50%;transform:translateY(-50%)}
.lightbox-next{right:24px;top:50%;transform:translateY(-50%)}
.lightbox button:hover{background:rgba(246,244,235,.25)}
.lightbox svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.6;stroke-linecap:round}

/* ============================================================
   AVIS - carousel
   ============================================================ */
.avis{background:var(--surface-warm)}
.avis-head{
  display:grid;
  grid-template-columns:1fr;
  gap:32px;
  align-items:end;
  margin-bottom:48px;
}
.avis-score{
  display:flex;flex-direction:column;gap:8px;
  padding-left:24px;
  border-left:1px solid var(--border);
}
.avis-score-num{
  font-family:var(--ff-display);
  font-size:clamp(3rem, 8vw, 4.4rem);
  font-weight:400;
  color:var(--accent);
  line-height:1;
  letter-spacing:-.02em;
}
.avis-score-num .sub{font-size:.4em;color:var(--text-2);font-style:italic}
.avis-score-stars{display:flex;align-items:center;gap:10px}
.avis-score-stars .stars svg{width:18px;height:18px}
.avis-score-stars span{
  font-family:var(--ff-ui);
  font-size:.84rem;
  color:var(--text-2);
}
@media (min-width:900px){.avis-head{grid-template-columns:2fr 1fr}}

.avis-carousel-wrap{
  margin:0 -24px;
  position:relative;
}
.avis-carousel{
  display:flex;
  gap:18px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scrollbar-width:none;
  padding:8px 24px 28px;
  -webkit-overflow-scrolling:touch;
}
.avis-carousel::-webkit-scrollbar{display:none}
.avis-card{
  flex:0 0 88%;
  scroll-snap-align:center;
  background:var(--surface);
  border-radius:var(--r-lg);
  padding:32px 28px;
  border:1px solid var(--border-soft);
  display:flex;flex-direction:column;gap:18px;
  box-shadow:var(--sh-1);
}
.avis-quote-mark{
  font-family:var(--ff-display);
  font-size:3.5rem;
  font-style:italic;
  color:var(--accent);
  line-height:.5;
  margin-bottom:-8px;
}
.avis-card .stars{font-size:0}
.avis-card .stars svg{width:16px;height:16px}
.avis-text{
  font-family:var(--ff-display);
  font-size:1.15rem;
  line-height:1.45;
  font-style:italic;
  color:var(--text);
  font-weight:400;
}
.avis-author{
  margin-top:auto;
  padding-top:18px;
  border-top:1px solid var(--border-soft);
  display:flex;justify-content:space-between;align-items:flex-end;
  gap:14px;
}
.avis-author strong{
  display:block;
  font-family:var(--ff-ui);font-weight:600;font-size:.94rem;color:var(--text);
}
.avis-author small{
  display:block;
  font-size:.78rem;
  color:var(--text-mute);
  margin-top:4px;
}
.google-tag{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.74rem;
  color:var(--text-mute);
  font-family:var(--ff-ui);
}
.google-tag svg{width:14px;height:14px}
@media (min-width:768px){.avis-card{flex:0 0 60%}}
@media (min-width:1100px){.avis-card{flex:0 0 38%}}

/* ============================================================
   SAISONS - bloc "saison apres saison"
   ============================================================ */
.seasons{
  background:var(--accent-deep);
  color:var(--on-dark);
  position:relative;
  overflow:hidden;
}
.seasons::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(246,244,235,.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(246,244,235,.022) 1px, transparent 1px);
  background-size:48px 48px;
}
.seasons>.container{position:relative}
.seasons .section-head h2{color:var(--on-dark)}
.seasons .section-head p{color:var(--on-dark-2)}
.seasons .eyebrow{color:var(--on-dark-2)}
.seasons .eyebrow::before{background:var(--on-dark-2)}
.seasons-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:0;
  border-top:1px solid rgba(246,244,235,.14);
}
.season{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:24px;
  padding:32px 0;
  border-bottom:1px solid rgba(246,244,235,.14);
  align-items:baseline;
}
.season-mark{
  font-family:var(--ff-display);
  font-size:1.1rem;
  font-style:italic;
  color:var(--gold);
  letter-spacing:.04em;
}
.season-name{
  font-family:var(--ff-display);
  font-size:clamp(1.8rem, 4vw, 2.4rem);
  font-weight:400;
  color:var(--on-dark);
  letter-spacing:-.01em;
  margin-bottom:8px;
}
.season-name em{font-style:italic;color:var(--gold);font-weight:300}
.season-desc{color:var(--on-dark-2);font-size:1rem;line-height:1.55;max-width:48ch}
.season-tasks{
  list-style:none;margin:14px 0 0;padding:0;
  display:flex;flex-wrap:wrap;gap:8px;
}
.season-tasks li{
  font-family:var(--ff-ui);
  font-size:.78rem;
  color:var(--on-dark-2);
  padding:5px 12px;
  border:1px solid rgba(246,244,235,.22);
  border-radius:999px;
  letter-spacing:.02em;
}
@media (min-width:900px){
  .season{grid-template-columns:200px 1fr;gap:48px;padding:40px 0}
}

/* ============================================================
   FAQ
   ============================================================ */
.faq-grid{
  max-width:820px;
  margin:0 auto;
  border-top:1px solid var(--border);
}
.faq-item{
  border-bottom:1px solid var(--border);
}
.faq-q{
  width:100%;text-align:left;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:24px 0;
  font-family:var(--ff-display);
  font-size:clamp(1.15rem, 2.4vw, 1.35rem);
  font-weight:500;
  color:var(--text);
}
.faq-q .chev{
  width:32px;height:32px;
  border-radius:50%;
  border:1px solid var(--border);
  display:grid;place-items:center;flex:none;
  transition:transform .3s var(--ease), background .25s var(--ease), color .25s var(--ease);
}
.faq-q .chev svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.faq-item.is-open .faq-q .chev{
  transform:rotate(180deg);
  background:var(--accent);
  color:var(--on-dark);
  border-color:var(--accent);
}
.faq-a{
  display:grid;
  grid-template-rows:0fr;
  transition:grid-template-rows .35s var(--ease);
}
.faq-a-inner{overflow:hidden}
.faq-item.is-open .faq-a{grid-template-rows:1fr}
.faq-a p{
  padding:0 0 24px;
  margin:0;
  color:var(--text-2);
  font-size:1rem;
  line-height:1.65;
  max-width:60ch;
}

/* ============================================================
   ZONE D'INTERVENTION
   ============================================================ */
.zone{background:var(--bg-alt)}
.zone-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:32px;
}
.zone-map{
  position:relative;
  padding-top:62%;
  border-radius:var(--r-lg);
  overflow:hidden;
  border:1px solid var(--border);
  background:var(--bg);
}
.zone-map iframe{
  position:absolute;inset:0;
  width:100%;height:100%;
  border:0;
}
.zone-info h3{
  font-family:var(--ff-display);
  font-size:1.5rem;
  font-weight:500;
  margin-bottom:14px;
}
.zone-info p{color:var(--text-2);line-height:1.6;margin-bottom:20px}
.communes{
  display:flex;flex-wrap:wrap;gap:8px;
  margin-bottom:32px;
}
.communes li{
  list-style:none;
  font-family:var(--ff-ui);
  font-size:.84rem;
  padding:7px 14px;
  border-radius:999px;
  background:var(--surface);
  border:1px solid var(--border);
  color:var(--text);
}
.hours{
  background:var(--surface);
  border-radius:var(--r-md);
  border:1px solid var(--border-soft);
  padding:24px;
}
.hours-head{
  display:flex;align-items:center;justify-content:space-between;
  gap:14px;
  padding-bottom:16px;
  border-bottom:1px solid var(--border-soft);
  margin-bottom:14px;
}
.hours-head h4{
  font-family:var(--ff-display);
  font-size:1.15rem;font-weight:500;
  text-transform:none;letter-spacing:0;
}
.status-pill{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--ff-ui);
  font-size:.78rem;font-weight:500;
  padding:6px 12px;
  border-radius:999px;
  background:var(--bg-alt);
  color:var(--text-2);
}
.status-pill .dot{width:8px;height:8px;border-radius:50%;background:var(--text-mute)}
.status-pill.is-open{background:rgba(58,156,80,.12);color:#1F6A36}
.status-pill.is-open .dot{background:#3a9c50;box-shadow:0 0 0 3px rgba(58,156,80,.18)}
.hours table{width:100%;border-collapse:collapse;font-family:var(--ff-ui);font-size:.92rem}
.hours td{padding:8px 0;color:var(--text-2)}
.hours td:first-child{color:var(--text);text-transform:capitalize}
.hours td:last-child{text-align:right;font-variant-numeric:tabular-nums}
.hours tr.is-today td{font-weight:600;color:var(--accent)}
.hours tr.is-today td:first-child::before{
  content:"";display:inline-block;width:6px;height:6px;border-radius:50%;
  background:var(--accent);margin-right:8px;vertical-align:middle;
}
@media (min-width:900px){.zone-grid{grid-template-columns:1.3fr 1fr}}

/* ============================================================
   CONTACT - cards row (LAY-4)
   ============================================================ */
.contact{background:var(--accent-deep);color:var(--on-dark);position:relative;overflow:hidden}
.contact::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(246,244,235,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(246,244,235,.025) 1px, transparent 1px);
  background-size:48px 48px;
}
.contact>.container{position:relative}
.contact .section-head h2{color:var(--on-dark)}
.contact .section-head p{color:var(--on-dark-2)}
.contact .eyebrow{color:var(--gold)}
.contact .eyebrow::before{background:var(--gold)}
.contact-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:18px;
  margin-top:8px;
}
.contact-card{
  display:flex;flex-direction:column;gap:12px;
  padding:28px;
  border-radius:var(--r-lg);
  background:rgba(246,244,235,.05);
  border:1px solid rgba(246,244,235,.14);
  backdrop-filter:blur(6px);
  transition:background .3s var(--ease), border-color .3s var(--ease), transform .3s var(--ease);
}
.contact-card:hover{transform:translateY(-3px);background:rgba(246,244,235,.08);border-color:rgba(246,244,235,.28)}
.contact-card .picto-wrap{
  width:46px;height:46px;
  border-radius:12px;
  background:rgba(246,244,235,.08);
  display:grid;place-items:center;
}
.contact-card .picto-wrap svg{
  width:22px;height:22px;
  stroke:var(--gold);fill:none;
  stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round;
}
.contact-card h3{
  font-family:var(--ff-ui);
  font-size:.76rem;
  font-weight:500;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--on-dark-2);
}
.contact-card .val{
  font-family:var(--ff-display);
  font-size:1.6rem;
  color:var(--on-dark);
  font-weight:500;
  letter-spacing:-.005em;
  line-height:1.2;
}
.contact-card p{color:var(--on-dark-2);margin:0;font-size:.94rem;line-height:1.5}
.contact-card a{color:var(--on-dark);text-decoration:underline;text-underline-offset:3px}
.contact-card a:hover{color:var(--gold)}
.contact-cta{
  margin-top:40px;
  padding:36px 28px;
  border-radius:var(--r-lg);
  border:1px solid rgba(246,244,235,.18);
  background:rgba(246,244,235,.06);
  display:flex;flex-direction:column;gap:18px;
  text-align:center;
}
.contact-cta h3{font-family:var(--ff-display);font-size:1.8rem;color:var(--on-dark)}
.contact-cta p{color:var(--on-dark-2);margin:0 auto;max-width:46ch}
.contact-cta .actions{display:flex;flex-direction:column;gap:12px;max-width:360px;margin:0 auto;width:100%}
.contact-cta .actions .btn{width:100%;justify-content:center}
@media (min-width:560px){
  .contact-cta .actions{flex-direction:row;max-width:none;justify-content:center}
  .contact-cta .actions .btn{width:auto}
}
@media (min-width:768px){.contact-grid{grid-template-columns:repeat(3, 1fr)}}

/* ============================================================
   Modal mentions legales
   ============================================================ */
.modal-backdrop{
  position:fixed;inset:0;
  background:rgba(27,42,32,.72);
  z-index:var(--z-modal);
  display:none;
  align-items:flex-start;justify-content:center;
  padding:24px;
  overflow-y:auto;
}
.modal-backdrop.is-open{display:flex}
.modal{
  background:var(--surface);
  border-radius:var(--r-lg);
  width:100%;max-width:640px;
  margin:auto;
  padding:32px;
  border:1px solid var(--border);
  box-shadow:var(--sh-3);
}
.modal h3{font-family:var(--ff-display);font-size:1.6rem;margin-bottom:18px}
.modal h4{font-family:var(--ff-ui);font-size:.76rem;letter-spacing:.18em;margin:18px 0 8px;color:var(--accent)}
.modal p,.modal li{font-size:.92rem;color:var(--text-2);line-height:1.6}
.modal-close{
  float:right;margin:-12px -12px 0 0;
  width:36px;height:36px;border-radius:50%;
  background:var(--bg-alt);
  display:grid;place-items:center;
}
.modal-close svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.6;stroke-linecap:round}
