/* ░░░░░░░░ 56k Studio — Landing · charte officielle ░░░░░░░░
   Redaction 35 (display + signature "56k") · Geist (corps)
   ZERO radius · accent rose #FFB3FF · plat / éditorial          */

/* ——— Fonts ——— */
@font-face{font-family:'Redaction35';src:url('/fonts/redaction-35-400.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Redaction35';src:url('/fonts/redaction-35-400-italic.woff2') format('woff2');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'Redaction35';src:url('/fonts/redaction-35-700.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'Geist';src:url('/fonts/geist-400.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Geist';src:url('/fonts/geist-500.woff2') format('woff2');font-weight:500;font-display:swap}
@font-face{font-family:'Geist';src:url('/fonts/geist-600.woff2') format('woff2');font-weight:600;font-display:swap}
@font-face{font-family:'Geist';src:url('/fonts/geist-700.woff2') format('woff2');font-weight:700;font-display:swap}

/* ——— Tokens ——— */
:root{
  --cream:#F4F0E8;
  --cream-2:#EFEAE0;
  --paper:#FBF9F4;
  --ink:#15130E;
  --ink-2:#3B362D;
  --ink-3:#6B6456;
  --line:rgba(21,19,14,.14);
  --line-2:rgba(21,19,14,.08);
  --rose:#FFB3FF;
  --rose-ink:#7A2E7A;
  --maxw:1240px;
  --pad:clamp(20px,5vw,64px);
  --ease:cubic-bezier(.22,.61,.18,1);
  --disp:'Redaction35',Georgia,serif;
  --body:'Geist',-apple-system,BlinkMacSystemFont,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);
  background:var(--cream);
  color:var(--ink);
  line-height:1.5;
  letter-spacing:-.01em;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--rose);color:var(--ink)}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}

/* grain overlay */
.grain{position:fixed;inset:0;z-index:60;pointer-events:none;opacity:.04;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ——— Typography helpers ——— */
.ital{font-style:italic}
.muted{color:var(--ink-3)}
.eyebrow,.label,.foot__lab,.logos__label,.config__steps,.mock__kicker,.work__sector,.pill{
  font-family:var(--body);text-transform:uppercase;letter-spacing:.22em;font-size:11px;font-weight:600;color:var(--ink-3)}
.label{display:flex;align-items:center;gap:.7em;margin-bottom:26px}
.label span{font-family:var(--disp);font-weight:400;font-size:13px;letter-spacing:0;color:var(--ink);
  border:1px solid var(--line);padding:3px 9px;background:var(--paper)}
.label--rose span{background:var(--rose);border-color:var(--rose);color:var(--ink)}

/* ——— Buttons (flat, zéro radius) ——— */
.btn{display:inline-flex;align-items:center;gap:.7em;font-family:var(--body);font-weight:500;
  font-size:14px;letter-spacing:-.01em;padding:13px 20px;border:1px solid var(--ink);
  cursor:pointer;transition:transform .5s var(--ease),background .4s var(--ease),color .4s var(--ease),box-shadow .4s var(--ease);
  background:transparent;color:var(--ink);will-change:transform}
.btn--solid{background:var(--ink);color:var(--cream)}
.btn--ghost{background:transparent}
.btn--lg{padding:16px 24px;font-size:15px}
.btn--block{width:100%;justify-content:center}
.btn__ico{display:inline-flex;width:22px;height:22px;align-items:center;justify-content:center;
  border:1px solid currentColor;font-size:13px;transition:transform .5s var(--ease)}
.btn:hover{transform:translateY(-2px)}
.btn--solid:hover{box-shadow:5px 5px 0 var(--rose)}
.btn--ghost:hover{background:var(--ink);color:var(--cream)}
.btn:hover .btn__ico{transform:translate(3px,-2px)}
.btn:active{transform:translateY(0)}

/* ░░ NAV ░░ */
.nav{position:fixed;top:0;left:0;right:0;z-index:40;
  background:color-mix(in srgb,var(--cream) 82%,transparent);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:border-color .4s var(--ease),background .4s var(--ease)}
.nav.scrolled{border-bottom-color:var(--line)}
.nav__inner{max-width:var(--maxw);margin:0 auto;padding:14px var(--pad);display:flex;align-items:center;gap:24px}
.nav__logo{height:24px;width:auto;image-rendering:pixelated}
.nav__brand{display:flex;align-items:center}
.nav__links{display:flex;gap:30px;margin-left:auto;font-size:14px;font-weight:500;color:var(--ink-2)}
.nav__links a{position:relative;padding:4px 0;transition:color .3s var(--ease)}
.nav__links a:hover{color:var(--ink)}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--rose);transition:width .4s var(--ease)}
.nav__links a:hover::after{width:100%}
.nav__num{font-family:var(--disp);font-size:11px;color:var(--ink-3);margin-right:3px}
.nav__cta{padding:10px 16px}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;margin-left:auto}
.nav__burger span{width:24px;height:2px;background:var(--ink);transition:transform .4s var(--ease),opacity .3s}
.nav__burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__burger[aria-expanded="true"] span:nth-child(2){transform:translateY(-0px) rotate(-45deg)}

/* mobile menu */
.menu{position:fixed;inset:0;z-index:39;background:var(--cream);
  transform:translateY(-100%);transition:transform .6s var(--ease);
  display:flex;align-items:center;justify-content:center}
.menu.open{transform:translateY(0)}
.menu__links{display:flex;flex-direction:column;gap:8px;text-align:center}
.menu__links a{font-family:var(--disp);font-size:34px;padding:8px;color:var(--ink)}
.menu__links a span{font-size:14px;color:var(--ink-3);font-family:var(--body)}
.menu__links .btn{font-family:var(--body);font-size:16px;justify-content:center;margin-top:18px}

/* ░░ HERO ░░ */
.hero{padding-top:148px;position:relative}
.hero::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:min(1100px,92vw);height:520px;z-index:-1;
  background:radial-gradient(60% 70% at 70% 12%,rgba(255,179,255,.34),transparent 70%)}
.hero__grid{display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(28px,4vw,60px);align-items:center}
.hero__copy{max-width:600px}
.hero__title{font-family:var(--disp);font-weight:400;letter-spacing:-.02em;line-height:.98;
  font-size:clamp(38px,6.4vw,90px);margin:22px 0 24px;overflow-wrap:break-word}
.rot{max-width:100%}
.rot__list b{max-width:100%}
.hero__title-line{display:block}
.hero__title .ital{color:var(--ink)}
.rot{display:inline-grid;vertical-align:baseline;overflow:hidden;height:1em;position:relative}
.rot__list{display:flex;flex-direction:column;animation:rot 9s steps(1) infinite}
.rot__list b{font-weight:400;font-style:italic;color:var(--rose-ink);height:1em;line-height:1;
  border-bottom:3px solid var(--rose);width:max-content}
@keyframes rot{0%,22%{transform:translateY(0)}25%,47%{transform:translateY(-1em)}
  50%,72%{transform:translateY(-2em)}75%,97%{transform:translateY(-3em)}100%{transform:translateY(0)}}
.hero__lede{font-size:clamp(16px,1.6vw,19px);color:var(--ink-2);max-width:30em;line-height:1.65}
.hero__cta{display:flex;gap:12px;flex-wrap:wrap;margin:30px 0 24px}
.hero__trust{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--ink-3)}
.hero__trust b{color:var(--ink);font-weight:600}
.stars{color:#E0A92E;letter-spacing:2px}
.eyebrow{display:inline-flex;align-items:center;gap:9px;color:var(--ink-2)}
.eyebrow .dot{width:7px;height:7px;background:#3FA66A;box-shadow:0 0 0 3px rgba(63,166,106,.18);animation:pulse 2.4s var(--ease) infinite}
@keyframes pulse{50%{box-shadow:0 0 0 6px rgba(63,166,106,0)}}

/* hero mockup (flat) */
.mock{background:var(--paper);border:1px solid var(--ink);box-shadow:14px 14px 0 rgba(21,19,14,.07)}
.mock__bar{display:flex;justify-content:space-between;align-items:center;padding:11px 14px;border-bottom:1px solid var(--line)}
.mock__chip{font-size:12px;font-weight:600}
.mock__meta{font-size:9px;letter-spacing:.18em;color:var(--ink-3)}
.mock__body{display:grid;grid-template-columns:148px 1fr}
.mock__side{border-right:1px solid var(--line);padding:14px 12px;display:flex;flex-direction:column;gap:14px;background:var(--cream-2)}
.mock__brand{font-size:11px;font-weight:600}
.mock__navi{display:flex;flex-direction:column;gap:7px;font-size:11px;color:var(--ink-3)}
.mock__navi span{display:flex;justify-content:space-between}
.mock__navi .on{color:var(--ink);font-weight:600;border-left:2px solid var(--rose);padding-left:6px;margin-left:-8px}
.mock__navi i{font-style:normal;background:var(--cream);border:1px solid var(--line);padding:0 5px;font-size:10px}
.mock__user{margin-top:auto;font-size:10px;color:var(--ink-3);border-top:1px solid var(--line);padding-top:10px}
.mock__main{padding:15px 16px}
.mock__head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:13px}
.mock__h{font-family:var(--disp);font-weight:400;font-size:18px;letter-spacing:-.02em;line-height:1.1;margin-top:3px}
.mock__sync{font-size:9px;color:#3FA66A;white-space:nowrap}
.mock__kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:13px}
.kpi{border:1px solid var(--line);padding:9px;background:var(--cream)}
.kpi span{display:block;font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3)}
.kpi b{font-family:var(--disp);font-weight:400;font-size:18px;display:block;margin:3px 0 1px}
.kpi i{font-style:normal;font-size:9px;color:var(--ink-3)}
.kpi .up{color:#3FA66A}.kpi .down{color:#C2502E}
.mock__rows{display:flex;flex-direction:column}
.row{display:grid;grid-template-columns:1.2fr .9fr 1fr auto;gap:8px;align-items:center;padding:8px 0;border-top:1px solid var(--line-2);font-size:11px}
.row__name{font-weight:600}.row__loc{color:var(--ink-3);font-size:10px}
.bar{height:5px;background:var(--cream-2);border:1px solid var(--line-2)}
.bar i{display:block;height:100%;background:var(--ink)}
.bar i.late{background:var(--rose)}
.row__st{font-size:10px;font-weight:600;text-align:right}
.row__st.on{color:var(--ink)}.row__st.late{color:#C2502E}.row__st.done{color:#3FA66A}
.mock__tag{margin-top:14px;display:inline-block;font-size:11px;font-weight:600;background:var(--ink);color:var(--cream);padding:7px 12px}

/* logos */
.logos{margin-top:clamp(56px,8vw,96px);padding-block:30px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:30px;flex-wrap:wrap}
.logos__label{white-space:nowrap}
.logos__row{display:flex;flex-wrap:wrap;gap:14px 34px;font-family:var(--disp);font-size:18px;color:var(--ink-2)}
.logos__row span{opacity:.7;transition:opacity .3s,color .3s}
.logos__row span:hover{opacity:1;color:var(--ink)}

/* ░░ Sections génériques ░░ */
.sec{padding-block:clamp(76px,11vw,150px)}
.sec__head{max-width:680px;margin-bottom:clamp(42px,6vw,72px)}
.sec__title{font-family:var(--disp);font-weight:400;letter-spacing:-.02em;line-height:1.02;
  font-size:clamp(34px,5vw,62px)}
.sec__lede{margin-top:22px;font-size:clamp(15px,1.5vw,18px);color:var(--ink-2);max-width:34em;line-height:1.65}
.sec__lede a{border-bottom:1.5px solid var(--rose)}
.pill{display:inline-block;margin-top:20px;border:1px solid var(--line);padding:7px 13px;background:var(--paper);color:var(--ink-2)}

/* problem cards */
.sec--problem{background:var(--paper)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.card{background:var(--paper);padding:clamp(26px,3vw,40px);transition:background .4s var(--ease)}
.card:hover{background:var(--cream)}
.card__idx{font-family:var(--disp);font-size:22px;color:var(--rose-ink)}
.card h3{font-family:var(--disp);font-weight:400;font-size:23px;letter-spacing:-.02em;margin:18px 0 12px;line-height:1.15}
.card p{color:var(--ink-2);font-size:15px;line-height:1.6}

/* process steps */
.steps{list-style:none;border-top:1px solid var(--line)}
.step{display:grid;grid-template-columns:120px 1fr;gap:clamp(16px,4vw,60px);
  padding:clamp(28px,4vw,46px) 0;border-bottom:1px solid var(--line);transition:padding-left .5s var(--ease)}
.step:hover{padding-left:14px}
.step__n{font-family:var(--disp);font-size:clamp(40px,5vw,70px);color:var(--ink);line-height:1}
.step:hover .step__n{color:var(--rose-ink)}
.step__body h3{font-family:var(--disp);font-weight:400;font-size:clamp(24px,2.6vw,34px);letter-spacing:-.02em;margin-bottom:12px}
.step__body p{color:var(--ink-2);max-width:46em;font-size:16px;line-height:1.6}
.step__dur{display:inline-block;margin-top:16px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);border-top:1px solid var(--line);padding-top:8px}

/* work / case studies */
.sec--work{background:var(--paper)}
.work{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(28px,4vw,64px);align-items:center;
  padding-block:clamp(40px,6vw,84px);border-top:1px solid var(--line)}
.work--rev .work__txt{order:2}
.work__sector{margin-bottom:22px;color:var(--ink-3)}
.work__ba{display:flex;flex-direction:column;gap:14px;margin-bottom:22px}
.work__ba p{font-size:15.5px;line-height:1.6;color:var(--ink-2);max-width:40em}
.ba{display:inline-block;font-size:10px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;
  background:var(--cream-2);border:1px solid var(--line);padding:2px 8px;margin-right:8px;color:var(--ink-3)}
.ba--now{background:var(--rose);border-color:var(--rose);color:var(--ink)}
.tags{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.tags li{font-size:12px;border:1px solid var(--line);padding:5px 11px;color:var(--ink-2)}
.work__kpis{display:flex;flex-wrap:wrap;gap:24px;border-top:1px solid var(--line);padding-top:20px}
.work__kpis span{font-size:13px;color:var(--ink-3)}
.work__kpis b{font-family:var(--disp);font-weight:400;font-size:30px;color:var(--ink);display:block;letter-spacing:-.02em}
.work__shots{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.work__shots figure{border:1px solid var(--ink);overflow:hidden;background:var(--cream-2);box-shadow:10px 10px 0 rgba(21,19,14,.06)}
.work__shots img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.work__shots figure:hover img{transform:scale(1.04)}
.work__shots--phone img{object-fit:contain;background:var(--cream)}

/* métiers (humain) */
.sec--trades{background:var(--cream)}
.trades{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.trade{position:relative;border:1px solid var(--ink);overflow:hidden;background:var(--ink)}
.trade img{width:100%;aspect-ratio:3/4;object-fit:cover;filter:grayscale(1) contrast(1.04);
  transition:transform .9s var(--ease),filter .7s var(--ease),opacity .7s var(--ease);opacity:.92}
.trade:hover img{transform:scale(1.05);filter:grayscale(0) contrast(1);opacity:1}
.trade figcaption{position:absolute;left:0;right:0;bottom:0;padding:14px;
  background:linear-gradient(to top,rgba(21,19,14,.86),rgba(21,19,14,0));color:var(--cream)}
.trade figcaption b{display:block;font-family:var(--disp);font-weight:400;font-size:18px;letter-spacing:-.02em}
.trade figcaption span{font-size:11px;color:rgba(244,240,232,.72)}
.trade::after{content:"";position:absolute;inset:0;border:0;pointer-events:none;
  box-shadow:inset 0 0 0 0 var(--rose);transition:box-shadow .5s var(--ease)}
.trade:hover::after{box-shadow:inset 0 0 0 4px var(--rose)}

/* reviews */
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.quote{background:var(--cream);padding:clamp(22px,2.4vw,32px);display:flex;flex-direction:column;justify-content:space-between;gap:24px;transition:background .4s var(--ease)}
.quote:hover{background:var(--paper)}
.quote blockquote{font-family:var(--disp);font-weight:400;font-size:17px;line-height:1.4;letter-spacing:-.01em}
.quote figcaption{display:flex;align-items:center;gap:11px}
.ava{width:38px;height:38px;display:grid;place-items:center;background:var(--ink);color:var(--cream);font-size:12px;font-weight:600;letter-spacing:.04em}
.quote figcaption b{display:block;font-size:13px;font-weight:600}
.quote figcaption i{font-style:normal;font-size:11px;color:var(--ink-3)}

/* configurateur */
.config__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,72px);align-items:center}
.config__pts{list-style:none;margin-top:26px;display:flex;flex-direction:column;gap:10px}
.config__pts li{position:relative;padding-left:24px;font-size:15px;color:var(--ink-2)}
.config__pts li::before{content:"→";position:absolute;left:0;color:var(--rose-ink);font-family:var(--disp)}
.config__panel{border:1px solid var(--ink);background:var(--paper);padding:clamp(22px,2.6vw,34px);box-shadow:14px 14px 0 rgba(21,19,14,.07)}
.config__steps{display:flex;gap:6px;margin-bottom:26px;flex-wrap:wrap}
.config__steps span{padding:5px 11px;border:1px solid var(--line);color:var(--ink-3);font-size:10px}
.config__steps .on{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.config__q{font-family:var(--disp);font-size:26px;letter-spacing:-.02em;margin-bottom:6px}
.config__hint{font-size:13px;color:var(--ink-3);margin-bottom:20px}
.config__opts{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:22px}
.opt{text-align:left;background:var(--cream);border:1px solid var(--line);padding:15px;cursor:pointer;
  transition:transform .4s var(--ease),border-color .3s,box-shadow .3s}
.opt b{display:block;font-size:14px;margin-bottom:3px}
.opt span{font-size:12px;color:var(--ink-3)}
.opt:hover{transform:translateY(-3px);border-color:var(--ink);box-shadow:5px 5px 0 var(--rose)}
.config__next{width:100%;justify-content:center}

/* faq */
.faq__grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(30px,5vw,72px);align-items:start}
.faq{border-top:1px solid var(--line)}
.faq__i{border-bottom:1px solid var(--line)}
.faq__i summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:18px;
  padding:24px 0;transition:color .3s}
.faq__i summary::-webkit-details-marker{display:none}
.faq__q{font-family:var(--disp);font-size:clamp(18px,2vw,23px);letter-spacing:-.02em}
.faq__plus{position:relative;width:18px;height:18px;flex:none}
.faq__plus::before,.faq__plus::after{content:"";position:absolute;background:var(--ink);transition:transform .4s var(--ease)}
.faq__plus::before{top:8px;left:0;width:18px;height:2px}
.faq__plus::after{left:8px;top:0;width:2px;height:18px}
.faq__i[open] .faq__plus::after{transform:scaleY(0)}
.faq__i[open] .faq__q{color:var(--rose-ink)}
.faq__i p{padding:0 0 26px;max-width:46em;color:var(--ink-2);font-size:15px;line-height:1.65}

/* cta final */
.sec--cta{background:var(--ink);color:var(--cream)}
.sec--cta .label{color:rgba(244,240,232,.6)}
.sec--cta .label span{background:var(--rose);border-color:var(--rose);color:var(--ink)}
.cta{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(34px,5vw,80px);align-items:center}
.cta__title{font-family:var(--disp);font-weight:400;letter-spacing:-.02em;line-height:1.03;font-size:clamp(34px,4.6vw,58px)}
.cta__title .ital{color:var(--rose)}
.cta__lede{margin-top:20px;color:rgba(244,240,232,.72);font-size:17px;line-height:1.6;max-width:32em}
.cta__pts{list-style:none;display:flex;flex-wrap:wrap;gap:10px 22px;margin-top:24px}
.cta__pts li{position:relative;padding-left:18px;font-size:13px;color:rgba(244,240,232,.85)}
.cta__pts li::before{content:"●";position:absolute;left:0;color:var(--rose);font-size:8px;top:4px}
.cta__form{background:var(--cream);color:var(--ink);padding:clamp(24px,3vw,36px);display:flex;flex-direction:column;gap:16px}
.cta__form label{display:flex;flex-direction:column;gap:7px;font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-3);font-weight:600}
.cta__form input{font-family:var(--body);font-size:16px;letter-spacing:-.01em;color:var(--ink);
  background:var(--paper);border:1px solid var(--line);padding:13px 14px;transition:border-color .3s,box-shadow .3s}
.cta__form input:focus{outline:none;border-color:var(--ink);box-shadow:3px 3px 0 var(--rose)}
.cta__or{font-size:13px;color:var(--ink-3);text-align:center}
.cta__or a{border-bottom:1.5px solid var(--rose);color:var(--ink)}

/* footer */
.foot{background:var(--cream);border-top:1px solid var(--line);padding-block:clamp(48px,6vw,80px) 28px}
.foot__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px}
.foot__logo{height:30px;image-rendering:pixelated;margin-bottom:18px}
.foot__brand p{color:var(--ink-3);font-size:14px;line-height:1.6;max-width:34em}
.foot__col{display:flex;flex-direction:column;gap:10px;font-size:14px;color:var(--ink-2)}
.foot__lab{text-transform:uppercase;letter-spacing:.18em;font-size:11px;color:var(--ink-3);font-weight:600;margin-bottom:4px}
.foot__col a{transition:color .3s}.foot__col a:hover{color:var(--rose-ink)}
.foot__base{display:flex;justify-content:space-between;border-top:1px solid var(--line);margin-top:48px;padding-top:22px;font-size:12px;color:var(--ink-3)}

/* ——— Reveal motion ——— */
.js .reveal{opacity:0;transform:translateY(26px);filter:blur(6px);
  transition:opacity .9s var(--ease),transform .9s var(--ease),filter .9s var(--ease)}
.reveal{opacity:1}
.reveal.in{opacity:1;transform:none;filter: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}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;filter:none}.rot__list{animation:none}}

/* ——— Responsive ——— */
@media(max-width:980px){
  .hero__grid{grid-template-columns:1fr;gap:40px}
  .hero__mock{max-width:560px}
  .config__grid,.faq__grid,.cta{grid-template-columns:1fr}
  .grid-4{grid-template-columns:1fr 1fr}
  .trades{grid-template-columns:1fr 1fr}
  .work,.work--rev .work__txt{grid-template-columns:1fr;order:0}
  .work__txt{order:0!important}
}
@media(max-width:760px){
  .nav__links,.nav__cta{display:none}
  .nav__burger{display:flex}
  .grid-3{grid-template-columns:1fr}
  .step{grid-template-columns:1fr;gap:8px}
  .step__n{font-size:42px}
  .config__opts{grid-template-columns:1fr}
  .grid-4{grid-template-columns:1fr}
  .foot__grid{grid-template-columns:1fr;gap:30px}
  .foot__base{flex-direction:column;gap:8px}
  .logos{gap:18px}
}
/* petit écran : mot rotatif seul sur sa ligne + mockup qui respire (zéro débordement) */
@media(max-width:520px){
  .hero__title{font-size:clamp(27px,7.8vw,40px);line-height:1.06}
  .rot{display:block;height:1em;max-width:100%}
  .rot__list b{width:auto;max-width:100%;white-space:nowrap}
  .hero__copy,.hero__mock{min-width:0;max-width:100%}
  .mock__body{grid-template-columns:1fr}
  .mock__side{flex-direction:row;flex-wrap:wrap;align-items:center;gap:8px 14px;
    border-right:0;border-bottom:1px solid var(--line)}
  .mock__user{margin-top:0;border-top:0;padding-top:0}
  .mock__kpis{grid-template-columns:1fr 1fr}
  .row{grid-template-columns:1fr auto auto;gap:6px}
  .row .row__loc{display:none}
}

.opt.is-sel{border-color:var(--ink);background:var(--rose);box-shadow:5px 5px 0 var(--ink)}
.opt.is-sel span{color:var(--ink)}
