/* Sections */
main{position:relative;z-index:1;}
section{padding:64px 0;position:relative;}
@media (min-width:900px){section{padding:96px 0;}}
@media (max-width:560px){section{padding:48px 0;}}

/* ----------- HERO GRILLE 7:5 (PAY-10 / Neo-Editorial) ----------- */
.hero{
  padding-top:calc(var(--header-h) + 56px);
  padding-bottom:56px;
  position:relative;overflow:hidden;
}
.hero-bg-oklch{position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(60% 60% at 12% 8%, color-mix(in oklab,var(--accent) 16%,var(--bg)) 0%, transparent 60%),
    radial-gradient(50% 50% at 92% 22%, color-mix(in oklab,var(--accent-2) 12%,var(--bg)) 0%, transparent 55%),
    var(--bg);
}
.hero-grid75{position:relative;z-index:1;display:grid;grid-template-columns:7fr 5fr;gap:clamp(28px,4vw,64px);align-items:center;max-width:1240px;margin:0 auto;padding:0 24px;}
.hero-eyebrow{font-family:var(--ff-ui);text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;color:var(--accent);margin-bottom:18px;display:inline-flex;align-items:center;gap:10px;}
.hero-eyebrow::before{content:"";width:32px;height:1px;background:var(--accent);}
.hero-title{font-family:var(--ff-display);font-weight:500;font-size:clamp(2.4rem,5.4vw,4.6rem);line-height:1.04;color:var(--text);letter-spacing:-.005em;margin:0;}
.hero-title em{font-style:italic;color:var(--accent);position:relative;display:inline-block;}
.hero-title em::after{
  content:"";position:absolute;left:-2%;right:-2%;bottom:6%;height:.42em;
  background:color-mix(in srgb,var(--accent) 18%,transparent);
  transform:skewX(-8deg);z-index:-1;border-radius:3px;
}
.hero-sub{font-family:var(--ff-body);font-size:clamp(1rem,1.4vw,1.18rem);color:var(--text-2);margin:22px 0 28px;max-width:44ch;line-height:1.6;}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;}
.hero-meta{display:inline-flex;align-items:center;gap:18px;margin-top:28px;flex-wrap:wrap;font-family:var(--ff-ui);font-size:.85rem;color:var(--text-2);}
.hero-meta__dot{width:8px;height:8px;border-radius:50%;background:var(--wa-green);box-shadow:0 0 0 0 rgba(37,211,102,.5);animation:dotpulse 2.2s infinite;display:inline-block;margin-right:6px;vertical-align:middle;}
@keyframes dotpulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.45);}70%{box-shadow:0 0 0 10px rgba(37,211,102,0);}100%{box-shadow:0 0 0 0 rgba(37,211,102,0);}}
.hero-since{font-family:var(--ff-display);font-style:italic;color:var(--accent-2);font-size:1.05rem;}

.hero-media{position:relative;width:100%;}
.hero-media__frame{width:100%;aspect-ratio:4/5;border-radius:14px 4px 14px 4px;overflow:hidden;box-shadow:0 22px 50px rgba(46,40,32,.14);}
.hero-media__frame img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(1.05);}
.hero-media__tag{
  position:absolute;bottom:-14px;left:-14px;background:var(--text);color:var(--bg);
  font-family:var(--ff-ui);font-size:.7rem;text-transform:uppercase;letter-spacing:.18em;
  padding:8px 14px;border-radius:4px;display:inline-flex;align-items:center;gap:8px;
}
.hero-media__tag em{font-family:var(--ff-display);font-style:italic;text-transform:none;letter-spacing:0;font-size:1rem;color:var(--bg);}

@media (max-width:900px){
  .hero{padding-top:calc(var(--header-h-mobile) + 28px);}
  .hero-grid75{grid-template-columns:1fr;gap:28px;padding:0 20px;}
  .hero-media__frame{aspect-ratio:16/11;}
  .hero-media{order:-1;}
  .hero-cta .btn{flex:1 1 100%;}
  .hero-cta{flex-direction:column;}
  .hero-cta .btn{width:100%;}
}

/* ----------- PROCESS (COMP-4 process rassurant) ----------- */
.process{background:var(--bg-alt);}
.process-intro{max-width:740px;margin-bottom:48px;}
.process-intro p{font-size:1.08rem;line-height:1.7;color:var(--text-2);}
.process-intro p:first-letter{
  font-family:var(--ff-display);font-style:italic;font-weight:500;font-size:3.2rem;
  float:left;line-height:.95;padding:8px 12px 0 0;color:var(--accent);
}
.process-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.process-step{position:relative;padding:32px 28px 28px;background:var(--surface);border-radius:22px 4px 22px 4px;border:1px solid var(--border);}
.process-num{font-family:var(--ff-display);font-style:italic;font-weight:500;color:var(--accent);font-size:2.6rem;line-height:1;margin-bottom:14px;display:block;}
.process-step h3{font-size:1.25rem;margin-bottom:10px;}
.process-step p{font-size:.95rem;color:var(--text-2);margin:0;line-height:1.6;}
@media (max-width:900px){.process-steps{grid-template-columns:1fr;gap:18px;}}

/* ----------- SERVICES (LAY-6 grid-asym) ----------- */
.services-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:20px;}
.svc-card{padding:32px 28px;}
.svc-icon{width:48px;height:48px;display:grid;place-items:center;border-radius:14px;background:var(--accent-soft);color:var(--accent);margin-bottom:18px;}
.svc-icon svg{width:24px;height:24px;}
.svc-card h3{font-size:1.32rem;margin-bottom:8px;}
.svc-card p{font-size:.95rem;color:var(--text-2);margin:0;line-height:1.6;}
.svc-card--lead{grid-column:span 4;}
.svc-card--wide{grid-column:span 3;}
.svc-card{grid-column:span 2;}
.svc-card--dark .svc-icon{background:rgba(255,255,255,.1);color:var(--bg);}
.svc-card--lead .svc-icon{background:rgba(255,255,255,.18);color:#fff;}
.svc-card--lead h3{font-size:1.6rem;}
@media (max-width:900px){
  .services-grid{grid-template-columns:1fr;}
  .svc-card,.svc-card--lead,.svc-card--wide{grid-column:1/-1;}
}

/* ----------- REALISATIONS (LAY-6 gallery grid-feat) ----------- */
.gal-feat{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:1fr;gap:14px;}
.gal-feat__cell{position:relative;border-radius:14px;overflow:hidden;cursor:zoom-in;background:var(--bg-alt);}
.gal-feat__cell img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:1/1;transition:transform var(--t-slow);}
.gal-feat__cell:hover img{transform:scale(1.04);}
.gal-feat__cell::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(46,40,32,.4));opacity:0;transition:opacity var(--t-base);pointer-events:none;}
.gal-feat__cell:hover::after{opacity:1;}
.gal-feat__big{grid-column:span 2;grid-row:span 2;}
.gal-feat__big img{aspect-ratio:auto;}
.gal-feat__tag{
  position:absolute;left:14px;bottom:14px;z-index:2;
  font-family:var(--ff-ui);font-size:.68rem;text-transform:uppercase;letter-spacing:.16em;
  color:#fff;background:rgba(46,40,32,.65);padding:5px 10px;border-radius:3px;
  opacity:0;transform:translateY(6px);transition:opacity var(--t-base),transform var(--t-base);
}
.gal-feat__cell:hover .gal-feat__tag{opacity:1;transform:translateY(0);}
.gal-feat__more{margin-top:28px;text-align:center;}
@media (max-width:560px){
  .gal-feat{grid-template-columns:1fr;grid-auto-rows:auto;}
  .gal-feat__big,.gal-feat__cell{grid-column:1/-1;grid-row:auto;}
  .gal-feat__cell img{aspect-ratio:4/3;}
  .gal-feat__big img{aspect-ratio:4/3;}
  .gal-feat__tag{opacity:1;transform:translateY(0);}
}

/* ----------- AVIS (LAY-6 row-sep) ----------- */
.avis-section{background:var(--bg-alt);}
.avis-rows{max-width:760px;margin:0 auto;}
.avis-row{padding:28px 0;border-top:1px solid var(--border);display:flex;align-items:flex-start;gap:24px;flex-wrap:wrap;}
.avis-row:last-child{border-bottom:1px solid var(--border);}
.avis-row__left{flex:0 0 auto;min-width:160px;}
.avis-row__rating{display:inline-flex;align-items:center;gap:6px;font-family:var(--ff-display);font-style:italic;font-size:1.5rem;color:var(--accent);}
.avis-row__rating svg{width:18px;height:18px;color:var(--accent-2);}
.avis-row__meta{font-family:var(--ff-ui);font-size:.82rem;color:var(--text-mute);margin-top:6px;}
.avis-row__body{flex:1 1 240px;}
.avis-row__body p{margin:0 0 8px;color:var(--text-2);font-size:1rem;line-height:1.65;}
.avis-row__author{display:inline-flex;align-items:center;gap:8px;font-family:var(--ff-ui);font-size:.85rem;color:var(--text);}
.badge-google{display:inline-flex;align-items:center;gap:6px;font-family:var(--ff-ui);font-size:.72rem;color:var(--text-mute);background:var(--surface);border:1px solid var(--border);padding:3px 8px;border-radius:999px;}
.badge-google svg{width:12px;height:12px;}
.avis-google-link{display:block;text-align:center;margin-top:28px;font-family:var(--ff-ui);font-size:.92rem;color:var(--accent);text-decoration:underline;text-underline-offset:4px;}

/* ----------- ZONE ----------- */
.zone-cols{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
.zone-info p{color:var(--text-2);line-height:1.7;margin-bottom:18px;}
.zone-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px;margin-bottom:28px;}
.horaires-table{margin-top:24px;}
.horaires-table h3{font-family:var(--ff-ui);font-weight:600;font-size:.92rem;text-transform:uppercase;letter-spacing:.16em;color:var(--accent);margin-bottom:14px;}
.horaires-table table{width:100%;border-collapse:collapse;font-family:var(--ff-ui);font-size:.95rem;}
.horaires-table td{padding:9px 0;border-bottom:1px solid var(--border);color:var(--text-2);}
.horaires-table td:first-child{font-weight:500;color:var(--text);text-transform:capitalize;}
.horaires-table td:last-child{text-align:right;}
.horaires-table tr.is-today td{color:var(--accent);font-weight:600;}
.horaires-table tr.is-today td:first-child::before{content:"\\2022";color:var(--accent);margin-right:8px;}
.horaires-table tr.is-closed td:last-child{color:var(--text-mute);font-style:italic;}
.map-wrapper{width:100%;aspect-ratio:4/3;border-radius:14px;overflow:hidden;box-shadow:0 12px 30px rgba(46,40,32,.1);border:1px solid var(--border);}
.map-wrapper iframe{width:100%;height:100%;border:0;display:block;}
@media (max-width:900px){.zone-cols{grid-template-columns:1fr;gap:36px;}}

/* ----------- CONTACT ----------- */
.contact-section{background:var(--text);color:var(--bg);}
.contact-section .sec-eyebrow{color:var(--accent-2);}
.contact-section .sec-eyebrow::before{background:var(--accent-2);}
.contact-section h2{color:var(--bg);}
.contact-section .sec-heading p{color:rgba(246,240,230,.78);}
.contact-cols{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
.contact-info p{color:rgba(246,240,230,.82);line-height:1.7;}
.contact-tel{font-family:var(--ff-display);font-style:italic;font-size:clamp(2rem,4vw,2.6rem);color:var(--accent-2);text-decoration:none;display:inline-block;margin:14px 0 18px;letter-spacing:.005em;}
.contact-tel:hover{color:#fff;}
.contact-actions{display:flex;flex-direction:column;gap:12px;margin:18px 0 28px;}
.contact-actions .btn{justify-content:center;}
.contact-rows{display:flex;flex-direction:column;gap:12px;margin-top:24px;}
.contact-row{display:flex;align-items:center;gap:14px;font-family:var(--ff-ui);font-size:.96rem;color:rgba(246,240,230,.88);}
.contact-row__icon{width:36px;height:36px;border-radius:8px;background:rgba(255,255,255,.07);color:var(--accent-2);display:grid;place-items:center;flex-shrink:0;}
.contact-row__icon svg{width:18px;height:18px;}
.contact-card{background:rgba(255,255,255,.04);padding:32px 28px;border-radius:22px 4px 22px 4px;border:1px solid rgba(255,255,255,.08);}
.contact-card h3{color:var(--bg);font-size:1.45rem;margin-bottom:6px;}
.contact-card .form input,.contact-card .form textarea{background:rgba(255,255,255,.06);color:var(--bg);border-color:rgba(255,255,255,.12);}
.contact-card .form input::placeholder,.contact-card .form textarea::placeholder{color:rgba(246,240,230,.5);}
.contact-card .form label{color:rgba(246,240,230,.78);}
@media (max-width:900px){.contact-cols{grid-template-columns:1fr;gap:32px;}}
