/* =========================================================================
   SKGENIUS · structure encre teal SKGENIUS (≠ violet)
   Hero sombre + sections alternées claires/sombres · Archivo / Inter
   ========================================================================= */
:root{
  /* nuit teal SKGENIUS */
  --night:#06171C;        /* fond hero / sections sombres */
  --night2:#0A2027;       /* surface élevée */
  --night3:#0E2C35;       /* cartes sombres */
  --ink-0:#031013;        /* intro la plus sombre */
  --dline:rgba(255,255,255,.10);
  --dline2:rgba(255,255,255,.18);

  --teal:#0E5A6B;         /* brand */
  --teal-d:#0A4250;
  --teal-l:#27C2D9;       /* teal lumineux (accent sur sombre) */
  --signal:#E2231A;       /* rouge action */
  --signal-soft:#ff5a4d;
  --gold:#F2B705;

  /* clair (sections inversées) */
  --ink:#0C1A1F;
  --ink2:#3A4A50;
  --dim:#6B7B82;
  --paper:#FFFFFF;
  --paper2:#F4F7F8;
  --paper3:#E9F0F1;
  --line:#E2E9EB;
  --line2:#D0DADD;

  --on-dark:#E7F2F3;
  --on-dark-dim:rgba(231,242,243,.62);

  --disp:'Archivo',sans-serif;
  --body:'Inter',sans-serif;
  --mono:'Lato',monospace;
  --rad:16px; --rad-lg:26px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--paper);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--signal);color:#fff}
.wrap{max-width:1240px;margin:0 auto;padding:0 30px}
:focus-visible{outline:2px solid var(--teal-l);outline-offset:3px}

/* HEADER (clair, sticky) */
header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.88);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
.topbar{background:var(--night);color:var(--on-dark);font-family:var(--mono);font-size:.74rem}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:38px}
.topbar a{color:var(--on-dark)}.topbar .tb-right{display:flex;gap:18px}.topbar b{color:#fff}
@media(max-width:720px){.topbar .tb-right{display:none}}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px}
.logo{display:flex;align-items:center;gap:12px;color:var(--ink)}
.logo svg{height:40px;width:auto}
nav.links{display:flex;gap:30px;align-items:center}
nav.links a{font-size:.93rem;font-weight:500;color:var(--ink2);transition:color .2s}
nav.links a:hover{color:var(--teal)}
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--disp);font-weight:600;font-size:.9rem;padding:12px 24px;border-radius:999px;cursor:pointer;border:none;transition:transform .25s,box-shadow .25s,background .25s,color .25s;white-space:nowrap}
.btn-signal{background:var(--signal);color:#fff !important;}
.btn-signal:hover{transform:translateY(-2px);box-shadow:0 14px 30px -12px var(--signal)}
.btn-teal{background:var(--teal);color:#fff}.btn-teal:hover{transform:translateY(-2px);box-shadow:0 14px 30px -12px var(--teal)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line2)}.btn-ghost:hover{border-color:var(--teal);color:var(--teal)}
.btn-light{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.32)}.btn-light:hover{background:rgba(255,255,255,.18)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--ink);transition:.3s}
@media(max-width:960px){
  nav.links{position:fixed;inset:116px 0 auto 0;background:var(--paper);flex-direction:column;gap:0;padding:8px 0;border-bottom:1px solid var(--line);transform:translateY(-160%);transition:transform .35s;box-shadow:0 30px 50px -30px rgba(0,0,0,.25)}
  nav.links.open{transform:none}
  nav.links a{width:100%;padding:15px 30px;border-bottom:1px solid var(--line)}
  nav.links .btn{margin:12px 30px;justify-content:center}
  .burger{display:flex}
}

/* eyebrow */
.eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--teal);display:inline-flex;align-items:center;gap:11px;font-weight:500}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--signal)}
.eyebrow.center{justify-content:center}
.dark .eyebrow,.hero .eyebrow{color:var(--gold)}.dark .eyebrow::before,.hero .eyebrow::before{background:var(--gold)}

/* =========================================================================
   HERO — carte sombre unique : contenu à gauche + panneaux verticaux à droite
   ========================================================================= */
.hero{padding:24px 0 0;background:var(--paper)}
.hero-card{position:relative;border-radius:var(--rad-lg);overflow:hidden;background:linear-gradient(155deg,var(--night2) 0%,var(--ink-0) 100%);border:1px solid var(--dline);display:grid;grid-template-columns:1fr 250px;min-height:560px}
.hero-card::before{content:"";position:absolute;width:560px;height:560px;border-radius:50%;top:-180px;left:38%;filter:blur(80px);z-index:0;background:radial-gradient(circle,rgba(39,194,217,.16),transparent 65%)}
.hero-card::after{content:"";position:absolute;width:420px;height:420px;border-radius:50%;bottom:-220px;left:-80px;filter:blur(80px);z-index:0;background:radial-gradient(circle,rgba(226,35,26,.12),transparent 65%)}

/* intro animée */
.hero-intro{position:absolute;inset:0;z-index:30;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--ink-0);animation:fadeOutIntro 2500ms forwards}
.hero-intro-letter{font-family:var(--disp);font-size:clamp(90px,16vw,210px);font-weight:800;color:#fff;letter-spacing:-.05em;line-height:.9;animation:introPop 1s cubic-bezier(.2,.8,.2,1)}
.hero-intro-tagline{font-family:var(--mono);font-size:clamp(11px,2.2vw,16px);color:var(--on-dark-dim);letter-spacing:.42em;text-transform:uppercase;margin-top:16px;padding-left:.42em}
.hero-progress{position:absolute;bottom:0;left:0;height:3px;background:linear-gradient(90deg,var(--signal),var(--gold));animation:heroProgress 2500ms linear forwards}
@keyframes fadeOutIntro{0%{opacity:1}74%{opacity:1;visibility:visible}100%{opacity:0;visibility:hidden}}
@keyframes introPop{from{opacity:0;transform:scale(.7)}to{opacity:1;transform:none}}
@keyframes heroProgress{from{width:0}to{width:100%}}

/* contenu hero */
.hero-content{position:relative;z-index:10;padding:56px 50px;align-self:center}
.hero-tag{font-family:var(--mono);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:10px;margin-bottom:22px}
.hero-tag::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--gold)}
.hero h1{font-family:var(--disp);font-weight:800;font-size:clamp(2.1rem,4vw,3.2rem);line-height:1.05;letter-spacing:-.03em;color:#fff}
.hero h1 em{font-style:normal;color:var(--gold)}
.hero-lede{font-size:1.05rem;color:var(--on-dark);max-width:54ch;margin-top:20px;opacity:.9}
.hero-stats{display:flex;gap:34px;flex-wrap:wrap;margin-top:34px}
.hero-stats .hs b{font-family:var(--disp);font-weight:700;font-size:1.6rem;color:#fff;display:block;letter-spacing:-.01em}
.hero-stats .hs span{font-size:.82rem;color:var(--on-dark-dim);max-width:22ch;display:block;margin-top:2px}
.hero-cta{display:flex;gap:13px;flex-wrap:wrap;margin-top:34px}

/* panneaux verticaux à droite (accordéon horizontal) */
.hpanels{position:relative;z-index:10;display:flex}
.hpanel{position:relative;width:62px;cursor:pointer;overflow:hidden;border-left:1px solid var(--dline);transition:width .55s cubic-bezier(.4,0,.2,1);background:linear-gradient(180deg,var(--night3),var(--ink-0))}
.hpanel:first-child{border-left:none}
.hpanel.open,.hpanel:hover,.hpanel:focus-within{width:200px}
.hpanel .pg{position:absolute;inset:0;opacity:.9;z-index:0}
.hpanel:nth-child(1) .pg{background:linear-gradient(180deg,rgba(226,35,26,.5),transparent 70%)}
.hpanel:nth-child(2) .pg{background:linear-gradient(180deg,rgba(14,90,107,.7),transparent 70%)}
.hpanel:nth-child(3) .pg{background:linear-gradient(180deg,rgba(242,183,5,.4),transparent 70%)}
.hpanel-v{position:absolute;top:22px;left:0;right:0;text-align:center;writing-mode:vertical-rl;transform:rotate(180deg);margin:0 auto;font-family:var(--mono);font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:#fff;z-index:2;white-space:nowrap}
.hpanel-c{position:absolute;inset:0;z-index:2;padding:22px;display:flex;flex-direction:column;justify-content:flex-end;opacity:0;transition:opacity .4s}
.hpanel.open .hpanel-c,.hpanel:hover .hpanel-c,.hpanel:focus-within .hpanel-c{opacity:1}
.hpanel.open .hpanel-v,.hpanel:hover .hpanel-v,.hpanel:focus-within .hpanel-v{opacity:0}
.hpanel-c .num{font-family:var(--mono);font-size:.72rem;color:rgba(255,255,255,.7)}
.hpanel-c h3{font-family:var(--disp);font-weight:700;font-size:1.1rem;color:#fff;margin-top:6px}
.hpanel-c p{font-size:.82rem;color:rgba(255,255,255,.82);margin-top:8px}
.hpanel-c .go{margin-top:14px;width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.4);display:grid;place-items:center;color:#fff;transition:.3s}
.hpanel:hover .go{background:#fff;color:var(--night)}
@media(max-width:880px){
  .hero-card{grid-template-columns:1fr;min-height:0}
  .hpanels{flex-direction:column}
  .hpanel{width:100%!important;border-left:none;border-top:1px solid var(--dline)}
  .hpanel-v{display:none}
  .hpanel{height:96px}
  .hpanel-c{opacity:1;justify-content:center}
  .hero-content{padding:40px 26px}
}
@media(prefers-reduced-motion:reduce){.hero-intro{display:none}.hpanel{transition:none}}

/* MARQUEE confiance */
.trust{padding:54px 0 60px;background:var(--paper)}
.trust h4{font-family:var(--disp);font-weight:700;font-size:1.3rem;color:var(--ink);margin-bottom:4px}
.trust .sub{font-size:.9rem;color:var(--dim);margin-bottom:28px}
.trust-logos{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.trust-logos .lg{font-family:var(--disp);font-weight:700;font-size:1.15rem;color:var(--ink2);opacity:.7;transition:.25s}
.trust-logos .lg:hover{opacity:1;color:var(--teal)}

/* CERTIFICATIONS (strip teal, cartes blanches) */
.certs{background:linear-gradient(160deg,var(--teal),var(--teal-d));padding:62px 0}
.certs-title{font-family:var(--disp);font-weight:700;color:#fff;font-size:clamp(1.4rem,3vw,2rem);letter-spacing:-.02em;margin:0 0 28px}
.cert-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:18px}
@media(max-width:900px){.cert-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.cert-grid{grid-template-columns:repeat(2,1fr)}}
.cert-card{background:#fff;border-radius:18px;aspect-ratio:1/.9;display:flex;align-items:center;justify-content:center;text-align:center;padding:18px;box-shadow:0 14px 30px -20px rgba(0,0,0,.4);transition:transform .3s}
.cert-card:hover{transform:translateY(-4px)}
.cert-card span{font-family:var(--disp);font-weight:600;font-size:.9rem;line-height:1.25;color:var(--teal-d)}

/* SECTIONS */
section{padding:90px 0}
.sec-head{max-width:760px}
h2{font-family:var(--disp);font-weight:700;font-size:clamp(1.8rem,3.4vw,2.5rem);letter-spacing:-.03em;line-height:1.12;margin-top:14px;color:var(--ink)}
.sec-lede{color:var(--ink2);font-size:1.05rem;max-width:62ch;margin-top:16px}

/* section claire alt */
.alt{background:var(--paper2)}
/* section sombre */
.dark{background:linear-gradient(160deg,var(--night2),var(--night));color:var(--on-dark);position:relative;overflow:hidden}
.dark h2{color:#fff}.dark .sec-lede{color:var(--on-dark)}

/* AGENCE — intro claire avec photo + stats (façon "Depuis 2018") */
.agence-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:54px;align-items:center}
@media(max-width:880px){.agence-grid{grid-template-columns:1fr;gap:32px}}
.agence-photo{border-radius:var(--rad);overflow:hidden;aspect-ratio:4/3;background:linear-gradient(150deg,var(--teal),var(--night));position:relative}
.agence-photo .ph-badge{position:absolute;inset:auto 0 0 0;padding:22px;color:#fff;font-family:var(--disp);font-weight:600;font-size:1.05rem;background:linear-gradient(0deg,rgba(3,16,19,.8),transparent)}
.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:36px}
@media(max-width:560px){.statband{grid-template-columns:1fr 1fr}}
.statband .s b{font-family:var(--disp);font-weight:800;font-size:2.1rem;color:var(--teal);display:block;letter-spacing:-.02em}
.statband .s span{font-size:.86rem;color:var(--ink2)}
.cii{margin-top:30px;padding:16px 22px;border:1px dashed var(--line2);border-radius:var(--rad);font-size:.92rem;color:var(--ink2);background:var(--paper)}
.cii b{color:var(--teal)}

/* EXPERTISES — onglets numérotés */
.xp{margin-top:48px;border-top:1px solid var(--line)}
.xp-row{display:grid;grid-template-columns:auto 1fr auto auto;gap:28px;align-items:center;padding:28px 8px;border-bottom:1px solid var(--line);transition:background .3s,padding .3s;position:relative}
.xp-row::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--signal);transform:scaleY(0);transition:transform .35s;transform-origin:top}
.xp-row:hover{background:var(--paper);padding-left:22px}
.alt .xp-row:hover{background:#fff}
.xp-row:hover::before{transform:scaleY(1)}
.xp-num{font-family:var(--mono);font-size:.82rem;color:var(--teal)}
.xp-main h3{font-family:var(--disp);font-weight:700;font-size:1.45rem;color:var(--ink);letter-spacing:-.01em}
.xp-main p{color:var(--ink2);font-size:.95rem;margin-top:6px;max-width:62ch}
.xp-tags{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;max-width:250px}
.xp-tags em{font-style:normal;font-family:var(--mono);font-size:.67rem;color:var(--ink2);border:1px solid var(--line2);padding:5px 11px;border-radius:999px}
.xp-go{font-size:1.5rem;color:var(--line2);transition:color .3s,transform .3s}
.xp-row:hover .xp-go{color:var(--signal);transform:translateX(4px)}
@media(max-width:820px){.xp-row{grid-template-columns:auto 1fr auto;gap:18px}.xp-tags{display:none}}

/* SOUVERAINETÉ — bandeau avec barre */
.souv{display:grid;grid-template-columns:1fr 1fr;gap:54px;margin-bottom:40px}
@media(max-width:880px){.souv{grid-template-columns:1fr;gap:24px}}
.souv-bar-card{background:linear-gradient(135deg,var(--teal),var(--night));border-radius:var(--rad);padding:34px;display:grid;grid-template-columns:auto 1fr;gap:30px;align-items:center;color:#fff;position:relative;overflow:hidden}
@media(max-width:620px){.souv-bar-card{grid-template-columns:1fr;gap:18px}}
.souv-bar-card .pct{font-family:var(--disp);font-weight:800;font-size:3.4rem;line-height:1;color:#fff}
.souv-bar-card .pct small{display:block;font-size:.8rem;font-weight:500;color:var(--on-dark-dim);margin-top:8px;letter-spacing:0}
.souv-bar-card .txt b{font-family:var(--disp);font-weight:600;font-size:1.02rem;display:block;margin-bottom:6px}
.souv-bar-card .txt p{font-size:.9rem;color:var(--on-dark)}
.bars{margin-top:18px;display:flex;flex-direction:column;gap:12px}
.bar .bl{display:flex;justify-content:space-between;font-family:var(--mono);font-size:.72rem;color:var(--on-dark-dim);margin-bottom:5px}
.bar .bt{height:7px;border-radius:999px;background:rgba(255,255,255,.14);overflow:hidden}
.bar .bf{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--gold),var(--signal));width:0;transition:width 1.4s cubic-bezier(.4,0,.2,1)}
.bar.in .bf{width:var(--w)}

/* SECTEURS (4 colonnes) */
.sectors{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;margin-top:48px}
@media(max-width:880px){.sectors{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.sectors{grid-template-columns:1fr}}
.sector{border-top:2px solid var(--line2);padding-top:20px;position:relative;transition:border-color .3s}
.sector::before{content:"";position:absolute;top:-2px;left:0;width:40px;height:2px;background:var(--signal)}
.sector:hover{border-top-color:var(--teal)}
.sector .si{width:40px;height:40px;border-radius:10px;background:var(--paper3);color:var(--teal);display:grid;place-items:center;font-family:var(--disp);font-weight:700;margin-bottom:14px}
.sector h3{font-family:var(--disp);font-weight:700;font-size:1.1rem;color:var(--ink);line-height:1.25}
.sector p{color:var(--ink2);font-size:.9rem;margin-top:10px}

/* REFS */
.refs{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:48px}
@media(max-width:780px){.refs{grid-template-columns:1fr}}
.ref{position:relative;border:1px solid var(--line);border-radius:var(--rad);padding:32px;background:var(--paper);transition:.3s;display:block;overflow:hidden}
.ref:hover{border-color:var(--line2);transform:translateY(-4px);box-shadow:0 24px 50px -32px rgba(14,90,107,.4)}
.ref .client{font-family:var(--mono);font-size:.72rem;color:var(--teal);letter-spacing:.05em}
.ref h3{font-family:var(--disp);font-weight:700;font-size:1.38rem;margin:10px 0 4px;color:var(--ink)}
.ref .stitle{color:var(--ink2);font-weight:500;font-size:.93rem;margin-bottom:12px}
.ref p{color:var(--ink2);font-size:.91rem}
.ref .tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:18px}
.ref .tags em{font-style:normal;font-family:var(--mono);font-size:.66rem;color:var(--ink2);border:1px solid var(--line2);padding:4px 10px;border-radius:999px}
.badge-giz{display:inline-block;background:var(--gold);color:var(--ink);font-family:var(--mono);font-size:.64rem;font-weight:600;padding:3px 9px;border-radius:999px;letter-spacing:.05em;margin-left:8px;vertical-align:middle}

/* PROJETS — liste sobre */
.projects{margin-top:44px;border-top:1px solid var(--line)}
.proj{display:flex;justify-content:space-between;align-items:baseline;gap:20px;padding:18px 8px;border-bottom:1px solid var(--line);transition:padding .3s,background .3s}
.proj:hover{padding-left:16px;background:var(--paper)}
.alt .proj:hover{background:#fff}
.proj .pt{font-family:var(--disp);font-weight:500;font-size:1.04rem;color:var(--ink)}
.proj .pi{font-family:var(--mono);font-size:.73rem;color:var(--teal);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}
.proj-note{font-size:.85rem;color:var(--dim);margin-top:18px}

/* ===== BLOC FINAL "NOS CLIENTS" — galerie + onglets secteurs (sombre) ===== */
.clients{background:linear-gradient(180deg,var(--night),var(--ink-0));color:var(--on-dark);padding:90px 0}
.clients .eyebrow{color:var(--gold)}.clients .eyebrow::before{background:var(--gold)}
.clients h2{color:#fff;max-width:20ch}
.client-tabs{display:flex;gap:10px;flex-wrap:wrap;margin-top:30px}
.client-tab{font-family:var(--disp);font-weight:600;font-size:.9rem;padding:9px 20px;border-radius:999px;border:1px solid var(--dline2);color:var(--on-dark);cursor:pointer;transition:.25s;background:transparent}
.client-tab.active,.client-tab:hover{background:#fff;color:var(--night);border-color:#fff}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px;margin-top:34px}
@media(max-width:880px){.gallery{grid-template-columns:repeat(2,1fr)}}
.tile{position:relative;border-radius:var(--rad);overflow:hidden;background:var(--night3);border:1px solid var(--dline)}
.tile.tall{grid-row:span 2}
.tile .tg{position:absolute;inset:0;background:linear-gradient(160deg,rgba(14,90,107,.5),rgba(3,16,19,.7))}
.tile.s2 .tg{background:linear-gradient(160deg,rgba(226,35,26,.4),rgba(3,16,19,.7))}
.tile.s3 .tg{background:linear-gradient(160deg,rgba(242,183,5,.35),rgba(3,16,19,.75))}
.tile.s4 .tg{background:linear-gradient(160deg,rgba(39,194,217,.4),rgba(3,16,19,.7))}
.tile .tc{position:absolute;inset:auto 0 0 0;padding:20px;z-index:2}
.tile .tc .tt{font-family:var(--disp);font-weight:700;font-size:1.05rem;color:#fff}
.tile .tc .td{font-size:.82rem;color:rgba(255,255,255,.8);margin-top:4px}
.tile .ttag{position:absolute;top:14px;left:14px;z-index:2;font-family:var(--mono);font-size:.64rem;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:rgba(0,0,0,.3);padding:4px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.2)}

/* STEPS (méthode) */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:48px}
@media(max-width:820px){.steps{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.steps{grid-template-columns:1fr}}
.step{border-top:2px solid var(--line2);padding-top:20px;position:relative}
.step::before{content:"";position:absolute;top:-2px;left:0;width:40px;height:2px;background:var(--signal)}
.step .n{font-family:var(--mono);font-size:.74rem;color:var(--teal);letter-spacing:.1em}
.step h4{font-family:var(--disp);font-weight:700;font-size:1.12rem;margin:12px 0 8px;color:var(--ink)}
.step p{font-size:.9rem;color:var(--ink2)}
.dark .step{border-top-color:var(--dline2)}.dark .step h4{color:#fff}.dark .step p{color:var(--on-dark-dim)}.dark .step .n{color:var(--gold)}

/* POSTS */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px}
@media(max-width:880px){.posts{grid-template-columns:1fr}}
.post{border:1px solid var(--line);border-radius:var(--rad);overflow:hidden;background:var(--paper);transition:.3s;display:flex;flex-direction:column}
.post:hover{transform:translateY(-4px);box-shadow:0 24px 50px -32px rgba(14,90,107,.4)}
.post .body{padding: 1.4rem}
.post .ph{height:6px;background:linear-gradient(90deg,var(--teal),var(--signal))}
.post .pbody{padding:26px;display:flex;flex-direction:column;flex:1}
.post .cat{font-family:var(--mono);font-size:.7rem;color:var(--teal);text-transform:uppercase;letter-spacing:.08em}
.post h3{font-family:var(--disp);font-weight:700;font-size:1.12rem;margin:10px 0 8px;line-height:1.3;color:var(--ink)}
.post p{color:var(--ink2);font-size:.9rem;flex:1}
.post .meta{font-family:var(--mono);font-size:.72rem;color:var(--dim);margin-top:16px}

/* TECH (capacités) */
.tech{display:flex;flex-wrap:wrap;gap:12px;margin-top:44px}
.tech .t{font-family:var(--mono);font-size:.84rem;padding:12px 18px;border-radius:999px;background:var(--paper);border:1px solid var(--line2);transition:.25s;color:var(--ink2)}
.tech .t:hover{border-color:var(--teal);color:var(--teal);transform:translateY(-2px)}

/* PROSE */
.prose{max-width:760px}.prose p{margin-bottom:16px;color:var(--ink2)}.prose h2{font-size:1.5rem;margin:34px 0 12px}.prose strong{color:var(--ink)}
.prose a,.article a{color:var(--teal);text-decoration:underline;text-underline-offset:3px}
.article{max-width:780px;margin:0 auto}.article p{margin-bottom:16px;color:var(--ink2);font-size:1.05rem}.article h2{font-size:1.55rem;margin:36px 0 14px;color:var(--ink)}

/* crumb / phead */
.crumb{font-family:var(--mono);font-size:.74rem;color:var(--dim);padding-top:32px}.crumb a:hover{color:var(--teal)}
.phead{padding:54px 0 22px}
.phead h1{font-family:var(--disp);font-weight:800;font-size:clamp(2rem,4.2vw,3.1rem);letter-spacing:-.03em;line-height:1.07;margin-top:16px;max-width:20ch;color:var(--ink)}
.phead .lede{color:var(--ink2);font-size:1.1rem;max-width:62ch;margin-top:18px}

/* final cta */
.final-card{position:relative;border-radius:var(--rad-lg);overflow:hidden;background:linear-gradient(150deg,var(--teal),var(--night));padding:70px 56px;text-align:center;color:#fff}
.final-card::before{content:"";position:absolute;width:560px;height:560px;border-radius:50%;top:-280px;left:50%;transform:translateX(-50%);filter:blur(80px);background:radial-gradient(circle,rgba(242,183,5,.2),transparent 65%)}
.final-card>*{position:relative}
.final-card h2{color:#fff;margin:14px auto 0;max-width:20ch}
.final-card p{color:var(--on-dark);font-size:1.08rem;max-width:50ch;margin:14px auto 28px}
.final-card .hero-cta{justify-content:center}
.contact-line{display:flex;gap:28px;justify-content:center;flex-wrap:wrap;margin-top:26px;font-family:var(--mono);font-size:.84rem}
.contact-line a{color:var(--on-dark)}.contact-line a:hover{color:#fff}

/* contact form */
.cform{display:grid;gap:16px;max-width:640px;margin-top:32px}
.cform .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.cform .row{grid-template-columns:1fr}}
.cform label{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--dim);display:block;margin-bottom:6px}
.cform input,.cform textarea,.cform select{width:100%;padding:13px 15px;border:1px solid var(--line2);border-radius:11px;font-family:var(--body);font-size:.95rem;background:var(--paper);color:var(--ink)}
.cform input:focus,.cform textarea:focus,.cform select:focus{outline:none;border-color:var(--teal)}
.cform textarea{min-height:140px;resize:vertical}
.panel-card{border:1px solid var(--line);border-radius:var(--rad);padding:30px;background:var(--paper2)}

/* metrics + cards (compat pages internes) */
.metrics{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.metrics>div{flex:1 1 150px;border:1px solid var(--line);border-radius:var(--rad);padding:22px;background:var(--paper2)}
.metrics>div b{font-family:var(--disp);font-size:1.35rem;font-weight:700;color:var(--ink);display:block}
.metrics>div span{font-size:.84rem;color:var(--ink2)}
.intro-block{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
@media(max-width:820px){.intro-block{grid-template-columns:1fr;gap:28px}}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:46px}
@media(max-width:880px){.cards{grid-template-columns:1fr}}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--rad);padding:30px;transition:.3s;display:flex;flex-direction:column}
.card:hover{border-color:var(--line2);transform:translateY(-3px);box-shadow:0 22px 46px -32px rgba(14,90,107,.4)}
.card .num{font-family:var(--mono);font-size:.72rem;color:var(--teal)}
.card h3{font-family:var(--disp);font-weight:700;font-size:1.18rem;margin:12px 0 9px;color:var(--ink)}
.card p{color:var(--ink2);font-size:.93rem;flex:1}
.card .tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:18px}
.card .tags em{font-style:normal;font-family:var(--mono);font-size:.68rem;color:var(--ink2);border:1px solid var(--line2);padding:5px 10px;border-radius:999px}
.card .more{font-family:var(--disp);font-weight:600;font-size:.85rem;color:var(--signal);margin-top:16px}
.band{position:relative;background:linear-gradient(150deg,var(--teal),var(--night));border-radius:var(--rad-lg);padding:52px;overflow:hidden;color:#fff;margin-top:10px}
.band h2{color:#fff;max-width:18ch}.band .lede2{color:var(--on-dark);font-size:1.02rem;margin-top:16px}
.band-in{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:46px}
@media(max-width:820px){.band{padding:34px}.band-in{grid-template-columns:1fr;gap:26px}}
.band .eyebrow{color:var(--gold)}.band .eyebrow::before{background:var(--gold)}
.checklist div{display:flex;gap:14px;padding:15px 0;border-bottom:1px solid rgba(255,255,255,.16);align-items:flex-start}
.checklist div:last-child{border-bottom:none}
.checklist .k{font-family:var(--mono);font-size:.74rem;color:var(--gold);flex:none;width:30px;padding-top:3px}
.checklist b{font-family:var(--disp);font-weight:600;font-size:1rem;display:block;color:#fff}
.checklist p{color:var(--on-dark-dim);font-size:.86rem;margin-top:2px}

/* footer */
footer{background:var(--ink-0);color:var(--on-dark);padding:64px 0 36px}
footer .logo{color:#fff}
.foot{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:30px}
@media(max-width:820px){.foot{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot{grid-template-columns:1fr}}
.foot .col h5{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--on-dark-dim);margin-bottom:14px}
.foot .col a,.foot .col p{display:block;font-size:.92rem;color:var(--on-dark);margin-bottom:8px;opacity:.86}
.foot .col a:hover{opacity:1;color:#fff}
.foot-tag{color:var(--on-dark);opacity:.82;font-size:.92rem;margin-top:16px;max-width:36ch}
.foot-base{margin-top:44px;padding-top:24px;border-top:1px solid var(--dline);font-family:var(--mono);font-size:.76rem;color:var(--on-dark-dim);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}

/* reveal */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s,transform .8s}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}

/* =========================================================================
   ACCORDÉON PLEIN ÉCRAN — 4 panneaux, 1 ouvert, 3 onglets
   ========================================================================= */
.acc{display:flex;gap:12px;height:620px;margin-top:6px}
@media(max-width:980px){.acc{height:auto;flex-direction:column}}
.acc-panel{position:relative;border-radius:var(--rad-lg);overflow:hidden;cursor:pointer;
  flex:0 0 70px;transition:flex .6s cubic-bezier(.4,0,.2,1);background:linear-gradient(160deg,var(--night2),var(--ink-0));border:1px solid var(--dline)}
.acc-panel.open{flex:1 1 auto;cursor:default}
@media(max-width:980px){
  .acc-panel{flex:none}
  .acc-panel:not(.open){min-height:64px}
  .acc-panel.open{min-height:auto}
}
/* onglet vertical (panneau fermé) */
.acc-tab{position:absolute;inset:0;z-index:3;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:22px 0;opacity:1;transition:opacity .3s}
.acc-panel.open .acc-tab{opacity:0;pointer-events:none}
.acc-tab .dot{width:9px;height:9px;border-radius:50%;border:1px solid rgba(255,255,255,.5)}
.acc-tab .vlabel{writing-mode:vertical-rl;transform:rotate(180deg);font-family:var(--mono);font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:#fff;font-weight:500}
.acc-tab .plus{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.4);display:grid;place-items:center;color:#fff;font-size:18px;transition:.3s}
.acc-panel:hover .acc-tab .plus{background:var(--signal);border-color:var(--signal)}
@media(max-width:980px){
  .acc-tab{flex-direction:row;padding:0 22px;height:64px;justify-content:space-between}
  .acc-tab .vlabel{writing-mode:horizontal-tb;transform:none}
}
/* couleur d'onglet par type */
.acc-panel[data-kind="hero"]{background:linear-gradient(160deg,var(--night2),var(--ink-0))}
.acc-panel[data-kind="references"]{}
.acc-panel[data-kind="references"] .acc-tab,.acc-panel[data-kind="references"] {background-image:url('/assets/img/reference_hp.png'); background-position: center right; background-size: cover;}
.acc-panel[data-kind="agence"]:not(.open){background:linear-gradient(180deg,var(--teal-d),var(--ink-0))}
.acc-panel[data-kind="methode"]:not(.open){background:linear-gradient(180deg,#2a2410,var(--ink-0))}



/* contenu ouvert */
.acc-body{position:absolute;inset:0;z-index:2;opacity:0;transition:opacity .5s .15s;overflow:hidden}
.acc-panel.open .acc-body{opacity:1;position:relative}
.acc-panel:not(.open) .acc-body{pointer-events:none}

/* glows */
.acc-body::before{content:"";position:absolute;width:560px;height:560px;border-radius:50%;top:-200px;right:-120px;filter:blur(80px);z-index:0}
.acc-panel[data-kind="hero"] .acc-body::before{background:radial-gradient(circle,rgba(39,194,217,.16),transparent 65%)}
.acc-panel[data-kind="references"] .acc-body::before{background:radial-gradient(circle,rgba(226,35,26,.16),transparent 65%)}
.acc-panel[data-kind="agence"] .acc-body{background:linear-gradient(155deg,var(--teal),var(--teal-d))}
.acc-panel[data-kind="methode"] .acc-body{background:linear-gradient(155deg,var(--night2),var(--ink-0))}
.acc-panel[data-kind="methode"] .acc-body::before{background:radial-gradient(circle,rgba(242,183,5,.14),transparent 65%)}

.acc-in{position:relative;z-index:2;height:100%;padding:52px 50px;display:flex;flex-direction:column;justify-content:center;overflow-y:auto}
@media(max-width:980px){.acc-in{padding:40px 26px}}
.acc-kicker{font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;display:inline-flex;align-items:center;gap:10px;margin-bottom:18px;font-weight:500}
.acc-kicker::before{content:"";width:8px;height:8px;border-radius:50%}
.acc-panel[data-kind="hero"] .acc-kicker{color:var(--gold)}.acc-panel[data-kind="hero"] .acc-kicker::before{background:var(--gold)}
.acc-panel[data-kind="references"] .acc-kicker{color:var(--signal-soft)}.acc-panel[data-kind="references"] .acc-kicker::before{background:var(--signal-soft)}
.acc-panel[data-kind="agence"] .acc-kicker{color:#fff}.acc-panel[data-kind="agence"] .acc-kicker::before{background:#fff}
.acc-panel[data-kind="methode"] .acc-kicker{color:var(--gold)}.acc-panel[data-kind="methode"] .acc-kicker::before{background:var(--gold)}

/* ----- contenu HERO ----- */
.acc-hero h1{font-family:var(--disp);font-weight:800;font-size:clamp(2rem,3.6vw,3rem);line-height:1.06;letter-spacing:-.03em;color:#fff;max-width:16ch}
.acc-hero h1 em{font-style:normal;color:var(--gold)}
.acc-hero .lede{font-size:1.05rem;color:var(--on-dark);max-width:52ch;margin-top:20px;opacity:.9}
.acc-hero .stats{display:flex;gap:34px;flex-wrap:wrap;margin-top:32px}
.acc-hero .stats b{font-family:var(--disp);font-weight:700;font-size:1.55rem;color:#fff;display:block;letter-spacing:-.01em}
.acc-hero .stats span{font-size:.8rem;color:var(--on-dark-dim);max-width:22ch;display:block;margin-top:2px}
.acc-hero .cta{display:flex;gap:13px;flex-wrap:wrap;margin-top:16px}

/* ----- contenu RÉFÉRENCES ----- */
.acc-ref{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;height:100%}
@media(max-width:880px){.acc-ref{grid-template-columns:1fr;gap:24px}}
.acc-ref .left h2{font-family:var(--disp);font-weight:800;font-size:clamp(1.8rem,3vw,2.6rem);line-height:1.08;color:#fff}
.acc-ref .left h2 em{font-style:normal;color:var(--signal-soft)}
.acc-ref .left .sep{width:80px;height:3px;background:var(--signal);margin:22px 0}
.acc-ref .left p{color:var(--on-dark);font-size:1rem;max-width:42ch}
.acc-ref .card{background:#fff;border-radius:var(--rad);padding:38px;text-align:center;box-shadow:0 30px 60px -30px rgba(0,0,0,.5)}
.acc-ref .card .np{font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--signal);font-weight:600}
.acc-ref .card .logo-circle{width:203px;height:72px;margin:14px auto 18px;display:grid;place-items:center;font-family:var(--disp);font-weight:800;color:var(--teal);font-size:1.3rem}
.acc-ref .card .cname{font-family:var(--disp);font-weight:800;font-size:1.7rem;color:var(--ink);line-height:1.1}
.acc-ref .card .csec{font-size:.86rem;color:var(--dim);margin-top:8px}
.acc-ref .card .cline{border-top:1px solid var(--line);margin:20px 0 0;padding-top:16px;font-family:var(--disp);font-weight:600;color:var(--ink2);font-size:.95rem}

/* ----- contenu AGENCE ----- */
.acc-agence{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center;height:100%}
@media(max-width:880px){.acc-agence{grid-template-columns:1fr;gap:26px}}
.acc-agence h2{font-family:var(--disp);font-weight:800;font-size:clamp(1.7rem,2.8vw,2.3rem);color:#fff;line-height:1.1}
.acc-agence .sub{font-family:var(--disp);font-weight:600;color:#fff;font-size:1.05rem;margin-top:14px}
.acc-agence p{color:var(--on-dark);font-size:.98rem;margin-top:10px;max-width:46ch}
.acc-agence .st{display:flex;gap:16px;margin-top:26px;flex-wrap:wrap}
.acc-agence .st b{font-family:var(--disp);font-weight:800;font-size:1.6rem;color:#fff;display:block}
.acc-agence .st span{font-size:.78rem;color:var(--on-dark-dim)}
.acc-agence .photo{border-radius:var(--rad);overflow:hidden;aspect-ratio:4/3;background:linear-gradient(150deg,var(--night2),var(--ink-0));position:relative;border:1px solid rgba(255,255,255,.2)}
.acc-agence .photo .cap{position:absolute;inset:auto 0 0 0;padding:20px;color:#fff;font-size:.9rem;font-weight:500;background:linear-gradient(0deg,rgba(3,16,19,.85),transparent)}
.acc-agence .subnav{margin-top:28px;border-top:1px solid rgba(255,255,255,.2);padding-top:16px;display:flex;gap:22px;flex-wrap:wrap;font-family:var(--mono);font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:var(--on-dark-dim)}
.acc-agence .subnav b{color:#fff;font-weight:500}

/* ----- contenu MÉTHODE ----- */
.acc-meth{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center;height:100%}
@media(max-width:880px){.acc-meth{grid-template-columns:1fr;gap:26px}}
.acc-meth h2{font-family:var(--disp);font-weight:800;font-size:clamp(1.7rem,2.8vw,2.3rem);color:#fff;line-height:1.1}
.acc-meth .sub{font-family:var(--disp);font-weight:600;color:#fff;font-size:1.02rem;margin-top:12px}
.acc-meth p{color:var(--on-dark);font-size:.96rem;margin-top:10px;max-width:46ch}
.acc-meth .nums{display:flex;gap:30px;margin-top:24px}
.acc-meth .nums b{font-family:var(--disp);font-weight:800;font-size:1.9rem;color:#fff;display:block}
.acc-meth .nums span{font-size:.78rem;color:var(--on-dark-dim)}
.meth-card{background:rgba(255,255,255,.05);border:1px solid var(--dline2);border-radius:var(--rad);overflow:hidden}
.meth-card .mh{display:flex;justify-content:space-between;align-items:baseline;padding:18px 22px;border-bottom:1px solid var(--dline)}
.meth-card .mh b{font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:#fff}
.meth-card .mh span{font-family:var(--mono);font-size:.72rem;color:var(--on-dark-dim)}
.meth-row{display:grid;grid-template-columns:auto 1fr;gap:16px;padding:15px 22px;border-bottom:1px solid var(--dline);align-items:baseline}
.meth-row:last-child{border-bottom:none}
.meth-row .ml{font-family:var(--mono);font-size:.8rem;color:var(--gold)}
.meth-row .mt b{font-family:var(--disp);font-weight:700;color:#fff;font-size:.98rem}
.meth-row .mt em{font-style:normal;color:var(--on-dark-dim);font-size:.92rem}
.acc-meth .footnav{margin-top:26px;border-top:1px solid var(--dline);padding-top:14px;display:flex;gap:18px;flex-wrap:wrap;font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--on-dark-dim)}

/* =========================================================================
   AJOUTS — carousel logos, slider projets, ref-cards, villes, spec, FAQ,
   modèles d'intervention, filtres références
   ========================================================================= */

/* --- Carousel logos clients (marquee) --- */
.logo-marquee{overflow:hidden;width:100%;padding:10px 0;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.logo-track{display:flex;align-items:center;gap:64px;width:max-content;animation:logo-scroll 42s linear infinite}
.logo-marquee:hover .logo-track{animation-play-state:paused}
.logo-track .lg-item{flex:none;display:flex;align-items:center;justify-content:center;height:54px}
.logo-track .lg-item img{max-height:48px;max-width:150px;width:auto;object-fit:contain;filter:grayscale(1);opacity:.62;transition:.3s}
.logo-track .lg-item img:hover{filter:grayscale(0);opacity:1}
@keyframes logo-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.logo-track{animation:none;flex-wrap:wrap;justify-content:center}}

/* --- Modèles d'intervention --- */
.inter-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:46px}
@media(max-width:980px){.inter-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.inter-grid{grid-template-columns:1fr}}
.inter-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--rad);padding:26px;display:flex;flex-direction:column;transition:.3s}
.inter-card:hover{border-color:var(--line2);transform:translateY(-3px);box-shadow:0 22px 46px -32px rgba(14,90,107,.35)}
.inter-card h3{font-family:var(--disp);font-weight:700;font-size:1.12rem;color:var(--ink);margin-bottom:4px}
.inter-card .inter-sub{font-family:var(--mono);font-size:.74rem;color:var(--teal);text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px}
.inter-card p{color:var(--ink2);font-size:.9rem;flex:1}
.inter-card .tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:16px}
.inter-card .tags em{font-style:normal;font-family:var(--mono);font-size:.66rem;color:var(--ink2);border:1px solid var(--line2);padding:4px 9px;border-radius:999px}

/* --- Slider projets livrés (image · titre · desc · lien) --- */
.slider{position:relative;margin-top:48px}
.slider-viewport{overflow:hidden}
.slider-track{display:flex;gap:20px;scroll-behavior:smooth;overflow-x:auto;padding-bottom:8px;scrollbar-width:none}
.slider-track::-webkit-scrollbar{display:none}
.slide{flex:0 0 clamp(280px,42%,440px);background:var(--night2);border:1px solid var(--dline);border-radius:var(--rad-lg);overflow:hidden;position:relative;text-decoration:none;display:flex;flex-direction:column;transition:.3s;min-height:380px}
.slide:hover{transform:translateY(-4px);border-color:var(--dline2)}
.slide-media{height:200px;background:linear-gradient(150deg,var(--night3),var(--ink-0));display:flex;align-items:center;justify-content:center;padding:30px;position:relative}
.slide-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,var(--night2))}
.slide-media img{max-height:90px;max-width:70%;object-fit:contain;filter:brightness(0) invert(1);opacity:.92;position:relative;z-index:1}
.slide-body{padding:24px 26px 28px;display:flex;flex-direction:column;flex:1;color:#fff}
.slide-tag{font-family:var(--mono);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--teal-l);margin-bottom:10px}
.slide-body h3{font-family:var(--disp);font-weight:700;font-size:1.3rem;color:#fff;margin-bottom:10px}
.slide-body p{color:var(--on-dark-dim);font-size:.92rem;line-height:1.6;flex:1}
.slide-go{margin-top:18px;font-family:var(--disp);font-weight:600;font-size:.88rem;color:var(--signal-soft)}
.slider-nav{position:absolute;top:38%;z-index:5;width:46px;height:46px;border-radius:50%;border:1px solid var(--line2);background:#fff;color:var(--ink);font-size:1.6rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.25s;box-shadow:0 10px 24px -14px rgba(0,0,0,.4)}
.slider-nav:hover{background:var(--signal);color:#fff;border-color:var(--signal)}
.slider-nav.prev{left:-10px}.slider-nav.next{right:-10px}
@media(max-width:680px){.slider-nav{display:none}.slide{flex:0 0 84%}}

/* --- Cartes références (grille flexible) --- */
.ref-filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:34px}
.ref-chip{font-family:var(--mono);font-size:.78rem;letter-spacing:.02em;padding:9px 18px;border-radius:999px;border:1px solid var(--line2);color:var(--ink2);transition:.25s;background:#fff}
.ref-chip:hover{border-color:var(--teal);color:var(--teal)}
.ref-chip.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.ref-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:880px){.ref-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.ref-grid{grid-template-columns:1fr}}
.ref-card{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:var(--rad);padding:26px;display:flex;flex-direction:column;min-height:200px;transition:.3s;text-decoration:none}
.ref-card:hover{border-color:var(--line2);transform:translateY(-3px);box-shadow:0 22px 46px -32px rgba(14,90,107,.4)}
.ref-card.static{cursor:default}
.ref-card.static:hover{transform:none;box-shadow:none;border-color:var(--line)}
.ref-logo{height:64px;display:flex;align-items:center;margin-bottom:18px}
.ref-logo img{max-height:56px;max-width:160px;object-fit:contain}
.ref-meta{flex:1}
.ref-card h3{font-family:var(--disp);font-weight:700;font-size:1.12rem;color:var(--ink);line-height:1.25}
.ref-sector{display:inline-block;margin-top:8px;font-family:var(--mono);font-size:.72rem;color:var(--teal);text-transform:uppercase;letter-spacing:.05em}
.ref-go{margin-top:18px;font-family:var(--disp);font-weight:600;font-size:.84rem;color:var(--signal)}
.ref-hero-logo{height:90px;display:flex;align-items:center;margin-bottom:26px}
.ref-hero-logo img{max-height:80px;max-width:240px;object-fit:contain}
.ref-facts{display:flex;flex-wrap:wrap;gap:14px;margin-top:26px}
.ref-facts .fact{display:flex;flex-direction:column;gap:3px;background:var(--paper2);border:1px solid var(--line);border-radius:12px;padding:12px 18px;min-width:140px}
.ref-facts .fact b{font-family:var(--mono);font-size:.66rem;text-transform:uppercase;letter-spacing:.06em;color:var(--dim)}
.ref-facts .fact{font-size:.92rem;color:var(--ink)}
.badge-giz{display:inline-block;vertical-align:middle;font-family:var(--mono);font-size:.6rem;font-weight:700;letter-spacing:.05em;background:var(--signal);color:#fff;padding:2px 7px;border-radius:5px;margin-left:6px}

/* --- Villes (agences) — cartes manquantes, désormais stylées --- */
.villes{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
@media(max-width:780px){.villes{grid-template-columns:1fr}}
.ville{display:block;background:var(--paper);border:1px solid var(--line);border-radius:var(--rad);padding:30px;transition:.3s;text-decoration:none}
.ville:hover{border-color:var(--line2);transform:translateY(-3px);box-shadow:0 22px 46px -32px rgba(14,90,107,.4)}
.ville .sub{font-family:var(--mono);font-size:.72rem;color:var(--teal);text-transform:uppercase;letter-spacing:.05em}
.ville h3{font-family:var(--disp);font-weight:700;font-size:1.3rem;color:var(--ink);margin:8px 0 10px}
.ville p{color:var(--ink2);font-size:.92rem}
.ville .more{display:inline-block;margin-top:16px;font-family:var(--disp);font-weight:600;font-size:.85rem;color:var(--signal)}

/* --- Label "spec" (à lire aussi / nos expertises à…) — manquait --- */
.spec{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:var(--dim)}
.spec::before{content:"";width:26px;height:1px;background:var(--line2)}

/* --- FAQ --- */
.faq h2{font-family:var(--disp);font-weight:700;font-size:1.5rem;color:var(--ink);margin-bottom:18px}
.faq-item{border:1px solid var(--line);border-radius:12px;margin-bottom:12px;background:var(--paper);overflow:hidden}
.faq-item summary{cursor:pointer;list-style:none;padding:18px 22px;font-family:var(--disp);font-weight:600;font-size:1.02rem;color:var(--ink);position:relative;padding-right:48px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";position:absolute;right:22px;top:50%;transform:translateY(-50%);font-size:1.4rem;color:var(--teal);transition:.25s}
.faq-item[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq-item p{padding:0 22px 20px;color:var(--ink2);font-size:.94rem;line-height:1.7}

/* --- correctif logo-ref dans hero references panel --- */
.acc-ref .logo-ref img{max-height:60px;max-width:180px;object-fit:contain}
