/* HERO-GRILLE-7-5 -------------------------------------------------------- */
.hero-grid75{
  padding:36px 0 28px;
  display:grid;grid-template-columns:1fr;gap:28px;align-items:center;
}
.hero-grid75__media{
  width:100%;aspect-ratio:16/10;
  border-radius:var(--r-lg);overflow:hidden;
  order:-1;
  position:relative;
}
.hero-grid75__media img{width:100%;height:100%;object-fit:cover;display:block;}
.hero-grid75__tag{
  position:absolute;left:14px;bottom:14px;
  background:color-mix(in srgb,var(--bg) 86%,transparent);
  backdrop-filter:blur(6px);
  border:1px solid var(--border);
  padding:6px 12px;border-radius:99px;
  font-family:var(--ff-ui);font-size:.78rem;font-weight:500;color:var(--text);
}
.hero-grid75__title{
  font-family:var(--ff-display);
  font-size:clamp(2.2rem,5.6vw,4.2rem);
  line-height:1.04;color:var(--text);margin:0 0 16px;
}
.hero-grid75__title em{font-style:italic;color:var(--accent);}
.hero-grid75__sub{
  font-size:clamp(1rem,1.5vw,1.15rem);color:var(--text-2);
  margin:0 0 22px;max-width:48ch;
}
.hero-grid75__usps{
  display:flex;flex-wrap:wrap;gap:8px;
  margin:18px 0 22px;
}
.hero-grid75__rating{margin-top:18px;}
@media(min-width:900px){
  .hero-grid75{
    grid-template-columns:7fr 5fr;
    gap:56px;padding:64px 0 48px;
  }
  .hero-grid75__media{aspect-ratio:4/5;order:0;}
}

/* STATS STRIP ------------------------------------------------------------ */
.stats-strip{
  background:var(--bg-alt);
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  padding:32px 0;
}
.stats-grid{
  display:grid;grid-template-columns:1fr;gap:24px;text-align:center;
}
@media(min-width:640px){.stats-grid{grid-template-columns:repeat(3,1fr);}}
.stat-item{
  display:flex;flex-direction:column;gap:6px;
  padding:8px 12px;
  border-left:1px solid transparent;
}
@media(min-width:640px){
  .stat-item + .stat-item{border-left-color:var(--border);}
}
.stat-number{
  font-family:var(--ff-display);
  font-size:clamp(2rem,4vw,2.6rem);font-weight:600;
  color:var(--accent);line-height:1;
}
.stat-label{
  font-family:var(--ff-ui);font-size:.86rem;font-weight:500;
  color:var(--text-2);
}

/* SERVICES grid-3 / cards risograph -------------------------------------- */
.svc-grid{display:grid;grid-template-columns:1fr;gap:18px;}
@media(min-width:640px){.svc-grid{grid-template-columns:repeat(2,1fr);gap:22px;}}
@media(min-width:960px){.svc-grid{grid-template-columns:repeat(3,1fr);}}
.svc-card{display:flex;flex-direction:column;gap:14px;min-height:100%;}
.svc-card__head{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.svc-card__icon{
  width:44px;height:44px;border-radius:10px;
  display:grid;place-items:center;
  background:var(--accent-soft);color:var(--accent);
  flex-shrink:0;
}
.svc-card__icon svg{width:24px;height:24px;}
.svc-num{
  font-family:var(--ff-display);font-style:italic;font-weight:500;
  color:var(--accent);font-size:1.05rem;
  margin-left:auto;
}
.svc-card h3{font-size:1.2rem;margin:0;}
.svc-card p{margin:0;color:var(--text-2);font-size:.95rem;}

/* REALISATIONS / gallery grid -------------------------------------------- */
.gal-grid{display:grid;grid-template-columns:1fr;gap:14px;}
@media(min-width:560px){.gal-grid{grid-template-columns:repeat(2,1fr);}}
@media(min-width:960px){.gal-grid{grid-template-columns:repeat(3,1fr);}}
.gal-item{
  position:relative;width:100%;
  aspect-ratio:4/3;
  border-radius:12px;overflow:hidden;
  background:var(--bg-alt);
  cursor:zoom-in;
  transition:transform .25s ease;
}
.gal-item img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .4s ease;
}
.gal-item:hover{transform:translateY(-3px);}
.gal-item:hover img{transform:scale(1.04);}
.gal-tag{
  position:absolute;left:10px;bottom:10px;
  background:rgba(20,18,12,.62);color:#fff;
  font-family:var(--ff-ui);font-size:.74rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.1em;
  padding:5px 10px;border-radius:99px;
  backdrop-filter:blur(4px);
}

/* A PROPOS --------------------------------------------------------------- */
.about-cols{
  display:grid;grid-template-columns:1fr;gap:28px;align-items:start;
}
@media(min-width:900px){.about-cols{grid-template-columns:1.1fr .9fr;gap:56px;}}
.about-text p{font-size:1rem;color:var(--text-2);}
.about-text p:first-of-type::first-letter{
  font-family:var(--ff-display);font-style:italic;
  font-size:3.2rem;line-height:.85;
  color:var(--accent);
  float:left;padding:6px 10px 0 0;
}
.about-points{
  display:grid;grid-template-columns:1fr;gap:6px;
  margin-top:18px;
}
@media(min-width:560px){.about-points{grid-template-columns:1fr 1fr;}}
.about-media{
  position:relative;width:100%;
  aspect-ratio:4/5;
  border-radius:14px;overflow:hidden;
}
.about-media img{width:100%;height:100%;object-fit:cover;display:block;}
.about-tag{
  position:absolute;top:14px;left:14px;
  background:color-mix(in srgb,var(--bg) 86%,transparent);
  backdrop-filter:blur(6px);
  border:1px solid var(--border);
  padding:6px 12px;border-radius:99px;
  font-family:var(--ff-ui);font-size:.78rem;font-weight:500;
  color:var(--text);
}

/* AVIS = cards ----------------------------------------------------------- */
.avis-cards{display:grid;grid-template-columns:1fr;gap:18px;}
@media(min-width:768px){.avis-cards{grid-template-columns:repeat(2,1fr);}}
@media(min-width:1024px){.avis-cards{grid-template-columns:repeat(3,1fr);}}
.avis-card{display:flex;flex-direction:column;gap:14px;}
.avis-card .stars{display:inline-flex;gap:2px;color:var(--gold);}
.avis-card .stars svg{width:16px;height:16px;}
.avis-card blockquote{
  font-family:var(--ff-display);font-style:italic;font-weight:500;
  font-size:1.02rem;line-height:1.5;color:var(--text);
  margin:0;quotes:"\201C" "\201D";
}
.avis-card blockquote::before{content:open-quote;color:var(--accent);font-size:1.5em;line-height:0;margin-right:2px;}
.avis-foot{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  font-family:var(--ff-ui);font-size:.86rem;color:var(--text-2);
  margin-top:auto;padding-top:8px;border-top:1px dashed var(--border);
}
.avis-foot strong{color:var(--text);font-weight:600;}
.avis-foot small{display:block;font-size:.74rem;color:var(--text-mute);margin-top:2px;}
.badge-google{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.74rem;color:var(--text-mute);
}
.badge-google svg{width:14px;height:14px;}
.avis-link{
  display:inline-flex;align-items:center;gap:8px;margin-top:24px;
  font-family:var(--ff-ui);font-size:.92rem;font-weight:600;
  color:var(--accent);text-decoration:underline;text-underline-offset:4px;
}

/* FAQ accordion ---------------------------------------------------------- */
.faq-list{display:flex;flex-direction:column;gap:0;margin:0;padding:0;}
.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:14px;
  padding:18px 4px;
  font-family:var(--ff-display);font-size:1.08rem;font-weight:500;
  text-align:left;color:var(--text);
}
.faq-chevron{
  position:relative;width:18px;height:18px;flex-shrink:0;
}
.faq-chevron::before,
.faq-chevron::after{
  content:"";position:absolute;top:50%;left:0;
  width:100%;height:2px;background:var(--accent);
  border-radius:2px;
  transition:transform .25s ease;
}
.faq-chevron::after{transform:rotate(90deg);}
.faq-trigger[aria-expanded="true"] .faq-chevron::after{transform:rotate(0);}
.faq-answer{
  padding:0 4px 18px;
  font-size:.96rem;color:var(--text-2);
}
.faq-answer p{margin:0;}

/* ZONE + carte ----------------------------------------------------------- */
.zone-cols{display:grid;grid-template-columns:1fr;gap:28px;}
@media(min-width:900px){.zone-cols{grid-template-columns:1fr 1fr;gap:40px;}}
.zone-chips{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 22px;}
.dispo-line{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--ff-ui);font-weight:500;
  color:var(--text);
  margin-bottom:14px;
}
.dispo-dot{
  width:10px;height:10px;border-radius:50%;
  background:var(--accent);position:relative;
}
.dispo-line.is-open .dispo-dot{background:#2faa53;}
.dispo-line.is-closed .dispo-dot{background:#c95252;}
.dispo-line.is-open .dispo-dot::after{
  content:"";position:absolute;inset:-3px;border-radius:50%;
  border:2px solid #2faa53;opacity:.4;animation:pulse 1.8s ease-out infinite;
}
@keyframes pulse{0%{transform:scale(1);opacity:.5;}100%{transform:scale(2);opacity:0;}}
@media (prefers-reduced-motion:reduce){.dispo-line.is-open .dispo-dot::after{animation:none;}}

.horaires-table{
  display:grid;grid-template-columns:1fr auto;gap:0;
  background:var(--surface);
  border:1px solid var(--border);border-radius:var(--r-md);
  overflow:hidden;
}
.horaires-row{
  display:contents;
  font-family:var(--ff-ui);
}
.horaires-row > *{
  padding:11px 16px;
  border-bottom:1px solid var(--border);
  font-size:.93rem;color:var(--text-2);
}
.horaires-row:last-child > *{border-bottom:0;}
.horaires-row .h-day{font-weight:500;color:var(--text);}
.horaires-row.is-today > *{background:var(--accent-soft);color:var(--accent);font-weight:600;}
.horaires-row.is-closed .h-hours{color:var(--text-mute);}

.map-wrapper{
  width:100%;
  border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--border);
  background:var(--bg-alt);
}
.map-wrapper iframe{display:block;width:100%;height:320px;border:0;}
@media(min-width:900px){.map-wrapper iframe{height:420px;}}

/* CONTACT ---------------------------------------------------------------- */
.contact-section{
  background:var(--surface-deep);
  color:var(--text-on-dark);
}
.contact-section .eyebrow{color:var(--accent-on-dark);}
.contact-section .eyebrow::before{background:var(--accent-on-dark);}
.contact-section h2,
.contact-section h3{color:var(--text-on-dark);}
.contact-section h2 em{color:var(--accent-on-dark);}
.contact-section p,
.contact-section .sec-head p{color:rgba(236,227,203,.78);}
.contact-cols{display:grid;grid-template-columns:1fr;gap:32px;}
@media(min-width:900px){.contact-cols{grid-template-columns:1fr 1fr;gap:56px;}}
.contact-rows{display:flex;flex-direction:column;gap:12px;margin-bottom:20px;}
.contact-row{
  display:flex;align-items:center;gap:14px;
  padding:12px 14px;border-radius:12px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
}
.contact-row__icon{
  width:42px;height:42px;border-radius:10px;
  display:grid;place-items:center;flex-shrink:0;
  background:rgba(199,211,140,.18);color:var(--accent-on-dark);
}
.contact-row__icon svg{width:20px;height:20px;}
.contact-row__txt{display:flex;flex-direction:column;min-width:0;}
.contact-row__txt .lbl{
  font-family:var(--ff-ui);font-size:.72rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.12em;color:var(--accent-on-dark);
}
.contact-row__txt .val{
  font-family:var(--ff-display);font-size:1.04rem;color:var(--text-on-dark);
  word-break:break-word;
}
.contact-section .form{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  padding:24px;border-radius:14px;
}
.contact-section .field label{color:var(--accent-on-dark);}
.contact-section .field input,
.contact-section .field select,
.contact-section .field textarea{
  background:rgba(255,255,255,.06);color:var(--text-on-dark);
  border-color:rgba(255,255,255,.18);
}
.contact-section .field input::placeholder,
.contact-section .field textarea::placeholder{color:rgba(236,227,203,.5);}
.contact-section .field input:focus,
.contact-section .field select:focus,
.contact-section .field textarea:focus{
  border-color:var(--accent-on-dark);
  box-shadow:0 0 0 3px rgba(199,211,140,.18);
}
