/* ============================================================
   INGER SARLU — Direction artistique
   Palette : noir profond · béton clair · bleu acier
   Typo : Fraunces (éditorial) · Inter (technique) · JetBrains Mono (data)
   Signature : Liquid Glass · Bento Grid · grille blueprint
   ============================================================ */

:root{
  /* Couleurs */
  --ink:#15171C;          /* noir profond */
  --ink-2:#ECEAE2;        /* noir secondaire */
  --ink-3:#E7E4DB;        /* surface sombre */
  --paper:#F8F6F0;        /* blanc cassé / béton clair */
  --paper-2:#FFFFFF;
  --concrete:#6B6860;     /* gris béton */
  --concrete-d:#5C5E63;   /* gris ardoise */
  --steel:#3E5C6E;        /* bleu acier */
  --steel-l:#3E5C6E;      /* bleu acier clair */
  --steel-glow:#2E4A5E;
  --line-d:rgba(24,26,31,.10);  /* ligne sur fond sombre */
  --line-l:rgba(255,255,255,.12);     /* ligne sur fond clair */

  /* Glass */
  --glass-d:rgba(255,255,255,.45);
  --glass-d-2:rgba(255,255,255,.62);
  --glass-border-d:rgba(24,26,31,.10);
  --glass-l:rgba(255,255,255,.55);
  --glass-border-l:rgba(255,255,255,.7);

  /* Typo */
  --serif:'Fraunces',Georgia,serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;

  /* Rythme */
  --maxw:1280px;
  --gut:clamp(20px,5vw,72px);
  --r:18px;
  --r-lg:26px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-2:cubic-bezier(.65,.05,.36,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.55;
  overflow-x:hidden;
  font-weight:300;
  letter-spacing:.005em;
}
::selection{background:var(--steel);color:var(--paper)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer}

/* ---------- Curseur custom ---------- */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:9999;mix-blend-mode:difference;will-change:transform}
.cursor-dot{width:6px;height:6px;background:var(--paper);transform:translate(-50%,-50%)}
.cursor-ring{width:34px;height:34px;border:1px solid rgba(24,26,31,.5);transform:translate(-50%,-50%);transition:width .3s var(--ease),height .3s var(--ease),background .3s var(--ease),border-color .3s}
.cursor-ring.hover{width:54px;height:54px;background:rgba(143,185,206,.12);border-color:rgba(143,185,206,.6)}
@media(hover:none),(max-width:860px){.cursor-dot,.cursor-ring{display:none}}

/* ---------- Grille blueprint de fond ---------- */
.grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.5;
  background-image:radial-gradient(rgba(24,26,31,.025) 1px,transparent 1px);
  background-size:3px 3px;mix-blend-mode:overlay}

/* ============================================================
   LAYOUT
   ============================================================ */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);position:relative;z-index:2}
section{position:relative;z-index:2}

/* En-tête de section éditorial */
.sec-head{display:flex;align-items:baseline;gap:22px;margin-bottom:clamp(40px,6vw,72px)}
.sec-idx{font-family:var(--mono);font-size:12px;letter-spacing:.18em;color:var(--steel-l);
  border:1px solid var(--line-d);border-radius:40px;padding:6px 14px;white-space:nowrap;text-transform:uppercase}
.sec-kicker{font-family:var(--mono);font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--concrete)}
.sec-title{font-family:var(--serif);font-weight:400;line-height:1.02;letter-spacing:-.02em;
  font-size:clamp(2.1rem,5vw,4rem);font-optical-sizing:auto}
.sec-title em{font-style:italic;color:var(--steel-l)}

/* Liquid glass utilitaire */
.glass{
  background:var(--glass-d);
  backdrop-filter:blur(22px) saturate(150%);
  -webkit-backdrop-filter:blur(22px) saturate(150%);
  border:1px solid var(--glass-border-d);
  border-radius:var(--r-lg);
  position:relative;overflow:hidden;
  box-shadow:0 2px 6px rgba(36,52,68,.05),0 26px 54px -34px rgba(36,52,68,.30);
}
.glass::before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(135deg,rgba(255,255,255,.62),transparent 42%,transparent 60%,rgba(255,255,255,.14));
  opacity:.9}

/* Boutons */
.btn{display:inline-flex;align-items:center;gap:12px;font-family:var(--sans);font-weight:400;font-size:14px;
  letter-spacing:.01em;padding:15px 26px;border-radius:46px;border:1px solid transparent;
  transition:all .45s var(--ease);position:relative;overflow:hidden;will-change:transform}
.btn .arr{transition:transform .45s var(--ease)}
.btn:hover .arr{transform:translateX(5px)}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--steel);color:var(--paper)}
.btn-ghost{background:transparent;border-color:var(--glass-border-d);color:var(--ink);
  backdrop-filter:blur(10px)}
.btn-ghost:hover{border-color:var(--steel-l);background:var(--glass-d-2)}

/* Reveal au scroll */
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease),transform 1.1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}

/* ============================================================
   NAVIGATION
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;transition:all .5s var(--ease)}
.nav-inner{max-width:var(--maxw);margin:14px auto 0;padding:0 18px;display:flex;align-items:center;
  justify-content:space-between;height:64px;border-radius:60px;
  background:rgba(255,255,255,.35);backdrop-filter:blur(20px) saturate(160%);
  -webkit-backdrop-filter:blur(20px) saturate(160%);
  border:1px solid var(--glass-border-d);box-shadow:0 10px 34px -16px rgba(36,52,68,.20);transition:all .5s var(--ease)}
.nav.scrolled .nav-inner{background:rgba(255,255,255,.72);margin-top:8px}
.nav-logo{display:flex;align-items:center;gap:11px;padding-left:12px}
.nav-logo .mark{width:30px;height:30px;flex:none}
.nav-logo .lt{line-height:1.05}
.nav-logo .lt b{font-family:'Inter', sans-serif !important;font-weight:500;font-size:18px;letter-spacing:.01em;display:block}
.nav-logo .lt span{font-family:'Inter', sans-serif !important;font-size:8.5px;letter-spacing:.22em;color:var(--concrete);text-transform:uppercase}
.nav-links{display:flex;gap:4px;align-items:center}
.nav-links a{font-size:13.5px;font-weight:400;color:rgba(24,26,31,.78);padding:9px 15px;border-radius:40px;
  transition:all .35s var(--ease);position:relative}
.nav-links a:hover{color:var(--ink);background:var(--glass-d-2)}
.nav-cta{display:flex;align-items:center;gap:10px}
.nav-cta .btn{padding:11px 20px;font-size:13px}
/* Sélecteur de langue FR/EN */
.lang-switch{display:inline-flex;align-items:center;gap:2px;padding:4px;border-radius:40px;
  border:1px solid var(--glass-border-d);background:var(--glass-d-2)}
.lang-opt{font-family:var(--mono);font-size:11px;letter-spacing:.06em;cursor:pointer;border:none;
  background:transparent;color:var(--concrete);padding:5px 11px;border-radius:30px;line-height:1;
  transition:color .3s var(--ease),background .3s var(--ease)}
.lang-opt:hover{color:var(--ink)}
.lang-opt.active{background:var(--ink);color:var(--paper)}
.lang-sep{width:1px;height:13px;background:var(--glass-border-d)}
.m-menu-head .lang-switch{margin-left:auto;margin-right:12px}
.nav-burger{display:none;width:44px;height:44px;border-radius:50%;border:1px solid var(--glass-border-d);
  background:transparent;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.nav-burger span{width:17px;height:1.5px;background:var(--ink);transition:transform .35s var(--ease),opacity .3s;transform-origin:center}
@media(max-width:1080px){.nav-links{display:none}.nav-burger{display:flex}}
@media(max-width:560px){.nav-cta .btn{display:none}}

/* Menu mobile */
.m-menu{position:fixed;inset:0;z-index:999;background:rgba(255,255,255,.96);backdrop-filter:blur(30px);
  display:flex;flex-direction:column;justify-content:center;padding:0 var(--gut);
  opacity:0;pointer-events:none;transition:opacity .5s var(--ease)}
.m-menu.open{opacity:1;pointer-events:auto}
.m-links a{font-family:var(--serif);font-size:clamp(1.7rem,7.5vw,2.7rem);font-weight:400;padding:13px 0;
  color:var(--ink);border-bottom:1px solid var(--line-d);transition:color .35s,padding-left .35s;display:flex;align-items:baseline}
.m-links a:hover,.m-links a:active{color:var(--steel-l);padding-left:12px}

/* ============================================================
   HERO
   ============================================================ */
.hero{min-height:100vh;display:flex;align-items:center;padding-top:120px;padding-bottom:60px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-bg .glowA{position:absolute;width:60vw;height:60vw;top:-20%;right:-12%;border-radius:50%;
  background:radial-gradient(circle,rgba(62,92,110,.15),transparent 64%);filter:blur(30px)}
.hero-bg .glowB{position:absolute;width:46vw;height:46vw;bottom:-22%;left:-14%;border-radius:50%;
  background:radial-gradient(circle,rgba(143,185,206,.13),transparent 64%);filter:blur(40px)}
.hero-bg .bp{position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(var(--line-d) 1px,transparent 1px),linear-gradient(90deg,var(--line-d) 1px,transparent 1px);
  background-size:64px 64px;mask-image:radial-gradient(circle at 70% 35%,#000,transparent 72%);
  -webkit-mask-image:radial-gradient(circle at 70% 35%,#000,transparent 72%)}
.hero-bg .hero-fil{position:absolute;inset:0;width:100%;height:100%;stroke:var(--steel);fill:none;
  opacity:.06;pointer-events:none;
  mask-image:radial-gradient(125% 105% at 64% 45%,#000 52%,transparent 100%);
  -webkit-mask-image:radial-gradient(125% 105% at 64% 45%,#000 52%,transparent 100%)}
.hero-bg .hero-fil text{font-family:var(--mono);font-size:9px;fill:var(--steel);stroke:none}
@media(max-width:760px){.hero-bg .hero-fil{opacity:.04}}

.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:48px;align-items:center;width:100%}
@media(max-width:980px){.hero-grid{grid-template-columns:1fr;gap:40px}}

.hero-tag{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:11px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--steel-l);
  border:1px solid var(--line-d);border-radius:40px;padding:8px 16px;margin-bottom:30px}
.hero-tag .dot{width:6px;height:6px;border-radius:50%;background:var(--steel-glow);
  box-shadow:0 0 0 0 rgba(143,185,206,.6);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(143,185,206,.5)}70%{box-shadow:0 0 0 9px rgba(143,185,206,0)}100%{box-shadow:0 0 0 0 rgba(143,185,206,0)}}

.hero h1{font-family:var(--serif);font-weight:300;font-size:clamp(3.2rem,8.8vw,7rem);line-height:.94;
  letter-spacing:-.035em;font-optical-sizing:auto;margin-bottom:28px}
.hero h1 .l2{display:block;font-style:italic;font-weight:400;color:var(--steel-l);margin-left:.06em}
.hero p.lead{font-size:clamp(1rem,1.5vw,1.18rem);color:rgba(24,26,31,.74);max-width:30em;
  font-weight:300;line-height:1.62;margin-bottom:38px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:54px}

.hero-stats{display:flex;gap:34px;flex-wrap:wrap}
.hstat .n{font-family:var(--serif);font-weight:400;font-size:clamp(2.2rem,4vw,3rem);line-height:1;letter-spacing:-.02em}
.hstat .n .u{font-family:var(--mono);font-size:.42em;color:var(--steel-l);vertical-align:super;margin-left:2px}
.hstat .lab{font-family:var(--mono);font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;
  color:var(--concrete);margin-top:8px}
.hstat{position:relative;padding-left:20px}
.hstat::before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:1px;background:var(--line-d)}

/* Visuel hero : pile de cartes liquid glass */
.hero-visual{position:relative;height:min(60vh,560px);perspective:1400px}
.hv-card{position:absolute;border-radius:22px;overflow:hidden;
  background:var(--glass-d-2);backdrop-filter:blur(18px) saturate(150%);
  -webkit-backdrop-filter:blur(18px) saturate(150%);
  border:1px solid var(--glass-border-d);box-shadow:0 30px 70px -36px rgba(36,52,68,.26);
  transition:transform 1.1s var(--ease)}
.hv-1{width:62%;height:74%;top:4%;right:2%;z-index:3}
.hv-2{width:54%;height:50%;bottom:2%;left:0;z-index:4}
.hv-3{width:36%;height:30%;top:0;left:8%;z-index:2}
.hv-card .lbl{position:absolute;top:14px;left:16px;font-family:var(--mono);font-size:9.5px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--steel-glow);z-index:3}
.hv-card .lbl.br{top:auto;left:auto;bottom:14px;right:16px;color:rgba(24,26,31,.5)}
.hv-img{position:absolute;inset:0;z-index:1}
.hv-img svg{width:100%;height:100%}
@media(max-width:980px){.hero-visual{height:54vh;max-height:440px}}
@media(max-width:560px){.hero-visual{height:46vh}}

/* ============================================================
   TICKER CLIENTS
   ============================================================ */
.ticker{border-top:1px solid var(--line-d);border-bottom:1px solid var(--line-d);
  padding:26px 0;overflow:hidden;background:var(--ink-2);position:relative;z-index:2}
.ticker::before,.ticker::after{content:"";position:absolute;top:0;bottom:0;width:140px;z-index:3;pointer-events:none}
.ticker::before{left:0;background:linear-gradient(90deg,var(--ink-2),transparent)}
.ticker::after{right:0;background:linear-gradient(270deg,var(--ink-2),transparent)}
.ticker-track{display:flex;gap:0;width:max-content;animation:scroll-x 76s linear infinite}
.ticker:hover .ticker-track{animation-play-state:paused}
@keyframes scroll-x{to{transform:translateX(-50%)}}
.ticker-item{display:flex;align-items:center;gap:46px;padding:0 23px;font-family:var(--sans);
  font-weight:400;font-size:0.9rem;color:rgba(24,26,31,.62);white-space:nowrap;/*font-style:italic*/}
.ticker-item::after{content:"";width:5px;height:5px;border-radius:50%;background:var(--steel-l);opacity:.6}

/* ============================================================
   À PROPOS
   ============================================================ */
.about{padding:clamp(90px,12vw,150px) 0}
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(40px,6vw,90px);align-items:start}
@media(max-width:900px){.about-grid{grid-template-columns:1fr;gap:46px}.about-media{aspect-ratio:16/10;margin-top:24px}}
.about-lead{font-family:var(--serif);font-weight:300;font-size:clamp(1.5rem,2.6vw,2.15rem);line-height:1.32;
  letter-spacing:-.015em}
.about-lead em{font-style:italic;color:var(--steel-l)}
.about-body{color:rgba(24,26,31,.66);font-size:1.02rem;line-height:1.75;font-weight:300}
.about-points{list-style:none;margin-top:30px;display:grid;gap:2px}
.about-points li{display:flex;gap:18px;padding:18px 0;border-top:1px solid var(--line-d);align-items:flex-start}
.about-points li .pn{font-family:var(--mono);font-size:11px;color:var(--steel-l);padding-top:3px;letter-spacing:.1em}
.about-points li .pt{font-size:.98rem;color:rgba(24,26,31,.82);font-weight:300}
/* À propos — visuel éditorial */
.about-media{position:relative;margin-top:clamp(26px,3vw,40px);aspect-ratio:4/5;
  border-radius:var(--r-lg);overflow:hidden;background:var(--ink-2);
  border:1px solid var(--glass-border-d);
  box-shadow:0 2px 6px rgba(36,52,68,.05),0 34px 72px -38px rgba(36,52,68,.34)}
.about-media .slot-img{transition:transform 1.4s var(--ease)}
.about-media:hover .slot-img{transform:scale(1.05)}
.about-media::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;border-radius:inherit;
  background:linear-gradient(180deg,rgba(255,255,255,.10),transparent 28%,transparent 60%,rgba(18,23,28,.42));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.28)}
.am-cap{position:absolute;left:16px;bottom:16px;z-index:2;display:inline-flex;align-items:center;gap:9px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:#fff;
  background:rgba(18,23,28,.30);backdrop-filter:blur(10px) saturate(140%);-webkit-backdrop-filter:blur(10px) saturate(140%);
  padding:9px 14px;border-radius:30px;border:1px solid rgba(255,255,255,.20)}
.am-cap .am-dot{width:6px;height:6px;border-radius:50%;background:var(--steel-l);box-shadow:0 0 0 3px rgba(143,185,206,.25)}

/* Citation signature */
.about-quote{margin-top:clamp(56px,8vw,90px);padding:clamp(40px,6vw,72px);border-radius:var(--r-lg);
  text-align:center;position:relative}
.about-quote .q{font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(1.8rem,4.5vw,3.4rem);line-height:1.2;letter-spacing:-.02em}
.about-quote .q span{color:var(--steel-l)}
.about-quote .qc{font-family:var(--serif);font-size:6rem;line-height:0;color:var(--line-d);
  position:absolute;top:54px;left:40px}

/* ============================================================
   BENTO IDENTITÉ
   ============================================================ */
.bento{padding:0 0 clamp(90px,12vw,150px)}
.bento-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;grid-auto-rows:minmax(140px,auto)}
@media(max-width:900px){.bento-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.bento-grid{grid-template-columns:1fr}}
.bento-cell{padding:28px;display:flex;flex-direction:column;justify-content:space-between;
  transition:transform .6s var(--ease),border-color .6s,background .6s}
.bento-cell:hover{transform:translateY(-4px);border-color:rgba(143,185,206,.4)}
.bento-cell .ck{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--concrete)}
.bento-cell .cv{font-family:var(--serif);font-weight:400;line-height:1.18;letter-spacing:-.01em;margin-top:auto}
.bc-span2{grid-column:span 2}
.bc-row2{grid-row:span 2}
@media(max-width:560px){.bc-span2,.bc-row2{grid-column:auto;grid-row:auto}}
.bento-num .big{font-family:var(--serif);font-weight:300;font-size:clamp(3rem,6vw,4.6rem);line-height:.9;letter-spacing:-.03em}
.bento-num .big .u{font-family:var(--mono);font-size:.32em;color:var(--steel-l);vertical-align:super}
.bento-feature{background:linear-gradient(150deg,rgba(62,92,110,.13),rgba(255,255,255,.42));position:relative}
.bento-feature .cv{font-size:clamp(1.4rem,2.4vw,2rem)}
.bento-cell .cv-sub{font-size:.86rem;color:rgba(24,26,31,.6);font-weight:300;margin-top:10px;line-height:1.5}
.bento-mark{position:absolute;right:-30px;bottom:-30px;width:160px;height:160px;opacity:.16}

/* ============================================================
   SAVOIR-FAIRE / PRESTATIONS NUMÉROTÉES
   ============================================================ */
.skills{padding:clamp(90px,12vw,150px) 0;background:var(--ink-2);border-top:1px solid var(--line-d)}
.poles{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:54px}
.pole-chip{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  padding:9px 18px;border-radius:40px;border:1px solid var(--line-d);color:var(--steel-l);
  background:var(--glass-d)}
.presta-list{display:grid;grid-template-columns:repeat(2,1fr);gap:0}
@media(max-width:760px){.presta-list{grid-template-columns:1fr}}
.presta{display:flex;gap:24px;align-items:center;padding:30px 8px;border-top:1px solid var(--line-d);
  transition:padding-left .5s var(--ease),background .5s;position:relative;cursor:default}
.presta:hover{padding-left:24px}
.presta:hover .presta-name{color:var(--steel-glow)}
.presta:nth-child(1),.presta:nth-child(2){border-top:1px solid var(--line-d)}
.presta-no{font-family:var(--mono);font-size:13px;color:var(--steel-l);letter-spacing:.05em;flex:none;width:34px}
.presta-name{font-family:var(--serif);font-weight:400;font-size:clamp(1.25rem,2vw,1.65rem);
  letter-spacing:-.01em;transition:color .4s;line-height:1.15}

/* Séparateur de clôture sous le bloc Prestations (sous 05/06) */
.presta-end{display:flex;align-items:center;justify-content:center;gap:22px;
  padding:34px 8px 6px;border-top:1px solid var(--line-d)}
.presta-end .pe-rule{flex:1;max-width:160px;height:1px;
  background:linear-gradient(90deg,transparent,var(--line-d) 30%,var(--line-d) 70%,transparent)}
.presta-end .pe-mark{width:9px;height:9px;border:1px solid var(--steel-l);transform:rotate(45deg);
  opacity:.7;transition:transform .6s var(--ease),opacity .6s var(--ease),background .6s var(--ease)}
.presta-end:hover .pe-mark{transform:rotate(225deg);opacity:1;background:rgba(62,92,110,.08)}
@media(max-width:760px){.presta-end{gap:14px;padding:24px 4px 2px}.presta-end .pe-rule{max-width:90px}}
@media(prefers-reduced-motion:reduce){.presta-end .pe-mark{transition:none}}
.presta .arr{margin-left:auto;opacity:0;transform:translateX(-8px);transition:.45s var(--ease);color:var(--steel-l)}
.presta:hover .arr{opacity:1;transform:none}

/* Approche : 5 piliers */
.pillars{margin-top:clamp(70px,9vw,110px)}
.pillars-title{margin-top:8px}
.pillars-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
@media(max-width:1000px){.pillars-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.pillars-grid{grid-template-columns:1fr}}
.pillar{padding:26px 24px;border-radius:var(--r);min-height:230px;display:flex;flex-direction:column;
  transition:transform .6s var(--ease),background .6s,border-color .6s}
.pillar:hover{transform:translateY(-6px);border-color:rgba(143,185,206,.4)}
.pillar .pico{width:38px;height:38px;margin-bottom:auto;color:var(--steel-l)}
.pillar h4{font-family:var(--serif);font-weight:400;font-size:1.22rem;margin:22px 0 10px;letter-spacing:-.01em}
.pillar p{font-size:.84rem;color:rgba(24,26,31,.6);font-weight:300;line-height:1.55}

/* ============================================================
   DOMAINES D'EXPERTISE (3 cartes premium)
   ============================================================ */
.domains{padding:clamp(90px,12vw,150px) 0}
.domains-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:980px){.domains-grid{grid-template-columns:1fr}}
.domain{padding:0;overflow:hidden;display:flex;flex-direction:column;
  transition:transform .6s var(--ease),border-color .6s}
.domain:hover{transform:translateY(-6px);border-color:rgba(143,185,206,.45)}
.domain-vis{height:200px;position:relative;overflow:hidden;border-bottom:1px solid var(--line-d)}
.domain-vis svg{width:100%;height:100%}
.domain:hover .domain-vis svg{transform:scale(1.04)}
.domain-vis svg{transition:transform 1.2s var(--ease)}
.domain-agr{position:absolute;top:16px;left:16px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;
  background:rgba(255,255,255,.6);backdrop-filter:blur(8px);border:1px solid var(--glass-border-d);
  padding:7px 13px;border-radius:30px;color:var(--steel-glow)}
.domain-body{padding:30px 28px 32px;display:flex;flex-direction:column;flex:1}
.domain-body h3{font-family:var(--serif);font-weight:400;font-size:1.7rem;letter-spacing:-.01em;margin-bottom:6px}
.domain-cat{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--concrete);margin-bottom:22px}
.domain-list{list-style:none;display:grid;gap:0;margin-top:auto}
.domain-list li{font-size:.9rem;color:rgba(24,26,31,.72);font-weight:300;padding:11px 0;
  border-top:1px solid var(--line-d);display:flex;gap:12px;align-items:flex-start;line-height:1.45}
.domain-list li::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--steel-l);
  margin-top:8px;flex:none;opacity:.55;box-shadow:0 0 0 4px rgba(62,92,110,.08)}

/* ============================================================
   PORTFOLIO BENTO
   ============================================================ */
.portfolio{padding:clamp(90px,12vw,150px) 0;background:var(--ink-2);border-top:1px solid var(--line-d)}
.pf-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;grid-auto-rows:200px;grid-auto-flow:row dense}
@media(max-width:980px){.pf-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:620px){.pf-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:170px}}
.pf-card{border-radius:var(--r);overflow:hidden;position:relative;cursor:pointer;
  border:1px solid var(--line-d);transition:transform .6s var(--ease)}
.pf-card:hover{transform:translateY(-5px)}
.pf-vis{position:absolute;inset:0;z-index:0;transition:transform 1.3s var(--ease)}
.pf-vis svg{width:100%;height:100%}
.pf-card:hover .pf-vis{transform:scale(1.07)}
.pf-shade{position:absolute;inset:0;z-index:1;
  background:linear-gradient(to top,rgba(255,255,255,.92) 8%,rgba(255,255,255,.25) 55%,rgba(255,255,255,.45) 100%);
  transition:background .5s}
.pf-card:hover .pf-shade{background:linear-gradient(to top,rgba(255,255,255,.95) 12%,rgba(62,92,110,.30) 70%,rgba(255,255,255,.4))}
.pf-meta{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:20px}
.pf-cat{font-family:var(--mono);font-size:9.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--steel-glow);
  margin-bottom:8px;display:block}
.pf-name{font-family:var(--serif);font-weight:400;font-size:1.05rem;line-height:1.18;letter-spacing:-.01em}
.pf-arr{position:absolute;top:18px;right:18px;z-index:2;width:34px;height:34px;border-radius:50%;
  border:1px solid var(--glass-border-d);background:rgba(255,255,255,.4);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.8) rotate(-20deg);
  transition:.5s var(--ease);color:var(--ink)}
.pf-card:hover .pf-arr{opacity:1;transform:none}
/* tailles bento */
.pf-w2{grid-column:span 2}.pf-w3{grid-column:span 3}.pf-h2{grid-row:span 2}
/* Voir plus / Voir moins (desktop) */
.pf-loadmore-wrap{display:flex;justify-content:center;margin-top:36px}
.pf-loadmore{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:11.5px;
  letter-spacing:.1em;text-transform:uppercase;padding:13px 28px;border-radius:40px;border:1px solid var(--line-d);
  background:transparent;color:var(--concrete-d);cursor:pointer;transition:all .4s var(--ease)}
.pf-loadmore:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.pf-loadmore .pm-arr{font-size:13px;line-height:1;transition:transform .4s var(--ease)}
.pf-loadmore.full .pm-arr{transform:rotate(180deg)}
@media(min-width:769px){.pf-grid .pf-card.pf-hidden{display:none}}
.pf-card.pf-reveal{animation:pfIn .55s var(--ease) both}
@keyframes pfIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.pf-card.pf-out{opacity:0;transform:translateY(10px);transition:opacity .34s var(--ease),transform .34s var(--ease)}
@media(min-width:981px){
  .pf-grid.pf-collapsed{grid-template-columns:repeat(2,1fr);grid-auto-rows:clamp(232px,24vw,300px)}
  .pf-grid.pf-collapsed .pf-card{grid-column:auto;grid-row:auto}
}
@media(max-width:768px){.pf-loadmore-wrap{display:none}}
/* Lightbox : navigation gauche / droite */
.lb-nav{position:fixed;top:50%;transform:translateY(-50%);z-index:1210;width:54px;height:54px;border-radius:50%;
  border:1px solid rgba(255,255,255,.28);background:rgba(20,23,28,.32);color:#fff;cursor:pointer;
  display:grid;place-items:center;opacity:0;pointer-events:none;
  backdrop-filter:blur(7px) saturate(140%);-webkit-backdrop-filter:blur(7px) saturate(140%);
  transition:opacity .35s var(--ease),background .3s var(--ease),transform .35s var(--ease)}
.lb-prev{left:clamp(14px,3vw,38px)}.lb-next{right:clamp(14px,3vw,38px)}
.lightbox.show .lb-nav{opacity:.5;pointer-events:auto}
.lightbox.show .lb-nav:hover{opacity:1;background:rgba(20,23,28,.6)}
.lightbox.show .lb-prev:hover{transform:translateY(-50%) translateX(-3px)}
.lightbox.show .lb-next:hover{transform:translateY(-50%) translateX(3px)}
@media(max-width:768px){.lb-nav{display:none}}
@media(hover:none){.lb-nav{display:none}}
@media(max-width:620px){.pf-w3{grid-column:span 2}.pf-h2{grid-row:span 1}}
.pf-more{display:flex;justify-content:center;margin-top:52px}

/* ============================================================
   RÉFÉRENCES PRINCIPALES (liste éditoriale)
   ============================================================ */
.refs{padding:clamp(90px,12vw,150px) 0}
.refs-top{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:18px}
.refs-tabs{display:flex;gap:8px;margin-bottom:44px;flex-wrap:wrap}
.ref-tab{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  padding:10px 20px;border-radius:40px;border:1px solid var(--line-d);background:transparent;color:var(--concrete);
  transition:all .4s var(--ease)}
.ref-tab.active,.ref-tab:hover{background:var(--paper);color:var(--ink);border-color:var(--ink)}
.ref-row{display:grid;grid-template-columns:64px 1fr;gap:30px;align-items:center;padding:32px 12px;
  border-top:1px solid var(--line-d);transition:padding-left .5s var(--ease),background .5s;position:relative}
.ref-row:last-of-type{border-bottom:1px solid var(--line-d)}
.ref-row:hover{padding-left:24px;background:linear-gradient(90deg,rgba(62,92,110,.10),transparent)}
.ref-no{font-family:var(--mono);font-size:13px;color:var(--steel-l);letter-spacing:.04em}
.ref-main h4{font-family:var(--serif);font-weight:400;font-size:clamp(1.15rem,2vw,1.55rem);line-height:1.22;
  letter-spacing:-.01em;margin-bottom:6px;transition:color .4s}
.ref-row:hover .ref-main h4{color:var(--steel-glow)}
.ref-client{font-size:.86rem;color:rgba(24,26,31,.55);font-weight:300}
.ref-tagb{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--concrete);border:1px solid var(--line-d);padding:7px 14px;border-radius:30px;white-space:nowrap}
/* ---------- Onglets dynamiques + Voir tout ---------- */
.ref-tab{cursor:pointer}
.refs-panels{position:relative}
.ref-panel{display:none}
.ref-panel.active{display:block;animation:refPanelIn .5s var(--ease)}
@keyframes refPanelIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.refs-list{border-bottom:1px solid var(--line-d)}
.ref-extra{display:none}
.ref-extra.ref-shown{display:grid;animation:refRowIn .55s var(--ease) both}
.ref-extra.ref-shown.ref-out{animation:none;opacity:0;transform:translateY(-8px);transition:opacity .3s var(--ease),transform .3s var(--ease)}
@keyframes refRowIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.ref-more{display:flex;align-items:center;gap:10px;width:max-content;margin:30px auto 0;
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  padding:13px 26px;border-radius:40px;border:1px solid var(--line-d);background:transparent;
  color:var(--concrete);cursor:pointer;transition:all .4s var(--ease)}
.ref-more:hover{background:var(--paper);color:var(--ink);border-color:var(--ink)}
.ref-more .rm-arr{font-size:13px;line-height:1;transition:transform .4s var(--ease)}
.ref-more.full .rm-arr{transform:rotate(180deg)}
.ref-more .rm-hide{display:none}
@media(max-width:680px){.ref-row{grid-template-columns:40px 1fr;gap:16px}.ref-tagb{display:none}}

/* ============================================================
   EXPERTISE / AGRÉMENTS (bandeau premium)
   ============================================================ */
.expertise{padding:clamp(90px,12vw,150px) 0;background:var(--ink-2);border-top:1px solid var(--line-d);
  border-bottom:1px solid var(--line-d);position:relative;overflow:hidden}
.expertise .exp-glow{position:absolute;width:50vw;height:50vw;top:-25%;left:50%;transform:translateX(-50%);
  background:radial-gradient(circle,rgba(62,92,110,.22),transparent 60%);filter:blur(30px);z-index:0}
.exp-head{text-align:center;max-width:760px;margin:0 auto clamp(50px,7vw,80px)}
.exp-head .sec-kicker{display:block;margin-bottom:18px}
.exp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:880px){.exp-grid{grid-template-columns:1fr}}
.exp-card{padding:38px 32px;text-align:center;display:flex;flex-direction:column;align-items:center;
  transition:transform .6s var(--ease),border-color .6s}
.exp-card:hover{transform:translateY(-6px);border-color:rgba(143,185,206,.45)}
.exp-no{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--steel-glow);
  border:1px solid var(--line-d);padding:8px 18px;border-radius:40px;margin-bottom:26px}
.exp-card h3{font-family:var(--serif);font-weight:400;font-size:1.9rem;letter-spacing:-.01em;margin-bottom:14px}
.exp-card p{font-size:.92rem;color:rgba(24,26,31,.64);font-weight:300;line-height:1.6}
.exp-foot{text-align:center;margin-top:48px}
.exp-foot .ref-arr{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--concrete);margin-bottom:20px}
.exp-foot a{display:inline-flex;align-items:center;gap:10px;font-size:14px;color:var(--steel-glow);
  border-bottom:1px solid var(--line-d);padding-bottom:5px;transition:.4s}
.exp-foot a:hover{color:var(--ink);border-color:var(--steel-glow)}

/* ============================================================
   ZONE D'INTERVENTION (carte)
   ============================================================ */
.zone{padding:clamp(90px,12vw,150px) 0}
.zone-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(40px,6vw,80px);align-items:center}
@media(max-width:920px){.zone-grid{grid-template-columns:1fr;gap:50px}}
.zone-body p{color:rgba(24,26,31,.68);font-size:1.05rem;line-height:1.75;font-weight:300;margin-bottom:30px;max-width:34em}
.zone-funders{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.zone-funders .fchip{font-family:var(--mono);font-size:11px;letter-spacing:.06em;padding:9px 16px;
  border-radius:34px;border:1px solid var(--line-d);color:var(--steel-l);background:var(--glass-d);
  transition:.4s}
.zone-funders .fchip:hover{border-color:var(--steel-l);color:var(--ink)}
.zone-map{border-radius:var(--r-lg);overflow:hidden;padding:24px}
.zone-map svg{width:100%;height:auto;display:block}
.zone-legend{display:flex;gap:24px;flex-wrap:wrap;margin-top:20px;padding-top:20px;border-top:1px solid var(--line-d)}
.zleg{display:flex;align-items:center;gap:9px;font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--concrete)}
.zleg .dot{width:9px;height:9px;border-radius:50%}

/* ============================================================
   FAQ
   ============================================================ */
.faq{padding:clamp(90px,12vw,150px) 0;background:var(--ink-2);border-top:1px solid var(--line-d)}
.faq-grid{display:grid;grid-template-columns:.7fr 1.3fr;gap:clamp(40px,6vw,80px);align-items:start}
@media(max-width:880px){.faq-grid{grid-template-columns:1fr;gap:40px}}
.faq-aside p{color:rgba(24,26,31,.6);font-weight:300;margin:18px 0 26px;line-height:1.6}
.faq-aside a{display:inline-flex;align-items:center;gap:9px;font-size:14px;color:var(--steel-glow);
  border-bottom:1px solid var(--line-d);padding-bottom:5px;transition:.4s}
.faq-aside a:hover{color:var(--ink);border-color:var(--steel-glow)}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-top:1px solid var(--line-d)}
.faq-item:last-child{border-bottom:1px solid var(--line-d)}
.faq-q{width:100%;text-align:left;background:transparent;border:none;color:var(--ink);
  display:flex;align-items:center;gap:20px;padding:28px 4px;font-family:var(--serif);font-weight:400;
  font-size:clamp(1.05rem,1.7vw,1.3rem);letter-spacing:-.005em;transition:color .4s}
.faq-q:hover{color:var(--steel-glow)}
.faq-q .qn{font-family:var(--mono);font-size:12px;color:var(--steel-l);flex:none}
.faq-q .qi{margin-left:auto;flex:none;width:24px;height:24px;position:relative;transition:transform .5s var(--ease)}
.faq-q .qi::before,.faq-q .qi::after{content:"";position:absolute;background:var(--steel-l);transition:.4s}
.faq-q .qi::before{top:11px;left:3px;right:3px;height:1.5px}
.faq-q .qi::after{left:11px;top:3px;bottom:3px;width:1.5px}
.faq-item.open .qi::after{transform:scaleY(0)}
.faq-item.open .qi{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .6s var(--ease)}
.faq-a-in{padding:0 4px 30px 50px;color:rgba(24,26,31,.66);font-weight:300;line-height:1.7;font-size:.98rem}
@media(max-width:560px){.faq-a-in{padding-left:4px}}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{padding:clamp(90px,12vw,150px) 0}
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(40px,5vw,64px);align-items:start}
@media(max-width:920px){.contact-grid{grid-template-columns:1fr;gap:48px}}
.ci-block{padding:26px 28px;border-radius:var(--r);margin-bottom:14px;transition:border-color .5s,transform .5s}
.ci-block:hover{border-color:rgba(143,185,206,.4);transform:translateY(-3px)}
.ci-block .cl{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--steel-l);margin-bottom:14px}
.ci-block .cd{font-size:.96rem;color:rgba(24,26,31,.84);font-weight:300;line-height:1.7}
.ci-block .cd a{transition:color .3s}.ci-block .cd a:hover{color:var(--steel-glow)}
.ci-block .cd .gps{font-family:var(--mono);font-size:.8rem;color:var(--concrete);margin-top:6px;display:block}

.cform{padding:clamp(30px,4vw,46px);border-radius:var(--r-lg)}
.cform h3{font-family:var(--serif);font-weight:400;font-size:1.5rem;margin-bottom:8px;letter-spacing:-.01em}
.cform .csub{font-size:.9rem;color:rgba(24,26,31,.55);font-weight:300;margin-bottom:30px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:560px){.frow{grid-template-columns:1fr}}
.field{margin-bottom:14px;position:relative}
.field label{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--concrete);margin-bottom:8px}
.field input,.field select,.field textarea{width:100%;background:rgba(255,255,255,.4);border:1px solid var(--line-d);
  border-radius:12px;padding:13px 16px;color:var(--ink);font-family:var(--sans);font-size:14px;font-weight:300;
  transition:border-color .4s,background .4s;outline:none}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--steel-l);background:rgba(255,255,255,.6)}
.field textarea{resize:vertical;min-height:110px}
.field select{appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%233E5C6E' stroke-width='1.4' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center}
.cform .btn{width:100%;justify-content:center;margin-top:10px}
.cform-privacy{display:flex;align-items:flex-start;gap:9px;margin-top:18px;margin-bottom:20px;padding-top:16px;
  border-top:1px solid var(--line-d);color:rgba(24,26,31,.56);font-size:12px;line-height:1.55;font-weight:300}
.cform-privacy svg{flex:none;margin-top:2px;color:var(--steel-l)}
.cform-privacy a{color:var(--steel-glow);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .3s var(--ease);white-space:nowrap}
.cform-privacy a:hover{border-color:var(--steel-glow)}
.cform-note{font-family:var(--mono);font-size:10px;color:var(--concrete);text-align:center;margin-top:14px;letter-spacing:.04em}
.cform-note:empty{margin-top:0}
.cform-note.sending{color:var(--concrete-d)}
.cform-note.ok{color:#1a8a45;font-size:12px}
.cform-note.err{color:#a32d2d;font-size:12px}
.cform-hp{position:absolute!important;left:-9999px;width:1px;height:1px;opacity:0;overflow:hidden}
/* Bloc CTA Carrière (accueil) */
.career-cta{padding:0 0 clamp(60px,9vw,110px)}
.cc-card{display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;
  padding:clamp(30px,5vw,56px);border-radius:var(--r-lg)}
.cc-title{font-family:var(--serif);font-weight:400;font-size:clamp(1.6rem,3.4vw,2.6rem);letter-spacing:-.02em;
  color:var(--ink);margin:10px 0 0;line-height:1.06}
.cc-title em{font-style:italic;color:var(--steel-l)}
.cc-sub{margin:14px 0 0;max-width:46em;color:rgba(24,26,31,.66);font-weight:300;line-height:1.7}
.cc-card .btn{flex:none}
@media(max-width:760px){.cc-card{flex-direction:column;align-items:flex-start}.cc-card .btn{width:100%;justify-content:center}}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{padding:clamp(70px,9vw,110px) 0 0;background:var(--ink-2);border-top:1px solid var(--line-d);position:relative;overflow:hidden}
.foot-big{font-family:var(--serif);font-weight:300;font-style:italic;font-size:clamp(2.4rem,9vw,7rem);
  line-height:.95;letter-spacing:-.03em;margin-bottom:clamp(50px,7vw,80px);color:var(--ink)}
.foot-big .reg{font-style:normal;color:var(--concrete-d)}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:60px;
  border-bottom:1px solid var(--line-d)}
@media(max-width:880px){.foot-grid{grid-template-columns:1fr 1fr;gap:36px}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}
.foot-col h5{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--steel-l);margin-bottom:20px}
.foot-col ul{list-style:none;display:grid;gap:11px}
.foot-col ul a{font-size:.92rem;color:rgba(24,26,31,.66);font-weight:300;
  display:inline-block;transition:color .3s,transform .3s var(--ease)}
.foot-col ul a:hover{color:var(--ink);transform:translateX(5px)}
.foot-brand .fb-logo{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.foot-brand .fb-logo b{font-family:var(--serif);font-weight:500;font-size:20px}
.foot-brand p{font-size:.88rem;color:rgba(24,26,31,.55);font-weight:300;line-height:1.65;max-width:24em}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;padding:30px 0 40px}
.foot-bottom .legal{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--concrete-d);line-height:1.8}
.foot-bottom .legal a{color:var(--steel-l);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .3s var(--ease)}
.foot-bottom .legal a:hover{border-color:var(--steel-l)}
.foot-bottom .copy{font-size:.85rem;color:rgba(24,26,31,.5);font-weight:300}
.to-top{width:46px;height:46px;border-radius:50%;border:1px solid var(--line-d);background:var(--glass-d);
  display:flex;align-items:center;justify-content:center;color:var(--steel-l);transition:.4s;flex:none}
.to-top:hover{background:var(--paper);color:var(--ink);transform:translateY(-3px)}

/* Réduction des animations */
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}


/* ============================================================
   EMPLACEMENTS IMAGES (slots remplaçables)
   ============================================================ */
.slot-img{width:100%;height:100%;object-fit:cover;display:block}
.hv-img .slot-img{position:absolute;inset:0}
.domain-vis .slot-img,.pf-vis .slot-img{transition:transform 1.2s var(--ease)}
.domain:hover .domain-vis .slot-img{transform:scale(1.04)}
.zone-map .slot-img.zone-img{height:auto;border-radius:14px}

/* ============================================================
   MENU MOBILE — structure plein écran (tête / liens / pied)
   ============================================================ */
.m-menu{justify-content:flex-start;padding:0;z-index:1100;overflow-y:auto;
  background:rgba(248,246,240,.82);backdrop-filter:blur(28px) saturate(150%);-webkit-backdrop-filter:blur(28px) saturate(150%)}
.m-menu-head{display:flex;align-items:center;justify-content:space-between;
  padding:calc(20px + env(safe-area-inset-top)) var(--gut) 14px}
.m-brand{font-family:var(--serif);font-weight:600;font-size:22px;letter-spacing:.01em}
.m-close{width:46px;height:46px;border-radius:50%;border:1px solid var(--glass-border-d);
  background:var(--glass-d);color:var(--ink);display:flex;align-items:center;justify-content:center;
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:transform .4s var(--ease),background .3s}
.m-close:active{transform:rotate(90deg) scale(.92)}
.m-links{display:flex;flex-direction:column;justify-content:center;flex:1;
  padding:2vh var(--gut);counter-reset:mi}
.m-links a{counter-increment:mi}
.m-links a::before{content:counter(mi,decimal-leading-zero);font-family:var(--mono);font-size:11px;
  font-weight:400;color:var(--steel-l);margin-right:18px;letter-spacing:.05em;transform:translateY(-.35em)}
.m-links a:last-child{border-bottom:none}
/* révélation décalée */
.m-links a{opacity:0;transform:translateY(22px);
  transition:opacity .55s var(--ease),transform .55s var(--ease),color .35s,padding-left .35s}
.m-menu.open .m-links a{opacity:1;transform:none}
.m-menu.open .m-links a:nth-child(1){transition-delay:.10s}
.m-menu.open .m-links a:nth-child(2){transition-delay:.16s}
.m-menu.open .m-links a:nth-child(3){transition-delay:.22s}
.m-menu.open .m-links a:nth-child(4){transition-delay:.28s}
.m-menu.open .m-links a:nth-child(5){transition-delay:.34s}
.m-menu.open .m-links a:nth-child(6){transition-delay:.40s}
.m-menu.open .m-links a:nth-child(7){transition-delay:.46s}
.m-foot{padding:22px var(--gut) calc(26px + env(safe-area-inset-bottom));border-top:1px solid var(--line-d);
  opacity:0;transform:translateY(16px);transition:opacity .5s var(--ease) .5s,transform .5s var(--ease) .5s}
.m-menu.open .m-foot{opacity:1;transform:none}
.m-foot .btn{width:100%;justify-content:center;padding:17px 24px}
.m-contact{display:flex;flex-wrap:wrap;gap:6px 22px;margin-top:18px}
.m-contact a{font-family:var(--mono);font-size:12px;letter-spacing:.02em;color:var(--concrete)}
.m-contact a:active{color:var(--steel-l)}

/* ============================================================
   BARRE D'ACTION FLOTTANTE (mobile)
   ============================================================ */
.m-actionbar{position:fixed;left:0;right:0;bottom:0;z-index:900;display:none;gap:10px;
  padding:11px 16px calc(11px + env(safe-area-inset-bottom));
  background:linear-gradient(to top,var(--paper) 55%,rgba(248,246,240,0));
  transform:translateY(130%);transition:transform .55s var(--ease)}
.m-actionbar.show{transform:none}
.m-actionbar a{display:inline-flex;align-items:center;justify-content:center;gap:9px;height:54px;
  border-radius:40px;font-family:var(--sans);font-size:14.5px;font-weight:400;transition:transform .3s var(--ease)}
.m-actionbar a:active{transform:scale(.96)}
.mab-call{flex:0 0 54px;width:54px;background:var(--glass-d-2);border:1px solid var(--glass-border-d);
  color:var(--ink);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  box-shadow:0 8px 24px -12px rgba(36,52,68,.4)}
.mab-cta{flex:1;background:var(--ink);color:var(--paper);box-shadow:0 14px 32px -10px rgba(36,52,68,.55)}
.mab-cta .arr{transition:transform .4s var(--ease)}

/* ============================================================
   ███  EXPÉRIENCE MOBILE DÉDIÉE  ███  (≤ 768px)
   ============================================================ */
@media (max-width:768px){
  html{-webkit-text-size-adjust:100%}
  body{-webkit-tap-highlight-color:transparent}
  section[id],header[id]{scroll-margin-top:88px}

  /* Allègement des flous (fluidité) */
  .glass,.hv-card,.nav-inner,.pf-arr,.domain-agr,.btn-ghost,.pole-chip,.zone-funders .fchip{
    backdrop-filter:blur(13px) saturate(140%);-webkit-backdrop-filter:blur(13px) saturate(140%)}

  /* Rythme vertical resserré et homogène */
  .about,.skills,.domains,.portfolio,.refs,.expertise,.zone,.faq,.contact{
    padding-top:clamp(60px,13vw,90px);padding-bottom:clamp(60px,13vw,90px)}
  .bento{padding-bottom:clamp(60px,13vw,90px)}

  /* En-têtes de section en pile */
  .sec-head{flex-direction:column;align-items:flex-start;gap:14px;margin-bottom:32px}
  .sec-title{font-size:clamp(2rem,8.5vw,2.9rem)}

  /* ---------- NAV ---------- */
  .nav-inner{margin:10px 12px 0;height:58px;padding:0 8px 0 14px}
  .nav.scrolled .nav-inner{margin-top:6px}
  .nav-logo .lt b{font-size:16px}
  .nav-burger{width:42px;height:42px}
  body.menu-open{overflow:hidden}

  /* Barre d'action visible sur mobile */
  .m-actionbar{display:flex}

  /* ---------- HERO ---------- */
  .hero{min-height:auto;padding-top:104px;padding-bottom:44px}
  .hero-grid{gap:30px}
  .hero-tag{margin-bottom:20px;font-size:9.5px;letter-spacing:.12em;padding:7px 13px}
  .hero h1{font-size:clamp(3rem,15.5vw,4.6rem);margin-bottom:20px;line-height:.96}
  .hero p.lead{font-size:1.04rem;line-height:1.6;margin-bottom:26px;max-width:none}
  .hero-cta{flex-direction:column;gap:11px;margin-bottom:34px}
  .hero-cta .btn{width:100%;justify-content:center;padding:16px 24px;font-size:14.5px}

  /* Chiffres clés : liste verticale en carte verre (lisible + ergonomique) */
  .hero-stats{display:flex;flex-direction:column;gap:0;
    border:1px solid var(--line-d);border-radius:18px;overflow:hidden;background:var(--glass-d);
    -webkit-backdrop-filter:blur(13px);backdrop-filter:blur(13px);
    box-shadow:0 2px 6px rgba(36,52,68,.05),0 20px 46px -30px rgba(36,52,68,.30)}
  .hstat{display:flex;align-items:center;justify-content:space-between;gap:18px;
    padding:16px 20px;text-align:left}
  .hstat::before{display:none}
  .hstat+.hstat{border-top:1px solid var(--line-d);border-left:none}
  .hstat .n{font-size:2.1rem;line-height:1;white-space:nowrap;flex:none}
  .hstat .n .u{font-size:.32em}
  .hstat .lab{font-size:11px;letter-spacing:.1em;margin-top:0;text-align:right;
    color:var(--concrete);max-width:9.5em;line-height:1.35}

  /* Visuel hero : collage soigné + flottement subtil */
  .hero-visual{height:clamp(300px,82vw,420px);max-height:none;margin-top:4px}
  .hv-card .lbl{font-size:8px;top:11px;left:12px}
  .hv-card .lbl.br{bottom:11px;right:12px}
  .hv-1{width:74%;height:80%;top:0;right:0}
  .hv-2{width:53%;height:43%;bottom:0;left:0}
  .hv-3{width:35%;height:27%;top:5%;left:1%}
  .hv-card{animation:floaty 7.5s ease-in-out infinite}
  .hv-2{animation-delay:-2.4s}.hv-3{animation-delay:-4.8s}

  /* ---------- TICKER ---------- */
  .ticker{padding:20px 0}
  .ticker-item{font-size:1.15rem;gap:34px;padding:0 17px}
  .ticker::before,.ticker::after{width:70px}

  /* ---------- À PROPOS ---------- */
  .about-lead{font-size:clamp(1.5rem,6.5vw,1.95rem)}
  .about-quote{margin-top:46px;padding:34px 24px}
  .about-quote .qc{font-size:4rem;top:34px;left:20px}

  /* ---------- BENTO IDENTITÉ : reflow intentionnel 2 colonnes ---------- */
  .bento-grid{grid-template-columns:repeat(2,1fr);gap:12px;grid-auto-rows:minmax(118px,auto)}
  .bento-cell{padding:20px}
  .bc-span2,.bento-feature{grid-column:span 2}
  .bc-row2{grid-row:auto}
  .bento-feature .cv{font-size:1.5rem}
  .bento-num .big{font-size:clamp(2.6rem,13vw,3.4rem)}
  .bento-mark{width:120px;height:120px;right:-24px;bottom:-24px}

  /* ---------- SAVOIR-FAIRE ---------- */
  .poles{gap:8px;margin-bottom:28px}
  .pole-chip{font-size:10px;padding:8px 14px}
  .presta{padding:21px 4px;gap:16px}
  .presta-name{font-size:1.18rem}
  .presta .arr{opacity:.55;transform:none}

  /* ---------- PILIERS : 2 colonnes, 5e pleine largeur ---------- */
  .pillars{margin-top:60px}
  .pillars-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .pillar{min-height:auto;padding:22px 18px}
  .pillar:last-child{grid-column:span 2}
  .pillar .pico{width:30px;height:30px}
  .pillar h4{font-size:1.08rem;margin:16px 0 8px}
  .pillar p{font-size:.85rem}

  /* ---------- DOMAINES ---------- */
  .domains-grid{gap:14px}
  .domain-vis{height:172px}
  .domain-body{padding:24px 22px 26px}
  .domain-body h3{font-size:1.5rem}

  /* ---------- PORTFOLIO : carrousel horizontal à accroche ---------- */
  .pf-grid{display:flex;align-items:flex-start;grid-template-columns:none;grid-auto-rows:auto;gap:13px;
    overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
    margin:0 calc(-1*var(--gut));padding:4px var(--gut) 14px;scroll-padding-left:var(--gut);
    scrollbar-width:none}
  .pf-grid::-webkit-scrollbar{display:none}
  .pf-card{flex:0 0 78%;scroll-snap-align:start;aspect-ratio:4/5}
  .pf-card.pf-w3,.pf-card.pf-h2{flex-basis:84%}
  .pf-w2,.pf-w3,.pf-h2{grid-column:auto;grid-row:auto}
  .pf-arr{opacity:1;transform:none}
  .pf-meta{padding:18px}
  .pf-name{font-size:1.05rem}
  .portfolio .pf-hint{display:flex}
  .pf-more{margin-top:30px}

  /* ---------- RÉFÉRENCES ---------- */
  .refs-top{flex-direction:column;align-items:flex-start;gap:18px}
  .refs-top .btn{width:100%;justify-content:center}
  .refs-tabs{margin-bottom:30px}
  .ref-row{padding:22px 4px;gap:14px;align-items:flex-start}
  .ref-main h4{font-size:1.1rem}

  /* ---------- EXPERTISE ---------- */
  .exp-grid{gap:12px}
  .exp-card{padding:30px 24px}
  .exp-card h3{font-size:1.65rem}

  /* ---------- ZONE / CARTE ---------- */
  .zone-grid{gap:34px}
  .zone-map{padding:16px}
  .zone-body p{font-size:1rem}
  .zone-legend{gap:14px 18px}

  /* ---------- FAQ ---------- */
  .faq-q{padding:21px 2px;gap:13px;font-size:1.08rem;align-items:flex-start}
  .faq-q .qi{margin-top:3px}
  .faq-a-in{padding:0 2px 24px 2px}

  /* ---------- CONTACT ---------- */
  .contact-grid{gap:32px}
  .cform{padding:26px 20px}
  .ci-block{padding:22px}

  /* ---------- FOOTER (mobile : 2 colonnes + carte contact tactile) ---------- */
  .footer{padding-top:clamp(54px,12vw,78px)}
  .foot-big{font-size:clamp(2.2rem,13vw,3.6rem);margin-bottom:clamp(38px,9vw,58px)}
  .foot-grid{grid-template-columns:1fr 1fr;gap:26px 22px;padding-bottom:38px}
  .foot-brand{grid-column:span 2;margin-bottom:2px}
  .foot-brand p{font-size:.92rem;max-width:42ch}
  .foot-col h5{margin-bottom:15px}
  .foot-col ul{gap:1px}
  .foot-col ul a{display:block;padding:8px 0;font-size:.96rem}
  /* Bloc Contact = carte verre, lignes tactiles */
  .footer .foot-col:nth-child(4){grid-column:span 2;margin-top:6px;
    background:var(--glass-d);border:1px solid var(--glass-border-d);border-radius:18px;
    padding:22px 20px 10px;-webkit-backdrop-filter:blur(13px);backdrop-filter:blur(13px);
    box-shadow:0 2px 6px rgba(36,52,68,.05),0 18px 42px -30px rgba(36,52,68,.30)}
  .footer .foot-col:nth-child(4) ul{gap:0}
  .footer .foot-col:nth-child(4) ul a{display:flex;align-items:center;justify-content:space-between;gap:14px;
    padding:14px 0;border-top:1px solid var(--line-d);min-height:50px;font-size:1rem;color:var(--ink)}
  .footer .foot-col:nth-child(4) ul a::after{content:"↗";font-family:var(--mono);font-size:13px;
    color:var(--steel-l);opacity:.55}
  .footer .foot-col:nth-child(4) ul a:active{transform:translateX(5px);color:var(--steel-glow)}
  .foot-bottom{flex-direction:column;align-items:flex-start;gap:16px;padding:26px 0 120px}
}

/* Indice de glissement du portfolio (mobile only) */
.pf-hint{display:none;align-items:center;gap:8px;justify-content:flex-end;
  font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--concrete);margin:14px 2px 0}
.pf-hint .bar{width:30px;height:1px;background:var(--steel-l);position:relative;overflow:hidden}
.pf-hint .bar::after{content:"";position:absolute;inset:0;width:12px;background:var(--ink);
  animation:swipeHint 1.8s var(--ease) infinite}
@keyframes swipeHint{0%{transform:translateX(-14px)}100%{transform:translateX(34px)}}

@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* ============================================================
   PETITS ÉCRANS (≤ 430px) — réglages fins
   ============================================================ */
@media (max-width:430px){
  :root{--gut:18px}
  .hero h1{font-size:clamp(2.7rem,16vw,3.6rem)}
  .hero p.lead{font-size:1rem}
  .hstat{padding:15px 16px}
  .hstat .n{font-size:1.85rem}
  .hstat .lab{font-size:10px}
  .nav-logo .lt span{display:none}
  .sec-idx{font-size:11px;white-space:normal;border-radius:18px;padding:8px 14px;line-height:1.5;max-width:100%;word-break:break-word}
  .foot-grid{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:span 2}
  .foot-col ul a{font-size:.9rem}
  .pf-card{flex-basis:84%}
  .pf-card.pf-w3,.pf-card.pf-h2{flex-basis:88%}
  .about-quote .q{font-size:clamp(1.6rem,8vw,2.2rem)}
}

/* Le flottement hero respecte la réduction de mouvement */
@media (prefers-reduced-motion:reduce){.hv-card{animation:none}.pf-hint .bar::after{animation:none}}

/* ============================================================
   LIGHTBOX — ouverture plein écran des projets (zoom shared-element)
   ============================================================ */
.pf-card{cursor:pointer}
.lightbox{position:fixed;inset:0;z-index:1200;display:none;align-items:center;justify-content:center;
  padding:clamp(16px,4vw,56px)}
.lightbox.open{display:flex}
.lightbox::before{content:"";position:absolute;inset:0;background:rgba(18,20,25,.55);
  backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);
  opacity:0;transition:opacity .5s var(--ease)}
.lightbox.show::before{opacity:1}
.lb-fig{position:relative;z-index:2;margin:0;border-radius:12px;overflow:hidden;
  max-width:min(1100px,94vw);will-change:transform,opacity;
  box-shadow:0 50px 140px -50px rgba(18,28,38,.85),0 0 0 1px rgba(255,255,255,.35)}
.lb-img{display:block;width:auto;height:auto;max-width:min(1100px,94vw);max-height:84vh;background:var(--paper)}
.lb-cap{position:absolute;left:0;right:0;bottom:0;padding:30px 26px 22px;
  background:linear-gradient(to top,rgba(18,20,25,.85),rgba(18,20,25,.18) 72%,transparent)}
.lb-cat{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
  color:#cfe0ea;display:block;margin-bottom:8px}
.lb-name{font-family:var(--serif);font-weight:400;font-size:clamp(1.2rem,3.4vw,1.7rem);line-height:1.2;color:#fff}
.lb-close{position:fixed;top:16px;right:16px;z-index:3;width:48px;height:48px;border-radius:50%;
  border:1px solid rgba(255,255,255,.28);background:rgba(18,20,25,.4);color:#fff;
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  opacity:0;transform:scale(.9);transition:opacity .4s var(--ease) .12s,transform .4s var(--ease)}
.lightbox.show .lb-close{opacity:1;transform:none}
.lb-close:hover{transform:rotate(90deg);background:rgba(18,20,25,.6)}
@media(max-width:560px){.lb-cap{padding:22px 18px 18px}.lb-close{top:12px;right:12px;width:44px;height:44px}}

/* ==========================================================
   MODAL — POLITIQUE QUALITÉ
   ========================================================== */
.pq-modal{position:fixed;inset:0;z-index:1200;display:none;align-items:flex-start;justify-content:center;
  padding:clamp(16px,3vw,40px);overflow-y:auto;
  -webkit-overflow-scrolling:touch}
.pq-modal.show{display:flex}
.pq-backdrop{position:fixed;inset:0;background:rgba(18,20,25,.62);
  backdrop-filter:blur(14px) saturate(130%);-webkit-backdrop-filter:blur(14px) saturate(130%);
  opacity:0;transition:opacity .45s var(--ease);cursor:pointer}
.pq-modal.show .pq-backdrop{opacity:1}
.pq-dialog{position:relative;z-index:2;width:min(820px,100%);margin:auto;
  background:var(--paper);border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--line-d);
  box-shadow:0 60px 160px -60px rgba(18,28,38,.55),0 0 0 1px rgba(255,255,255,.5) inset;
  opacity:0;transform:translateY(18px) scale(.985);
  transition:opacity .5s var(--ease) .05s,transform .5s var(--ease) .05s;
  display:flex;flex-direction:column;max-height:calc(100vh - clamp(32px,6vw,80px))}
.pq-modal.show .pq-dialog{opacity:1;transform:none}

.pq-head{position:relative;padding:clamp(28px,4vw,40px) clamp(28px,4vw,48px) clamp(20px,3vw,28px);
  border-bottom:1px solid var(--line-d);
  background:linear-gradient(180deg,rgba(255,255,255,.6),transparent)}
.pq-kicker{display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--concrete)}
.pq-kicker .pq-dot{width:7px;height:7px;border-radius:50%;background:var(--steel-l);
  box-shadow:0 0 0 4px rgba(62,92,110,.12)}
.pq-kicker .pq-sep{opacity:.5}
.pq-title{font-family:var(--serif);font-weight:400;font-size:clamp(1.85rem,4.4vw,2.85rem);
  line-height:1.05;letter-spacing:-.02em;color:var(--ink);margin:14px 0 0;max-width:18ch}
.pq-title em{font-style:italic;color:var(--steel-l)}
.pq-close{position:absolute;top:18px;right:18px;width:42px;height:42px;border-radius:50%;
  border:1px solid var(--line-d);background:rgba(255,255,255,.7);color:var(--ink);
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  transition:all .35s var(--ease);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}
.pq-close:hover{background:var(--ink);color:var(--paper);border-color:var(--ink);transform:rotate(90deg)}

.pq-body{padding:clamp(24px,3.4vw,36px) clamp(28px,4vw,48px) clamp(28px,4vw,40px);
  overflow-y:auto;flex:1;
  display:flex;flex-direction:column;gap:18px;
  scrollbar-width:thin;scrollbar-color:rgba(24,26,31,.18) transparent}
.pq-body::-webkit-scrollbar{width:8px}
.pq-body::-webkit-scrollbar-thumb{background:rgba(24,26,31,.16);border-radius:8px}
.pq-body::-webkit-scrollbar-track{background:transparent}

.pq-intro{font-size:clamp(.98rem,1.4vw,1.08rem);line-height:1.65;color:rgba(24,26,31,.72);
  font-weight:300;max-width:62ch;margin-bottom:8px}

.pq-card{display:flex;gap:clamp(18px,2.6vw,28px);align-items:flex-start;
  padding:clamp(20px,2.6vw,26px);background:var(--paper-2);
  border:1px solid var(--line-d);border-radius:var(--r);
  transition:border-color .35s var(--ease),transform .35s var(--ease)}
.pq-card:hover{border-color:rgba(62,92,110,.32);transform:translateY(-2px)}
.pq-num{flex:0 0 auto;font-family:var(--mono);font-size:11px;letter-spacing:.14em;
  color:var(--steel-l);border:1px solid var(--line-d);border-radius:30px;
  padding:6px 11px;background:rgba(62,92,110,.05)}
.pq-card-body{flex:1;min-width:0}
.pq-card-body h3{font-family:var(--serif);font-weight:500;font-size:clamp(1.2rem,2vw,1.45rem);
  line-height:1.2;color:var(--ink);margin:0 0 10px;letter-spacing:-.01em}
.pq-card-body p{font-size:.96rem;line-height:1.65;color:rgba(24,26,31,.72);font-weight:300;margin:0}
.pq-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px}
.pq-list li{position:relative;padding-left:18px;font-size:.96rem;line-height:1.6;
  color:rgba(24,26,31,.74);font-weight:300}
.pq-list li::before{content:"";position:absolute;left:0;top:.7em;width:8px;height:1px;
  background:var(--steel-l)}

.pq-banner{margin-top:8px;padding:clamp(22px,3vw,28px) clamp(22px,3vw,30px);
  background:linear-gradient(135deg,var(--ink),var(--steel-glow));color:var(--paper);
  border-radius:var(--r);display:flex;flex-direction:column;gap:6px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.05)}
.pq-banner-label{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;
  text-transform:uppercase;color:rgba(248,246,240,.55)}
.pq-banner-text{font-family:var(--serif);font-weight:400;font-style:italic;
  font-size:clamp(1.15rem,2.2vw,1.55rem);line-height:1.3;color:#fff}

.pq-foot{display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:18px clamp(28px,4vw,48px);border-top:1px solid var(--line-d);
  background:linear-gradient(0deg,rgba(255,255,255,.6),transparent)}
.pq-meta{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--concrete)}
.pq-foot-close{appearance:none;border:1px solid var(--ink);background:var(--ink);color:var(--paper);
  font-family:var(--sans);font-size:13px;font-weight:400;cursor:pointer;
  padding:11px 22px;border-radius:30px;transition:all .35s var(--ease)}
.pq-foot-close:hover{background:var(--steel-glow);border-color:var(--steel-glow);transform:translateY(-1px)}

@media(max-width:640px){
  .pq-modal{padding:0;align-items:stretch}
  .pq-dialog{border-radius:0;max-height:100vh;width:100%}
  .pq-head{padding:24px 22px 18px}
  .pq-close{top:14px;right:14px;width:40px;height:40px}
  .pq-body{padding:20px 22px 26px}
  .pq-card{flex-direction:column;gap:12px;padding:18px}
  .pq-foot{padding:16px 22px;flex-direction:column;align-items:stretch;text-align:center}
  .pq-foot-close{width:100%}
}

body.pq-locked{overflow:hidden}
@media(prefers-reduced-motion:reduce){
  .pq-backdrop,.pq-dialog,.pq-close,.pq-card,.pq-foot-close{transition:none!important}
  .pq-dialog{transform:none!important}
}

/* ==========================================================
   A11Y — Focus visible global + Skip link
   ========================================================== */
:focus{outline:none}
:focus-visible{
  outline:2px solid var(--steel-l);
  outline-offset:3px;
  border-radius:6px;
  transition:outline-offset .15s ease;
}
button:focus-visible,a:focus-visible,input:focus-visible,
select:focus-visible,textarea:focus-visible{
  outline:2px solid var(--steel-l);
  outline-offset:3px;
  box-shadow:0 0 0 4px rgba(62,92,110,.18);
}
.lang-opt:focus-visible,.btn:focus-visible{outline-offset:4px;border-radius:30px}

/* Skip-to-content link (caché jusqu'au focus clavier) */
.skip-link{
  position:fixed;top:-100px;left:14px;z-index:9999;
  font-family:var(--mono);font-size:13px;
  background:var(--ink);color:var(--paper);
  padding:12px 18px;border-radius:30px;border:2px solid var(--steel-l);
  text-decoration:none;
  transition:top .25s var(--ease);
}
.skip-link:focus{top:14px;outline:none}

/* Cibles tactiles ≥ 44×44 sur mobile (WCAG 2.5.5) */
@media(max-width:760px){
  .btn,.lang-opt,.m-links a,.faq-q,.refs-tabs button,
  .ref-tab,.pf-loadmore,.ref-more,
  .nav-burger,.m-close,.to-top{min-height:44px}
}
