/* ============================================================
   BORNELINK — site vitrine (recrutement techniciens IRVE)
   Design system partagé. Tokens repris de la plateforme.
   Clair par défaut, bascule sombre (data-theme sur <html>).
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  /* fallback = clair (le <html> porte data-theme, mais on protège) */
  --bg:#E9EEF7; --bg2:#F4F7FC; --panel:#FFFFFF; --panel2:#EEF3FB;
  --line:rgba(23,53,120,.10); --line2:rgba(23,53,120,.17);
  --blue:#1F5FE0; --blue-deep:#1648C0; --cyan:#0892A6;
  --amber:#B07300; --green:#168A54;
  --text:#0E1B33; --muted:#4A5B7C; --muted2:#586A8E; --cyan-ink:#0B7C8C;

  --c-urgente:#0892A6; --c-en_cours:#B07300; --c-planifiee:#1F5FE0; --c-terminee:#168A54;
  --bg-urgente:rgba(8,146,166,.12); --bg-en_cours:rgba(176,115,0,.13);
  --bg-planifiee:rgba(31,95,224,.12); --bg-terminee:rgba(22,138,84,.13);
  --tp-dc:#0892A6; --bg-dc:rgba(8,146,166,.12); --tp-ac:#1F5FE0; --bg-ac:rgba(31,95,224,.12);

  --tint-soft:rgba(31,95,224,.05); --tint-mid:rgba(31,95,224,.11);
  --glow:rgba(31,95,224,.10);
  --shadow:0 12px 30px -18px rgba(23,53,120,.30);
  --shadow-lg:0 30px 60px -28px rgba(23,53,120,.40);
  --shadow-sm:0 4px 14px -8px rgba(23,53,120,.30);
  --topbar-bg:rgba(244,247,252,.78);
  --overlay:rgba(255,255,255,.86);

  --fd:'Space Grotesk',system-ui,sans-serif;
  --fb:'Inter',system-ui,sans-serif;
  --fm:'JetBrains Mono',ui-monospace,monospace;

  --r-sm:10px; --r:14px; --r-lg:20px; --r-xl:28px;
  --wrap:1200px;
  --pad:clamp(20px,5vw,40px);
}
[data-theme="light"]{ color-scheme:light; }
[data-theme="dark"]{
  color-scheme:dark;
  --bg:#0A1426; --bg2:#0B182F; --panel:#0F1E3C; --panel2:#14264A;
  --line:rgba(125,165,255,.14); --line2:rgba(125,165,255,.26);
  --blue:#2E7BFF; --blue-deep:#1657F0; --cyan:#19D6E8;
  --amber:#F5A623; --green:#34C77B;
  --text:#EAF1FF; --muted:#93A6CC; --muted2:#8094BC; --cyan-ink:#19D6E8;

  --c-urgente:#19D6E8; --c-en_cours:#F5A623; --c-planifiee:#2E7BFF; --c-terminee:#34C77B;
  --bg-urgente:rgba(25,214,232,.14); --bg-en_cours:rgba(245,166,35,.16);
  --bg-planifiee:rgba(46,123,255,.16); --bg-terminee:rgba(52,199,123,.14);
  --tp-dc:#19D6E8; --bg-dc:rgba(25,214,232,.14); --tp-ac:#7FB0FF; --bg-ac:rgba(46,123,255,.16);

  --tint-soft:rgba(46,123,255,.06); --tint-mid:rgba(46,123,255,.16);
  --glow:rgba(46,123,255,.16);
  --shadow:0 18px 40px -24px rgba(0,0,0,.6);
  --shadow-lg:0 40px 80px -30px rgba(0,0,0,.7);
  --shadow-sm:0 6px 18px -10px rgba(0,0,0,.6);
  --topbar-bg:rgba(10,20,38,.66);
  --overlay:rgba(10,20,38,.82);
}

/* ---------- Base ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg); color:var(--text);
  font-family:var(--fb); font-size:16px; line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
body,.nav,.card,.panel,.feature,.btn,.theme-btn,.input,.textarea,.select,.mission,.hab,.faq__item{
  transition:background-color .28s ease,border-color .28s ease,color .2s ease,box-shadow .28s ease,transform .2s ease;
}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
h1,h2,h3,h4{font-family:var(--fd);font-weight:700;letter-spacing:-.02em;line-height:1.08}
.mono{font-family:var(--fm)}
strong{font-weight:600;color:var(--text)}
::selection{background:var(--cyan);color:#04121b}

:focus-visible{outline:2px solid var(--blue);outline-offset:3px;border-radius:6px}

.skip{position:absolute;left:-999px;top:0;background:var(--panel);color:var(--text);
  padding:10px 16px;border-radius:0 0 var(--r-sm) 0;border:1px solid var(--line2);z-index:200}
.skip:focus{left:0}

/* ---------- Layout ---------- */
.wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:var(--pad)}
.section{padding-block:clamp(64px,9vw,120px);position:relative}
.section--tight{padding-block:clamp(44px,6vw,72px)}
.section--alt{background:var(--bg2)}
.section--panel{background:var(--panel)}
.divider{height:1px;background:var(--line);border:0}

.grid{display:grid;gap:22px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:920px){ .cols-2{grid-template-columns:1fr} .cols-3,.cols-4{grid-template-columns:repeat(2,1fr)} .form__row{grid-template-columns:1fr} }
@media(max-width:620px){ .cols-2,.cols-3,.cols-4{grid-template-columns:1fr} }

/* ---------- Eyebrow / headings / lead ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--fm);font-size:12px;font-weight:600;letter-spacing:.16em;
  text-transform:uppercase;color:var(--cyan-ink);margin-bottom:18px;
}
.eyebrow::before{content:"";width:22px;height:2px;background:linear-gradient(90deg,var(--cyan),transparent)}
.section-title{font-size:clamp(28px,4.4vw,46px);max-width:18ch}
.section-title.wide{max-width:24ch}
.lead{font-size:clamp(16px,1.7vw,19px);color:var(--muted);max-width:60ch;margin-top:18px}
.kicker{color:var(--cyan-ink)}
.head{max-width:760px;margin-bottom:clamp(36px,5vw,56px)}
.head--center{margin-inline:auto;text-align:center}
.head--center .eyebrow{justify-content:center}
.head--center .lead{margin-inline:auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--fd);font-weight:600;font-size:15px;line-height:1;
  padding:13px 20px;border-radius:var(--r-sm);border:1px solid transparent;cursor:pointer;
  white-space:nowrap;
}
.btn svg{width:17px;height:17px;stroke:currentColor;stroke-width:2;fill:none}
.btn--primary{background:linear-gradient(135deg,#3A86FF,var(--blue-deep));color:#fff;
  box-shadow:0 10px 24px -12px rgba(31,95,224,.7)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(31,95,224,.8)}
.btn--ghost{background:var(--tint-soft);border-color:var(--line2);color:var(--text)}
.btn--ghost:hover{background:var(--tint-mid);transform:translateY(-2px)}
.btn--line{background:transparent;border-color:var(--line2);color:var(--text)}
.btn--line:hover{border-color:var(--blue);color:var(--blue)}
.btn--lg{padding:16px 26px;font-size:16px}
.btn--block{width:100%}

/* ---------- Topbar ---------- */
.nav{position:sticky;top:0;z-index:60;background:var(--topbar-bg);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav__inner{display:flex;align-items:center;gap:18px;height:68px;
  max-width:var(--wrap);margin-inline:auto;padding-inline:var(--pad)}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--fd);font-weight:700;font-size:20px;letter-spacing:-.01em}
.brand__mark{width:32px;height:32px;flex-shrink:0}
.nav__links{display:flex;align-items:center;gap:4px;margin-left:14px}
.nav__link{font-size:14.5px;font-weight:500;color:var(--muted);padding:9px 13px;border-radius:9px}
.nav__link:hover{color:var(--text);background:var(--tint-soft)}
.nav__link[aria-current="page"]{color:var(--text);background:var(--tint-mid)}
.nav__actions{display:flex;align-items:center;gap:10px;margin-left:auto}
.theme-btn{background:var(--panel);border:1px solid var(--line);border-radius:10px;
  width:40px;height:40px;display:grid;place-items:center;cursor:pointer;color:var(--muted)}
.theme-btn:hover{color:var(--text);border-color:var(--line2)}
.theme-btn svg{width:18px;height:18px;stroke:currentColor;stroke-width:1.9;fill:none}
.ic-sun,.ic-moon{display:none}
[data-theme="light"] .ic-moon{display:block}
[data-theme="dark"] .ic-sun{display:block}
.menu-toggle{display:none;background:var(--panel);border:1px solid var(--line);border-radius:10px;
  width:40px;height:40px;place-items:center;cursor:pointer;color:var(--text)}
.menu-toggle svg{width:20px;height:20px;stroke:currentColor;stroke-width:2;fill:none}
.nav__cta{display:inline-flex}

/* mobile drawer */
.drawer{display:none;position:fixed;inset:68px 0 auto 0;z-index:55;background:var(--panel);
  border-bottom:1px solid var(--line2);box-shadow:var(--shadow-lg);padding:14px var(--pad) 22px}
.drawer.open{display:block}
.drawer a{display:block;padding:13px 6px;font-family:var(--fd);font-weight:600;font-size:17px;
  border-bottom:1px solid var(--line);color:var(--text)}
.drawer .btn{margin-top:16px}
@media(max-width:880px){
  .nav__links{display:none}
  .nav__cta{display:none}
  .menu-toggle{display:grid}
}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;
  background:
    radial-gradient(ellipse 80% 70% at 78% 18%,var(--glow),transparent 60%),
    radial-gradient(ellipse 70% 60% at 8% 90%,var(--tint-soft),transparent 55%);
}
.hero__inner{display:grid;grid-template-columns:1.06fr .94fr;gap:clamp(28px,4vw,56px);
  align-items:center;padding-block:clamp(48px,7vw,96px)}
.hero__copy,.hero__visual{min-width:0}
.hero__title{font-size:clamp(34px,5.6vw,62px);letter-spacing:-.03em}
.hero__title .grad{
  background:linear-gradient(120deg,var(--blue),var(--cyan));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero__sub{font-size:clamp(16px,1.9vw,20px);color:var(--muted);max-width:46ch;margin-top:20px}
.hero__cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}
.hero__meta{display:flex;flex-wrap:wrap;gap:18px 26px;margin-top:30px;
  font-family:var(--fm);font-size:12.5px;color:var(--muted2)}
.hero__meta span{display:inline-flex;align-items:center;gap:8px}
.hero__meta b{color:var(--text);font-weight:500}
.tick{width:16px;height:16px;border-radius:50%;display:grid;place-items:center;
  background:var(--bg-terminee);color:var(--green);flex-shrink:0}
.tick svg{width:10px;height:10px;stroke:currentColor;stroke-width:3;fill:none}
@media(max-width:860px){
  .hero__inner{grid-template-columns:1fr;gap:34px}
  .hero__visual{order:-1}
}

/* signature: panneau "dispatch" (missions entrantes) */
.dispatch{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg);padding:18px;position:relative}
.dispatch::before{content:"";position:absolute;inset:0;border-radius:var(--r-lg);
  padding:1px;background:linear-gradient(140deg,var(--cyan),transparent 40%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:.5;pointer-events:none}
.dispatch__head{display:flex;align-items:center;gap:10px;padding:6px 8px 16px}
.dispatch__head .label{font-family:var(--fm);font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted2)}
.dispatch__live{margin-left:auto;display:inline-flex;align-items:center;gap:7px;
  font-family:var(--fm);font-size:11px;color:var(--cyan)}
.dispatch__live i{width:7px;height:7px;border-radius:50%;background:var(--cyan);
  box-shadow:0 0 0 0 var(--cyan);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--cyan) 60%,transparent)}
  70%{box-shadow:0 0 0 8px transparent}100%{box-shadow:0 0 0 0 transparent}}

.mission{display:flex;align-items:center;gap:13px;padding:14px;border-radius:var(--r);
  background:var(--bg2);border:1px solid var(--line);margin-bottom:10px}
.mission:last-child{margin-bottom:0}
.mission.is-new{box-shadow:inset 3px 0 0 var(--cyan)}
.tp{font-family:var(--fm);font-size:11px;font-weight:700;width:34px;height:34px;border-radius:9px;
  display:grid;place-items:center;flex-shrink:0}
.tp.DC{background:var(--bg-dc);color:var(--tp-dc)} .tp.AC{background:var(--bg-ac);color:var(--tp-ac)}
.mission__info{flex:1;min-width:0}
.mission__t{font-family:var(--fd);font-weight:600;font-size:14.5px;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis}
.mission__s{font-family:var(--fm);font-size:11.5px;color:var(--muted2);margin-top:3px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mission__r{text-align:right;flex-shrink:0}
.mission__amt{font-family:var(--fd);font-weight:700;font-size:15px}
.badge{font-family:var(--fm);font-size:9.5px;letter-spacing:.04em;padding:3px 8px;
  border-radius:6px;display:inline-block;margin-top:4px}
.b-urgente{background:var(--bg-urgente);color:var(--c-urgente)}
.b-en_cours{background:var(--bg-en_cours);color:var(--c-en_cours)}
.b-planifiee{background:var(--bg-planifiee);color:var(--c-planifiee)}
.b-terminee{background:var(--bg-terminee);color:var(--c-terminee)}

/* ---------- Cards / panels ---------- */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:26px;box-shadow:var(--shadow)}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--shadow);overflow:hidden}

/* pilier / feature */
.feature{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:26px;box-shadow:var(--shadow);height:100%}
.feature:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--line2)}
.feature__icon{width:48px;height:48px;border-radius:13px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--tint-mid),var(--tint-soft));border:1px solid var(--line2);
  color:var(--cyan);margin-bottom:18px}
.feature__icon svg{width:24px;height:24px;stroke:currentColor;stroke-width:1.8;fill:none}
.feature h3{font-size:19px;margin-bottom:9px}
.feature p{color:var(--muted);font-size:14.5px}
.feature__num{font-family:var(--fm);font-size:12px;color:var(--muted2);float:right}

/* ---------- Steps (séquence réelle => numérotation justifiée) ---------- */
.steps{counter-reset:step;display:grid;gap:20px}
.step{display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:start;
  padding:24px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow)}
.step__num{counter-increment:step;width:46px;height:46px;border-radius:13px;
  display:grid;place-items:center;font-family:var(--fd);font-weight:700;font-size:18px;
  background:linear-gradient(135deg,var(--blue),var(--blue-deep));color:#fff;flex-shrink:0}
.step__num::before{content:counter(step,decimal-leading-zero)}
.step h3{font-size:18px;margin-bottom:7px}
.step p{color:var(--muted);font-size:14.5px}

/* ---------- Stats ---------- */
.stat{padding:22px 4px}
.stat__v{font-family:var(--fd);font-weight:700;font-size:clamp(30px,4vw,44px);
  letter-spacing:-.03em;line-height:1}
.stat__v .u{color:var(--cyan-ink)}
.stat__l{font-family:var(--fm);font-size:12px;color:var(--muted2);margin-top:10px;
  text-transform:uppercase;letter-spacing:.06em}

/* ---------- BPU box ---------- */
.bpu{background:var(--bg2);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:22px;box-shadow:var(--shadow)}
.bpu__row{display:flex;justify-content:space-between;align-items:baseline;gap:14px;
  font-family:var(--fm);font-size:14px;color:var(--muted);padding:9px 0}
.bpu__row span:last-child{color:var(--text)}
.bpu__row--total{color:var(--text);font-weight:700;border-top:1px solid var(--line2);
  margin-top:8px;padding-top:14px;font-size:17px}
.bpu__row--total .amt{color:var(--cyan);font-family:var(--fd);font-size:22px}

/* ---------- Table ---------- */
.tablewrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow)}
.table{width:100%;border-collapse:collapse;min-width:520px;background:var(--panel)}
.table th,.table td{padding:15px 18px;text-align:left;border-bottom:1px solid var(--line);font-size:14.5px}
.table th{font-family:var(--fm);font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--muted2);font-weight:600;background:var(--bg2)}
.table td.mono{font-family:var(--fm)}
.table tr:last-child td{border-bottom:0}
.table tr:hover td{background:var(--tint-soft)}

/* ---------- Habilitation chips & cards ---------- */
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{font-family:var(--fm);font-size:11.5px;color:var(--muted);border:1px solid var(--line2);
  padding:6px 11px;border-radius:8px;background:var(--bg2)}
.chip--on{color:var(--cyan);border-color:var(--cyan);background:var(--bg-dc)}
.hab{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:22px;box-shadow:var(--shadow);height:100%}
.hab__level{font-family:var(--fm);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--cyan-ink);margin-bottom:10px}
.hab h3{font-size:18px;margin-bottom:8px}
.hab p{color:var(--muted);font-size:14px;margin-bottom:14px}

/* ---------- Callout ---------- */
.callout{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:center;
  background:linear-gradient(135deg,var(--tint-mid),var(--tint-soft));
  border:1px solid var(--line2);border-radius:var(--r-lg);padding:24px 26px}
.callout__icon{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;
  background:var(--panel);border:1px solid var(--line2);color:var(--cyan);flex-shrink:0}
.callout__icon svg{width:24px;height:24px;stroke:currentColor;stroke-width:1.8;fill:none}
.callout h3{font-size:18px;margin-bottom:5px}
.callout p{color:var(--muted);font-size:14.5px}

/* ---------- App mockup ("Mon secteur") ---------- */
.mockup{border:1px solid var(--line2);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-lg);background:var(--panel)}
.mockup__bar{display:flex;align-items:center;gap:8px;padding:12px 16px;
  background:var(--bg2);border-bottom:1px solid var(--line)}
.mockup__bar i{width:11px;height:11px;border-radius:50%;background:var(--line2)}
.mockup__bar .t{margin-left:8px;font-family:var(--fm);font-size:12px;color:var(--muted2)}
.mockup__body{padding:18px}
.mockup__row{display:flex;align-items:center;gap:10px;font-family:var(--fm);
  font-size:12px;color:var(--muted);padding:9px 0;border-bottom:1px solid var(--line)}
.mockup__row:last-child{border-bottom:0}
.lg-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}

/* ---------- FAQ (details natif = a11y + sans JS) ---------- */
.faq{display:grid;gap:12px}
.faq__item{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow-sm);overflow:hidden}
.faq__item[open]{border-color:var(--line2)}
.faq__q{list-style:none;cursor:pointer;display:flex;align-items:center;gap:14px;
  padding:18px 22px;font-family:var(--fd);font-weight:600;font-size:16px}
.faq__q::-webkit-details-marker{display:none}
.faq__q::after{content:"";margin-left:auto;width:11px;height:11px;border-right:2px solid var(--muted2);
  border-bottom:2px solid var(--muted2);transform:rotate(45deg);transition:transform .25s ease;flex-shrink:0}
.faq__item[open] .faq__q::after{transform:rotate(-135deg)}
.faq__a{padding:0 22px 20px;color:var(--muted);font-size:14.5px;max-width:70ch}

/* ---------- Timeline ---------- */
.timeline{display:grid;gap:0;position:relative}
.timeline__item{display:grid;grid-template-columns:auto 1fr;gap:18px;padding-bottom:26px;position:relative}
.timeline__item:last-child{padding-bottom:0}
.timeline__dot{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;
  background:var(--panel);border:1px solid var(--line2);color:var(--cyan);
  font-family:var(--fm);font-weight:700;font-size:13px;z-index:1}
.timeline__item:not(:last-child) .timeline__dot::after{content:"";position:absolute;
  left:18px;top:38px;bottom:0;width:2px;background:var(--line2)}
.timeline h3{font-size:16px;margin-bottom:4px}
.timeline p{color:var(--muted);font-size:14px}

/* ---------- Forms ---------- */
.form{display:grid;gap:18px}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:560px){ .form__row{grid-template-columns:1fr} }
.field{display:grid;gap:8px}
.label{font-family:var(--fm);font-size:12px;letter-spacing:.04em;color:var(--muted);font-weight:600}
.label .opt{color:var(--muted2);font-weight:400;text-transform:none;letter-spacing:0}
.input,.textarea,.select{
  width:100%;font-family:var(--fb);font-size:15px;color:var(--text);
  background:var(--bg2);border:1px solid var(--line2);border-radius:var(--r-sm);padding:13px 15px;
}
.textarea{resize:vertical;min-height:120px}
.select{appearance:none;
  background-image:linear-gradient(45deg,transparent 50%,var(--muted2) 50%),linear-gradient(135deg,var(--muted2) 50%,transparent 50%);
  background-position:calc(100% - 20px) center,calc(100% - 15px) center;
  background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:40px}
.input:focus,.textarea:focus,.select:focus{border-color:var(--blue);background:var(--panel);outline:none;
  box-shadow:0 0 0 3px var(--tint-mid)}
.input::placeholder,.textarea::placeholder{color:var(--muted2)}
.help{font-family:var(--fm);font-size:11.5px;color:var(--muted2)}
.field.invalid .input,.field.invalid .textarea,.field.invalid .select{border-color:#d6485c}
.field .err{font-family:var(--fm);font-size:11.5px;color:#d6485c;display:none}
.field.invalid .err{display:block}

/* checkbox habilitations */
.checks{display:flex;flex-wrap:wrap;gap:10px}
.check{position:relative;display:inline-flex}
.check input{position:absolute;opacity:0;width:1px;height:1px}
.check label{font-family:var(--fm);font-size:13px;color:var(--muted);cursor:pointer;
  border:1px solid var(--line2);background:var(--bg2);border-radius:9px;padding:10px 14px;
  display:inline-flex;align-items:center;gap:9px;user-select:none}
.check label::before{content:"";width:15px;height:15px;border-radius:4px;border:1.5px solid var(--muted2);flex-shrink:0}
.check input:checked + label{color:var(--cyan);border-color:var(--cyan);background:var(--bg-dc)}
.check input:checked + label::before{background:var(--cyan);border-color:var(--cyan);
  box-shadow:inset 0 0 0 2px var(--panel)}
.check input:focus-visible + label{outline:2px solid var(--blue);outline-offset:2px}
.checks.invalid{outline:1.5px dashed #d6485c;outline-offset:8px;border-radius:12px}

/* autocomplete (recherche entreprise) */
.ac{position:relative}
.ac__list{position:absolute;z-index:30;top:calc(100% + 4px);left:0;right:0;
  background:var(--panel);border:1px solid var(--line2);border-radius:var(--r-sm);
  box-shadow:var(--shadow-lg);max-height:264px;overflow-y:auto;padding:4px;margin:0;list-style:none}
.ac__item{padding:10px 12px;border-radius:8px;cursor:pointer}
.ac__item:hover,.ac__item[aria-selected="true"]{background:var(--tint-mid)}
.ac__item b{display:block;font-family:var(--fd);font-weight:600;font-size:14px}
.ac__item small{font-family:var(--fm);font-size:11.5px;color:var(--muted2)}
.ac__empty{padding:11px 12px;font-family:var(--fm);font-size:12.5px;color:var(--muted2)}

.note{font-family:var(--fm);font-size:12px;color:var(--muted2);background:var(--bg2);
  border:1px dashed var(--line2);border-radius:var(--r-sm);padding:12px 14px}
.form__ok{display:none;text-align:center;padding:30px;background:var(--bg-terminee);
  border:1px solid var(--green);border-radius:var(--r-lg);color:var(--text)}
.form__ok.show{display:block}
.form__ok .ic{width:54px;height:54px;border-radius:50%;background:var(--green);color:#fff;
  display:grid;place-items:center;margin:0 auto 14px}
.form__ok .ic svg{width:28px;height:28px;stroke:currentColor;stroke-width:3;fill:none}

/* placeholder de preuve à compléter */
.todo-proof{font-family:var(--fm);font-size:11px;color:var(--amber);
  border:1px dashed var(--amber);border-radius:7px;padding:3px 8px;display:inline-block}

/* ---------- Page légale (prose) ---------- */
.legal h2,.legal h3{font-size:19px;line-height:1.3;margin:34px 0 10px;letter-spacing:-.01em;color:var(--text)}
.legal h2:first-child,.legal h3:first-child{margin-top:0}
.legal p{color:var(--muted);margin-bottom:12px;max-width:74ch}
.legal p:last-child{margin-bottom:0}
.legal a{color:var(--blue)}
.legal a:hover{text-decoration:underline}
.legal strong{color:var(--text)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;border-radius:var(--r-xl);padding:clamp(36px,5vw,64px);
  background:linear-gradient(135deg,var(--blue-deep),#0B3DBC);color:#EAF1FF;
  box-shadow:var(--shadow-lg)}
.cta-band::after{content:"";position:absolute;right:-60px;top:-60px;width:280px;height:280px;
  border-radius:50%;background:radial-gradient(circle,rgba(25,214,232,.35),transparent 65%)}
.cta-band h2{color:#fff;font-size:clamp(26px,3.6vw,40px);max-width:20ch;position:relative}
.cta-band p{color:rgba(234,241,255,.82);max-width:52ch;margin-top:14px;position:relative}
.cta-band .btn{position:relative;margin-top:26px}
.cta-band .btn--primary{background:#fff;color:var(--blue-deep)}
.cta-band .btn--primary:hover{background:#eaf1ff}
.cta-band .btn--line{border-color:rgba(255,255,255,.45);color:#fff}
.cta-band .btn--line:hover{border-color:#fff;color:#fff;background:rgba(255,255,255,.1)}

/* ---------- Footer ---------- */
.footer{background:var(--bg2);border-top:1px solid var(--line);padding-block:clamp(48px,6vw,72px) 28px}
.footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:32px}
@media(max-width:820px){ .footer__grid{grid-template-columns:1fr 1fr} }
@media(max-width:520px){ .footer__grid{grid-template-columns:1fr} }
.footer__brand .brand{margin-bottom:14px}
.footer__brand p{color:var(--muted);font-size:14px;max-width:34ch}
.footer__col h4{font-family:var(--fm);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted2);margin-bottom:16px}
.footer__col a{display:block;color:var(--muted);font-size:14.5px;padding:6px 0}
.footer__col a:hover{color:var(--text)}
.footer__bottom{display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;align-items:center;
  margin-top:clamp(36px,5vw,56px);padding-top:24px;border-top:1px solid var(--line);
  font-family:var(--fm);font-size:12.5px;color:var(--muted2)}
.footer__bottom a:hover{color:var(--text)}

/* ---------- Reveal animation ---------- */
/* visible par défaut ; masqué seulement si JS actif (progressive enhancement) */
.reveal{transition:opacity .6s ease,transform .6s ease}
.js .reveal{opacity:0;transform:translateY(18px)}
.js .reveal.in,.reveal.in{opacity:1;transform:none}
.js-ready .reveal{opacity:1!important;transform:none!important}
.js-ready .dispatch .mission{opacity:1!important;transform:none!important}
.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}

/* hero dispatch entrance — missions visibles par défaut, masquées seulement si JS actif */
.js .dispatch .mission{opacity:0;transform:translateX(16px)}
.dispatch.play .mission{animation:slidein .5s ease forwards}
.dispatch.play .mission:nth-child(1){animation-delay:.15s}
.dispatch.play .mission:nth-child(2){animation-delay:.35s}
.dispatch.play .mission:nth-child(3){animation-delay:.55s}
.dispatch.play .mission:nth-child(4){animation-delay:.75s}
@keyframes slidein{to{opacity:1;transform:none}}

/* ---------- Reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .js .reveal,.reveal{opacity:1;transform:none}
  .js .dispatch .mission,.dispatch .mission{opacity:1;transform:none}
  .dispatch__live i{animation:none}
}
