
/* ===================== ACCUEIL — HERO ANIMÉ (v6) ===================== */
:root{ --m-chauf:#C9542C; --m-plomb:#2C6FA6; --m-pv:#4F8A1E; --m-elec:#C2941B; }

/* --- Logo détouré (sans cercle), au-dessus de l'animation, aligné à gauche --- */
.hero-logo{display:block;width:120px;max-width:52%;height:50px;margin:-18px 0 32px;
  background:url(../img/logo-roy.png) left center/contain no-repeat}

/* --- Icônes métiers : barres TOUJOURS colorées, seules les icônes s'animent --- */
.roy-rotator{display:flex;gap:7px;align-items:flex-end;margin:64px 0 22px}
.roy-rotator .rr-item{position:relative;display:flex}
.roy-rotator .rr-line{width:28px;height:7px;border-radius:4px;background:currentColor;transition:width .55s cubic-bezier(.22,1,.36,1)}
.roy-rotator .rr-item.actif .rr-line{width:74px}
.roy-rotator .rr-ico{position:absolute;bottom:calc(100% + 12px);left:50%;width:52px;height:52px;display:grid;place-items:center;border-radius:14px;background:color-mix(in srgb,currentColor 17%,#fff);color:currentColor;opacity:0;transform:translateX(-50%) translateY(8px) scale(.85);transition:opacity .45s ease,transform .45s cubic-bezier(.22,1,.36,1);pointer-events:none}
.roy-rotator .rr-ico svg{width:27px;height:27px;display:block}
.roy-rotator .rr-item.actif .rr-ico{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}
.rr-item.m-chauf{color:#DB692C} .rr-item.m-plomb{color:#44A0D4}
.rr-item.m-pv{color:#7BAF34} .rr-item.m-elec{color:#EFCB33}

/* --- Titre : taille d'origine, la pastille déborde sur la photo --- */
.hero-headline{line-height:1.12}
.hero-headline .hh-lead{display:block;white-space:nowrap}
.hero-headline .hh-line2{display:inline-block;white-space:nowrap}
.hero-headline .hh-en{font-weight:800;color:var(--bleu-nuit)}
.word-rotate{display:inline-grid;vertical-align:baseline;line-height:1.05}
.word-rotate .wr-word{grid-area:1/1;justify-self:start;opacity:0;transform:translateY(10px);transition:opacity .55s ease,transform .55s ease;padding:.08em .36em;border-radius:.3em;white-space:nowrap;color:var(--bleu-nuit)}
.word-rotate .wr-word.actif{opacity:1;transform:translateY(0)}
.word-rotate .m-chauf{background:#F7E9E1} .word-rotate .m-plomb{background:#E9F0F6}
.word-rotate .m-pv{background:#ECF3E4} .word-rotate .m-elec{background:#F7F1DC}
/* Petit mobile : reduire le titre pour que le mot anime le plus long tienne (desktop/tablette inchanges) */
@media (max-width:430px){ .hero-headline{font-size:clamp(27px,8.1vw,37px)} .groupe-noto{grid-template-columns:repeat(2,1fr) !important} }

/* --- Accroche mise en valeur : « la marque locale … » --- */
.hero-secondary{font-family:'Sora',sans-serif;font-weight:700;font-size:clamp(17px,2vw,23px);line-height:1.3;color:var(--bleu-nuit);margin:16px 0 6px;letter-spacing:-.1px}
.hero-secondary .hs-accent{position:relative;color:var(--orange);white-space:nowrap;padding:0 .04em}
.hero-secondary .hs-accent::after{content:'';position:absolute;left:-.02em;right:-.02em;bottom:.05em;height:.30em;border-radius:4px;background:linear-gradient(120deg,rgba(255,140,66,.32),rgba(232,93,47,.16));z-index:-1}

/* --- Colonne gauche étroite, collée à gauche, au 1er plan --- */
.hero,.hero-grid,.hero-right{min-height:92vh}
.hero-grid{grid-template-columns:0.72fr 1.28fr}
.hero-text{padding-top:100px;padding-bottom:44px;padding-left:clamp(24px,3vw,44px);position:relative;z-index:3;min-width:0}

/* --- Colonne droite : image bien plus à gauche, bas REHAUSSÉ, en arrière-plan --- */
.hero-right{position:relative;height:100%;overflow:visible;min-width:0;z-index:1}
.hero-photo{display:block !important;position:absolute;top:0;right:0;left:0;bottom:calc(9.2vh + 27px);width:auto;height:auto;min-height:0;border-radius:0 0 0 18px;overflow:hidden}
.hero-google{top:138px !important;right:28px !important;padding:6px 14px !important;gap:10px !important}.hero-google-g{width:25px !important;height:25px !important}.hero-google-label{font-size:10px !important;line-height:1.05 !important}.hero-google-num{font-size:15px !important}.hero-google-stars{font-size:12px !important}
.hero-google-count{margin-top:1px;font-family:'Manrope',sans-serif;font-weight:600;font-size:10px;line-height:1.05;color:var(--gris-texte);letter-spacing:.2px}

/* --- Cartes : remontées (visibles dès l'ouverture), débordent sous l'image --- */
.hero-cards{position:absolute;left:0;right:0;bottom:calc(9.2vh + 27px);width:auto;padding:0;overflow:hidden;margin:0}
.hero-cards-track{display:flex;gap:16px;width:max-content;will-change:transform}
.hc-card{position:relative;flex:0 0 auto;width:297px;height:206px;border-radius:18px;overflow:hidden;border:1.5px solid rgba(255,255,255,.9);background:#fff;text-decoration:none;transition:opacity .55s cubic-bezier(.22,1,.36,1)}
.hc-card.is-leaving{opacity:0}
.hc-card img{width:100%;height:100%;object-fit:cover;display:block}
.hc-label{position:absolute;top:11px;left:11px;padding:6px 13px;border-radius:999px;font-family:'Manrope',sans-serif;font-weight:700;font-size:12px;letter-spacing:.2px;background:rgba(255,255,255,.94);backdrop-filter:blur(5px);box-shadow:0 2px 8px rgba(26,20,16,.14)}
.hc-label.m-chauf{color:var(--m-chauf)} .hc-label.m-plomb{color:var(--m-plomb)}
.hc-label.m-pv{color:var(--m-pv)} .hc-label.m-elec{color:var(--m-elec)}

/* ===================== EN-TÊTE 2 ÉTATS ===================== */
header:not(.scrolled){padding-top:0px;position:absolute}
.topbar-secondary{position:absolute;top:22px;left:40vw;right:28px;display:flex;align-items:center;justify-content:flex-end;gap:22px;z-index:101;
  font-family:'Manrope',sans-serif;font-weight:600;font-size:14px;transition:opacity .3s ease}
.topbar-secondary a{color:#fff;text-decoration:none;text-shadow:0 1px 10px rgba(20,12,8,.6);transition:opacity .2s ease}
.topbar-secondary a:hover{opacity:.72}
.topbar-secondary .tb-sep{color:rgba(255,255,255,.55)}
.topbar-secondary .tb-tel{display:inline-flex;align-items:center;gap:7px;font-weight:700}
header.scrolled .topbar-secondary{opacity:0;pointer-events:none}
header:not(.scrolled) .header-inner{justify-content:flex-end;position:static}header:not(.scrolled) .nav-bar{position:absolute;top:60px;right:28px;left:auto;transform:scale(0.82);transform-origin:top right}
header.scrolled .header-inner{justify-content:center}
header:not(.scrolled) .nav-bar .logo{display:none}

/* --- Responsive --- */
@media (prefers-reduced-motion: reduce){ .hero-cards-track{animation:none} }
@media (max-width:1100px){
  .topbar-secondary{display:none}
  header:not(.scrolled){padding-top:22px}
  header:not(.scrolled) .header-inner{justify-content:center;position:relative}
  header:not(.scrolled) .nav-bar .logo{display:flex}
  .hero,.hero-grid,.hero-right{min-height:auto}
  .hero-grid{grid-template-columns:1fr}
  .hero-text{padding-top:104px;padding-left:24px}
  .hero-headline .hh-line2{white-space:normal}
  .hero-logo{width:132px;height:54px}
  /* fix tailles intermediaires (969-1100px) : sortir photo+cartes de l'absolu pour eviter le chevauchement */
  .hero-right{overflow:visible}
  .hero-photo{display:none !important}
  .hero-cards{position:static;left:auto;right:auto;bottom:auto;padding:0;margin-top:24px;overflow:hidden}
  .hero-cards-track{width:max-content;gap:14px}
  .hc-card{flex:0 0 auto;width:clamp(240px,33vw,300px);height:204px}
}
@media (max-width:968px){
  .hero-right{overflow:visible}
  .hero-photo{display:none !important}
  .hero-cards{position:static;left:0;right:0;padding:0;margin-top:18px;bottom:auto;overflow:hidden}
  .hero-cards-track{width:max-content;gap:12px}
  .hc-card{flex:0 0 auto;width:clamp(220px,70vw,300px);height:170px}
  .roy-rotator{gap:6px;margin-top:56px}
  .roy-rotator .rr-ico{width:46px;height:46px}
  .roy-rotator .rr-ico svg{width:24px;height:24px}
  .roy-rotator .rr-line{width:24px}
  .roy-rotator .rr-item.actif .rr-line{width:64px}
}

/* ===================== SECTIONS FIDÈLES roy-habitat.fr ===================== */
.aservice-cta{margin-top:26px}
.aservice-entites{display:flex;flex-direction:column;gap:12px;margin-top:30px}
.aservice-entite{display:flex;align-items:center;gap:15px;background:var(--blanc);border:1px solid var(--gris-bord);border-radius:16px;padding:13px 17px;box-shadow:var(--shadow-soft);text-decoration:none;transition:transform .3s ease,box-shadow .3s ease}
.aservice-entite:hover{transform:translateY(-3px);box-shadow:var(--shadow-medium)}
.aservice-entite .brand-logo{width:46px;height:46px;flex:0 0 auto}
.aservice-entite-txt{display:flex;flex-direction:column;min-width:0}
.aservice-entite-txt strong{font-family:'Sora',sans-serif;font-weight:700;font-size:15.5px;color:var(--bleu-nuit);line-height:1.2}
.aservice-entite-txt span{font-size:12.5px;color:var(--gris-texte);margin-top:2px}
.tc .zone2-dashes{justify-content:center}
/* Zone d'intervention — fond aérien de l'Ouest de la France */
.zone{position:relative;overflow:hidden;background:#0f0a07;padding:104px 0}
.zone-bg{position:absolute;inset:0;background:var(--grad-veil),var(--img-groupe);background-size:cover;background-position:center;transform:scale(1.04)}
.zone-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(115deg,rgba(11,7,4,.86) 0%,rgba(11,7,4,.58) 52%,rgba(11,7,4,.30) 100%)}
.zone .container{position:relative;z-index:2}
.zone-wrap{display:grid;grid-template-columns:1.08fr .92fr;gap:50px;align-items:center}
.zone .section-eyebrow{color:var(--orange-glow)}
.zone h2{color:#fff;font-size:clamp(28px,3.4vw,42px);margin-bottom:20px}
.zone h2 span{color:var(--orange-glow)}
.zone p{color:rgba(255,255,255,.86);font-size:18px;max-width:560px;margin-bottom:26px}
.zone-chips{display:flex;flex-wrap:wrap;gap:10px}
.zone-chip{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.24);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;font-weight:600;font-size:13.5px;padding:8px 15px;border-radius:100px}
.zone-card{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(18px) saturate(150%);-webkit-backdrop-filter:blur(18px) saturate(150%);border-radius:24px;padding:30px;box-shadow:var(--shadow-dark)}
.zone-card-pin{width:50px;height:50px;border-radius:15px;background:var(--grad-premium);display:grid;place-items:center;font-size:23px;margin-bottom:18px;box-shadow:0 8px 24px rgba(232,80,47,.45)}
.zone-card .zc-tag{color:var(--orange-glow);font-weight:700;font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px;display:block}
.zone-card h3{color:#fff;font-family:'Sora',sans-serif;font-weight:800;font-size:22px;margin-bottom:14px}
.zone-card address{font-style:normal;color:rgba(255,255,255,.85);font-size:15px;line-height:1.65;margin-bottom:20px}
.zone-card .zc-link{display:inline-flex;align-items:center;gap:8px;color:#fff;font-weight:700;font-size:14px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.3);padding:12px 19px;border-radius:13px;transition:.25s}
.zone-card .zc-link:hover{background:var(--orange);border-color:var(--orange);transform:translateY(-2px)}
/* Conseils / blog */
.conseils-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:46px}
.conseils-head .ch-left{max-width:660px}
.conseils-head .section-subtitle{margin-bottom:0}
.conseils-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.cons-card{display:flex;flex-direction:column;background:var(--blanc);border:1px solid var(--gris-bord);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-soft);transition:transform .35s ease,box-shadow .35s ease}
.cons-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-medium)}
.cons-card-img{height:178px;background-size:cover;background-position:center;position:relative}
.cons-card-cat{position:absolute;top:14px;left:14px;background:rgba(255,255,255,.93);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);color:var(--orange-dark);font-weight:700;font-size:12px;padding:6px 13px;border-radius:100px;letter-spacing:.04em}
.cons-card-body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.cons-card-body h3{font-size:18px;line-height:1.32;margin-bottom:11px;color:var(--bleu-nuit)}
.cons-card-body p{font-size:14.5px;color:var(--gris-texte);line-height:1.6;margin-bottom:18px;flex:1}
.cons-card-link{color:var(--orange);font-weight:700;font-size:14px;display:inline-flex;align-items:center;gap:6px;transition:gap .25s}
.cons-card:hover .cons-card-link{gap:11px}
/* Réalisations 4-up */
.realz-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.realz-card{position:relative;height:350px;border-radius:22px;overflow:hidden;background-size:cover;background-position:center;box-shadow:var(--shadow-dark);display:block;transition:transform .4s ease}
.realz-card:hover{transform:translateY(-5px)}
.realz-card::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,11,7,.04) 32%,rgba(12,7,4,.92) 100%)}
.realz-content{position:absolute;left:18px;right:18px;bottom:18px;z-index:2}
.realz-tag{display:inline-block;background:rgba(255,255,255,.93);color:var(--orange-dark);font-weight:700;font-size:11.5px;padding:5px 12px;border-radius:100px;margin-bottom:10px}
.realz-loc{color:rgba(255,255,255,.86);font-size:12.5px;font-weight:600;margin-bottom:5px}
.realz-title{color:#fff;font-family:'Sora',sans-serif;font-weight:800;font-size:16px;line-height:1.28;text-shadow:0 2px 12px rgba(0,0,0,.55)}
/* Certifications */
.certs{background:var(--creme)}
.certs-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:18px}
.cert-card{display:flex;flex-direction:column;align-items:center;gap:14px;background:var(--blanc);border:1px solid var(--gris-bord);border-radius:18px;padding:26px 22px;width:clamp(162px,18.5vw,206px);box-shadow:var(--shadow-soft);transition:transform .3s ease,box-shadow .3s ease}
.cert-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-medium)}
.cert-emblem{width:100%;height:clamp(72px,8.5vw,90px);display:grid;place-items:center;overflow:hidden;background:transparent;border-radius:0;box-shadow:none;color:var(--bleu-nuit)}
.cert-emblem img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;display:block;margin:0 auto}
.cert-emblem.is-empty::after{content:attr(data-fb);font-family:'Sora',sans-serif;font-weight:800;font-size:15px;color:var(--bleu-nuit);text-align:center;line-height:1.2}
.cert-name{font-family:'Sora',sans-serif;font-weight:800;font-size:15px;color:var(--bleu-nuit);text-align:center}
.cert-sub{font-size:12px;color:var(--gris-texte);text-align:center;line-height:1.4}
@media (max-width:968px){
  .zone{padding:72px 0}
  .zone-wrap{grid-template-columns:1fr;gap:30px}
  .conseils-grid{grid-template-columns:1fr}
  .realz-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){ .realz-grid{grid-template-columns:1fr} }

/* ===== Nos métiers — reproduction fidèle (cartes claires + tuile + bouton +) ===== */
.metiers{position:relative;overflow:hidden;padding:100px 0 104px}
.metiers-blob{position:absolute;z-index:0;pointer-events:none;border-radius:50%}
.metiers-blob-a{width:560px;height:440px;left:-90px;top:30px;background:radial-gradient(closest-side, rgba(255,170,92,.20), rgba(255,170,92,0))}
.metiers-blob-b{width:520px;height:520px;left:140px;top:24px;background:radial-gradient(closest-side, rgba(245,197,24,.13), rgba(245,197,24,0))}
.metiers-blob-c{width:460px;height:460px;right:-90px;bottom:120px;background:radial-gradient(closest-side, rgba(63,163,220,.09), rgba(63,163,220,0))}
.metiers .container{position:relative;z-index:1}
.metiers-head{margin-bottom:92px}
.metiers-title{font-family:'Sora',sans-serif;font-weight:800;font-size:clamp(34px,4.6vw,58px);color:var(--bleu-nuit);line-height:1.04;letter-spacing:-.02em;margin:0}
.metiers-sub{font-family:'Sora',sans-serif;font-weight:400;font-size:clamp(19px,2.4vw,30px);color:var(--bleu-nuit);opacity:.82;margin-top:6px}
.metiers-carousel{position:relative;overflow:hidden;padding:64px 0 44px;-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 5%,#000 95%,transparent 100%);mask-image:linear-gradient(90deg,transparent 0,#000 5%,#000 95%,transparent 100%)}
.metiers-track{display:flex;align-items:stretch;width:max-content;animation:metiersScroll 55s linear infinite}
.metiers-carousel:hover .metiers-track{animation-play-state:paused}
.metier-card{position:relative;background:#F6F7F9;border:1px solid var(--gris-bord);border-radius:22px;padding:76px 24px 58px;text-align:center;display:flex;flex-direction:column;align-items:center;text-decoration:none;transition:box-shadow .35s ease,background .35s ease,transform .35s ease}
.metier-card:hover{background:#fff;box-shadow:var(--shadow-medium);transform:translateY(-6px)}
.metier-ico{position:absolute;top:-50px;left:50%;transform:translateX(-50%);width:98px;height:98px;border-radius:24px;display:grid;place-items:center;background:color-mix(in srgb,var(--c) 15%,#fff);box-shadow:0 12px 30px color-mix(in srgb,var(--c) 28%,transparent);transition:transform .35s cubic-bezier(.22,1,.36,1)}
.metier-card:hover .metier-ico{transform:translateX(-50%) translateY(-5px)}
.metier-ico img{width:50px;height:50px;display:block}
.metier-ico svg{width:50px;height:50px;display:block;stroke:var(--c)}
.metier-name{font-family:'Sora',sans-serif;font-weight:800;font-size:21px;color:var(--bleu-nuit);margin-bottom:14px;letter-spacing:-.01em}
.metier-desc{font-size:15px;color:var(--gris-texte);line-height:1.62;margin:0}
.metier-plus{position:absolute;bottom:-27px;left:50%;transform:translateX(-50%);width:54px;height:54px;border-radius:50%;background:color-mix(in srgb,var(--c) 17%,#fff);color:var(--c);display:grid;place-items:center;font-family:'Sora',sans-serif;font-weight:600;font-size:30px;line-height:0;box-shadow:0 8px 22px color-mix(in srgb,var(--c) 26%,transparent);transition:transform .5s cubic-bezier(.34,1.45,.45,1),background .3s ease,color .3s ease}
.metier-card:hover .metier-plus{transform:translateX(-50%) scale(1.1) rotate(180deg);background:var(--c);color:#fff}
@keyframes metiersScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.metiers-track{animation:none}}
@media (max-width:968px){ .metiers-head{margin-bottom:60px} .metiers-grid{grid-template-columns:repeat(2,1fr);column-gap:22px} }
@media (max-width:560px){ .metiers-grid{grid-template-columns:1fr;row-gap:84px} .metier-card{margin:0} }

/* ===== Zone d'intervention v2 — fond clair + grande carte régionale full-bleed ===== */
.zone2{position:relative;padding:96px 0;min-height:760px;overflow-x:clip}
.zone2-blob{position:absolute;border-radius:50%;z-index:0;pointer-events:none}
.zone2-blob-a{width:640px;height:640px;left:-210px;top:-150px;background:radial-gradient(closest-side,rgba(120,178,43,.12),rgba(120,178,43,0))}
.zone2-blob-b{width:580px;height:580px;left:70px;top:-230px;background:radial-gradient(closest-side,rgba(255,170,92,.11),rgba(255,170,92,0))}
.zone2 .container{position:relative;z-index:2}
.zone2-left{max-width:440px}
.zone2-dashes{display:flex;gap:8px;margin-bottom:22px}
.zone2-dashes span{width:30px;height:6px;border-radius:100px;display:block}
.zone2-dashes span:nth-child(1){background:#EECB33}
.zone2-dashes span:nth-child(2){background:var(--orange)}
.zone2-dashes span:nth-child(3){background:#3EA3DC}
.zone2-dashes span:nth-child(4){background:#78B22B}
.zone2-title{font-family:'Sora',sans-serif;font-weight:800;font-size:clamp(32px,4.2vw,52px);line-height:1.04;color:var(--bleu-nuit);letter-spacing:-.02em;margin:0}
.zone2-sub{font-family:'Sora',sans-serif;font-weight:400;font-size:clamp(19px,2.3vw,29px);color:var(--bleu-nuit);opacity:.82;margin:4px 0 26px}
.zone2-left p{color:var(--gris-texte);font-size:16.5px;line-height:1.7;margin:0 0 16px;max-width:500px}
.zone2-left p strong{color:var(--bleu-nuit);font-weight:700}
.zone2-card{display:flex;align-items:stretch;gap:15px;background:var(--blanc);border:1px solid var(--gris-bord);border-radius:18px;padding:15px;box-shadow:var(--shadow-soft);max-width:470px;margin-top:28px;overflow:hidden}
.zone2-card-pin{width:46px;height:46px;border-radius:12px;background:color-mix(in srgb,#3EA3DC 15%,#fff);color:#3EA3DC;display:grid;place-items:center;flex:0 0 auto}
.zone2-card-pin svg{width:23px;height:23px}
.zone2-card-info{flex:1;min-width:0}
.zone2-card-info .z2-city{font-family:'Sora',sans-serif;font-weight:800;font-size:18px;color:var(--bleu-nuit);margin-bottom:5px}
.zone2-card-info .z2-lab{font-weight:700;color:var(--bleu-nuit);font-size:13px}
.zone2-card-info .z2-addr{color:var(--gris-texte);font-size:13px;line-height:1.5}
.zone2-card-thumb{width:178px;align-self:stretch;min-height:104px;object-fit:cover;flex:0 0 auto;margin:0;border-radius:14px}
.zone2-card-pin{align-self:center}
/* grande carte qui part jusqu'au bord droit de l'écran */
.zone2-map{position:absolute;left:45vw;top:48%;transform:translateY(-50%);width:54vw;max-width:980px;z-index:1;pointer-events:none;-webkit-mask-image:linear-gradient(180deg,transparent 0,#000 22%,#000 78%,transparent 100%);mask-image:linear-gradient(180deg,transparent 0,#000 22%,#000 78%,transparent 100%)}
.zone2-map svg{width:100%;height:auto;display:block;overflow:visible}
.zone2-map svg .map-fade-r{display:none}
.radar .ping{transform-box:fill-box;transform-origin:center;animation:rdrPing 3s ease-out infinite}
.radar .ping-b{animation-delay:1s}
.radar .ping-c{animation-delay:2s}
@keyframes rdrPing{0%{transform:scale(.16);opacity:.55}70%{opacity:.08}100%{transform:scale(1);opacity:0}}
.radar .core{transform-box:fill-box;transform-origin:center;animation:rdrCore 3s ease-in-out infinite}
@keyframes rdrCore{0%,100%{transform:scale(1)}50%{transform:scale(1.13)}}
@media (max-width:1280px){ .zone2-map{left:46vw;width:54vw} .zone2-left{max-width:400px} }
/* Tablette & mobile (<=1024) : empilé, carte centrée — desktop/laptop >=1025 inchangé */
@media (max-width:1024px){
  .zone2{display:flex;flex-direction:column;min-height:0;padding:80px 0}
  .zone2 .container{order:1}
  .zone2-left{max-width:none}
  .zone2-map{order:2;position:relative;top:auto;left:auto;transform:none;width:100%;max-width:600px;margin:32px auto 0}
  .zone2-map svg .map-fade-r{display:block}
}
@media (max-width:768px){
  .zone2{padding:64px 0}
  .zone2-map{max-width:540px;margin-top:26px}
}
@media (max-width:560px){
  .zone2{padding:54px 0}
  .zone2-map{max-width:none}
}
@media (prefers-reduced-motion:reduce){ .radar .ping,.radar .core{animation:none} .radar .ping{opacity:0} }


/* --- Section "Au service de nos clients" restructurée --- */
.groupe-title{font-family:'Sora',sans-serif;font-weight:800;font-size:clamp(34px,4.6vw,54px);color:var(--bleu-nuit);line-height:1.02;letter-spacing:-.02em;margin:0}
.groupe-title::after{content:none !important}
.groupe-sub{font-family:'Sora',sans-serif;font-weight:400;font-size:clamp(19px,2.4vw,30px);color:var(--bleu-nuit);opacity:.82;margin:6px 0 22px}
.groupe-photo{align-self:stretch;min-height:0;aspect-ratio:auto;--img-groupe:url('/wp-content/uploads/2026/06/adresse-entreprise.png')}
@media (max-width:968px){ .groupe-photo{aspect-ratio:16/9;align-self:auto} }
.aservice-entites{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:46px}
.aservice-entite{position:relative;overflow:hidden;padding:18px 18px 16px}
.aservice-entite-txt span{white-space:normal}
@media (max-width:760px){ .aservice-entites{gap:12px} }


/* --- Conseils : bento premium + réseaux sociaux --- */
.conseils-bento{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:200px;gap:18px}
.cb-card{position:relative;border-radius:22px;overflow:hidden;background-size:cover;background-position:center;display:block;text-decoration:none;box-shadow:var(--shadow-soft);transition:transform .4s ease,box-shadow .4s ease}
.cb-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-medium)}
.cb-card .cb-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,11,7,.04) 28%,rgba(11,7,4,.9) 100%)}
.cb-content{position:absolute;left:0;right:0;bottom:0;padding:24px;z-index:2}
.cb-cat{display:inline-block;background:rgba(255,255,255,.94);color:var(--orange-dark);font-weight:700;font-size:11.5px;padding:5px 12px;border-radius:100px;margin-bottom:12px;letter-spacing:.03em}
.cb-title-big{color:#fff;font-family:'Sora',sans-serif;font-weight:800;font-size:clamp(21px,2.1vw,28px);line-height:1.18;text-shadow:0 2px 14px rgba(0,0,0,.5);margin:0 0 10px}
.cb-excerpt{color:rgba(255,255,255,.92);font-size:14.5px;line-height:1.55;margin:0 0 14px;max-width:540px}
.cb-title{color:#fff;font-family:'Sora',sans-serif;font-weight:800;font-size:16.5px;line-height:1.24;text-shadow:0 2px 12px rgba(0,0,0,.55);margin:0}
.cb-link{color:#fff;font-weight:700;font-size:14px;display:inline-flex;align-items:center;gap:7px;transition:gap .25s}
.cb-card:hover .cb-link{gap:12px}
.cb-feature{grid-column:1 / 3;grid-row:1 / 3}
.cb-insta{grid-column:3;grid-row:1}
.cb-fb{grid-column:3;grid-row:2}
.cb-art2{grid-column:1;grid-row:3}
.cb-art3{grid-column:2;grid-row:3}
.cb-yt{grid-column:3;grid-row:3}
.cb-social{position:relative;border-radius:22px;overflow:hidden;padding:20px;display:flex;flex-direction:column;justify-content:space-between;gap:12px;text-decoration:none;color:#fff;box-shadow:var(--shadow-medium);transition:transform .4s ease,box-shadow .4s ease}
.cb-social:hover{transform:translateY(-5px);box-shadow:var(--shadow-dark)}
.cb-social::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 82% 4%,rgba(255,255,255,.26),transparent 58%);pointer-events:none}
.cb-insta{background:linear-gradient(135deg,#F58529 0%,#DD2A7B 46%,#8134AF 74%,#515BD4 100%)}
.cb-fb{background:linear-gradient(135deg,#1B8CFF 0%,#0A53BE 100%)}
.cb-yt{background:linear-gradient(135deg,#FF3030 0%,#C00000 100%)}
.cb-social-ico{width:42px;height:42px;display:grid;place-items:center;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.32);border-radius:13px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);position:relative;z-index:1}
.cb-social-ico svg{width:23px;height:23px}
.cb-social-head{display:flex;flex-direction:column;gap:10px;position:relative;z-index:1}
.cb-social-id{display:flex;flex-direction:column;line-height:1.16}
.cb-social-num{font-family:'Sora',sans-serif;font-weight:800;font-size:25px;line-height:1;display:block}
.cb-social-num-sm{font-size:17px}
.cb-social-lab{font-size:12.5px;opacity:.9}
.cb-social-stat{display:flex;align-items:baseline;gap:7px;position:relative;z-index:1}
.cb-social-net{font-family:'Sora',sans-serif;font-weight:800;font-size:15px;color:#fff;letter-spacing:.005em}
.cb-social-cta{align-self:flex-start;font-size:12.5px;font-weight:700;background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.34);padding:7px 15px;border-radius:100px;transition:background .25s;position:relative;z-index:1}
.cb-social:hover .cb-social-cta{background:rgba(255,255,255,.32)}
@media (max-width:968px){
  .conseils-bento{grid-template-columns:1fr 1fr;grid-auto-rows:172px}
  .cb-feature{grid-column:1 / 3;grid-row:auto;min-height:300px}
  .cb-insta,.cb-fb,.cb-art2,.cb-art3,.cb-yt{grid-column:auto;grid-row:auto}
}
@media (max-width:560px){
  .conseils-bento{grid-template-columns:1fr;grid-auto-rows:190px}
  .cb-feature{min-height:280px}
}


/* --- Réalisations : fond sombre + hauteurs décalées (masonry) --- */
.real{background:#0E0F14;padding:104px 0;position:relative}
.real .container{position:relative;z-index:1}
.real .section-eyebrow{color:#FF8A5B}
.real h2{color:#fff}
.real h2 .hl-warm{color:#FF8A5B;-webkit-text-fill-color:#FF8A5B}
.real .section-subtitle{color:rgba(255,255,255,.74)}
.real .btn-secondary{color:#fff;border-color:rgba(255,255,255,.32);background:rgba(255,255,255,.04)}
.real .btn-secondary:hover{background:var(--orange);border-color:var(--orange);color:#fff}
.realz-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;align-items:start}
.realz-card{height:356px;box-shadow:0 22px 50px rgba(0,0,0,.5)}
.realz-card:nth-child(1){height:372px;margin-top:0}
.realz-card:nth-child(2){height:300px;margin-top:54px}
.realz-card:nth-child(3){height:392px;margin-top:24px}
.realz-card:nth-child(4){height:312px;margin-top:70px}
@media (max-width:968px){
  .real{padding:74px 0}
  .realz-grid{grid-template-columns:1fr 1fr;gap:16px}
  .realz-card,.realz-card:nth-child(1),.realz-card:nth-child(2),.realz-card:nth-child(3),.realz-card:nth-child(4){height:300px;margin-top:0}
  .realz-card:nth-child(2),.realz-card:nth-child(4){margin-top:38px}
}
@media (max-width:560px){
  .realz-card,.realz-card:nth-child(n){height:260px;margin-top:0}
}


@media (max-width:640px){
  .cb-social{padding:17px}
  .cb-social-num{font-size:24px}
  .cb-social-num-sm{font-size:16.5px}
  .cb-social-net{font-size:14px}
  .cb-social-cta{padding:5px 10px;font-size:11.5px}
  .cb-social-ico{width:38px;height:38px}
}


/* === [MAJ] Métiers : grille statique 4+4 === */
.metiers-grid{display:grid;grid-template-columns:repeat(4,1fr);column-gap:26px;row-gap:84px;padding-top:62px}
.metiers-grid-c2pi{padding-top:62px}
/* [MAJ] colonnes responsive — placées source-après pour gagner la cascade */
@media (max-width:968px){ .metiers-grid{grid-template-columns:repeat(2,1fr);column-gap:22px;row-gap:78px} }
@media (max-width:560px){ .metiers-grid{grid-template-columns:repeat(2,1fr);column-gap:14px;row-gap:72px} }
@media (max-width:400px){ .metiers-grid{grid-template-columns:1fr;row-gap:72px} }
.metier-card{height:100%}
.metiers-split{display:flex;align-items:center;gap:22px;margin:56px 0 4px}
.metiers-split-line{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--gris-bord) 50%,transparent)}
.metiers-split-txt{font-family:'Sora',sans-serif;font-weight:700;font-size:16px;color:var(--bleu-nuit);white-space:nowrap;letter-spacing:-.01em}
.metiers-split-txt em{font-style:normal;color:var(--orange)}
@media (max-width:560px){ .metiers-split-txt{font-size:14px;white-space:normal;text-align:center} .metiers-split{gap:14px} }

/* === [MAJ] Cartes entités : dégradé + barre de marque (façon C2PI) === */
.aservice-entite::before{content:'';position:absolute;top:0;left:0;right:0;height:4px}
.ase-roy{background:linear-gradient(135deg,#FFFFFF 0%,#F2F5FA 100%);border-color:#E0E5EE}
.ase-roy::before{background:linear-gradient(90deg,#78B22B 0%,#3EA3DC 38%,#7A4FB0 68%,#E85D2F 100%)}
.ase-solaire{background:linear-gradient(135deg,#FFFFFF 0%,#EBF5E2 100%);border-color:#D2E7C2}
.ase-solaire::before{background:linear-gradient(90deg,#8FC23F 0%,#3FA34D 100%)}
.ase-c2pi{background:linear-gradient(135deg,#FFFFFF 0%,#FDEDE6 100%);border-color:var(--orange-pale)}
.ase-c2pi::before{background:linear-gradient(90deg,#E85D2F 0%,#FF6B35 55%,#C44A1F 100%)}

/* === [MAJ] Cartes réseaux : identité + descriptif === */
.cb-social-top{display:flex;align-items:center;gap:11px;position:relative;z-index:1}
.cb-social-handle{font-family:'Manrope',sans-serif;font-weight:600;font-size:12.5px;color:rgba(255,255,255,.86);letter-spacing:.005em}
.cb-social-desc{font-size:12.5px;line-height:1.45;opacity:.93;margin:0;max-width:97%}
@media (max-width:640px){ .cb-social-handle{font-size:12px} .cb-social-desc{font-size:11.5px} }


/* =================== [MAJ v2] PREMIUM =================== */
/* --- Promesses : nombre + petite unité (1 ligne), séparateurs verticaux --- */
.groupe-noto{display:flex !important;align-items:stretch;flex-wrap:nowrap;gap:0}
.gnoto{flex:0 1 auto;text-align:left;background:none;border:none;box-shadow:none;border-radius:0;padding:2px 30px 2px 0;position:relative}
.gnoto + .gnoto{padding-left:30px}
.gnoto + .gnoto::before{content:'';position:absolute;left:0;top:5px;bottom:5px;width:1px;background:var(--gris-bord)}
.gnoto-num{display:inline-flex;align-items:baseline;gap:2px;font-family:'Sora',sans-serif;line-height:1;margin-bottom:7px}
.gnoto-val{font-size:clamp(31px,3.4vw,50px);font-weight:800;color:var(--bleu-nuit);letter-spacing:-.03em}
.gnoto-unit{font-size:.42em;font-weight:800;color:var(--gris-texte);line-height:1}
.gnoto-unit-sup{align-self:flex-start;color:var(--orange);transform:translateY(2px)}
.gnoto-label{font-size:15px;color:var(--gris-texte);font-weight:600;letter-spacing:.004em}
@media (max-width:560px){
  .groupe-noto{justify-content:flex-start}
  .gnoto{padding:2px 16px 2px 0}
  .gnoto + .gnoto{padding-left:16px}
  .gnoto-label{font-size:12.5px}
}
@media (max-width:360px){ .gnoto{padding:2px 11px 2px 0} .gnoto + .gnoto{padding-left:11px} }

/* --- Cartes entités : maison-mère pleine largeur + 2 dessous, chevron, flux --- */
.aservice-entites{display:grid !important;grid-template-columns:1fr 1fr;gap:14px;margin-top:30px}
.ase-roy{grid-column:1 / -1}
.aservice-entite{display:flex;align-items:center;gap:15px;border-radius:16px;padding:18px 20px 17px;text-decoration:none;
  transition:transform .45s cubic-bezier(.22,1,.36,1),box-shadow .4s ease}
.aservice-entite::before{transition:height .35s ease}
.aservice-entite:hover{transform:translateY(-5px);box-shadow:var(--shadow-medium)}
.aservice-entite:hover::before{height:6px}
.ase-arrow{margin-left:auto;width:32px;height:32px;flex:0 0 auto;display:grid;place-items:center;border-radius:50%;
  color:var(--gris-texte);background:rgba(20,20,16,.05);transition:transform .4s cubic-bezier(.22,1,.36,1),background .3s ease,color .3s ease}
.ase-arrow svg{width:16px;height:16px}
.aservice-entite:hover .ase-arrow{transform:translateX(4px);background:var(--bleu-nuit);color:#fff}
.ase-roy::before{background:linear-gradient(90deg,#78B22B,#3EA3DC,#7A4FB0,#E85D2F,#3EA3DC,#78B22B);background-size:220% 100%;animation:aseFlow 7s linear infinite}
@keyframes aseFlow{to{background-position:220% 0}}
@media (max-width:760px){ .aservice-entites{grid-template-columns:repeat(3,1fr) !important} .ase-roy{grid-column:auto} }
@media (prefers-reduced-motion:reduce){ .ase-roy::before{animation:none} }

/* --- Métiers : cascade d'apparition + survol coloré --- */
.metier-card{transition:opacity .55s ease,transform .55s cubic-bezier(.22,1,.36,1),box-shadow .4s ease,background .35s ease,border-color .35s ease}
.metiers-grid .metier-card.reveal-scale:nth-child(2){transition-delay:.07s}
.metiers-grid .metier-card.reveal-scale:nth-child(3){transition-delay:.14s}
.metiers-grid .metier-card.reveal-scale:nth-child(4){transition-delay:.21s}
.metier-card:hover{border-color:color-mix(in srgb,var(--c) 50%,var(--gris-bord))}

/* --- Réalisations : cascade --- */
.realz-card.reveal-scale:nth-child(2){transition-delay:.08s}
.realz-card.reveal-scale:nth-child(3){transition-delay:.16s}
.realz-card.reveal-scale:nth-child(4){transition-delay:.24s}

/* --- Certifications : cascade + emblème animé au survol --- */
.cert-card.reveal-scale:nth-child(2){transition-delay:.06s}
.cert-card.reveal-scale:nth-child(3){transition-delay:.12s}
.cert-card.reveal-scale:nth-child(4){transition-delay:.18s}
.cert-card.reveal-scale:nth-child(5){transition-delay:.24s}
.cert-emblem{transition:transform .4s cubic-bezier(.34,1.4,.5,1)}
.cert-card:hover .cert-emblem{transform:scale(1.08) rotate(-4deg)}

/* --- Réseaux : icône qui réagit au survol --- */
.cb-social-ico{transition:transform .4s cubic-bezier(.34,1.4,.5,1),background .3s ease}
.cb-social:hover .cb-social-ico{transform:scale(1.09) rotate(3deg);background:rgba(255,255,255,.28)}

/* --- Boutons : léger reflet au survol --- */
.btn-primary{position:relative;overflow:hidden}
.btn-primary::after{content:'';position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.35),transparent);transform:skewX(-18deg);transition:left .6s ease}
.btn-primary:hover::after{left:160%}


/* =================== [MAJ v3] =================== */
/* --- Zone2 : haut encapsulé + bloc "second oeuvre" sous le siege --- */
.zone2-top{position:relative;min-height:600px}
.zone2-also{position:relative;z-index:3;margin-top:30px}
.zone2-also .metiers-split{margin:0 0 6px}
.zone2-also .metiers-grid-c2pi{padding-top:62px}
@media (max-width:1024px){
  .zone2-top{display:flex;flex-direction:column;min-height:0}
  .zone2-also{margin-top:18px}
}

/* --- Cartes entites : 3 petites cartes verticales, SANS bandeau --- */
.aservice-entites{display:grid !important;grid-template-columns:repeat(3,1fr);gap:16px;margin:30px auto 0;max-width:720px}
.ase-roy{grid-column:auto}
.ase-roy,.ase-solaire,.ase-c2pi{background:var(--blanc);border:1px solid var(--gris-bord)}
.aservice-entite{display:flex;flex-direction:column;align-items:flex-start;gap:0;border-radius:18px;padding:16px 18px 15px;
  box-shadow:var(--shadow-soft);overflow:visible;
  transition:transform .45s cubic-bezier(.22,1,.36,1),box-shadow .4s ease,border-color .35s ease}
.aservice-entite::before{content:none}
.aservice-entite .brand-logo{width:42px;height:42px;margin:0 0 9px}
.aservice-entite-txt{display:flex;flex-direction:column;min-width:0}
.aservice-entite-txt strong{font-family:'Sora',sans-serif;font-weight:800;font-size:17px;color:var(--bleu-nuit);line-height:1.2}
.aservice-entite-txt span{font-size:12.5px;color:var(--gris-texte);margin-top:4px;line-height:1.4;white-space:normal}
.ase-arrow{margin:11px 0 0;width:28px;height:28px;flex:0 0 auto;border-radius:50%;background:rgba(20,20,16,.05);color:var(--gris-texte);
  display:grid;place-items:center;transition:transform .4s cubic-bezier(.22,1,.36,1),background .3s ease,color .3s ease}
.ase-arrow svg{width:15px;height:15px}
.aservice-entite:hover{transform:translateY(-6px);box-shadow:var(--shadow-medium)}
.aservice-entite:hover .ase-arrow{transform:translateX(3px);background:var(--bleu-nuit);color:#fff}
.ase-roy:hover{border-color:#ccd5e6}
.ase-solaire:hover{border-color:#bcdca6}
.ase-c2pi:hover{border-color:var(--orange-pale)}
@media (max-width:600px){
  .aservice-entites{gap:10px;max-width:none}
  .aservice-entite{padding:18px 12px 16px;align-items:center;text-align:center}
  .aservice-entite .brand-logo{margin-bottom:11px;width:44px;height:44px}
  .aservice-entite-txt strong{font-size:14px}
  .aservice-entite-txt span{display:none}
  .ase-arrow{display:none}
}


/* =================== [MAJ v4] =================== */
/* --- Zone2 : carte poussee a droite + cartes second oeuvre plus basses --- */
.zone2-map{left:49vw;width:55vw}
.zone2-top{min-height:660px}
.zone2-also{margin-top:64px}
@media (max-width:1280px){ .zone2-map{left:50vw;width:56vw} }
@media (max-width:1024px){ .zone2-map{left:auto;width:100%} .zone2-also{margin-top:18px} }

/* --- Cartes entites : pleine largeur (= elements au-dessus) + degrade de fond --- */
.aservice-entites{max-width:none !important;margin:30px 0 0}
.ase-roy{background:linear-gradient(140deg,#FFFFFF 0%,#F3F6FB 100%);border-color:#E2E7F0}
.ase-solaire{background:linear-gradient(140deg,#FFFFFF 0%,#ECF6E4 100%);border-color:#D4E8C6}
.ase-c2pi{background:linear-gradient(140deg,#FFFFFF 0%,#FDEEE7 100%);border-color:var(--orange-pale)}

/* --- Realisations : masonry colonnes (2 lignes integrees) --- */
.realz-grid{display:block !important;column-count:4;column-gap:20px;align-items:initial}
.realz-card{display:block;width:100%;break-inside:avoid;-webkit-column-break-inside:avoid;margin:0 0 20px !important}
.realz-card:nth-child(1){height:300px}
.realz-card:nth-child(2){height:372px}
.realz-card:nth-child(3){height:340px}
.realz-card:nth-child(4){height:300px}
.realz-card:nth-child(5){height:364px}
.realz-card:nth-child(6){height:300px}
.realz-card:nth-child(7){height:344px}
.realz-card:nth-child(8){height:372px}
.realz-card.reveal-scale:nth-child(5){transition-delay:.10s}
.realz-card.reveal-scale:nth-child(6){transition-delay:.16s}
.realz-card.reveal-scale:nth-child(7){transition-delay:.22s}
.realz-card.reveal-scale:nth-child(8){transition-delay:.28s}
@media (max-width:968px){ .realz-grid{column-count:2} }

/* --- Aides : rangee de liens premium --- */
.aides-wrap{margin-top:46px;text-align:center}
.aides-intro{font-size:14.5px;font-weight:700;color:var(--gris-texte);margin-bottom:18px;letter-spacing:.01em}
.aides-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.aide-link{display:flex;align-items:center;gap:11px;background:var(--blanc);border:1px solid var(--gris-bord);border-radius:14px;
  padding:14px 16px;text-decoration:none;box-shadow:var(--shadow-soft);
  transition:transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s ease,border-color .3s ease}
.aide-link:hover{transform:translateY(-3px);box-shadow:var(--shadow-medium)}
.aide-ic{width:34px;height:34px;flex:0 0 auto;display:grid;place-items:center;border-radius:10px;font-size:17px}
.aide-tx{font-family:'Sora',sans-serif;font-weight:700;font-size:14px;color:var(--bleu-nuit);line-height:1.2;text-align:left;flex:1}
.aide-ar{width:22px;height:22px;flex:0 0 auto;display:grid;place-items:center;color:var(--gris-texte);transition:transform .35s ease}
.aide-ar svg{width:14px;height:14px}
.aide-link:hover .aide-ar{transform:translateX(3px)}
.aide-elec .aide-ic{background:rgba(244,185,42,.18);color:#B47C06} .aide-elec:hover{border-color:#F0D48A}
.aide-pv .aide-ic{background:rgba(120,178,43,.16);color:#4F8A1E} .aide-pv:hover{border-color:#BCDDA0}
.aide-chauf .aide-ic{background:rgba(214,56,57,.12);color:#C0392B} .aide-chauf:hover{border-color:#F0BFB6}
.aide-sdb .aide-ic{background:rgba(62,163,220,.14);color:#2C77B0} .aide-sdb:hover{border-color:#B9DBEF}
@media (max-width:900px){ .aides-row{grid-template-columns:1fr 1fr} }
@media (max-width:460px){ .aides-row{grid-template-columns:1fr} }


/* =================== [MAJ v5 — MOBILE] =================== */
/* M0 — header mobile : logo gauche / MENU droite, affiche direct (pas d'anim initiale) */
@media (max-width:1100px){
  .nav-bar{width:100%;justify-content:space-between}
  header:not(.scrolled) .nav-bar{position:static;transform:none;top:auto;right:auto;left:auto}
  header:not(.scrolled) .nav-bar .logo{display:flex}
  .hero-logo{display:none}
  .hero-text{padding-top:92px}
}

/* M4 desktop — wrapper reseaux transparent (preserve le bento existant) */
.cb-socials{display:contents}

/* ===== Decks / carrousels mobiles (cartes empilables, 1 a la fois) ===== */
.deck-dots{display:none;justify-content:center;gap:7px;margin-top:16px}
.deck-dots button{width:8px;height:8px;border-radius:50%;border:none;background:var(--gris-bord);padding:0;cursor:pointer;transition:width .3s ease,background .3s ease}
.deck-dots button.active{background:var(--orange);width:22px;border-radius:5px}

@media (max-width:768px){
  #services .metiers-grid,
  .zone2-also .metiers-grid-c2pi,
  .realz-grid,
  .cb-socials{
    display:flex !important;flex-direction:row;flex-wrap:nowrap;
    overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;gap:14px;
    margin-left:0;margin-right:0;padding-left:0;padding-right:0;
    -webkit-overflow-scrolling:touch;scrollbar-width:none;
    column-count:auto;grid-template-columns:none !important;row-gap:0;
  }
  #services .metiers-grid::-webkit-scrollbar,
  .zone2-also .metiers-grid-c2pi::-webkit-scrollbar,
  .realz-grid::-webkit-scrollbar,
  .cb-socials::-webkit-scrollbar{display:none}

  /* metiers : espace icone flottante + bouton + */
  #services .metiers-grid,.zone2-also .metiers-grid-c2pi{padding-top:60px;padding-bottom:38px}
  #services .metiers-grid > .metier-card,
  .zone2-also .metiers-grid-c2pi > .metier-card{flex:0 0 76%;scroll-snap-align:center;margin:0 !important;min-width:0}

  /* realisations : une carte a la fois */
  .realz-grid{padding-top:0;padding-bottom:0;overflow-y:visible}
  .realz-grid > .realz-card{flex:0 0 86% !important;scroll-snap-align:center;height:380px !important;margin:0 !important;width:auto;break-inside:auto}

  /* conseils : 3 articles empiles puis 3 reseaux en deck */
  .conseils-bento{display:flex !important;flex-direction:column;gap:14px;grid-auto-rows:auto}
  .conseils-bento > .cb-card{width:100%;grid-column:auto !important;grid-row:auto !important;min-height:210px}
  .cb-feature{min-height:300px !important}
  .cb-socials{padding-top:2px;padding-bottom:2px;margin-top:2px;overflow-y:visible}
  .cb-socials > .cb-social{flex:0 0 74%;scroll-snap-align:center;min-height:200px}

  /* cartes des decks toujours visibles (independamment de l'observer) */
  #services .metiers-grid .metier-card,
  .zone2-also .metiers-grid-c2pi .metier-card,
  .cb-socials .cb-social{opacity:1 !important;transform:none !important}
  /* realisations : pile de cartes -> garder visibles MAIS laisser buildStack gerer la transform */
  .realz-grid .realz-card{opacity:1 !important}

  .deck-dots{display:flex}
}

/* fix largeur : la zone2 est flex-column en mobile -> empecher le conteneur du deck de s'elargir */
@media (max-width:1024px){ .zone2 > .container{min-width:0;width:100%} }
@media (max-width:768px){
  .zone2-also{min-width:0;overflow:hidden}
  .zone2-also .metiers-grid-c2pi{min-width:0;width:100%;max-width:100%;box-sizing:border-box}
}
/* titre "second oeuvre" : libelle centre sans traits sur mobile (evite la coupe) */
@media (max-width:768px){
  .zone2-also .metiers-split{flex-direction:column;gap:0;margin:0 0 10px}
  .zone2-also .metiers-split-line{display:none}
  .zone2-also .metiers-split-txt{white-space:normal;text-align:center;font-size:15px;line-height:1.35}
}
/* M3 — carte France a cheval (haut tucke sous le siege) sur mobile */
@media (max-width:1024px){
  .zone2-top{overflow:visible}
  .zone2-card{position:relative;z-index:3}
  .zone2-map{margin-top:-30px;z-index:0;position:relative}
}


/* ============================================================
   AJUSTEMENTS ACCUEIL (retours client juin 2026)
   ============================================================ */

/* 1) Surlignage de la phrase d'intro : couleur par métier (plus tous orange) */
.hl-elec::after { background:linear-gradient(120deg, rgba(239,203,51,.62), rgba(180,124,6,.40)) !important; }
.hl-chauf::after{ background:linear-gradient(120deg, rgba(232,116,63,.55), rgba(184,55,25,.40)) !important; }
.hl-plomb::after{ background:linear-gradient(120deg, rgba(111,180,231,.55), rgba(44,111,166,.40)) !important; }
.hl-pv::after   { background:linear-gradient(120deg, rgba(139,195,74,.55), rgba(79,138,30,.40)) !important; }

/* 2) Badge avis Google : "143+ avis · 4,9/5" */
.hero-google-out{ font-size:.66em; font-weight:700; color:var(--gris-texte); margin-left:1px; align-self:flex-end; padding-bottom:2px; }

/* 3) Promesses (chiffres) centrées au lieu d'alignées à gauche */
.groupe .groupe-noto{ justify-content:center !important; }
.groupe .gnoto{ text-align:center; }
.groupe .gnoto-num{ justify-content:center; }

/* 4) Cartes métiers : icônes ligne de la marque (couleur métier) */
.metier-ico svg{ width:50px; height:50px; display:block; color:var(--c); stroke:var(--c); }

/* 5) Cartes métiers : pas de bug de survol "collé" sur tactile */
@media (hover:none){
  .metier-card:hover{ transform:none !important; box-shadow:none !important; background:#F6F7F9 !important; border-color:var(--gris-bord) !important; }
  .metier-card:hover .metier-ico{ transform:translateX(-50%) !important; }
  .metier-card:hover .metier-plus{ transform:translateX(-50%) !important; background:color-mix(in srgb, var(--c) 14%, #fff) !important; color:var(--c) !important; }
  .metier-card:active{ transform:translateY(-3px) !important; }
}

/* 6) Desktop : 8 cartes = 2 lignes, toutes alignées en haut */
@media (min-width:969px){
  .metiers .metiers-grid{ grid-template-columns:repeat(4,1fr); align-items:start; row-gap:118px; }
}

/* 7) Mobile/tablette : carousel horizontal intelligent (scroll-snap), cartes alignées en haut */
@media (max-width:968px){
  .metiers .metiers-grid{
    display:flex !important; grid-template-columns:none !important;
    flex-wrap:nowrap; align-items:flex-start;
    overflow-x:auto; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch;
    gap:18px; padding:62px 20px 30px; margin:0 -20px; row-gap:0;
    scrollbar-width:none;
  }
  .metiers .metiers-grid::-webkit-scrollbar{ display:none; }
  .metiers .metiers-grid > .metier-card{
    flex:0 0 clamp(232px,74vw,290px); scroll-snap-align:center; margin:0 !important; height:auto;
  }
}

/* 8) Titre hero accueil : tenir en 2 lignes (pas 3) sur mobile */
@media (max-width:640px){
  .hero-headline{ font-size:clamp(22px,6.4vw,32px) !important; }
  .hero-headline .hh-line2{ white-space:nowrap; }
  .word-rotate .wr-word{ padding-left:.30em !important; padding-right:.30em !important; }
}

/* 9) Cartes métiers du hero (mobile) : remontées (moins de blanc au-dessus) */
@media (max-width:968px){
  .hero{ min-height:0 !important; padding:0 0 22px !important; }
  .hero .hero-grid{ min-height:0 !important; align-items:start !important; gap:0 !important; row-gap:0 !important; }
  .hero .hero-right{ min-height:0 !important; margin-top:0 !important; padding-top:0 !important; }
  .hero .hero-text{ justify-content:flex-start !important; min-height:0 !important; padding-bottom:6px !important; }
  .hero .hero-cards{ position:static !important; margin-top:-10px !important; }
}

/* 11) Mobile/tablette : cartes metiers sur 2 LIGNES defilantes horizontalement
   (ligne 1 = metiers, ligne 2 = second oeuvre). Remplace le carousel 1 ligne. */
@media (max-width:968px){
  #services .metiers-grid,
  .metiers .metiers-grid{
    display:grid !important;
    grid-auto-flow:row !important;
    grid-template-rows:repeat(2,auto) !important;
    grid-template-columns:repeat(4,clamp(198px,57vw,236px)) !important;
    align-items:stretch !important;
    column-gap:14px !important; row-gap:88px !important;
    overflow-x:auto !important; overflow-y:hidden !important;
    scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    padding:58px 4px 60px !important; margin:0 -4px !important;
    width:auto !important; max-width:100% !important; min-width:0 !important;
  }
  #services .metiers-grid::-webkit-scrollbar,
  .metiers .metiers-grid::-webkit-scrollbar{ display:none !important; }
  #services .metiers-grid > .metier-card,
  .metiers .metiers-grid > .metier-card{
    flex:none !important; width:auto !important; min-width:0 !important;
    height:100% !important; margin:0 !important; scroll-snap-align:start;
  }
}

/* 12) Accueil — bouton CTA 1re section en NOIR (orange trop dominant) */
.hero .hero-ctas .btn-primary{
  background:#17130f !important;
  box-shadow:0 10px 26px rgba(20,14,10,.30) !important;
}
.hero .hero-ctas .btn-primary:hover{
  background:#221c16 !important;
  box-shadow:0 16px 36px rgba(20,14,10,.40) !important;
}

/* Phrase hero : "marque deux-sévrienne" en manuscrit (artisan), sans couleur dominante */
.hero-secondary .hs-hand{
  font-family:'Caveat',cursive;
  font-weight:700;
  font-size:1.5em;
  line-height:1;
  color:#1c1a18;
  white-space:nowrap;
  padding:0 .06em;
  letter-spacing:.2px;
}

/* 13) Bouton "Découvrir nos services" en NOIR aussi (pas de couleur dominante) */
.hero .hero-ctas .btn-secondary{
  background:transparent !important;
  color:#17130f !important;
  border:1.5px solid #17130f !important;
}
.hero .hero-ctas .btn-secondary:hover{
  background:#17130f !important;
  color:#fff !important;
  border-color:#17130f !important;
}


/* === Réalisations accueil — pile de cartes (Uno) sur mobile (remplace le scroll horizontal) === */
@media (max-width:968px){
  .real .realz-grid{ display:block !important; position:relative !important; height:430px !important;
    margin:8px 0 20px !important; overflow:visible !important; column-count:auto !important;
    scroll-snap-type:none !important; }
  .real .realz-grid > .realz-card{ position:absolute !important; top:0 !important; left:50% !important;
    width:86% !important; height:340px !important; flex:none !important; margin:0 !important;
    scroll-snap-align:none !important; break-inside:auto; }
}
