
/* ===================== 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(16px,1.8vw,21px);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:290px;width:auto;height:auto;min-height:0;border-radius:0 0 0 30px}
.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:212px;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 ===================== */
/* en-tête simplifié (base reprise de pompe-a-chaleur) : pilule centrée, pas de topbar secondaire */
.topbar-secondary{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}
}
@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-x:auto;-webkit-overflow-scrolling:touch}
  .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:13px;background:var(--blanc);border:1px solid var(--gris-bord);border-radius:18px;padding:28px 30px;width:190px;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:56px;height:56px;border-radius:15px;display:grid;place-items:center;font-size:25px;color:#fff;box-shadow:var(--shadow-soft)}
.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}
@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:22px;display:flex;flex-direction:column;justify-content:space-between;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-meta{position:relative;z-index:1}
.cb-social-num{font-family:'Sora',sans-serif;font-weight:800;font-size:27px;line-height:1;display:block}
.cb-social-num-sm{font-size:21px}
.cb-social-lab{font-size:13px;opacity:.92}
.cb-social-foot{display:flex;align-items:center;justify-content:space-between;position:relative;z-index:1}
.cb-social-net{font-family:'Sora',sans-serif;font-weight:700;font-size:15px}
.cb-social-cta{font-size:12.5px;font-weight:700;background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.34);padding:6px 13px;border-radius:100px;transition:background .25s}
.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 : handle + descriptif === */
.cb-social-top{display:flex;align-items:center;gap:11px;position:relative;z-index:1}
.cb-social-handle{font-family:'Sora',sans-serif;font-weight:700;font-size:14px;color:#fff;letter-spacing:.005em}
.cb-social-desc{display:block;font-size:12.5px;line-height:1.42;opacity:.93;margin-top:6px;max-width:97%}
@media (max-width:640px){ .cb-social-handle{font-size:13px} .cb-social-desc{font-size:11.5px;margin-top:4px} }


/* =================== [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}

  .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}
}


/* ===================== PAGE ÉLECTRICITÉ ===================== */
:root{ --elec:#E0A21A; --elec-d:#B47C06; --elec-soft:#FCF3D8; --elec-mist:rgba(230,162,26,.14); }

/* hero accents */
.el-hero-eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:'Sora',sans-serif;font-weight:700;font-size:13px;letter-spacing:.03em;color:var(--elec-d);background:var(--elec-mist);border:1px solid color-mix(in srgb,var(--elec) 32%,transparent);padding:7px 15px;border-radius:100px;margin:0 0 20px}
.el-hee-bolt{font-size:14px}
.hh-elec{position:relative;color:var(--bleu-nuit);white-space:nowrap}
.hh-elec::after{content:'';position:absolute;left:-.02em;right:-.02em;bottom:.07em;height:.32em;background:linear-gradient(90deg,var(--elec),#F4C948);opacity:.42;border-radius:5px;z-index:-1}
.el-hero-badge{position:absolute;left:18px;bottom:18px;z-index:3;display:inline-flex;align-items:center;gap:6px;background:rgba(10,10,10,.6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fff;font-family:'Sora',sans-serif;font-weight:700;font-size:12px;padding:8px 14px;border-radius:100px;border:1px solid rgba(255,255,255,.18)}

/* trust strip */
.el-trust{background:var(--blanc);padding:26px 0;border-bottom:1px solid var(--gris-bord)}
.el-trust-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;text-align:center}
.el-trust-item{display:flex;flex-direction:column;gap:3px;position:relative}
.el-trust-item:not(:last-child)::after{content:'';position:absolute;right:-8px;top:14%;height:72%;width:1px;background:var(--gris-bord)}
.el-trust-num{font-family:'Sora',sans-serif;font-weight:800;font-size:27px;color:var(--bleu-nuit);line-height:1}
.el-trust-num small{font-size:15px;color:var(--gris-texte);font-weight:700}
.el-trust-lab{font-size:13px;color:var(--gris-texte);font-weight:600}
@media(max-width:600px){.el-trust-row{grid-template-columns:1fr 1fr;gap:24px 16px}.el-trust-item:nth-child(2)::after{display:none}.el-trust-num{font-size:23px}}

/* services */
.el-services{padding:94px 0 64px;background:var(--creme)}
.el-serv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:20px}
.el-serv-card{display:flex;flex-direction:column;background:var(--blanc);border:1px solid var(--gris-bord);border-radius:22px;overflow:hidden;text-decoration:none;box-shadow:var(--shadow-soft);transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s ease}
.el-serv-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-medium)}
.el-serv-img{height:190px;background-size:cover;background-position:center;position:relative;transition:transform .6s ease}
.el-serv-card:hover .el-serv-img{transform:scale(1.05)}
.el-serv-img::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,11,7,0) 45%,rgba(12,7,4,.45) 100%)}
.el-serv-body{padding:26px 26px 26px;display:flex;flex-direction:column;flex:1;position:relative}
.el-serv-ico{position:absolute;top:-28px;right:24px;width:56px;height:56px;border-radius:16px;display:grid;place-items:center;font-size:25px;background:var(--blanc);border:1px solid var(--gris-bord);box-shadow:var(--shadow-soft)}
.el-serv-body h3{font-family:'Sora',sans-serif;font-weight:800;font-size:21px;color:var(--bleu-nuit);margin:0 0 10px;letter-spacing:-.01em}
.el-serv-body p{color:var(--gris-texte);font-size:15px;line-height:1.6;margin:0 0 18px;flex:1}
.el-serv-link{display:inline-flex;align-items:center;gap:7px;font-family:'Sora',sans-serif;font-weight:700;font-size:14.5px;color:var(--elec-d)}
.el-serv-link svg{width:15px;height:15px;transition:transform .35s ease}
.el-serv-card:hover .el-serv-link svg{transform:translateX(4px)}
@media(max-width:760px){.el-serv-grid{grid-template-columns:1fr}}

/* why us */
.el-why{padding:90px 0 80px;background:var(--blanc)}
.el-why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:16px}
.el-why-item{background:var(--creme);border:1px solid var(--gris-bord);border-radius:18px;padding:26px 24px;transition:transform .35s ease,box-shadow .35s ease}
.el-why-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}
.el-why-ico{width:48px;height:48px;border-radius:13px;display:grid;place-items:center;font-size:22px;background:var(--elec-mist);margin-bottom:14px}
.el-why-item h3{font-family:'Sora',sans-serif;font-weight:700;font-size:16.5px;color:var(--bleu-nuit);margin:0 0 7px}
.el-why-item p{color:var(--gris-texte);font-size:14px;line-height:1.55;margin:0}
.el-why-certs{margin-top:48px;text-align:center}
.el-why-certs-lab{font-size:14.5px;font-weight:700;color:var(--gris-texte);margin-bottom:22px}
.el-why-certs .certs-grid{margin-bottom:28px}
@media(max-width:900px){.el-why-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.el-why-grid{grid-template-columns:1fr}}

/* estimateur */
.el-estim{padding:18px 0 92px;background:var(--blanc)}
.el-estim-card{display:grid;grid-template-columns:1.15fr .85fr;border-radius:28px;overflow:hidden;background:linear-gradient(135deg,#15110A,#241B0C);box-shadow:0 30px 80px rgba(0,0,0,.34)}
.el-estim-left{padding:46px 46px}
.el-estim-left .section-eyebrow{color:var(--elec)}
.el-estim-left h2{font-family:'Sora',sans-serif;font-weight:800;font-size:30px;color:#fff;margin:6px 0 12px;line-height:1.15}
.el-estim-left h2 .hl-warm{color:var(--elec)}
.el-estim-left h2 .hl-warm::after{display:none}
.el-estim-left>p{color:rgba(255,255,255,.7);font-size:15px;line-height:1.6;margin:0 0 26px;max-width:440px}
.el-estim-pills{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:24px}
.el-estim-pills button{font-family:'Manrope',sans-serif;font-weight:700;font-size:13.5px;color:rgba(255,255,255,.82);background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);border-radius:100px;padding:9px 16px;cursor:pointer;transition:all .25s ease}
.el-estim-pills button:hover{background:rgba(255,255,255,.13)}
.el-estim-pills button.active{background:var(--elec);border-color:var(--elec);color:#1A1206}
.el-estim-surface label{display:block;color:rgba(255,255,255,.8);font-size:14px;font-weight:600;margin-bottom:11px}
.el-estim-surface label span{color:var(--elec);font-weight:800}
.el-estim-surface input[type=range]{width:100%;accent-color:var(--elec);height:5px;cursor:pointer}
.el-estim-right{background:rgba(255,255,255,.04);border-left:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;padding:40px 34px}
.el-estim-result{text-align:center;width:100%}
.el-estim-result-lab{text-transform:uppercase;letter-spacing:.12em;font-size:11.5px;font-weight:700;color:rgba(255,255,255,.55);margin-bottom:12px}
.el-estim-result-val{font-family:'Sora',sans-serif;font-weight:800;font-size:29px;color:#fff;line-height:1.1;margin-bottom:12px}
.el-estim-note{font-size:11.5px;color:rgba(255,255,255,.5);line-height:1.5;margin-bottom:22px}
@media(max-width:860px){.el-estim-card{grid-template-columns:1fr}.el-estim-left{padding:36px 26px 26px}.el-estim-right{border-left:none;border-top:1px solid rgba(255,255,255,.08);padding:30px 26px 36px}}

/* process */
.el-process{padding:90px 0;background:var(--creme)}
.el-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin:30px 0 40px;position:relative}
.el-steps::before{content:'';position:absolute;top:31px;left:9%;right:9%;height:2px;background:linear-gradient(90deg,var(--elec-mist),var(--elec) 50%,var(--elec-mist));z-index:0}
.el-step{position:relative;padding-top:8px}
.el-step-num{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-family:'Sora',sans-serif;font-weight:800;font-size:18px;color:#1A1206;background:linear-gradient(135deg,var(--elec),#F4C948);box-shadow:0 8px 22px var(--elec-mist);margin-bottom:16px;position:relative;z-index:2}
.el-step h3{font-family:'Sora',sans-serif;font-weight:700;font-size:16px;color:var(--bleu-nuit);margin:0 0 7px}
.el-step p{color:var(--gris-texte);font-size:13.5px;line-height:1.5;margin:0}
@media(max-width:860px){.el-steps{grid-template-columns:1fr;gap:0;margin-bottom:30px}.el-steps::before{top:0;bottom:0;left:22px;right:auto;width:2px;height:auto;background:linear-gradient(180deg,var(--elec-mist),var(--elec),var(--elec-mist))}.el-step{display:grid;grid-template-columns:46px 1fr;gap:18px;padding:0 0 30px}.el-step-num{margin-bottom:0}.el-step-tx{padding-top:6px}}

/* reviews */
.el-reviews{padding:90px 0;background:var(--blanc)}
.el-rev-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:16px}
.el-rev-card{background:var(--creme);border:1px solid var(--gris-bord);border-radius:20px;padding:28px 28px 24px;box-shadow:var(--shadow-soft)}
.el-rev-stars{color:#F4B400;font-size:15px;letter-spacing:2px;margin-bottom:13px}
.el-rev-text{color:var(--texte);font-size:15px;line-height:1.65;margin:0 0 18px}
.el-rev-foot{display:flex;align-items:center;gap:11px}
.el-rev-ava{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--elec),#F4C948);display:grid;place-items:center;font-family:'Sora',sans-serif;font-weight:800;color:#1A1206;font-size:16px;flex:0 0 auto}
.el-rev-name{font-family:'Sora',sans-serif;font-weight:700;font-size:14.5px;color:var(--bleu-nuit)}
.el-rev-src{font-size:12px;color:var(--gris-texte)}
@media(max-width:760px){.el-rev-grid{grid-template-columns:1fr}}

/* articles */
.el-articles{padding:18px 0 96px;background:var(--blanc)}
.el-art-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:16px}
.el-art-card{display:block;border-radius:20px;overflow:hidden;border:1px solid var(--gris-bord);background:var(--blanc);text-decoration:none;box-shadow:var(--shadow-soft);transition:transform .4s ease,box-shadow .4s ease}
.el-art-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-medium)}
.el-art-img{height:186px;background-size:cover;background-position:center}
.el-art-body{padding:22px 24px 24px}
.el-art-cat{display:inline-block;background:var(--elec-mist);color:var(--elec-d);font-weight:700;font-size:11.5px;padding:4px 11px;border-radius:100px;margin-bottom:11px}
.el-art-body h3{font-family:'Sora',sans-serif;font-weight:700;font-size:18px;color:var(--bleu-nuit);line-height:1.3;margin:0 0 9px}
.el-art-body p{color:var(--gris-texte);font-size:14px;line-height:1.55;margin:0 0 14px}
.el-art-link{font-family:'Sora',sans-serif;font-weight:700;font-size:14px;color:var(--elec-d)}
@media(max-width:680px){.el-art-grid{grid-template-columns:1fr}}


/* ============ MAJ ÉLECTRICITÉ v2 ============ */
/* 1) Titre du hero dans un encart jaune qui déborde sur la photo */
.el-title-box{display:block;width:calc(100% + 84px);background:linear-gradient(128deg,#F8D15A 0%,#E7A41C 100%);color:#1A1206;border-radius:20px;padding:14px 26px 18px;margin:8px 0 24px;position:relative;z-index:6;box-shadow:0 26px 58px rgba(214,150,20,.30)}
.el-title-box .hero-headline{margin:0}
.el-title-box .hh-lead,.el-title-box .hh-en,.el-title-box .hh-elec{color:#1A1206}
.el-title-box .hh-elec::after{display:none}
@media (max-width:1100px){ .el-title-box{width:auto;box-shadow:0 16px 36px rgba(214,150,20,.26);padding:14px 22px 16px;margin:6px 0 22px} }

/* 2) Services : 4 cartes sur une seule ligne */
.el-serv-grid{grid-template-columns:repeat(4,1fr);gap:18px}
.el-serv-img{height:148px}
.el-serv-body{padding:24px 20px 22px}
.el-serv-ico{width:48px;height:48px;font-size:21px;top:-24px;right:18px;border-radius:14px}
.el-serv-body h3{font-size:18px;margin-bottom:9px}
.el-serv-body p{font-size:13.5px;line-height:1.55;margin-bottom:16px}
.el-serv-link{font-size:13.5px}
@media (max-width:1080px){ .el-serv-grid{grid-template-columns:repeat(2,1fr);gap:22px} .el-serv-img{height:170px} }
@media (max-width:600px){ .el-serv-grid{grid-template-columns:1fr} }

/* 3) Petite section qualifications */
.el-qualif{padding:64px 0;background:var(--creme)}
.el-qualif-card{display:grid;grid-template-columns:1.35fr .65fr;gap:34px;align-items:center;background:var(--blanc);border:1px solid var(--gris-bord);border-radius:24px;padding:38px 42px;box-shadow:var(--shadow-soft)}
.el-qualif-txt .section-eyebrow{margin-bottom:8px}
.el-qualif-txt h2{font-family:'Sora',sans-serif;font-weight:800;font-size:27px;color:var(--bleu-nuit);margin:0 0 12px;line-height:1.15}
.el-qualif-txt p{color:var(--gris-texte);font-size:15px;line-height:1.6;margin:0 0 22px;max-width:600px}
.el-qualif-badges{display:flex;flex-direction:column;gap:13px}
.el-qb{display:flex;align-items:center;gap:13px;font-family:'Sora',sans-serif;font-weight:700;font-size:14.5px;color:var(--bleu-nuit)}
.el-qb-em{width:44px;height:44px;border-radius:13px;display:grid;place-items:center;font-size:21px;color:#fff;box-shadow:var(--shadow-soft);flex:0 0 auto}
@media (max-width:760px){ .el-qualif-card{grid-template-columns:1fr;gap:24px;padding:30px 26px} .el-qualif-badges{flex-direction:row;flex-wrap:wrap;gap:16px} .el-qualif-txt h2{font-size:23px} }

/* 4) Réalisations : hauteurs nettement plus contrastées */
.realz-grid .realz-card:nth-child(1){height:248px}
.realz-grid .realz-card:nth-child(2){height:430px}
.realz-grid .realz-card:nth-child(3){height:300px}
.realz-grid .realz-card:nth-child(4){height:236px}
.realz-grid .realz-card:nth-child(5){height:410px}
.realz-grid .realz-card:nth-child(6){height:272px}
.realz-grid .realz-card:nth-child(7){height:356px}
.realz-grid .realz-card:nth-child(8){height:452px}
.realz-grid{column-gap:22px}
.realz-card{margin:0 0 22px !important;border-radius:24px}

/* 5) Avis Google : version compacte (moins visible) */
.el-reviews{padding:60px 0}
.el-reviews h2{font-size:clamp(24px,3vw,32px)}
.el-rev-grid{grid-template-columns:repeat(4,1fr);gap:14px;margin-top:8px}
.el-rev-card{padding:20px 20px 18px;border-radius:16px}
.el-rev-stars{font-size:12.5px;margin-bottom:9px;letter-spacing:1px}
.el-rev-text{font-size:13px;line-height:1.55;margin:0 0 14px;display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;overflow:hidden}
.el-rev-foot{gap:9px}
.el-rev-ava{width:34px;height:34px;font-size:14px}
.el-rev-name{font-size:13px}
.el-rev-src{font-size:11px}
@media (max-width:980px){ .el-rev-grid{grid-template-columns:1fr 1fr} }
@media (max-width:560px){ .el-rev-grid{grid-template-columns:1fr} .el-rev-text{-webkit-line-clamp:4} }

/* 6) Articles : section développée (3 cartes + méta) */
.el-articles{padding:18px 0 92px}
.el-art-grid{grid-template-columns:repeat(3,1fr);gap:22px}
.el-art-img{height:172px}
.el-art-meta{display:flex;gap:14px;font-size:12px;color:var(--gris-texte);font-weight:600;margin:0 0 14px}
.el-art-body h3{font-size:17.5px}
@media (max-width:900px){ .el-art-grid{grid-template-columns:1fr 1fr} }
@media (max-width:600px){ .el-art-grid{grid-template-columns:1fr} }


/* ============ MAJ ÉLECTRICITÉ v3 ============ */
/* Hero : on resserre fortement avec la section services (presque pas de blanc) */
.hero,.hero-grid,.hero-right{min-height:auto}
.hero-text{padding-bottom:34px}
.hero-photo{bottom:26px}
.el-services{padding-top:14px}

/* Services : cartes empilables sur mobile + navigation par flèches */
.el-serv-nav{display:none;align-items:center;justify-content:center;gap:20px;margin-top:24px}
.el-serv-nav .esn-btn{width:48px;height:48px;border-radius:50%;border:1px solid var(--gris-bord);background:var(--blanc);color:var(--bleu-nuit);font-size:22px;line-height:1;cursor:pointer;box-shadow:var(--shadow-soft);display:grid;place-items:center;transition:all .25s ease}
.el-serv-nav .esn-btn:hover{background:var(--elec);border-color:var(--elec);color:#1A1206}
.el-serv-nav .esn-btn:active{transform:scale(.94)}
.el-serv-nav .esn-ind{font-family:'Sora',sans-serif;font-weight:700;font-size:14px;color:var(--gris-texte);min-width:52px;text-align:center}
.el-serv-nav .esn-ind b{color:var(--bleu-nuit);font-size:17px}
@media (max-width:700px){
  .el-serv-grid{position:relative;display:block;height:474px;margin-top:26px}
  .el-serv-card{position:absolute;top:0;left:0;right:0;width:100%;height:418px;transition:transform .5s cubic-bezier(.22,1,.36,1),opacity .45s ease;will-change:transform}
  .el-serv-img{height:182px}
  .el-serv-body{padding:24px 24px 22px}
  .el-serv-body p{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
  .el-serv-nav{display:flex}
}


/* =================================================================
   OVERRIDES ÉLECTRICITÉ — ajustements (insérés en dernier)
   ================================================================= */

/* (2) Dégradé blanc -> crème pour masquer la séparation sous le hero */
.hero{background:linear-gradient(180deg,#FFFFFF 0%,#FFFFFF 58%,var(--creme) 100%)}

/* (4) Couleur dominante = jaune/or du logo (au lieu de bleu + orange) */
:root{
  --grad-orange-flow:linear-gradient(110deg,#A87107 0%,#C8890C 27%,#E0A21A 50%,#C8890C 73%,#A87107 100%);
  --grad-cool-flow:linear-gradient(110deg,#B47C06 0%,#D49414 27%,#E8B84B 50%,#D49414 73%,#B47C06 100%);
  --grad-premium:linear-gradient(135deg,#E0A21A 0%,#C0860A 52%,#9C6C00 100%);
}
.section-eyebrow{color:var(--elec-d)}
.hero-eyebrow{color:var(--elec-d);border-color:color-mix(in srgb,var(--elec) 34%,transparent)}
.hero-eyebrow::before{background:var(--elec)}
.hero-stat-num{color:var(--elec-d)}
.hero-secondary .hs-accent{color:var(--elec-d)}
.hero-secondary .hs-accent::after{background:linear-gradient(120deg,rgba(224,162,26,.34),rgba(180,124,6,.16))}
.btn-primary{box-shadow:0 8px 24px rgba(180,124,6,.32)}
.btn-secondary{border-color:var(--elec)}
.btn-secondary:hover{background:var(--elec-soft)}
.groupe-badge::before,.brand-arrow{color:var(--elec)}
/* titres sur fond sombre (section réalisations) : or vif lisible */
.real h2 .hl-warm{color:#F4C430;-webkit-text-fill-color:#F4C430}
.real h2 .hl-cool{color:#F4C430;-webkit-text-fill-color:#F4C430}
/* flèches de pile + points de deck en or */
.stack-arrow{color:var(--elec) !important}
.stack-arrow:active{background:var(--elec-soft) !important}
.deck-dots button.active{background:var(--elec)}
/* soulignés .hl en or (au lieu d'orange) */
.hl::after{background:linear-gradient(120deg,rgba(224,162,26,.5),rgba(180,124,6,.42))}
.hero .hl::after{background:linear-gradient(120deg,rgba(224,162,26,.55),rgba(180,124,6,.45))}
.hl-num{background:linear-gradient(transparent 62%,rgba(224,162,26,.4) 62%)}

/* (8) Hero : image adaptée à la largeur sur tablette, masquée sur mobile */
@media (max-width:1100px) and (min-width:601px){
  .hero-right{display:block !important;width:100%;height:auto;overflow:visible;min-height:0 !important}
  .hero-photo{display:block !important;position:relative !important;top:auto !important;right:auto !important;left:auto !important;bottom:auto !important;
    width:100% !important;height:clamp(230px,40vw,360px) !important;min-height:0 !important;border-radius:24px !important;margin-top:8px}
  .hero-google{top:18px !important;right:18px !important}
}
@media (max-width:600px){
  .hero-right{display:none !important}
  .hero-photo{display:none !important}
}

/* (5/6) Piles de cartes type "Uno" (services + réalisations) sur mobile */
@media (min-width:769px){ .stack-nav,.swipe-hint{display:none !important} }
@media (max-width:768px){
  .swipe-hint{display:flex}
  .el-serv-nav{display:none !important}
  .deck-dots{display:none !important}

  /* conteneurs en pile */
  .el-serv-grid,.realz-grid{display:block !important;position:relative !important;overflow:visible !important;height:auto;margin:8px 0 18px}

  /* cartes empilées (centrées, 86% de large) */
  .el-serv-grid > .el-serv-card{position:absolute;top:0;left:50%;width:86% !important;height:430px !important}
  .realz-grid > .realz-card{position:absolute;top:0;left:50%;width:86% !important;height:360px !important;
    flex:none !important;scroll-snap-align:none !important;margin:0 !important;break-inside:auto;opacity:1}

  /* la carte du dessus reste cliquable, le clamp texte services conservé */
  .el-serv-grid > .el-serv-card .el-serv-body p{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
}


/* =================================================================
   OVERRIDES ÉLECTRICITÉ v2 — séparation, titre, burger, avis
   ================================================================= */

/* (séparation) Dégradé très progressif + fondu du bas de la photo hero */
.hero{background:#FFFFFF}
/* Image hero : bords nets conservés. Seul le FOND de la section se dégrade (partie basse). */

/* (titre) Effet "or" raffiné sur le mot pivot du hero : verre doré + reflet animé */
/* Mot Électricité : style normal (pastel) comme les autres catégories, sans effet doré */
.hero .word-rotate .wr-word.m-elec{background:#F7F1DC}
.hero .word-rotate .wr-word.m-elec::after{display:none;content:none}

/* (burger) supprimer le libellé MENU, bouton carré comme la page PAC */
.nav-burger{width:46px;gap:0;padding:0}
.burger-txt{display:none !important}

/* (avis v2) présentation premium */
.revx-section{padding:92px 0;background:var(--blanc)}
.revx-layout{display:grid;grid-template-columns:312px 1fr;gap:26px;align-items:start;margin-top:36px}
.revx-summary{position:sticky;top:104px;background:linear-gradient(165deg,#FFFFFF 0%,var(--elec-soft) 100%);
  border:1px solid color-mix(in srgb,var(--elec) 26%,var(--gris-bord));border-radius:26px;padding:34px 28px;text-align:center;
  box-shadow:0 18px 50px rgba(180,124,6,.12)}
.revx-glogo{display:block;width:46px;height:46px;margin:0 auto 14px}
.revx-glogo svg{width:100%;height:100%}
.revx-note{font-family:'Sora',sans-serif;font-weight:800;font-size:66px;line-height:1;color:var(--bleu-nuit);letter-spacing:-.02em}
.revx-note span{font-size:24px;color:var(--gris-texte);font-weight:700}
.revx-stars{color:#F5B301;font-size:22px;letter-spacing:3px;margin:8px 0 6px}
.revx-sublabel{font-family:'Sora',sans-serif;font-weight:700;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--elec-d)}
.revx-blurb{font-size:14px;color:var(--gris-texte);line-height:1.6;margin:16px 0 22px}
.revx-cta{display:inline-flex;align-items:center;gap:9px;background:var(--grad-premium);color:#fff;font-family:'Sora',sans-serif;
  font-weight:700;font-size:14.5px;padding:13px 22px;border-radius:13px;box-shadow:0 10px 26px rgba(180,124,6,.3);transition:transform .25s ease,box-shadow .25s ease}
.revx-cta:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(180,124,6,.42)}
.revx-cta svg{width:16px;height:16px;flex-shrink:0}
.revx-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.revx-card{position:relative;background:#fff;border:1px solid var(--gris-bord);border-radius:22px;padding:30px 26px 24px;
  box-shadow:var(--shadow-soft);overflow:hidden;transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s ease,border-color .3s ease}
.revx-card:hover{transform:translateY(-6px);box-shadow:0 22px 50px rgba(26,20,16,.12);border-color:color-mix(in srgb,var(--elec) 42%,transparent)}
.revx-card::before{content:'';position:absolute;left:0;top:0;width:4px;height:100%;background:var(--grad-premium);opacity:0;transition:opacity .3s ease}
.revx-card:hover::before{opacity:1}
.revx-quote{position:absolute;top:8px;right:22px;font-family:Georgia,'Times New Roman',serif;font-size:84px;line-height:1;color:var(--elec);opacity:.15;pointer-events:none}
.revx-rs{color:#F5B301;font-size:15px;letter-spacing:2px;margin-bottom:12px}
.revx-text{color:var(--texte);font-size:15px;line-height:1.65;margin:0 0 20px;position:relative;z-index:1}
.revx-foot{display:flex;align-items:center;gap:13px}
.revx-ava{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-family:'Sora',sans-serif;font-weight:800;
  font-size:18px;color:#3A2A05;background:linear-gradient(135deg,#FCE8A8,#E0A21A);flex-shrink:0}
.revx-id{display:flex;flex-direction:column;gap:2px;min-width:0}
.revx-name{font-family:'Sora',sans-serif;font-weight:700;font-size:15px;color:var(--bleu-nuit)}
.revx-src{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--gris-texte)}
.revx-src svg{width:14px;height:14px}
@media (max-width:920px){
  .revx-layout{grid-template-columns:1fr}
  .revx-summary{position:static;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:4px 20px;text-align:center}
  .revx-glogo,.revx-note,.revx-stars,.revx-sublabel{margin:0}
  .revx-note{font-size:52px}
  .revx-blurb{flex:1 1 100%;margin:8px 0 16px}
  .revx-cta{flex:1 1 100%;justify-content:center}
}
@media (max-width:620px){ .revx-grid{grid-template-columns:1fr} }


/* ============ OVERRIDES ÉLECTRICITÉ v3 ============ */

/* texte hero un peu plus à droite (desktop) */
@media (min-width:1101px){ .hero-text{padding-left:clamp(44px,5.2vw,92px)} }

/* menu : stabiliser le rendu (évite le scintillement du backdrop-filter) */
header{will-change:padding}
header,.nav-bar{-webkit-backface-visibility:hidden;backface-visibility:hidden}
.nav-bar{transform:translateZ(0)}

/* (8) Hero tablette : photo À DROITE du texte (jamais en dessous), masquée sur mobile */
@media (min-width:768px) and (max-width:1100px){
  .hero,.hero-grid{min-height:0}
  .hero-grid{grid-template-columns:0.92fr 1.08fr !important;align-items:center;gap:22px}
  .hero-text{padding-top:120px}
  .hero-right{display:block !important;min-height:0 !important;height:auto;overflow:visible}
  .hero-photo{display:block !important;position:relative !important;top:auto !important;right:auto !important;left:auto !important;bottom:auto !important;
    width:100% !important;height:clamp(360px,54vh,540px) !important;min-height:0 !important;border-radius:24px !important;margin:0}
  .hero-google{top:18px !important;right:18px !important}
}
@media (max-width:767px){
  .hero-grid{grid-template-columns:1fr !important}
  .hero-right,.hero-photo{display:none !important}
}

/* (inversion des fonds) Conseils -> sombre, Chantiers -> clair */
.el-articles{background:#0E0F14}
.el-articles .section-eyebrow{color:var(--elec)}
.el-articles h2{color:#fff}
.el-articles h2 .hl-warm,.el-articles h2 .hl-cool{color:#F4C430;-webkit-text-fill-color:#F4C430}
.el-articles .section-subtitle{color:rgba(255,255,255,.74)}
.el-articles .el-art-card{background:#fff;border-color:var(--gris-bord)}
.el-articles .el-art-body h3{color:var(--bleu-nuit)}
.el-articles .el-art-body p{color:var(--gris-texte)}
.el-articles .el-art-cat{background:var(--elec-mist);color:var(--elec-d)}

.real{background:var(--creme)}
.real .section-eyebrow{color:var(--elec-d)}
.real h2{color:var(--bleu-nuit)}
.real h2 .hl-warm,.real h2 .hl-cool{color:var(--elec-d);-webkit-text-fill-color:var(--elec-d)}
.real .section-subtitle{color:var(--gris-texte)}
.real .btn-secondary{color:var(--bleu-nuit);border-color:var(--elec);background:transparent}
.real .btn-secondary:hover{background:var(--elec-soft);border-color:var(--elec);color:var(--bleu-nuit)}
.real .realz-card{box-shadow:0 16px 40px rgba(26,20,16,.16)}


/* ====== Titre hero : toujours 2 lignes, jamais 3 ====== */
.hero-headline .hh-lead{white-space:nowrap}
.hero-headline .hh-line2{white-space:nowrap !important}
.hero-headline .word-rotate{max-width:100%}
/* plage tablette (photo à droite) : on réduit la taille pour que "en Électricité" tienne sur une ligne */
@media (min-width:768px) and (max-width:1100px){
  .hero-headline{font-size:clamp(30px,4.2vw,48px) !important;line-height:1.1}
}


/* ================= PAGE À PROPOS — marque ROY HABITAT ================= */
:root{ --ap:#E85D2F; --ap-d:#C44A1F; --ap-soft:#FDEDE6; }
.ap-eyebrow{display:inline-block;font-family:'Sora',sans-serif;font-weight:700;font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ap-d);background:var(--ap-soft);border:1px solid #FBE0D6;padding:7px 15px;border-radius:100px;margin-bottom:20px}
.ap-hl{color:var(--ap)}
.ap-link{display:inline-flex;align-items:center;gap:7px;font-family:'Sora',sans-serif;font-weight:700;font-size:15px;color:var(--ap-d);text-decoration:none}
.ap-link svg{width:17px;height:17px}
.ap-btn-primary{display:inline-flex;align-items:center;justify-content:center;font-family:'Sora',sans-serif;font-weight:700;font-size:15.5px;color:#fff;background:linear-gradient(135deg,#E85D2F 0%,#FF6B35 55%,#C44A1F 100%);border:none;border-radius:14px;padding:14px 28px;text-decoration:none;box-shadow:0 12px 30px rgba(196,74,31,.28);transition:transform .25s,box-shadow .25s}
.ap-btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 38px rgba(196,74,31,.4)}
.ap-btn-ghost{display:inline-flex;align-items:center;font-family:'Sora',sans-serif;font-weight:700;font-size:15.5px;color:var(--bleu-nuit);background:#fff;border:1px solid var(--gris-bord);border-radius:14px;padding:14px 26px;text-decoration:none;transition:border-color .2s,transform .2s}
.ap-btn-ghost:hover{border-color:#FBD3C3;transform:translateY(-2px)}

/* HERO */
.ap-hero{padding:150px 0 70px;background:radial-gradient(120% 80% at 88% 0%,#FDEDE6 0%,rgba(253,237,230,0) 55%),#FFFFFF}
.ap-hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
.ap-title{font-family:'Sora',sans-serif;font-weight:800;font-size:clamp(36px,5vw,60px);line-height:1.04;letter-spacing:-.025em;color:var(--bleu-nuit);margin:0 0 20px}
.ap-lead{font-size:clamp(16px,1.8vw,18.5px);line-height:1.6;color:var(--gris-texte);max-width:560px;margin:0 0 28px}
.ap-hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.ap-hero-media{position:relative;border-radius:26px;overflow:hidden;box-shadow:0 30px 70px rgba(26,20,16,.20);aspect-ratio:4/3}
.ap-hero-media img{width:100%;height:100%;object-fit:cover;display:block}
.ap-hero-badge{position:absolute;left:18px;bottom:18px;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-radius:14px;padding:12px 18px;display:flex;flex-direction:column;font-family:'Manrope',sans-serif;font-size:12.5px;color:var(--gris-texte);box-shadow:0 8px 20px rgba(0,0,0,.12)}
.ap-hero-badge strong{font-family:'Sora',sans-serif;font-weight:800;font-size:17px;color:var(--ap);line-height:1.1}
.ap-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;margin-top:50px;background:#fff;border:1px solid var(--gris-bord);border-radius:20px;padding:26px 20px;box-shadow:0 18px 44px rgba(26,20,16,.07)}
.ap-stat{text-align:center;border-right:1px solid var(--gris-bord)}
.ap-stat:last-child{border-right:none}
.ap-stat b{display:block;font-family:'Sora',sans-serif;font-weight:800;font-size:clamp(26px,3vw,36px);color:var(--bleu-nuit);line-height:1}
.ap-stat b i{font-style:normal;font-size:.5em;color:var(--ap);font-weight:700}
.ap-stat span{display:block;margin-top:7px;font-size:12.5px;color:var(--gris-texte);line-height:1.3}

/* HISTOIRE / TIMELINE */
.ap-story{padding:80px 0;background:var(--creme)}
.ap-timeline{position:relative;max-width:840px;margin:48px auto 0}
.ap-timeline::before{content:"";position:absolute;top:10px;bottom:30px;left:96px;width:2px;background:linear-gradient(var(--ap),rgba(232,93,47,.12))}
.ap-tl-item{position:relative;display:grid;grid-template-columns:80px 1fr;column-gap:42px;padding-bottom:26px}
.ap-tl-year{text-align:right;font-family:'Sora',sans-serif;font-weight:800;font-size:19px;color:var(--ap);padding-top:14px}
.ap-tl-dot{position:absolute;left:90px;top:19px;width:15px;height:15px;border-radius:50%;background:var(--ap);border:3px solid var(--creme);box-shadow:0 0 0 2px rgba(232,93,47,.25)}
.ap-tl-card{background:#fff;border:1px solid var(--gris-bord);border-radius:16px;padding:18px 24px;box-shadow:0 8px 22px rgba(26,20,16,.05)}
.ap-tl-card h3{font-family:'Sora',sans-serif;font-weight:700;font-size:17px;color:var(--bleu-nuit);margin:0 0 6px}
.ap-tl-card p{font-size:14.5px;line-height:1.6;color:var(--gris-texte);margin:0}
.ap-tl-card strong{color:var(--ap-d)}
.ap-quote{max-width:760px;margin:40px auto 0;text-align:center;font-family:'Sora',sans-serif;font-weight:600;font-size:clamp(18px,2.3vw,23px);line-height:1.5;color:var(--bleu-nuit)}
.ap-quote cite{display:block;margin-top:16px;font-family:'Manrope',sans-serif;font-style:normal;font-weight:700;font-size:14px;color:var(--ap-d)}

/* MARQUE (sombre) */
.ap-brand{padding:80px 0;background:linear-gradient(165deg,#181818 0%,#0C0C0C 100%);color:#fff}
.ap-brand h2{color:#fff}
.ap-umbrella{max-width:860px;margin:46px auto 0;display:flex;flex-direction:column;align-items:center}
.ap-umb-top{display:flex;flex-direction:column;align-items:center;gap:8px;background:#fff;border-radius:18px;padding:20px 34px;box-shadow:0 16px 40px rgba(0,0,0,.4)}
.ap-umb-logo img{height:42px;width:auto;display:block}
.ap-umb-top span{font-family:'Sora',sans-serif;font-weight:700;font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ap-d)}
.ap-umb-line{width:2px;height:40px;background:linear-gradient(rgba(255,255,255,.55),rgba(255,255,255,.12))}
.ap-umb-row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;width:100%;position:relative}
.ap-umb-node{position:relative;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-top:3px solid var(--c);border-radius:14px;padding:20px;text-align:center}
.ap-umb-node::before{content:"";position:absolute;top:-22px;left:50%;width:2px;height:22px;background:rgba(255,255,255,.22)}
.ap-umb-node strong{display:block;font-family:'Sora',sans-serif;font-weight:800;font-size:16px;color:var(--c);margin-bottom:6px}
.ap-umb-node{font-size:13px;color:rgba(255,255,255,.7);line-height:1.45}

/* ENTITÉS */
.ap-entities{padding:80px 0;background:var(--blanc)}
.ap-ent-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:14px}
.ap-ent{background:var(--eg,#fff);border:1px solid var(--gris-bord);border-radius:22px;padding:30px 28px;box-shadow:0 10px 30px rgba(26,20,16,.06);position:relative;overflow:hidden;transition:transform .3s,box-shadow .3s}
.ap-ent::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--ec)}
.ap-ent:hover{transform:translateY(-6px);box-shadow:0 20px 46px rgba(26,20,16,.12)}
.ap-ent-logo{height:46px;display:flex;align-items:center;margin-bottom:16px}
.ap-ent-logo img{max-height:46px;width:auto;max-width:180px;object-fit:contain}
.ap-ent-logo svg{height:42px;width:auto}
.ap-ent p{font-size:14.5px;line-height:1.6;color:var(--gris-texte);margin:0 0 16px}
.ap-ent-tags{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:18px}
.ap-ent-tags span{font-family:'Manrope',sans-serif;font-weight:700;font-size:12px;color:var(--ec);background:rgba(0,0,0,.04);border:1px solid rgba(0,0,0,.06);border-radius:100px;padding:5px 11px}
.ap-ent-link{font-family:'Sora',sans-serif;font-weight:700;font-size:14.5px;color:var(--ec);text-decoration:none}

/* VALEURS */
.ap-values{padding:80px 0;background:var(--creme)}
.ap-val-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:14px}
.ap-val{background:#fff;border:1px solid var(--gris-bord);border-radius:20px;padding:32px 28px;box-shadow:0 8px 24px rgba(26,20,16,.05);transition:transform .3s}
.ap-val:hover{transform:translateY(-5px)}
.ap-val-ic{width:54px;height:54px;border-radius:15px;background:var(--ap-soft);color:var(--ap-d);display:grid;place-items:center;margin-bottom:18px}
.ap-val-ic svg{width:26px;height:26px}
.ap-val h3{font-family:'Sora',sans-serif;font-weight:700;font-size:19px;color:var(--bleu-nuit);margin:0 0 10px}
.ap-val p{font-size:14.5px;line-height:1.6;color:var(--gris-texte);margin:0}

/* ÉQUIPE */
.ap-team{padding:80px 0;background:var(--blanc)}
.ap-team-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:50px;align-items:center}
.ap-team-media{position:relative;border-radius:24px;overflow:hidden;box-shadow:0 24px 56px rgba(26,20,16,.16);aspect-ratio:4/3}
.ap-team-media img{width:100%;height:100%;object-fit:cover;display:block}
.ap-team-tag{position:absolute;left:16px;bottom:16px;display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.94);backdrop-filter:blur(8px);border-radius:100px;padding:9px 16px;font-family:'Sora',sans-serif;font-weight:700;font-size:14px;color:var(--bleu-nuit);box-shadow:0 8px 20px rgba(0,0,0,.12)}
.ap-team-ic{width:26px;height:26px;border-radius:8px;background:var(--ap-soft);color:var(--ap-d);display:grid;place-items:center}
.ap-team-ic svg{width:16px;height:16px}
.ap-team-text h2{margin:0 0 18px}
.ap-team-text p{font-size:15.5px;line-height:1.65;color:var(--gris-texte);margin:0 0 14px}
.ap-team-text strong{color:var(--bleu-nuit)}
.ap-team-list{list-style:none;margin:18px 0 0;padding:0;display:grid;gap:10px}
.ap-team-list li{position:relative;padding-left:28px;font-size:14.5px;color:var(--bleu-nuit);font-weight:600}
.ap-team-list li::before{content:"";position:absolute;left:0;top:3px;width:18px;height:18px;border-radius:50%;background:var(--ap-soft);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23C44A1F' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}

/* ANCRAGE LOCAL */
.ap-local{padding:80px 0;background:var(--creme)}
.ap-local-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.ap-local-text h2{margin:0 0 18px}
.ap-local-text p{font-size:15.5px;line-height:1.65;color:var(--gris-texte);margin:0 0 14px}
.ap-local-text strong{color:var(--bleu-nuit)}
.ap-local-media{position:relative;border-radius:24px;overflow:hidden;box-shadow:0 24px 56px rgba(26,20,16,.16);aspect-ratio:16/11}
.ap-local-media img{width:100%;height:100%;object-fit:cover;display:block}
.ap-local-cap{position:absolute;right:16px;top:16px;background:rgba(20,16,12,.72);backdrop-filter:blur(6px);color:#fff;border-radius:100px;padding:7px 15px;font-family:'Sora',sans-serif;font-weight:700;font-size:12.5px}

/* PRÉSENCE EN LIGNE */
.ap-online{padding:80px 0;background:var(--blanc)}
.ap-online-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:14px}
.ap-on-card{background:#fff;border:1px solid var(--gris-bord);border-radius:20px;padding:30px 28px;box-shadow:0 8px 24px rgba(26,20,16,.05)}
.ap-on-ic{width:52px;height:52px;border-radius:14px;background:color-mix(in srgb,var(--c) 14%,#fff);color:var(--c);display:grid;place-items:center;margin-bottom:18px}
.ap-on-ic svg{width:26px;height:26px}
.ap-on-card h3{font-family:'Sora',sans-serif;font-weight:700;font-size:18px;color:var(--bleu-nuit);margin:0 0 10px}
.ap-on-card p{font-size:14.5px;line-height:1.6;color:var(--gris-texte);margin:0 0 16px}
.ap-soc{display:flex;gap:10px}
.ap-soc a{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;text-decoration:none;box-shadow:0 4px 12px rgba(0,0,0,.12);transition:transform .2s}
.ap-soc a svg{width:21px;height:21px;display:block}
.ap-soc a:hover{transform:translateY(-3px)}
.ap-soc a:nth-child(1){background:#1877F2}
.ap-soc a:nth-child(2){background:radial-gradient(circle at 30% 107%,#fdf497 0%,#fdf497 5%,#fd5949 45%,#d6249f 60%,#285AEB 90%)}
.ap-soc a:nth-child(3){background:#FF0000}
.ap-soc a:nth-child(4){background:#0A66C2}

/* AVIS */
.ap-reviews{padding:80px 0;background:var(--creme)}
.ap-rev-card{display:grid;grid-template-columns:.7fr 1.3fr;gap:44px;align-items:center;background:#fff;border:1px solid var(--gris-bord);border-radius:26px;padding:44px;box-shadow:0 18px 44px rgba(26,20,16,.07)}
.ap-rev-score{text-align:center;border-right:1px solid var(--gris-bord);padding-right:24px}
.ap-rev-g{display:inline-grid;place-items:center;width:30px;height:30px;border-radius:50%;background:conic-gradient(from -45deg,#EA4335 0 25%,#FBBC05 0 50%,#34A853 0 75%,#4285F4 0);color:#fff;font-weight:800;font-size:15px;font-family:'Sora',sans-serif;margin-bottom:10px}
.ap-rev-score b{display:block;font-family:'Sora',sans-serif;font-weight:800;font-size:52px;color:var(--bleu-nuit);line-height:1}
.ap-rev-score b i{font-style:normal;font-size:.42em;color:var(--gris-texte)}
.ap-rev-stars{display:flex;justify-content:center;gap:3px;margin:8px 0 6px}
.ap-rev-stars svg{width:18px;height:18px;color:#FFB400}
.ap-rev-sub{font-size:13px;color:var(--gris-texte)}
.ap-rev-text h2{margin:0 0 12px}
.ap-rev-text p{font-size:15px;line-height:1.65;color:var(--gris-texte);margin:0 0 20px}

/* CTA */
.ap-cta{padding:20px 0 90px;background:var(--blanc)}
.ap-cta-card{text-align:center;background:linear-gradient(135deg,#E85D2F 0%,#FF6B35 55%,#C44A1F 100%);border-radius:28px;padding:60px 30px;color:#fff;box-shadow:0 24px 60px rgba(196,74,31,.30)}
.ap-cta-card h2{color:#fff;margin:0 0 12px}
.ap-cta-card p{font-size:16px;line-height:1.6;color:rgba(255,255,255,.92);max-width:540px;margin:0 auto 26px}
.ap-cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.ap-btn-light{display:inline-flex;align-items:center;font-family:'Sora',sans-serif;font-weight:700;font-size:15.5px;color:var(--ap-d);background:#fff;border-radius:14px;padding:14px 28px;text-decoration:none;transition:transform .2s}
.ap-btn-light:hover{transform:translateY(-2px)}
.ap-btn-outline{display:inline-flex;align-items:center;font-family:'Sora',sans-serif;font-weight:700;font-size:15.5px;color:#fff;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.45);border-radius:14px;padding:14px 28px;text-decoration:none;transition:background .2s}
.ap-btn-outline:hover{background:rgba(255,255,255,.22)}

@media(max-width:980px){
  .ap-hero-grid,.ap-team-grid,.ap-local-grid,.ap-rev-card{grid-template-columns:1fr;gap:32px}
  .ap-rev-card{padding:32px}
  .ap-rev-score{border-right:none;border-bottom:1px solid var(--gris-bord);padding:0 0 24px}
  .ap-ent-grid,.ap-val-grid,.ap-online-grid,.ap-umb-row{grid-template-columns:1fr}
  .ap-umb-node::before{display:none}
  .ap-stats{grid-template-columns:repeat(2,1fr);gap:0}
  .ap-stat{border-right:none;border-bottom:1px solid var(--gris-bord);padding:16px 0}
  .ap-team-grid .ap-team-media{order:-1}
}
@media(max-width:560px){
  .ap-hero{padding-top:128px}
  .ap-timeline::before{left:66px}
  .ap-tl-item{grid-template-columns:56px 1fr;column-gap:28px}
  .ap-tl-dot{left:60px}
  .ap-tl-year{font-size:16px}
}


/* ===== À PROPOS v2 — ajustements ===== */
/* HERO : image plus grande à droite */
.ap-hero-grid{grid-template-columns:.92fr 1.18fr;gap:46px}
.ap-hero-media{aspect-ratio:auto;height:100%;min-height:440px}
@media(max-width:980px){.ap-hero-media{min-height:300px}}

/* TIMELINE alternée gauche/droite */
.ap-timeline{max-width:1060px}
.ap-timeline::before{left:50%;transform:translateX(-50%)}
.ap-tl-item{display:block;width:50%;grid-template-columns:none;column-gap:0;padding:0 0 30px}
.ap-tl-item:nth-child(odd){margin-left:0;padding-right:46px}
.ap-tl-item:nth-child(even){margin-left:50%;padding-left:46px}
.ap-tl-dot{top:24px}
.ap-tl-item:nth-child(odd) .ap-tl-dot{left:auto;right:-8px}
.ap-tl-item:nth-child(even) .ap-tl-dot{left:-8px}
.ap-tl-year{display:inline-block;text-align:left;font-family:'Sora',sans-serif;font-weight:800;font-size:13px;letter-spacing:.05em;color:#fff;background:linear-gradient(135deg,#E85D2F,#C44A1F);padding:4px 12px;border-radius:100px;margin-bottom:10px;padding-top:4px}
.ap-tl-card{padding:22px 24px}
@media(max-width:780px){
  .ap-timeline{max-width:560px}
  .ap-timeline::before{left:8px;transform:none}
  .ap-tl-item,.ap-tl-item:nth-child(odd),.ap-tl-item:nth-child(even){width:100%;margin-left:0;padding:0 0 22px 38px}
  .ap-tl-item .ap-tl-dot,.ap-tl-item:nth-child(odd) .ap-tl-dot,.ap-tl-item:nth-child(even) .ap-tl-dot{left:1px;right:auto}
}

/* MARQUE : titre 2 lignes + dégradé waouh */
.ap-brand .tc{max-width:none}
.ap-brand h2{font-size:clamp(30px,4.2vw,50px);line-height:1.08;max-width:none}
.ap-grad{background:linear-gradient(95deg,#FF8C42 0%,#FFC59B 26%,#E85D2F 52%,#FF6B35 78%,#FFA45C 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}

/* ORGANIGRAMME fusionné (cartes entités sur fond sombre) */
.ap-umb-row{grid-template-columns:repeat(4,1fr);gap:18px;align-items:stretch}
.ap-org-card{position:relative;display:flex;flex-direction:column;background:var(--eg,#fff);border:1px solid rgba(255,255,255,.1);border-top:3px solid var(--ec);border-radius:16px;padding:24px 22px;text-align:left;box-shadow:0 16px 40px rgba(0,0,0,.35)}
.ap-org-card::before{content:"";position:absolute;top:-22px;left:50%;width:2px;height:22px;background:rgba(255,255,255,.22)}
.ap-org-logo{height:40px;display:flex;align-items:center;gap:9px;margin-bottom:14px}
.ap-org-logo img{max-height:38px;width:auto;max-width:140px;object-fit:contain}
.ap-org-logo svg.lg{height:36px;width:auto}
.ap-org-mark{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:color-mix(in srgb,var(--ec) 16%,#fff);color:var(--ec);flex-shrink:0}
.ap-org-mark svg{width:21px;height:21px}
.ap-org-logo b{font-family:'Sora',sans-serif;font-weight:800;font-size:15px;color:var(--ec)}
.ap-org-card p{font-size:13.5px;line-height:1.55;color:#473f38;margin:0 0 14px}
.ap-org-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}
.ap-org-tags span{font-family:'Manrope',sans-serif;font-weight:700;font-size:11px;color:var(--ec);background:rgba(0,0,0,.05);border-radius:100px;padding:4px 9px}
@media(max-width:980px){.ap-umb-row{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.ap-umb-row{grid-template-columns:1fr}.ap-org-card::before{display:none}}

/* FAMILLE + ANCRAGE fusionnés */
.ap-famloc{padding:80px 0;background:var(--blanc)}
.ap-famloc-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center}
.ap-famloc-text h2{margin:0 0 18px}
.ap-famloc-text p{font-size:15.5px;line-height:1.65;color:var(--gris-texte);margin:0 0 14px}
.ap-famloc-text strong{color:var(--bleu-nuit)}
.ap-famloc-media{position:relative;border-radius:24px;overflow:hidden;box-shadow:0 24px 56px rgba(26,20,16,.16);aspect-ratio:3/4;max-height:560px}
.ap-famloc-media img{width:100%;height:100%;object-fit:cover;display:block}
.ap-famloc-badge{position:absolute;left:16px;bottom:16px;display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.94);backdrop-filter:blur(8px);border-radius:100px;padding:9px 16px;font-family:'Sora',sans-serif;font-weight:700;font-size:14px;color:var(--bleu-nuit);box-shadow:0 8px 20px rgba(0,0,0,.12)}
.ap-famloc-badge .ap-team-ic{width:24px;height:24px}
.ap-famloc-cap{position:absolute;right:16px;top:16px;background:rgba(20,16,12,.74);backdrop-filter:blur(6px);color:#fff;border-radius:100px;padding:7px 15px;font-family:'Sora',sans-serif;font-weight:700;font-size:12px}
@media(max-width:980px){.ap-famloc-grid{grid-template-columns:1fr;gap:32px}.ap-famloc-media{aspect-ratio:4/3;max-height:none;order:-1}}

/* BLOG vitrine */
.ap-blog{padding:80px 0;background:var(--creme)}
.ap-blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:14px}
.ap-blog-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--gris-bord);border-radius:20px;overflow:hidden;text-decoration:none;box-shadow:0 8px 24px rgba(26,20,16,.05);transition:transform .3s,box-shadow .3s}
.ap-blog-card:hover{transform:translateY(-6px);box-shadow:0 20px 46px rgba(26,20,16,.12)}
.ap-blog-img{position:relative;aspect-ratio:16/10;overflow:hidden}
.ap-blog-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s}
.ap-blog-card:hover .ap-blog-img img{transform:scale(1.05)}
.ap-blog-cat{position:absolute;left:12px;top:12px;background:rgba(255,255,255,.95);color:var(--ap-d);font-family:'Sora',sans-serif;font-weight:700;font-size:11px;letter-spacing:.03em;text-transform:uppercase;padding:5px 11px;border-radius:100px}
.ap-blog-body{padding:20px 22px 22px;display:flex;flex-direction:column;flex:1}
.ap-blog-body h3{font-family:'Sora',sans-serif;font-weight:700;font-size:16.5px;line-height:1.3;color:var(--bleu-nuit);margin:0 0 12px}
.ap-blog-read{margin-top:auto;font-family:'Sora',sans-serif;font-weight:700;font-size:14px;color:var(--ap-d)}
.ap-blog-foot{text-align:center;margin-top:36px}
.ap-blog-note{display:flex;justify-content:center;gap:26px;flex-wrap:wrap;margin:10px 0 26px;font-size:14px;color:var(--gris-texte)}
.ap-blog-note b{color:var(--bleu-nuit)}
@media(max-width:980px){.ap-blog-grid{grid-template-columns:1fr}}


/* ===== À PROPOS v3 ===== */
/* HERO : image plus grande, allongée, plus à droite ; masquée sur petit écran */
.ap-hero-grid{grid-template-columns:.78fr 1.36fr;gap:40px}
.ap-hero-media{min-height:560px;aspect-ratio:auto}
@media(min-width:1280px){.ap-hero-media{margin-right:-22px}}
@media(max-width:980px){
  .ap-hero-grid{grid-template-columns:1fr}
  .ap-hero-media{display:none}
  .ap-hero{padding:132px 0 54px}
}

/* DÉGRADÉ 4 couleurs du logo (vert, bleu, jaune, orange) + animation */
.ap-grad{background:linear-gradient(100deg,#3EA3DC 0%,#5FAE2E 30%,#ECC533 60%,#E85D2F 100%);background-size:220% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;animation:apShine 7s linear infinite}
@keyframes apShine{0%{background-position:0% center}100%{background-position:200% center}}

/* VALEURS : fonds dégradés (couleurs du logo) */
.ap-val{position:relative;overflow:hidden;border:1px solid var(--gris-bord)}
.ap-val::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--vc)}
.ap-val:nth-child(1){--vc:#E85D2F;background:linear-gradient(158deg,#FDEFE8,#FFFFFF 64%)}
.ap-val:nth-child(2){--vc:#3EA3DC;background:linear-gradient(158deg,#E7F2FB,#FFFFFF 64%)}
.ap-val:nth-child(3){--vc:#5C9E27;background:linear-gradient(158deg,#EDF6E3,#FFFFFF 64%)}
.ap-val:nth-child(1) .ap-val-ic{background:color-mix(in srgb,#E85D2F 14%,#fff);color:#C44A1F}
.ap-val:nth-child(2) .ap-val-ic{background:color-mix(in srgb,#3EA3DC 17%,#fff);color:#1E7BB0}
.ap-val:nth-child(3) .ap-val-ic{background:color-mix(in srgb,#5C9E27 17%,#fff);color:#4A8520}

/* carte avis Google intégrée dans la section marque (fond sombre) */
.ap-brand .ap-rev-card{margin-top:50px;text-align:left}

/* RÉSEAUX dans la section savoir-faire */
.ap-soc-head{text-align:center;margin:46px 0 18px;font-family:'Sora',sans-serif;font-weight:700;font-size:15.5px;color:var(--bleu-nuit)}
.ap-soc-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.ap-soc-card{display:flex;align-items:center;gap:13px;background:#fff;border:1px solid var(--gris-bord);border-radius:16px;padding:15px 17px;text-decoration:none;box-shadow:0 6px 18px rgba(26,20,16,.05);transition:transform .25s,box-shadow .25s}
.ap-soc-card:hover{transform:translateY(-4px);box-shadow:0 14px 32px rgba(26,20,16,.12)}
.ap-soc-ic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;flex-shrink:0;background:var(--sc)}
.ap-soc-ic svg{width:23px;height:23px;display:block}
.ap-soc-meta{display:flex;flex-direction:column;line-height:1.25;min-width:0}
.ap-soc-meta b{font-family:'Sora',sans-serif;font-weight:700;font-size:14px;color:var(--bleu-nuit)}
.ap-soc-meta i{font-style:normal;font-size:12px;color:var(--gris-texte);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media(max-width:980px){.ap-soc-row{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.ap-soc-row{grid-template-columns:1fr}}

/* carte avis blanche : texte foncé même dans la section sombre */
.ap-brand .ap-rev-card h2{color:var(--bleu-nuit)}
.ap-brand .ap-rev-card p{color:var(--gris-texte)}


/* ============ À PROPOS v4 ============ */
:root{--lg:linear-gradient(100deg,#3EA3DC 0%,#5FAE2E 32%,#ECC533 62%,#E85D2F 100%);--lgh:linear-gradient(90deg,#3EA3DC 0%,#5FAE2E 33%,#ECC533 64%,#E85D2F 100%)}
@keyframes apShine{0%{background-position:0% center}100%{background-position:200% center}}

/* (4) dégradé des couleurs du logo sur TOUS les accents */
.ap-hl,.ap-grad{background:var(--lg);background-size:220% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;animation:apShine 7s linear infinite}
.tc h2::after{background:var(--lgh)!important}
.ap-eyebrow{border:none;box-shadow:none;padding:0;font-size:13px;letter-spacing:.14em;margin-bottom:22px;background:none}
.ap-tl-year{background:var(--lgh)!important}
.ap-btn-primary{background:var(--lgh)!important}
.ap-stat b i{background:var(--lgh);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.ap-link,.ap-blog-read{background:var(--lgh);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}

/* (7) mobile : dernière promesse centrée sur toute la largeur */
@media(max-width:980px){.ap-stat:last-child{grid-column:1 / -1;border-bottom:none}}

/* (5) connecteur organigramme premium */
.ap-org-card::before{display:none!important}
.ap-umb-line{display:none}
.ap-umb-connect{position:relative;width:100%;height:54px}
.ap-umb-stem{position:absolute;top:0;left:50%;transform:translateX(-50%);width:2px;height:20px;background:rgba(255,255,255,.42);border-radius:2px}
.ap-umb-stem::before{content:"";position:absolute;top:-3px;left:50%;transform:translateX(-50%);width:8px;height:8px;border-radius:50%;background:#fff;box-shadow:0 0 0 4px rgba(255,255,255,.12)}
.ap-umb-bus{position:absolute;top:20px;left:12.5%;right:12.5%;height:2px;background:var(--lgh);border-radius:2px}
.ap-umb-drop{position:absolute;top:20px;width:2px;height:34px;transform:translateX(-50%);background:rgba(255,255,255,.34);border-radius:2px}
.ap-umb-drop::after{content:"";position:absolute;bottom:-4px;left:50%;transform:translateX(-50%);width:11px;height:11px;border-radius:50%;background:var(--dc);box-shadow:0 0 0 4px color-mix(in srgb,var(--dc) 30%,transparent)}
@media(max-width:980px){.ap-umb-connect{display:none}}

/* (6) icône ROY en ligne */
.ap-org-mark{border-radius:12px}

/* (8) timeline : dynamisme + images */
.ap-tl-card{overflow:hidden;padding:0;transition:transform .3s,box-shadow .3s,border-color .3s}
.ap-tl-card:hover{transform:translateY(-5px);box-shadow:0 20px 44px rgba(26,20,16,.14)}
.ap-tl-img{height:158px;overflow:hidden;position:relative}
.ap-tl-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.ap-tl-card:hover .ap-tl-img img{transform:scale(1.07)}
.ap-tl-body{padding:20px 24px 22px}
.ap-tl-card .ap-tl-year{margin-bottom:10px}
@media(max-width:780px){.ap-tl-img{height:130px}}

/* (3) cartes BLOG par entité */
.ap-blog-card{--bc:#E85D2F}
.ap-blog-img{aspect-ratio:16/10}
.ap-blog-badge{position:absolute;left:12px;top:12px;background:rgba(255,255,255,.96);border-radius:11px;height:34px;padding:0 12px;display:flex;align-items:center;box-shadow:0 5px 14px rgba(0,0,0,.14)}
.ap-blog-badge img{height:19px;width:auto;display:block}
.ap-blog-badge svg{height:19px;width:auto;display:block}
.ap-blog-card .ap-blog-body h3{font-size:18px}
.ap-blog-card .ap-blog-body p{font-size:13.5px;line-height:1.55;color:var(--gris-texte);margin:0 0 14px}
.ap-blog-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:0 0 16px;font-size:12.5px;color:var(--gris-texte)}
.ap-blog-chip{font-family:'Sora',sans-serif;font-weight:700;font-size:11.5px;color:var(--bc);background:color-mix(in srgb,var(--bc) 12%,#fff);border-radius:100px;padding:4px 11px}
.ap-blog-read{color:var(--bc)!important;-webkit-text-fill-color:initial!important;background:none!important}
.ap-blog-card{position:relative}

/* réseaux : titre */
.ap-soc-head{color:var(--bleu-nuit)}

/* cohérence finale : ligne/pastilles de la frise + badge hero en dégradé logo */
.ap-timeline::before{background:linear-gradient(#3EA3DC,#5FAE2E,#ECC533,#E85D2F)!important;opacity:.6}
.ap-tl-dot{background:var(--lgh)}
.ap-hero-badge strong{background:var(--lgh);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}


/* ============ À PROPOS v5 — fin de l'arc-en-ciel ============ */
/* dégradé dynamique : UNE couleur à la fois, transition progressive (aller-retour, pas de saut orange->bleu) */
@keyframes royHue{0%{color:#3EA3DC}33%{color:#5FAE2E}66%{color:#D99A16}100%{color:#E85D2F}}
@keyframes royHueBg{0%{background-color:#3EA3DC}33%{background-color:#5FAE2E}66%{background-color:#D99A16}100%{background-color:#E85D2F}}

/* TEXTES accent : plus de dégradé multicolore, une seule teinte qui évolue */
.ap-hl,.ap-grad,.section-eyebrow,.ap-eyebrow,.ap-stat b i,.ap-link,.ap-hero-badge strong{
  background:none!important;background-image:none!important;
  -webkit-text-fill-color:currentColor!important;
  color:#E85D2F;
  animation:royHue 9s ease-in-out infinite alternate!important;
}

/* BOUTONS : une couleur à la fois + léger relief (pas multicolore) */
.ap-btn-primary{
  background:#E85D2F!important;
  background-image:linear-gradient(180deg,rgba(255,255,255,.16),rgba(0,0,0,.05))!important;
  animation:royHueBg 9s ease-in-out infinite alternate!important;
}

/* TRAITS / BARRES : une couleur à la fois */
.tc h2::after,.ap-tl-year{background:#E85D2F!important;background-image:none!important;animation:royHueBg 9s ease-in-out infinite alternate!important}
.ap-tl-dot{background:#E85D2F!important;background-image:none!important;animation:royHueBg 9s ease-in-out infinite alternate!important}
.ap-timeline::before{background:#E85D2F!important;background-image:none!important;opacity:.5;animation:royHueBg 9s ease-in-out infinite alternate!important}

/* CONNECTEUR : on garde EXACTEMENT les 4 traits colorés, la barre redevient neutre (plus d'arc-en-ciel) */
.ap-umb-bus{background:rgba(255,255,255,.28)!important}

/* les liens "Découvrir le blog" gardent la couleur de leur entité (déjà géré) */
.ap-blog-read{animation:none!important}

/* les 4 traits du connecteur : bien colorés (couleur de chaque carte) */
.ap-umb-drop{background:var(--dc)!important;opacity:.92;width:2.5px}


/* ============ v6 — optimisation mobile & tablette ============ */
/* CHEVAUCHEMENT : quand le connecteur est masqué (<=980), espacer la carte marque des cartes entités */
@media(max-width:980px){
  .ap-umb-row{margin-top:42px}
  .ap-umb-top{box-shadow:0 12px 26px rgba(0,0,0,.30)}
  .ap-umbrella{margin-top:34px}
}

/* FRISE : rail gauche dès 980 (évite des cartes trop étroites sur tablette) */
@media(max-width:980px){
  .ap-timeline{max-width:640px}
  .ap-timeline::before{left:8px;transform:none}
  .ap-tl-item,
  .ap-tl-item:nth-child(odd),
  .ap-tl-item:nth-child(even){width:100%;margin-left:0;padding:0 0 24px 40px}
  .ap-tl-item .ap-tl-dot,
  .ap-tl-item:nth-child(odd) .ap-tl-dot,
  .ap-tl-item:nth-child(even) .ap-tl-dot{left:1px;right:auto}
}

/* TABLETTE : aérer un peu les grilles entre 600 et 980 */
@media(min-width:601px) and (max-width:980px){
  .ap-umb-row{gap:20px}
  .ap-blog-grid{grid-template-columns:1fr 1fr}     /* 2 blogs par ligne au lieu d'1 colonne */
  .ap-blog-grid > a:nth-child(3){grid-column:1 / -1;max-width:520px;margin:0 auto;width:100%}
  .ap-soc-row{grid-template-columns:1fr 1fr}
}

/* MOBILE étroit : marges latérales confortables */
@media(max-width:520px){
  .ap-soc-row{grid-template-columns:1fr}
}


/* ============ v7 ============ */
/* (5) organigramme : aération entre les pastilles et les cartes */
@media(min-width:981px){
  .ap-umb-row{margin-top:18px}
}

/* (4) HERO : image étirée jusqu'au bord droit de l'écran + coins droits supprimés (l'image "sort" à droite) */
@media(min-width:981px){
  .ap-hero-media{
    width:calc(100% + max(28px, (100vw - 1200px) / 2 + 28px));
    justify-self:start;
    margin-right:0;
    border-top-right-radius:0;
    border-bottom-right-radius:0;
  }
}

/* (3) sécurité : aucun bandeau coloré en haut des cartes blog */
.ap-blog-card::before{display:none!important}

/* O plus grand et plus présent sur mobile */
@media(max-width:600px){
  .cta-projet-card .cta-projet-bg{width:460px;height:460px;right:-70px;bottom:-150px;opacity:0.22}
}


/* ============ v8 — arrière-plan clair, neutre & aéré (fini le rouge pastel) ============ */
body{background:#FAFAFA!important}

/* hero : voiles très légers et neutres au lieu du pêche/rosé */
.ap-hero{
  background:
    radial-gradient(130% 92% at 84% -14%, #EEF3F7 0%, rgba(238,243,247,0) 60%),
    radial-gradient(80% 60% at 10% 6%, #F6F7F9 0%, rgba(246,247,249,0) 55%),
    linear-gradient(180deg,#FFFFFF 0%, #FAFAFA 100%) !important;
}

/* raccord doux avec la section suivante */
.ap-story{background:#FAFAFA}


/* ============ v9 — hero refondu : image demi-écran + barre des promesses ============ */
@media(min-width:981px){
  .ap-hero{padding:0 0 58px !important; overflow:visible}
  .ap-hero-grid{grid-template-columns:1fr 1.06fr; gap:0; align-items:stretch; min-height:86vh}
  .ap-hero-left{align-self:center; padding:92px 54px 28px 0}
  .ap-hero-photo{
    position:relative; min-height:86vh; overflow:hidden;
    background-size:cover; background-position:center;
    box-shadow:var(--shadow-strong);
    border-top-left-radius:44px; border-bottom-left-radius:44px;
    border-top-right-radius:0; border-bottom-right-radius:0;
    width:calc(100% + max(28px, (100vw - 1200px) / 2 + 28px));
    justify-self:start;
  }
  .ap-hero-photo::after{content:""; position:absolute; inset:0; pointer-events:none;
    background:linear-gradient(180deg, rgba(20,11,7,.08) 24%, rgba(15,8,5,.48) 100%)}
  .ap-stats{margin-top:34px}
}
@media(max-width:980px){
  .ap-hero-photo{display:none}
  .ap-hero{padding:128px 0 40px}
}

/* encadré "depuis 2006" — même traitement que les autres pages (boîte pâle, texte sombre) */
.ap-yearbox{display:inline-block; background:#F1E8CC; color:var(--bleu-nuit);
  padding:.02em .30em; border-radius:.28em; white-space:nowrap;
  -webkit-text-fill-color:var(--bleu-nuit); animation:none}

/* connecteur : aérer la pastille haute par rapport à la carte ROY */
@media(min-width:981px){ .ap-umb-connect{margin-top:16px} }


/* ============ v10 — hero split plein écran (proportions exactes des autres pages) ============ */
@media(min-width:981px){
  .ap-hero{padding:0 !important; min-height:88vh; overflow:visible}
  .ap-hero-grid{grid-template-columns:1fr 1.02fr; gap:0; align-items:stretch; min-height:88vh; width:100%}
  .ap-hero-left{align-self:center; padding:96px 56px 36px max(28px,(100vw - 1200px)/2 + 28px); position:relative; z-index:2; overflow:visible}
  .ap-hero-photo{position:relative; min-height:88vh; overflow:hidden; width:100%;
    background-size:cover; background-position:center; box-shadow:var(--shadow-strong);
    border-radius:0 0 0 48px}              /* seul le bas-gauche arrondi */
  .ap-hero-photo::after{content:""; position:absolute; inset:0; pointer-events:none;
    background:linear-gradient(180deg, rgba(20,11,7,.05) 24%, rgba(15,8,5,.30) 100%)}
  .ap-stats-wrap{margin-top:40px}
}
@media(max-width:980px){
  .ap-hero-photo{display:none}
  .ap-hero{padding:128px 0 40px}
}

/* encadré "depuis 2006" — exactement comme les autres pages */
.ap-yearbox{display:inline-block; background:#F7F1DC; color:var(--bleu-nuit);
  -webkit-text-fill-color:var(--bleu-nuit); animation:none;
  padding:.08em .36em; border-radius:.3em; white-space:nowrap; position:relative; z-index:4}

/* "depuis 2006" : ligne propre qui déborde légèrement sur l'image (desktop) */
@media(min-width:981px){
  .ap-yearline{display:block; text-align:right; margin-right:-92px; margin-top:.1em}
}


/* Mobile : éviter que le texte du hero touche les bords */
@media(max-width:980px){
  section.ap-hero .ap-hero-left{ padding-left:clamp(20px,5.6vw,40px) !important; padding-right:clamp(20px,5.6vw,40px) !important; }
}

/* ============================================================
   HERO À PROPOS — refonte du bloc titre : cohérent, sobre, pro
   (plus de jaune, "famille" en orange plein, "depuis 2006" aligné)
   ============================================================ */
.ap-title .ap-hl{
  background:none !important;
  -webkit-text-fill-color:#E85D2F !important;
  color:#E85D2F !important;
  animation:none !important;
}
.ap-title .ap-yearline{
  display:block !important;
  text-align:left !important;
  margin:18px 0 0 !important;
}
.ap-title .ap-yearbox{
  display:inline-block !important;
  background:var(--ap-soft) !important;
  color:var(--ap-d) !important;
  border:1px solid #FBE0D6 !important;
  font-family:'Sora',sans-serif !important;
  font-weight:700 !important;
  font-size:14px !important;
  letter-spacing:.08em !important;
  text-transform:uppercase !important;
  padding:7px 16px !important;
  border-radius:100px !important;
  box-shadow:none !important;
  line-height:1 !important;
}

/* ============================================================
   Titre À propos — 2 lignes garanties + badge "depuis 2006"
   en fin de ligne 2, adapté à toutes les largeurs d'écran.
   (ligne 1 "L'habitat, une affaire" insécable ; taille calée
    pour qu'elle tienne sur une seule ligne à toute largeur)
   ============================================================ */
.ap-title{ font-size:clamp(24px,7.2vw,50px) !important; line-height:1.1 !important; }
.ap-title .ap-tl1{ display:block; white-space:nowrap; }
.ap-title .ap-tl2{ display:block; }
.ap-title .ap-yearline{
  display:inline-block !important;
  text-align:left !important;
  margin:0 0 0 .5em !important;
  vertical-align:middle;
}
@media(min-width:981px){
  .ap-title{ font-size:clamp(33px,3.3vw,50px) !important; }
}

/* fix : stats hero qui débordaient (valeur large) */
.hero-stats > div{min-width:0}
.hero-stat-num{white-space:normal;overflow-wrap:break-word}
