/* ===========================================================
   KREABATI — Charte 2 « Terroir & Pierre » (feuille partagée)
   Palette chaude ocre/pierre + BLEU du logo en accent secondaire
   =========================================================== */
@import url('https://fonts.googleapis.com/css2?family=Roboto+Slab:wght@500;600;700;800&family=PT+Sans:wght@400;700&display=swap');

:root{
  --ocre:#B4622E;        /* terre de Sienne — primaire chaud */
  --ocre-fonce:#964e21;
  --dore:#D89A3C;        /* accent CTA */
  --pierre:#E7DEC9;
  --pierre-f:#C9B998;
  --olive:#6B7042;
  --brun:#3E2F23;        /* texte / charpente */
  --brun-noir:#2B2017;
  --creme:#F7F2E7;
  --bleu:#1A5FC2;        /* BLEU DU LOGO — accent secondaire (technique / confiance) */
  --bleu-fonce:#14478F;
  --texte:#3E2F23;
  --radius:4px;
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'PT Sans',system-ui,sans-serif;color:var(--texte);background:#fff;line-height:1.65}
h1,h2,h3,h4,.h{font-family:'Roboto Slab',serif;line-height:1.18;color:var(--brun)}
a{color:inherit;text-decoration:none}
img{max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.btn{display:inline-block;font-family:'Roboto Slab';font-weight:700;font-size:15px;padding:14px 26px;border-radius:var(--radius);cursor:pointer;border:0;transition:.18s}
.btn-ocre{background:var(--ocre);color:#fff}.btn-ocre:hover{background:var(--ocre-fonce)}
.btn-dore{background:var(--dore);color:var(--brun)}.btn-dore:hover{background:#c9892f}
.btn-bleu{background:var(--bleu);color:#fff}.btn-bleu:hover{background:var(--bleu-fonce)}     /* secondaire bleu */
.btn-ghost{background:transparent;color:#fff;border:2px solid #fff}.btn-ghost:hover{background:#fff;color:var(--brun)}
.btn-outline-bleu{background:transparent;color:var(--bleu);border:2px solid var(--bleu)}.btn-outline-bleu:hover{background:var(--bleu);color:#fff}

/* TOPBAR */
.topbar{background:var(--brun-noir);color:#d8cbb6;font-size:13.5px}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;min-height:42px;flex-wrap:wrap;gap:2px 14px;padding:5px 24px}
.topbar b{color:#fff}
.topbar .star{color:var(--bleu)}           /* accent bleu */
.topbar .sep{color:#6b5a47;margin:0 10px}

/* HEADER + LOGO recoloré */
header{position:sticky;top:0;z-index:50;background:var(--creme);border-bottom:2px solid var(--pierre-f);box-shadow:0 2px 12px rgba(62,47,35,.06)}
header .wrap{display:flex;align-items:center;justify-content:space-between;height:86px}
.brand{display:flex;align-items:center;gap:12px}
.logo-img{height:56px;display:block}   /* LOGO OFFICIEL DU CLIENT (inchangé) */
nav ul{list-style:none;display:flex;gap:19px;align-items:center}
nav a{font-family:'Roboto Slab';font-weight:600;font-size:15px;color:var(--brun);padding:6px 0;border-bottom:3px solid transparent;transition:.15s}
nav a:hover,nav a.active{color:var(--ocre);border-color:var(--ocre)}
.header-cta{display:flex;align-items:center;gap:18px}
.tel{font-family:'Roboto Slab';font-weight:700;color:var(--bleu);font-size:17px;white-space:nowrap}  /* tel en bleu */
.burger{display:none}  /* visible uniquement sur mobile */
.callbar{display:none}  /* barre d'appel fixe — mobile uniquement */

/* HERO accueil */
.hero{position:relative;color:#fff;background:linear-gradient(180deg,rgba(43,32,23,.80),rgba(62,47,35,.55)),url('hero.jpg') center 60%/cover no-repeat}
.hero .wrap{padding:96px 24px 92px;position:relative}
.eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--ocre);color:#fff;font-family:'Roboto Slab';font-weight:700;font-size:13px;letter-spacing:.5px;text-transform:uppercase;padding:7px 14px;border-radius:3px}
.hero h1{color:#fff;font-size:50px;font-weight:800;max-width:780px;margin:22px 0 16px}
.hero p.lead{font-size:20px;max-width:620px;color:#f0e8da}
.hero .actions{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap}
.cachet{position:absolute;right:24px;top:46px;width:128px;height:128px;border:2px solid var(--dore);border-radius:50%;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;transform:rotate(-12deg);font-family:'Roboto Slab';font-weight:700;font-size:11px;letter-spacing:.3px;line-height:1.3;background:rgba(180,98,46,.32);padding:14px}
.cachet b{display:block;font-size:16px;color:var(--dore);letter-spacing:.3px;margin:3px 0}

/* PAGE HEADER (pages internes) */
.pagehead{position:relative;color:#fff;background:linear-gradient(180deg,rgba(43,32,23,.32) 0%,rgba(43,32,23,.58) 55%,rgba(43,32,23,.9) 100%),url('hero.jpg') center 50%/cover no-repeat;padding:96px 0 40px;min-height:340px;display:flex;align-items:flex-end}
.pagehead>.wrap{width:100%}
.pagehead h1{color:#fff;font-size:42px;text-shadow:0 2px 14px rgba(0,0,0,.35);max-width:880px}
.breadcrumb{font-size:14px;color:#e7dcc9;margin-bottom:10px}
.breadcrumb a:hover{color:#fff}.breadcrumb .bl{color:var(--bleu)}

/* TRUST */
.trust{background:var(--creme);border-bottom:2px solid var(--pierre-f)}
.trust .wrap{display:flex;flex-wrap:wrap;gap:8px 16px;justify-content:space-between;padding:20px 24px}
.trust .item{display:flex;align-items:center;gap:8px;font-family:'Roboto Slab';font-weight:600;font-size:13px;color:var(--brun);white-space:nowrap}
.trust .dot{width:28px;height:28px;border-radius:50%;background:#fff;border:1px solid var(--pierre-f);display:grid;place-items:center;color:var(--bleu);flex:none}  /* icônes bleues */
.trust svg{width:18px;height:18px}

/* SECTIONS */
section{padding:78px 0}
.sec-head{text-align:center;max-width:700px;margin:0 auto 46px}
.sec-head .kicker{font-family:'Roboto Slab';font-weight:700;color:var(--ocre);text-transform:uppercase;letter-spacing:1.5px;font-size:13px}
.sec-head h2{font-size:36px;font-weight:800;margin:10px 0 12px}
.sec-head p{color:var(--olive);font-size:17px}

/* SERVICES grid */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.card{border:1px solid var(--pierre-f);border-radius:8px;overflow:hidden;background:#fff;transition:.2s}
.card:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(180,98,46,.16);border-color:var(--ocre)}
.card .ph{height:172px;background-size:cover;background-position:center}
.card .body{padding:22px}
.card h3{font-size:20px;margin-bottom:8px}
.card p{color:var(--olive);font-size:15px;margin-bottom:14px}
.card .more{font-family:'Roboto Slab';font-weight:700;color:var(--bleu);font-size:14px}  /* lien bleu */
.icon-svc{position:relative;margin-top:-34px;margin-left:18px;width:52px;height:52px;border-radius:8px;background:var(--ocre);display:grid;place-items:center;color:#fff;box-shadow:0 6px 16px rgba(150,78,33,.4)}
.icon-svc svg{width:26px;height:26px}

/* AVIS GOOGLE */
.avis{background:var(--pierre)}
.avis-top{display:flex;flex-wrap:wrap;gap:24px;align-items:center;justify-content:center;margin-bottom:40px}
.score{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid var(--pierre-f);border-radius:10px;padding:18px 26px}
.score .g{font-family:'Roboto Slab';font-weight:800;font-size:22px}
.score .g span:nth-child(1){color:#4285F4}.score .g span:nth-child(2){color:#EA4335}.score .g span:nth-child(3){color:#FBBC05}.score .g span:nth-child(4){color:#4285F4}.score .g span:nth-child(5){color:#34A853}.score .g span:nth-child(6){color:#EA4335}
.score .big{font-family:'Roboto Slab';font-weight:800;font-size:40px;color:var(--brun);line-height:1}
.stars{color:#E0A21C;font-size:18px;letter-spacing:2px}
.score small{color:var(--olive)}
.fiche-badges{display:flex;gap:12px;flex-wrap:wrap}
.fiche{background:#fff;border:1px solid var(--pierre-f);border-radius:8px;padding:12px 18px;font-size:14px}
.fiche b{font-family:'Roboto Slab'}
.avis-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.avis-card{background:#fff;border:1px solid var(--pierre-f);border-radius:8px;padding:22px;display:flex;flex-direction:column;gap:10px}
.avis-card .rh{display:flex;align-items:center;gap:12px}
.ava{width:42px;height:42px;border-radius:50%;background:var(--bleu);color:#fff;display:grid;place-items:center;font-family:'Roboto Slab';font-weight:700}  /* avatar bleu */
.avis-card .nm{font-family:'Roboto Slab';font-weight:700;font-size:15px}
.avis-card .meta{font-size:12.5px;color:var(--olive)}
.avis-card .txt{font-size:14.5px;color:#4a3c2e}
.avis-card .gg{font-size:12px;color:var(--olive);display:flex;align-items:center;gap:6px;margin-top:auto}

/* ZONE */
.zone{background:var(--olive);color:#fff}
.zone .wrap{display:flex;flex-wrap:wrap;gap:40px;align-items:center;justify-content:space-between}
.zone h2{color:#fff;font-size:30px}
.zone .villes{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px;max-width:640px}
.zone .villes span{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.3);padding:8px 14px;border-radius:30px;font-size:14px;font-family:'Roboto Slab';font-weight:600}

/* ===== PAGE SERVICE ===== */
.svc-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:46px;align-items:start}
.prose h2{font-size:28px;margin:34px 0 14px;position:relative;padding-left:18px}
.prose h2::before{content:"";position:absolute;left:0;top:5px;bottom:5px;width:5px;background:var(--dore);border-radius:3px}
.prose h3{font-size:21px;margin:28px 0 10px;color:var(--ocre)}
.prose p{margin-bottom:14px;color:#4a3c2e}
.prose > p:first-child{font-size:19px;line-height:1.7;color:var(--brun);border-left:4px solid var(--dore);padding:2px 0 2px 18px;margin-bottom:6px}
.checklist{list-style:none;display:grid;gap:10px;margin:8px 0 18px}
.checklist li{display:flex;gap:10px;align-items:flex-start}
.checklist li::before{content:"";flex:none;width:22px;height:22px;border-radius:50%;background:var(--bleu);margin-top:2px;
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'><path d='M20 6L9 17l-5-5'/></svg>") center/14px no-repeat;
  mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'><path d='M20 6L9 17l-5-5'/></svg>") center/14px no-repeat;}
.aside{position:sticky;top:104px;display:flex;flex-direction:column;gap:18px}
.aside .box{border:1px solid var(--pierre-f);border-radius:10px;padding:22px;background:var(--creme)}
.aside .box.bleu{background:var(--bleu);color:#fff;border:0}
.aside .box.bleu h4{color:#fff}.aside .box.bleu a{color:#fff}
.aside h4{font-size:18px;margin-bottom:10px}
.aside .tel-big{font-family:'Roboto Slab';font-weight:800;font-size:24px}
.aside ul{list-style:none;display:flex;flex-direction:column;gap:8px;font-size:15px}
.aside ul a{color:var(--brun)}.aside ul a:hover{color:var(--ocre)}

/* PROCESS étapes */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.step{text-align:center;padding:0 8px}
.step .num{width:54px;height:54px;border-radius:50%;background:var(--creme);border:2px solid var(--bleu);color:var(--bleu);font-family:'Roboto Slab';font-weight:800;font-size:22px;display:grid;place-items:center;margin:0 auto 14px}
.step h4{font-size:18px;margin-bottom:6px}
.step p{color:var(--olive);font-size:14.5px}

/* ===== GALERIE / RÉALISATIONS ===== */
.filters{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:34px}
.filters button{font-family:'Roboto Slab';font-weight:600;font-size:14px;padding:9px 18px;border-radius:30px;border:1px solid var(--pierre-f);background:#fff;color:var(--brun);cursor:pointer;transition:.15s}
.filters button.on,.filters button:hover{background:var(--ocre);border-color:var(--ocre);color:#fff}
.gallery{columns:3;column-gap:18px}
.gallery figure{break-inside:avoid;margin:0 0 18px;border-radius:8px;overflow:hidden;position:relative;border:1px solid var(--pierre-f)}
.gallery figure a{display:block;position:relative;color:inherit;text-decoration:none}
.gallery img{display:block;width:100%;transition:.3s}
.gallery figure:hover img{transform:scale(1.05)}
.gallery figcaption{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(0deg,rgba(43,32,23,.85),transparent);color:#fff;padding:26px 14px 12px;font-family:'Roboto Slab';font-weight:600;font-size:14px}
.gallery figcaption span{display:block;font-family:'PT Sans';font-weight:400;font-size:12.5px;color:var(--dore)}

/* ===== CONTACT ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.field{margin-bottom:16px}
.field label{display:block;font-family:'Roboto Slab';font-weight:600;font-size:14px;margin-bottom:6px}
.field input,.field textarea,.field select{width:100%;padding:12px 14px;border:1px solid var(--pierre-f);border-radius:6px;font-family:'PT Sans';font-size:15px;background:#fff;color:var(--brun)}
.field input:focus,.field textarea:focus,.field select:focus{outline:2px solid var(--bleu);border-color:var(--bleu)}
.info-card{border:1px solid var(--pierre-f);border-radius:10px;padding:22px;margin-bottom:18px;background:var(--creme)}
.info-card h4{font-size:18px;margin-bottom:8px;display:flex;align-items:center;gap:8px}
.info-card .pin{color:var(--bleu)}
.info-card p{color:#4a3c2e;font-size:15px}
.map{border:1px solid var(--pierre-f);border-radius:10px;overflow:hidden;height:230px;background:var(--pierre) url('hero.jpg') center/cover;position:relative;filter:saturate(.7)}
.map .badge{position:absolute;left:14px;bottom:14px;background:#fff;border-radius:6px;padding:8px 12px;font-size:13px;font-family:'Roboto Slab';font-weight:600;color:var(--brun)}

/* FOOTER */
footer{background:var(--brun-noir);color:#bcae9b;padding:54px 0 24px;font-size:14px}
footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:32px;margin-bottom:34px}
footer h4{font-family:'Roboto Slab';color:#fff;margin-bottom:14px;font-size:16px}
footer a:hover{color:#fff}
footer .logo-f{font-family:'Roboto Slab';font-weight:800;font-size:24px;color:#fff}
footer .logo-f .krea{color:#5b9be8}footer .logo-f .bati{color:#fff}footer .logo-f .dot{color:var(--bleu)}
.copyright{border-top:1px solid #4a3a29;padding-top:18px;text-align:center;color:#8a7a66;font-size:13px}

/* CHARTE STRIP */
.charte{background:#fff;border-top:6px solid var(--ocre);padding:56px 0}
.charte h2{font-size:26px;margin-bottom:6px}
.charte .sub{color:var(--olive);margin-bottom:28px}
.sw{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:30px}
.swatch{width:150px;border:1px solid var(--pierre-f);border-radius:8px;overflow:hidden}
.swatch .col{height:74px}
.swatch .lab{padding:8px 10px;font-size:12px}
.swatch .lab b{font-family:'Roboto Slab';display:block;font-size:12.5px}

/* COMPTEURS chiffres-clés */
.counters{background:var(--brun-noir);color:#fff;padding:46px 0}
.counters .wrap{display:flex;justify-content:space-around;flex-wrap:wrap;gap:24px;text-align:center}
.counters .cnt{min-width:120px}
.counters .num{font-family:'Roboto Slab';font-weight:800;font-size:46px;color:var(--dore);line-height:1}
.counters .num small{font-size:24px}
.counters .cnt p{color:#cfc4b4;font-size:14px;margin-top:8px;font-family:'Roboto Slab';font-weight:600}
@media(max-width:600px){.counters .num{font-size:34px}.counters .cnt{min-width:40%}}

/* RUBAN PRESTATIONS — carousel sur une seule ligne (inspiré entreprise-dupre.fr) */
.ribbon{background:#fff;border-top:1px solid var(--pierre-f);border-bottom:1px solid var(--pierre-f);overflow:hidden;padding:26px 0}
.ribbon .lbl{text-align:center;font-family:'Roboto Slab';font-weight:700;color:var(--ocre);text-transform:uppercase;letter-spacing:1.5px;font-size:13px;margin-bottom:22px}
.ribbon-mask{overflow:hidden;-webkit-mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.ribbon-track{display:flex;width:max-content;animation:ribbonscroll 48s linear infinite}
.ribbon-mask:hover .ribbon-track{animation-play-state:paused}
.ribbon-item{flex:none;width:152px;display:flex;flex-direction:column;align-items:center;gap:12px;padding:6px 12px;text-align:center;border-right:1px solid var(--pierre-f);color:var(--bleu)}
.ribbon-item svg{width:42px;height:42px}
.ribbon-item svg *{fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.ribbon-item span{font-family:'Roboto Slab';font-weight:600;font-size:13px;color:var(--brun);line-height:1.25}
@keyframes ribbonscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion: reduce){.ribbon-track{animation:none}.ribbon-mask{overflow:auto}}

/* RÉASSURANCE / POURQUOI */
.reasons{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.reason{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid var(--pierre-f);border-radius:8px;padding:20px}
.reason .ri{flex:none;width:46px;height:46px;border-radius:10px;background:var(--bleu);display:grid;place-items:center;color:#fff}  /* accent bleu */
.reason .ri svg{width:24px;height:24px}
.reason h3{font-size:17px;margin-bottom:4px}
.reason p{color:var(--olive);font-size:14px;line-height:1.5}

/* TEASER réalisations */
.teaser-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.teaser-grid a{display:block;border-radius:8px;overflow:hidden;position:relative;border:1px solid var(--pierre-f);aspect-ratio:1/1}
.teaser-grid img{width:100%;height:100%;object-fit:cover;transition:.3s}
.teaser-grid a:hover img{transform:scale(1.06)}
.teaser-grid figcaption{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(0deg,rgba(43,32,23,.85),transparent);color:#fff;padding:22px 10px 8px;font-size:12px;font-family:'Roboto Slab';font-weight:600}

/* FAQ */
.faq{max-width:840px;margin:0 auto}
.faq details{border:1px solid var(--pierre-f);border-radius:8px;margin-bottom:12px;background:#fff;overflow:hidden}
.faq summary{cursor:pointer;padding:16px 20px;font-family:'Roboto Slab';font-weight:600;font-size:16px;color:var(--brun);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--ocre);font-size:22px;font-weight:700;flex:none}
.faq details[open] summary::after{content:"\2013"}
.faq details[open] summary{color:var(--ocre)}
.faq .a{padding:0 20px 16px;color:#4a3c2e;font-size:15px}

/* CTA segmentés */
.cta-seg{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:28px}
.cta-seg a{font-family:'Roboto Slab';font-weight:600;font-size:14px;padding:11px 18px;border-radius:30px;border:2px solid var(--bleu);color:var(--bleu);background:#fff;transition:.15s}
.cta-seg a:hover{background:var(--bleu);color:#fff}

/* BANDEAU CTA final */
.cta-band{background:var(--ocre);color:#fff}
.cta-band .wrap{display:flex;flex-wrap:wrap;gap:24px;align-items:center;justify-content:space-between;padding:42px 24px}
.cta-band h2{color:#fff;font-size:30px;max-width:620px}
.cta-band .tel-big{font-family:'Roboto Slab';font-weight:800;font-size:30px;color:#fff;white-space:nowrap}

@media(max-width:900px){
  .cachet{display:none}
  .burger{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border:2px solid var(--brun);border-radius:8px;background:#fff;color:var(--brun);font-size:20px;cursor:pointer;padding:0}
  .header-cta .btn-ocre{display:none}
  header .wrap{position:relative}
  nav{display:none;position:absolute;left:0;right:0;top:100%;background:var(--creme);border-top:1px solid var(--pierre-f);border-bottom:3px solid var(--ocre);box-shadow:0 12px 26px rgba(43,32,23,.16);z-index:60}
  header.nav-open nav{display:block}
  nav ul{flex-direction:column;align-items:stretch;gap:0;padding:6px 0}
  nav a{display:block;padding:13px 24px;border-bottom:1px solid var(--pierre-f)}
  nav a:hover,nav a.active{background:#fff;color:var(--ocre);border-bottom-color:var(--pierre-f)}
  .tel{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border:2px solid var(--bleu);border-radius:50%;color:var(--bleu);font-size:18px;padding:0}
  .tel-num{display:none}
  .topbar{font-size:12.5px}
  .topbar .wrap{justify-content:center;text-align:center;gap:2px 10px}
  .ribbon-item{width:132px}
  .grid,.grid-2,.avis-grid,.steps,.contact-grid,.reasons{grid-template-columns:1fr}
  .teaser-grid{grid-template-columns:repeat(2,1fr)}
  .svc-layout{grid-template-columns:1fr}
  .gallery{columns:1}
  .hero h1{font-size:34px}
  footer .cols{grid-template-columns:1fr}
  .callbar{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:150;box-shadow:0 -4px 16px rgba(43,32,23,.2)}
  .callbar a{flex:1;text-align:center;padding:14px 8px;font-family:'Roboto Slab';font-weight:700;font-size:15px;text-decoration:none;color:#fff}
  .callbar a:first-child{background:var(--bleu)}
  .callbar a:last-child{background:var(--ocre)}
  body{padding-bottom:54px}
  .cookie-reopen{bottom:64px}
}

/* BANDEAU DE CONSENTEMENT COOKIES (RGPD) — partagé sur toutes les pages */
.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:200;background:#fff;border:1px solid var(--pierre-f);border-top:4px solid var(--bleu);border-radius:10px;box-shadow:0 12px 40px rgba(43,32,23,.25);padding:20px 22px;max-width:1100px;margin:0 auto}
.cookie-inner{display:flex;gap:22px;align-items:center;flex-wrap:wrap;justify-content:space-between}
.cookie-txt{flex:1;min-width:260px}
.cookie-txt strong{font-family:'Roboto Slab';font-size:16px;color:var(--brun)}
.cookie-txt p{font-size:14px;color:#4a3c2e;margin-top:4px}
.cookie-txt a{color:var(--bleu);font-weight:700}
.cookie-actions{display:flex;gap:10px;flex-wrap:wrap}
.ck-btn{font-family:'Roboto Slab';font-weight:700;font-size:14px;padding:11px 18px;border-radius:6px;cursor:pointer;border:2px solid var(--bleu);transition:.15s}
.ck-refuse,.ck-custom{background:#fff;color:var(--bleu)}
.ck-refuse:hover,.ck-custom:hover{background:#eef3fb}
.ck-accept{background:var(--ocre);border-color:var(--ocre);color:#fff}
.ck-accept:hover{background:var(--ocre-fonce)}
.cookie-prefs{margin-top:16px;border-top:1px solid var(--pierre-f);padding-top:14px}
.ck-row{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:8px 0;border-bottom:1px dashed var(--pierre-f)}
.ck-row small{color:var(--olive)}
.cookie-reopen{position:fixed;left:16px;bottom:16px;z-index:200;background:var(--bleu);color:#fff;border:0;border-radius:30px;padding:10px 16px;font-family:'Roboto Slab';font-weight:700;font-size:13px;cursor:pointer;box-shadow:0 6px 18px rgba(20,71,143,.35)}
@media(max-width:700px){.cookie-actions{width:100%}.ck-btn{flex:1}}

/* ===== PAGES RÉALISATION (détail chantier) ===== */
.rea-meta{display:flex;flex-wrap:wrap;gap:0;margin:22px 0 10px;background:var(--creme);border:1px solid var(--pierre-f);border-radius:10px;overflow:hidden}
.rea-meta span{flex:1;min-width:170px;padding:14px 20px;font-size:12px;font-family:'PT Sans';color:var(--olive);border-right:1px solid var(--pierre-f);text-transform:uppercase;letter-spacing:.4px}
.rea-meta span:last-child{border-right:0}
.rea-meta span b{display:block;font-family:'Roboto Slab';font-size:16px;color:var(--brun);margin-top:4px;text-transform:none;letter-spacing:0}
/* Bandeau avis (réalisations) */
.rea-avis{background:var(--brun-noir);color:#fff;padding:34px 0}
.rea-avis .wrap{display:flex;flex-wrap:wrap;align-items:center;gap:26px;justify-content:space-between}
.ra-score{text-align:center;flex:none}
.ra-score .ra-stars{color:var(--dore);font-size:18px;letter-spacing:2px;display:block}
.ra-score b{font-family:'Roboto Slab';font-size:30px;color:#fff;display:block;line-height:1.1}
.ra-score small{color:#bcae9b;font-size:12.5px}
.ra-quote{flex:1;min-width:260px;font-family:'Roboto Slab';font-weight:600;font-size:17px;color:#fff;line-height:1.45}
.ra-quote span{display:block;font-family:'PT Sans';font-weight:400;font-size:13px;color:#bcae9b;margin-top:6px}
/* Encadré CTA stylé (fin de page chantier) */
.rea-cta{background:linear-gradient(120deg,var(--bleu),var(--bleu-fonce));color:#fff;border-radius:12px;padding:26px 30px;margin-top:28px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:20px}
.rea-cta .txt{flex:1;min-width:260px}
.rea-cta h2{color:#fff;margin:0;padding:0;font-size:22px;border:0}
.rea-cta h2::before{display:none}
.rea-cta p{color:#e7eefb;margin:8px 0 0}
.rea-cta p a{color:#fff;text-decoration:underline;font-weight:700}
.rea-cta .btn{flex:none}
@media(max-width:600px){.rea-meta span{min-width:100%;border-right:0;border-bottom:1px solid var(--pierre-f)}.rea-meta span:last-child{border-bottom:0}}
.rea-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:8px}
.rea-gallery img{width:100%;aspect-ratio:4/3;object-fit:cover;margin:0;border-radius:8px;border:1px solid var(--pierre-f);cursor:zoom-in;display:block;transition:.25s}
.rea-gallery img:hover{filter:brightness(1.05);box-shadow:0 8px 20px rgba(180,98,46,.18)}
.map-embed{border:1px solid var(--pierre-f);border-radius:10px;overflow:hidden;line-height:0;margin-top:6px}
.map-embed iframe{width:100%;height:340px;border:0;display:block;filter:saturate(.85)}
.voir-aussi{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.va-card{display:block;border:1px solid var(--pierre-f);border-radius:10px;overflow:hidden;background:#fff;transition:.2s;color:var(--brun)}
.va-card:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(180,98,46,.16);border-color:var(--ocre)}
.va-card .va-ph{height:150px;background-size:cover;background-position:center}
.va-card .va-b{padding:16px 18px}
.va-card .va-b .va-k{font-family:'Roboto Slab';font-weight:700;color:var(--ocre);font-size:12px;text-transform:uppercase;letter-spacing:.6px}
.va-card .va-b h3{font-size:17px;margin:5px 0 0}
.va-card .va-b .more{font-family:'Roboto Slab';font-weight:700;color:var(--bleu);font-size:13.5px;margin-top:8px;display:inline-block}
/* Lightbox */
.lb{position:fixed;inset:0;background:rgba(43,32,23,.93);display:none;align-items:center;justify-content:center;z-index:300;padding:24px}
.lb.open{display:flex}
.lb img{max-width:92%;max-height:88%;border-radius:8px;box-shadow:0 12px 50px rgba(0,0,0,.55)}
.lb .lb-close{position:absolute;top:14px;right:26px;color:#fff;font-size:40px;line-height:1;cursor:pointer;font-family:'Roboto Slab'}
@media(max-width:900px){.rea-gallery{grid-template-columns:repeat(2,1fr)}.voir-aussi{grid-template-columns:1fr}.map-embed iframe{height:260px}.pagehead{min-height:240px;padding-top:64px}.pagehead h1{font-size:30px}}
@media(max-width:600px){.rea-gallery{grid-template-columns:1fr}}

/* === Chapô + icônes prestations par métier (centrées ~90%) === */
.svc-chapo{font-size:19px;line-height:1.7;color:var(--brun);border-left:4px solid var(--dore);padding:4px 0 4px 18px;max-width:900px;margin:0 0 6px}
.svc-icons{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;max-width:92%;margin:10px auto 30px}
.svc-icons .ic{flex:1 1 150px;max-width:210px;display:flex;flex-direction:column;align-items:center;gap:10px;padding:18px 10px;border:1px solid var(--pierre-f);border-radius:10px;background:var(--creme);text-align:center;text-decoration:none;cursor:pointer;transition:.15s}
.svc-icons a.ic:hover{border-color:var(--ocre);transform:translateY(-2px);box-shadow:0 8px 20px rgba(150,78,33,.18)}
.svc-icons .ic svg{width:34px;height:34px;color:var(--ocre)}
.svc-icons .ic svg *{fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.svc-icons .ic span{font-family:'Roboto Slab';font-weight:600;font-size:12.5px;color:var(--brun);line-height:1.2}
.svc-icons .ic-cta{flex:1 1 150px;max-width:210px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:9px;padding:18px 12px;border-radius:10px;background:var(--ocre);color:#fff;text-decoration:none;text-align:center;border:0;transition:.15s}
.svc-icons .ic-cta:hover{background:var(--ocre-fonce);transform:translateY(-2px);box-shadow:0 10px 24px rgba(150,78,33,.3)}
.svc-icons .ic-cta svg{width:30px;height:30px;color:#fff}
.svc-icons .ic-cta svg *{fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.svc-icons .ic-cta span{font-family:'Roboto Slab';font-weight:700;font-size:12.5px;line-height:1.25;color:#fff}

/* === Simulateur de projet === */
.sim-wrap{background:linear-gradient(135deg,var(--bleu-fonce),var(--bleu));color:#fff}
.sim-wrap .kicker,.sim-wrap .sec-head h2,.sim-wrap .sec-head p{color:#fff}
.sim{max-width:680px;margin:0 auto;background:#fff;color:var(--brun);border-radius:14px;padding:30px;box-shadow:0 18px 44px rgba(0,0,0,.28)}
.sim-box{max-width:90%;margin:14px auto 8px;background:linear-gradient(135deg,var(--bleu-fonce),var(--bleu));border-radius:16px;padding:26px;box-shadow:0 14px 36px rgba(20,71,143,.22)}
.sim-head{text-align:center;color:#fff;margin-bottom:18px}
.sim-head b{font-family:'Roboto Slab';font-weight:800;font-size:23px;display:block;margin-bottom:4px}
.sim-head span{font-size:14px;opacity:.92}
.sim-box .sim{max-width:720px;padding:26px}
/* simulateur en panneau crème (dans la colonne principale, sidebar conservée à droite) */
.sim-panel{background:var(--creme);border:1px solid var(--pierre-f);border-radius:12px;padding:0;overflow:hidden;margin:30px 0 26px}
.sim-panel .sim-head{background:linear-gradient(135deg,#565a35,var(--olive));color:#fff;text-align:left;margin:0;padding:18px 24px}
.sim-panel .sim-head b{color:#fff;font-size:20px}
.sim-panel .sim-head span{color:#fff;opacity:.92}
.sim-panel .sim{background:transparent;box-shadow:none;padding:24px;max-width:100%;margin:0}
.sim-panel .sim-dots{justify-content:flex-start}
/* box bleu cliquable -> scroll vers la galerie */
.scroll-box{display:flex;align-items:center;justify-content:space-between;gap:16px;background:linear-gradient(135deg,var(--bleu-fonce),var(--bleu));color:#fff;border-radius:12px;padding:18px 24px;margin:0 0 26px;text-decoration:none;transition:.15s}
.scroll-box:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(20,71,143,.32)}
.scroll-box b{font-family:'Roboto Slab';font-weight:800;font-size:17px;display:block}
.scroll-box span{font-size:13.5px;opacity:.9}
.scroll-box .sb-go{flex:none;font-size:26px;line-height:1}
/* carrousel galerie */
.carousel{position:relative;display:flex;align-items:center;gap:8px}
.car-track{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:4px 2px;flex:1;scrollbar-width:none}
.car-track::-webkit-scrollbar{display:none}
.car-track img{flex:0 0 200px;width:200px;min-width:0;aspect-ratio:4/3;object-fit:cover;border-radius:10px;scroll-snap-align:start;cursor:pointer;border:1px solid var(--pierre-f);transition:.2s}
.car-track img:hover{filter:brightness(1.05)}
.car-cta{flex:0 0 200px;width:200px;min-width:0;aspect-ratio:4/3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,var(--bleu-fonce),var(--bleu));color:#fff;border-radius:10px;scroll-snap-align:start;text-decoration:none;text-align:center;padding:18px;transition:.2s}
.car-cta b{font-family:'Roboto Slab';font-weight:800;font-size:16.5px;line-height:1.3}
.car-cta .ar{font-size:30px;line-height:1}
.car-cta:hover{filter:brightness(1.08)}
.car-btn{flex:none;width:46px;height:46px;border-radius:50%;border:1px solid var(--pierre-f);background:#fff;color:var(--brun);font-size:24px;cursor:pointer;display:grid;place-items:center;box-shadow:0 4px 14px rgba(0,0,0,.12)}
.car-btn:hover{background:var(--ocre);color:#fff;border-color:var(--ocre)}
@media(max-width:700px){.car-track img,.car-cta{flex-basis:72%}.car-btn{width:38px;height:38px}.scroll-box{flex-wrap:wrap}}
.sim-dots{display:flex;gap:8px;justify-content:center;margin-bottom:22px}
.sim-dot{width:32px;height:5px;border-radius:3px;background:var(--pierre-f)}
.sim-dot.on{background:var(--ocre)}
.sim-q{font-family:'Roboto Slab';font-weight:700;font-size:18px;margin-bottom:14px;color:var(--brun)}
.sim-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.sim-row{display:flex;flex-wrap:wrap;gap:10px}
.sim-opt{font-family:'PT Sans';font-size:14px;font-weight:700;padding:14px 12px;border:2px solid var(--pierre-f);border-radius:10px;background:#fff;color:var(--brun);cursor:pointer;transition:.15s}
.sim-opt:hover{border-color:var(--ocre);background:var(--creme)}
.sim-opt.sel{border-color:var(--ocre);background:var(--ocre);color:#fff}
.sim-slide{text-align:center;padding:12px 0 4px}
.sim-range{width:100%;accent-color:var(--ocre);height:6px}
.sim-val{margin-top:12px;font-size:16px;color:var(--olive)}
.sim-val b{font-family:'Roboto Slab';font-size:28px;color:var(--ocre)}
.sim-nav{display:flex;justify-content:space-between;margin-top:24px}
.sim-back,.sim-next{font-family:'Roboto Slab';font-weight:600;font-size:14px;padding:11px 22px;border-radius:30px;border:0;cursor:pointer}
.sim-back{background:transparent;color:var(--olive)}
.sim-next{background:var(--ocre);color:#fff}
.sim-next[disabled]{opacity:.4;cursor:not-allowed}
.sim-recap{text-align:center}
.sim-rtitle{font-family:'Roboto Slab';font-weight:800;font-size:22px;color:var(--olive);margin-bottom:18px}
.sim-sum{list-style:none;display:grid;gap:8px;margin:0 auto 20px;text-align:left;max-width:430px}
.sim-sum li{display:flex;justify-content:space-between;gap:12px;padding:11px 16px;background:var(--creme);border-radius:8px;font-size:15px}
.sim-sum li span{color:var(--olive)}
.sim-msg{font-size:15px;margin-bottom:20px;line-height:1.6}
.sim-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn-ghost{background:#fff;border:2px solid var(--ocre);color:var(--ocre)}
.sim-tel{margin-top:18px;font-size:13.5px;color:var(--olive)}
.sim-tel a{color:var(--brun)}
.sim-restart{background:none;border:0;color:var(--olive);text-decoration:underline;cursor:pointer;font-size:13.5px;font-family:'PT Sans'}
.sim-checks{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.sim-check{display:flex;align-items:center;gap:10px;padding:12px 14px;border:2px solid var(--pierre-f);border-radius:10px;cursor:pointer;font-family:'PT Sans';font-size:14px;font-weight:700;color:var(--brun);background:#fff;text-align:left;transition:.15s}
.sim-check:hover{border-color:var(--ocre)}
.sim-check.sel{border-color:var(--ocre);background:var(--creme)}
.sim-check input{accent-color:var(--ocre);width:18px;height:18px;flex:none}
.sim-form{display:grid;grid-template-columns:1fr 1fr;gap:14px;text-align:left}
.sim-form .full{grid-column:1 / -1}
.sim-form label{display:block;font-size:13px;font-weight:700;color:var(--olive);margin-bottom:6px}
.sim-form input{width:100%;padding:12px 14px;border:2px solid var(--pierre-f);border-radius:10px;font-family:'PT Sans';font-size:15px;color:var(--brun);box-sizing:border-box}
.sim-form input:focus{outline:none;border-color:var(--ocre)}
.sim-err{color:#c0392b;font-size:13.5px;font-weight:700;grid-column:1 / -1}
.sim-done .big{width:64px;height:64px;margin:0 auto 12px;border-radius:50%;background:var(--olive);color:#fff;font-size:34px;display:grid;place-items:center}
@media(max-width:600px){.sim-grid{grid-template-columns:1fr 1fr}.sim{padding:22px 16px}.sim-box{padding:16px 12px;max-width:96%}.sim-box .sim{padding:20px 14px}.svc-icons{max-width:100%}.sim-checks,.sim-form{grid-template-columns:1fr}.sim-cta{flex-direction:column}.sim-cta .btn{width:100%}}
