/* ============================================================
   Renfora — Le Bureau v3 (design system de la REFONTE validée Direction).
   Extrait VERBATIM de 99_Workspace/Le-Bureau-Renfora — maquette v3.html.
   Dalle flottante .app + top-bar + rail fin + librairie de composants.
   Polices système (doctrine RGPD : zéro hotlink). Clair/sombre [data-theme].
   ============================================================ */
/* v3 — reprend l'IDÉE de la v2 (verre froid, dalle flottante, board-graphe) + contenu/doctrine Renfora.
     Aucune police hotlinkée (doctrine RGPD données UE) — stack système. Icônes = SVG inline (thémables).
     Ajouts : mode sombre CÂBLÉ (☾/☀), numéros masqués, « ce qu'il ne fera jamais », badges live/UE. */
  :root{
    --ink:#10141b; --ink-soft:#5b6573; --ink-faint:#9aa3b2;
    --line:#e9ecf2; --bg:#dfe4ee;
    --card:#fff; --card-2:#f7f9fd;
    --glass:rgba(255,255,255,.55); --glass2:rgba(255,255,255,.78); --slab:rgba(255,255,255,.34); --slab-brd:rgba(255,255,255,.6);
    --accent:#2f5fff; --accent-soft:#e9eeff;
    --blue:#5b8def; --green:#2bb673; --green-soft:#e4f6ec; --green-ink:#11814f;
    --red:#e8503a; --red-soft:#fde9e5; --red-ink:#b5371f; --amber:#e0a23a; --amber-ink:#946100;
    --draft:#aab2c0;
    --conn:#bcd0f5; --conn-esc:#f0a89c; --conn-arrow:#10141b;
    --shadow:0 2px 6px rgba(16,20,27,.05), 0 22px 50px rgba(16,20,27,.10);
    --shadow-sm:0 1px 2px rgba(16,20,27,.05), 0 8px 20px rgba(16,20,27,.07);
    --pop:0 10px 24px rgba(16,20,27,.32);
    --field:radial-gradient(900px 520px at 8% -6%,#efeaff 0%,transparent 55%),radial-gradient(1000px 620px at 102% 0%,#e3eeff 0%,transparent 52%),linear-gradient(180deg,#eef1f7,var(--bg));
    --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  }
  @media (prefers-color-scheme:dark){:root:not([data-theme="light"]){
    --ink:#eaf0fb; --ink-soft:#aab5c9; --ink-faint:#6f7c93;
    --line:rgba(255,255,255,.09); --bg:#0b0f17;
    --card:#161d2b; --card-2:#1b2336;
    --glass:rgba(28,36,52,.55); --glass2:rgba(28,36,52,.82); --slab:rgba(22,28,42,.42); --slab-brd:rgba(255,255,255,.09);
    --accent:#6f93ff; --accent-soft:#1a2540;
    --blue:#6f93ff; --green:#39d08c; --green-soft:#11321f; --green-ink:#7ce6b3; --red:#ff6f57; --red-soft:#3a1d18; --red-ink:#ff9d8c; --amber:#e6b24f; --amber-ink:#ecc878;
    --draft:#5b6573;
    --conn:#39496b; --conn-esc:#7d4a40; --conn-arrow:#eaf0fb;
    --shadow:0 2px 6px rgba(0,0,0,.4),0 22px 50px rgba(0,0,0,.5);
    --shadow-sm:0 1px 2px rgba(0,0,0,.4),0 8px 20px rgba(0,0,0,.4);
    --pop:0 14px 30px rgba(0,0,0,.6);
    --field:radial-gradient(900px 520px at 8% -6%,#1c1840 0%,transparent 55%),radial-gradient(1000px 620px at 102% 0%,#10233f 0%,transparent 52%),linear-gradient(180deg,#0e1320,var(--bg));
  }}
  [data-theme="dark"]{
    --ink:#eaf0fb; --ink-soft:#aab5c9; --ink-faint:#6f7c93;
    --line:rgba(255,255,255,.09); --bg:#0b0f17;
    --card:#161d2b; --card-2:#1b2336;
    --glass:rgba(28,36,52,.55); --glass2:rgba(28,36,52,.82); --slab:rgba(22,28,42,.42); --slab-brd:rgba(255,255,255,.09);
    --accent:#6f93ff; --accent-soft:#1a2540;
    --blue:#6f93ff; --green:#39d08c; --green-soft:#11321f; --green-ink:#7ce6b3; --red:#ff6f57; --red-soft:#3a1d18; --red-ink:#ff9d8c; --amber:#e6b24f; --amber-ink:#ecc878;
    --draft:#5b6573;
    --conn:#39496b; --conn-esc:#7d4a40; --conn-arrow:#eaf0fb;
    --shadow:0 2px 6px rgba(0,0,0,.4),0 22px 50px rgba(0,0,0,.5);
    --shadow-sm:0 1px 2px rgba(0,0,0,.4),0 8px 20px rgba(0,0,0,.4);
    --pop:0 14px 30px rgba(0,0,0,.6);
    --field:radial-gradient(900px 520px at 8% -6%,#1c1840 0%,transparent 55%),radial-gradient(1000px 620px at 102% 0%,#10233f 0%,transparent 52%),linear-gradient(180deg,#0e1320,var(--bg));
  }
  *{box-sizing:border-box}
  body{margin:0;font-family:var(--font);color:var(--ink);-webkit-font-smoothing:antialiased;background:var(--field);min-height:100vh;padding:22px}
  svg{display:block}
  .icon{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
  .icon.sm{width:15px;height:15px}
  a{text-decoration:none;color:inherit}
  :focus-visible{outline:2.5px solid var(--accent);outline-offset:2px;border-radius:8px}
  .app{max-width:1480px;margin:0 auto;background:var(--slab);border:1px solid var(--slab-brd);border-radius:34px;box-shadow:var(--shadow);backdrop-filter:blur(10px);overflow:hidden}

  /* TOP BAR */
  .top{display:flex;align-items:center;gap:26px;padding:20px 30px;border-bottom:1px solid var(--slab-brd)}
  .brand{display:flex;align-items:center;gap:11px;font-weight:800;font-size:20px;letter-spacing:-.5px}
  .brand .mk{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;color:#fff;background:linear-gradient(140deg,#2f5fff,#6a3bff);box-shadow:0 6px 16px rgba(47,95,255,.4)}
  .brand small{display:block;font-weight:500;font-size:10px;color:var(--ink-faint);margin-top:-3px;letter-spacing:.3px}
  .nav{display:flex;gap:6px;margin-left:8px}
  .nav a{color:var(--ink-soft);font-weight:600;font-size:14px;padding:9px 16px;border-radius:999px;transition:.15s}
  .nav a:hover{color:var(--ink);background:var(--glass)}
  .nav a.on{background:var(--ink);color:var(--card)}
  .tr{margin-left:auto;display:flex;align-items:center;gap:11px}
  .ib{width:42px;height:42px;border-radius:50%;background:var(--card);border:1px solid var(--line);display:grid;place-items:center;color:var(--ink-soft);box-shadow:var(--shadow-sm);position:relative;cursor:pointer;transition:.15s}
  .ib:hover{color:var(--ink);transform:translateY(-1px)}
  .ib .d{position:absolute;top:9px;right:10px;width:8px;height:8px;border-radius:50%;background:var(--red);border:2px solid var(--card)}
  .me{width:44px;height:44px;border-radius:50%;background:linear-gradient(140deg,#ffd9a8,#ff9d6b);display:grid;place-items:center;font-weight:800;color:#7a3b12;border:2px solid var(--card);box-shadow:var(--shadow-sm)}

  /* LAYOUT */
  .body{display:flex}
  .rail{width:70px;flex:none;padding:26px 0;display:flex;flex-direction:column;align-items:center;gap:14px}
  .rail .rb{width:42px;height:42px;border-radius:50%;background:var(--glass);border:1px solid var(--slab-brd);display:grid;place-items:center;color:var(--ink-soft);box-shadow:var(--shadow-sm);cursor:pointer;transition:.15s}
  .rail .rb:hover{color:var(--ink);transform:translateY(-1px)}
  .rail .rb.on{background:var(--accent);color:#fff;border-color:transparent}
  .rail .rb.warn{color:var(--red);position:relative}
  .rail .rb.warn::after{content:"";position:absolute;top:7px;right:8px;width:7px;height:7px;border-radius:50%;background:var(--red)}
  .rail .sp{flex:1}
  .rail .rb.day{background:var(--card)}.rail .rb.night{background:var(--ink);color:var(--card)}
  /* RAIL = VOTRE STAFF : avatars d'agents (l'axe « agents », ≠ le transverse du top-nav). Photo du casting
     ou dégradé+initiale ; point d'état ; agent courant surligné ; Embaucher en (+) pointillé accent. */
  .rail .rba{position:relative;width:44px;height:44px;display:grid;place-items:center;cursor:pointer;transition:.15s}
  .rail .rba:hover{transform:translateY(-1px)}
  .rail .rav{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;font-weight:800;font-size:15px;color:#fff;box-shadow:var(--shadow-sm);border:2px solid transparent}
  .rail .rav-photo{background-size:cover;background-position:center}
  .rail .rba.on .rav{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent)}
  .rail .rdot{position:absolute;right:2px;bottom:2px;width:11px;height:11px;border-radius:50%;border:2px solid var(--card)}
  .rail .rdot.st-live{background:var(--green)}
  .rail .rdot.st-valid{background:var(--accent)}
  .rail .rdot.st-prep{background:var(--ink-faint)}
  .rail .rb.emb{border-style:dashed;border-color:var(--accent);color:var(--accent)}

  .main{flex:1;padding:8px 30px 30px 6px;min-width:0}
  h1{font-size:36px;font-weight:800;letter-spacing:-1.2px;margin:6px 0 4px}
  .sub{color:var(--ink-soft);font-size:14px;margin:0 0 14px;max-width:74ch;line-height:1.5}.sub b{color:var(--ink)}
  .chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
  .chip{display:inline-flex;align-items:center;gap:7px;font-size:11.5px;font-weight:700;padding:6px 12px;border-radius:999px;background:var(--glass);border:1px solid var(--slab-brd);color:var(--ink-soft)}
  .chip.live{color:var(--green-ink);background:var(--green-soft);border-color:transparent}
  .chip.live .dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 var(--green);animation:pulse 2.4s ease-out infinite}
  .chip.ue{color:var(--accent);background:var(--accent-soft);border-color:transparent}
  @keyframes pulse{0%{box-shadow:0 0 0 0 var(--green)}70%{box-shadow:0 0 0 6px transparent}100%{box-shadow:0 0 0 0 transparent}}
  @media (prefers-reduced-motion:reduce){*{animation:none!important}}

  /* BOARD */
  .board-card{background:var(--glass);border:1px solid var(--slab-brd);border-radius:28px;box-shadow:var(--shadow);padding:22px 22px 10px;position:relative;overflow:hidden;backdrop-filter:blur(14px)}
  .board-head{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:6px}
  .board-head h2{margin:0;font-size:18px;font-weight:800;letter-spacing:-.3px}
  .board-head p{margin:3px 0 0;font-size:12px;color:var(--ink-faint);font-weight:600}

  .scroller{overflow-x:auto;padding-bottom:6px}
  .board{position:relative;width:1240px;height:560px;margin:6px auto 0}
  .svg-layer{position:absolute;inset:0;width:1240px;height:560px;pointer-events:none;z-index:1}
  .svg-layer .c-base{stroke:var(--conn);stroke-width:2;fill:none}
  .svg-layer .c-esc{stroke:var(--conn-esc);stroke-width:2;stroke-dasharray:5 5;fill:none}
  .svg-layer .c-arrow{stroke:var(--conn-arrow);stroke-width:2.2;fill:none}
  .svg-layer marker path{fill:var(--conn-arrow)}
  .grp{position:absolute;z-index:2}
  .grp-lbl{position:absolute;z-index:2;font-size:12.5px;font-weight:800;color:var(--ink-soft);text-align:center}

  .bigcard{background:var(--card);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow-sm);padding:14px}
  .bcard{background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-sm);padding:14px;position:relative}
  .bcard .top2{display:flex;align-items:center;justify-content:space-between}
  .photo{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;color:#fff;font-weight:800;font-size:15px}
  .ic{width:30px;height:30px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;color:var(--ink-faint)}
  .ic.done{color:var(--green);border-color:color-mix(in srgb,var(--green) 40%,transparent)}
  .bcard .ttl{font-weight:700;font-size:13px;margin-top:12px;line-height:1.35}
  .bcard .ttl small{display:block;font-weight:600;color:var(--ink-faint);margin-top:3px}
  .bcard .num{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;font-weight:700;color:var(--ink-faint);letter-spacing:.02em}
  .sep{height:1px;background:var(--line);margin:13px -14px}
  .bigcard .sep{margin:11px -14px}

  .node{display:flex;align-items:center;gap:10px;padding:6px 2px}
  .node .nm{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:800;font-size:12px;flex:none}
  .node .tx{font-size:12.5px;font-weight:600;color:var(--ink);line-height:1.25;flex:1}
  .node .tx b{font-weight:800}
  .node .tx small{display:block;color:var(--ink-faint);font-weight:600;font-size:11px;margin-top:1px}
  .node .rc{display:flex;gap:5px}
  .node .rc .ic{width:26px;height:26px}
  .node.ghost .nm{background:var(--card-2);color:var(--accent);border:1px dashed var(--draft)}
  .node.ghost .tx{color:var(--ink-faint)}

  .tasknode{background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-sm);padding:13px 14px;font-size:12.5px;font-weight:700;color:var(--ink-soft);line-height:1.3}
  .tasknode small{display:block;font-size:11px;color:var(--ink-faint);font-weight:600;margin-top:2px}
  .tasknode.dark{background:var(--ink);color:var(--card);box-shadow:var(--pop)}
  [data-theme="dark"] .tasknode.dark,:root:not([data-theme="light"]) .tasknode.dark{background:var(--accent);color:#fff}
  .tasknode.dark small{color:color-mix(in srgb,var(--card) 65%,transparent)}

  /* BOTTOM */
  .bottom{display:grid;grid-template-columns:1.3fr 1fr;gap:18px;margin-top:18px}
  .panel{background:var(--glass);border:1px solid var(--slab-brd);border-radius:24px;box-shadow:var(--shadow);padding:20px 22px;backdrop-filter:blur(14px)}
  .panel .ph{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
  .panel h3{margin:0;font-size:16px;font-weight:800;letter-spacing:-.2px}
  .acts{display:flex;gap:7px}
  .mini{width:34px;height:34px;border-radius:50%;border:1px solid var(--line);background:var(--card);display:grid;place-items:center;color:var(--ink-soft);cursor:pointer}
  table{width:100%;border-collapse:collapse;font-size:13px}
  th{text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;color:var(--ink-faint);font-weight:800;padding:0 8px 9px}
  td{padding:11px 8px;border-top:1px solid var(--line);color:var(--ink-soft)}td b{color:var(--ink);font-weight:700}
  .st{font-size:10px;font-weight:800;padding:3px 9px;border-radius:7px;white-space:nowrap}
  .st.x{background:var(--green-soft);color:var(--green-ink)}.st.s{background:var(--accent-soft);color:var(--accent)}.st.a{background:color-mix(in srgb,var(--amber) 20%,transparent);color:var(--amber-ink)}
  .star{color:var(--amber)}
  .arcs{display:flex;justify-content:space-around;align-items:flex-end;gap:10px;padding-top:6px}
  .arc{position:relative;text-align:center}
  .arc .num{position:absolute;top:-2px;left:50%;transform:translateX(-50%);font-size:22px;font-weight:800}
  .arc .sm{margin-top:8px;font-size:12px;color:var(--ink-soft);font-weight:700}

  .foot{padding:14px 30px 22px;text-align:center;font-size:11.5px;color:var(--ink-faint);line-height:1.6}
  .foot b{color:var(--ink-soft)}

  @media(max-width:980px){.bottom{grid-template-columns:1fr}.nav{display:none}}

  /* ── Pont cockpit ↔ v3 (port par phases) ──────────────────────────────────────────────
     L'accueil v3 charge AUSSI /cockpit.css pour styler la panoplie fonctionnelle (sections
     `.lb` : « À votre attention », briefing, « Votre staff », décisions, récemment retirés).
     On neutralise ici les SEULES règles cockpit qui débordent sur la dalle v3 :
       1) le scroll INTERNE de `.main` (modèle dalle cockpit) — la dalle v3 grandit avec la
          panoplie et c'est la FENÊTRE qui scrolle ;
       2) l'absence de fond de base : `--field` est un dégradé radial qui ne couvre que le haut
          (la maquette tenait en un écran) → on pose `--bg` sur <html> pour toute la hauteur. ── */
  html{background:var(--bg)}
  .app .main{display:block;height:auto;overflow:visible}
  /* Cloche-shellbadge : compte d'actes en attente, en pastille accent sur la cloche de la top-bar. */
  .top .ib.shellbadge{position:relative;color:var(--ink-soft);text-decoration:none}
  .top .ib.shellbadge:hover{color:var(--ink)}
  .top .ib.shellbadge .shellbadge-n{position:absolute;top:-3px;right:-3px;min-width:18px;height:18px;border-radius:99px;background:var(--accent);color:#fff;font-size:10.5px;font-weight:800;display:grid;place-items:center;padding:0 5px;border:2px solid var(--card);box-shadow:var(--shadow-sm)}

  /* ── Tête + onglets d'un renfort (sous-pages cockpit) au look v3 — scopé .v3rf (markup/hooks conservés). ── */
  .v3rf .backlink{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--ink-faint);margin:8px 0;text-decoration:none}
  .v3rf .backlink:hover{color:var(--ink-soft)}
  .v3rf .rf-hero{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin:0;background:none;border:0;padding:0;box-shadow:none}
  .v3rf .rf-hero .av{width:60px;height:60px;border-radius:18px;font-size:22px;font-weight:800;flex:none;box-shadow:0 10px 22px rgba(47,95,255,.22)}
  .v3rf .rf-hero .hx{display:flex;flex-direction:column;min-width:0}
  .v3rf .rf-hero h1, .v3rf .rf-hero .hx h1{font-size:30px;font-weight:800;letter-spacing:-.8px;margin:0;text-transform:none;color:var(--ink)}
  .v3rf .rf-hero .role{font-size:13.5px;color:var(--ink-soft);font-weight:600;margin-top:2px}
  .v3rf .rf-hero .pill{font-size:11.5px;font-weight:700;padding:6px 12px;border-radius:999px;background:var(--glass);border:1px solid var(--slab-brd);color:var(--ink-soft)}
  .v3rf .rf-hero .pill.pill-live{color:var(--green-ink);background:var(--green-soft);border-color:transparent}
  .v3rf .rf-hero .gear{margin-left:auto;width:42px;height:42px;border-radius:50%;background:var(--card);border:1px solid var(--line);display:grid;place-items:center;color:var(--ink-soft);box-shadow:var(--shadow-sm);flex:none}
  .v3rf .rf-hero .gear:hover{color:var(--ink)}
  .v3rf .tabs{display:flex;gap:6px;flex-wrap:wrap;margin:16px 0 6px;border:0;padding:0}
  .v3rf .tab{color:var(--ink-soft);font-weight:600;font-size:14px;padding:9px 16px;border-radius:999px;text-decoration:none;border:0;background:none;transition:.15s}
  .v3rf .tab:hover{color:var(--ink);background:var(--glass)}
  .v3rf .tab.on{background:var(--ink);color:var(--card)}
  [data-theme="dark"] .v3rf .tab.on{background:var(--accent);color:#fff}
  /* La panoplie fonctionnelle (cockpit) hérite de la fonte système v3 pour rester cohérente
     avec la dalle (le haut maquette) — pas de bascule Hanken au milieu de l'accueil. */
  .app .main .lb{font-family:var(--font)}
  /* Cartes de contenu cockpit → panneaux verre v3 (signature maquette). Scopé `.app .main .lb` ; l'accueil
     n'utilise PAS .card/.ev (vérifié) donc ses sections fonctionnelles ne sont pas touchées. */
  .app .main .lb .card, .app .main .lb .ev{background:var(--glass);border:1px solid var(--slab-brd);
     border-radius:22px;box-shadow:var(--shadow);backdrop-filter:blur(12px)}
  /* TYPOGRAPHIE v3 du contenu cockpit — la maquette est TOUTE en fonte système, titres en casse normale.
     On remappe la police d'affichage condensée (Oswald `--cond`) et le mono (JetBrains `--mono`) → système,
     et on dé-CAPITALISE les titres de section (les petits libellés `.mono` gardent leur petite capitale).
     C'est ce qui rend la « splendeur » maquette vs les titres Oswald MAJUSCULES de la coquille cockpit. */
  .app{--cond:var(--font);--mono:var(--font)}
  .app .main .lb .h-cond, .app .main .lb .block-h h2{text-transform:none;letter-spacing:-.4px;font-weight:800}
  .app .main .lb .num,.app .main .lb .mono-fig{font-variant-numeric:tabular-nums}
  /* Pages AUTH (connexion/activation, coquille page_auth) au look v3 : champ froid + fonte système, en
     gardant le split-screen (formulaire + panneau marque). `body.auth-v3` (0,1,1) bat `.esp` de cockpit. */
  body.auth-v3{font-family:var(--font);background:var(--field);color:var(--ink)}
  body.auth-v3 .auth-shell, body.auth-v3 .auth-shell h1, body.auth-v3 .auth-shell h2,
  body.auth-v3 .auth-shell h3, body.auth-v3 .auth-shell .h-cond, body.auth-v3 .auth-shell b,
  body.auth-v3 .auth-shell button, body.auth-v3 .auth-shell input, body.auth-v3 .auth-shell label{font-family:var(--font)}

  /* ════════════════════════════════════════════════════════════════════════════════════
     FICHE RENFORT — vue d'ensemble : PORTÉE AU DESIGN v4 (port structurel S2). Le markup
     n'émet plus `.v3fiche` mais un wrapper `.v4` (cf. _fiche_v3_overview) → toute la
     bibliothèque visuelle est désormais dans design/bureau-v4.css (scopée `.app .main .v4`).
     L'ancien bloc `.v3fiche` (≈57 règles) a été retiré : DEAD CSS depuis le port. ═══════════ */
  @keyframes bar{0%,100%{transform:scaleY(.4)}50%{transform:scaleY(1)}}

  /* ════════════════════════════════════════════════════════════════════════════════════
     ÉCHANGE v3 (maquette « échange ») — scopé `.v3ech`. Le chat GARDE ses ids bf-* (JS inchangé) ;
     on le RESTYLE en .cv-* via des règles PLUS SPÉCIFIQUES que `_BRIEF_STYLE` inline (`.v3ech .bf-*`
     [0,2,0] > `.bf-*` [0,1,0] → gagne quel que soit l'ordre source). Avatars par ::before (orb agent /
     pastille patron `--me-ini`) → 0 changement JS. cockpit.css reste chargé (cartes d'action / maturité /
     besoins gardent leur style fonctionnel). ════════════════════════════════════════════════ */
  .v3ech .head{display:flex;align-items:center;gap:15px;flex-wrap:wrap}
  .v3ech .head .orb-sm{width:56px;height:56px;border-radius:18px;flex:none;display:grid;place-items:center;background:linear-gradient(140deg,#2f5fff,#6a3bff);box-shadow:0 10px 22px rgba(47,95,255,.34)}
  .v3ech .head .wave,.v3ech .who .ob .wave{display:flex;align-items:flex-end;gap:3px;height:22px}
  .v3ech .head .wave i,.v3ech .who .ob .wave i{width:4px;border-radius:3px;background:#fff;animation:bar 1.1s ease-in-out infinite}
  .v3ech .head .wave i:nth-child(1){height:8px}.v3ech .head .wave i:nth-child(2){height:15px;animation-delay:.1s}.v3ech .head .wave i:nth-child(3){height:22px;animation-delay:.2s}.v3ech .head .wave i:nth-child(4){height:12px;animation-delay:.3s;background:#d8e2ff}.v3ech .head .wave i:nth-child(5){height:7px;animation-delay:.4s}
  .v3ech h1{font-size:28px;font-weight:800;letter-spacing:-.8px;margin:0}
  .v3ech .head .role{font-size:13.5px;color:var(--ink-soft);font-weight:600;margin-top:2px}
  .v3ech .layout{display:grid;grid-template-columns:minmax(0,1.55fr) .9fr;gap:18px;margin-top:18px;align-items:start}
  .v3ech .conv{background:var(--glass);border:1px solid var(--slab-brd);border-radius:24px;box-shadow:var(--shadow);backdrop-filter:blur(14px);display:flex;flex-direction:column;overflow:hidden;min-height:540px;margin:0}
  .v3ech .conv .bf-log{max-height:64vh;min-height:300px;padding:24px;display:flex;flex-direction:column;gap:16px;flex:1;overflow-y:auto;background:none;border:0}
  .v3ech .conv .bf-row{display:flex;gap:11px;max-width:82%;width:max-content;align-items:flex-start}
  .v3ech .conv .bf-row.bf-a::before{content:"";width:34px;height:34px;border-radius:11px;flex:none;background:linear-gradient(140deg,#2f5fff,#6a3bff);box-shadow:var(--shadow-sm)}
  .v3ech .conv .bf-row.bf-u{align-self:flex-end;flex-direction:row-reverse}
  .v3ech .conv .bf-row.bf-u::before{content:var(--me-ini,"R");width:34px;height:34px;border-radius:11px;flex:none;background:linear-gradient(140deg,#ffd9a8,#ff9d6b);color:#7a3b12;font-weight:800;font-size:13px;display:grid;place-items:center}
  .v3ech .conv .bf-b{max-width:100%;background:var(--card);border:1px solid var(--line);border-radius:16px;border-top-left-radius:5px;padding:13px 16px;font-size:14.5px;line-height:1.55;box-shadow:var(--shadow-sm);color:var(--ink);white-space:pre-wrap;overflow-wrap:anywhere}
  .v3ech .conv .bf-row.bf-u .bf-b{background:var(--accent);color:#fff;border-color:transparent;border-top-left-radius:16px;border-top-right-radius:5px}
  .v3ech .conv .bf-input{display:flex;gap:11px;align-items:center;border-top:1px solid var(--slab-brd);padding:15px 18px;background:var(--glass2)}
  .v3ech .conv .bf-ta{flex:1;min-height:48px;max-height:120px;border:1px solid var(--line);border-radius:14px;background:var(--card);padding:13px 15px;color:var(--ink);font-size:14.5px;font-family:var(--font)}
  .v3ech .conv #bf-send{height:48px;border-radius:14px;background:var(--accent);color:#fff;padding:0 20px;font-weight:700;font-size:14px;flex:none;box-shadow:0 10px 20px -10px var(--accent);border:0}
  .v3ech .conv .bf-mic{width:48px;height:48px;border-radius:14px;background:var(--card);border:1px solid var(--line);color:var(--accent);display:grid;place-items:center;flex:none}
  .v3ech .conv .bf-relais-wrap,.v3ech .conv .bf-learn,.v3ech .conv .bf-tools{align-self:flex-start;max-width:92%;margin-left:45px}
  .v3ech .conv .bf-notice{padding:13px 24px;color:var(--ink-soft);font-size:13.5px;border-bottom:1px solid var(--slab-brd)}
  .v3ech .cv-side{display:flex;flex-direction:column;gap:18px;position:sticky;top:8px}
  .v3ech .cv-side .ph .n{font-size:11px;font-weight:800;color:#fff;background:var(--accent);min-width:20px;height:20px;border-radius:99px;display:grid;place-items:center;padding:0 6px;margin-left:auto}
  .v3ech .att{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line)}.v3ech .att:last-child{border-bottom:0}
  .v3ech .att .ic2{width:36px;height:36px;border-radius:11px;flex:none;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent)}
  .v3ech .att .ic2.a{background:color-mix(in srgb,var(--amber) 18%,transparent);color:var(--amber-ink)}
  .v3ech .att .tb{flex:1;min-width:0}.v3ech .att .tb b{font-size:13.5px;font-weight:700;display:block}.v3ech .att .tb span{font-size:12px;color:var(--ink-soft)}
  .v3ech .att .go{color:var(--ink-faint);margin-left:auto;display:flex}
  .v3ech .who{display:flex;align-items:center;gap:13px}
  .v3ech .who .ob{width:46px;height:46px;border-radius:14px;flex:none;display:grid;place-items:center;background:linear-gradient(140deg,#2f5fff,#6a3bff)}
  .v3ech .who .ob .wave{height:18px}
  .v3ech .who .wt b{font-size:15px;font-weight:800;display:block}.v3ech .who .wt span{font-size:12.5px;color:var(--ink-soft)}
  .v3ech .nfj{margin-top:14px;padding-top:13px;border-top:1px solid var(--line);font-size:12.5px;color:var(--ink-soft);line-height:1.5}.v3ech .nfj b{color:var(--ink)}
  /* Extras fonctionnels de la colonne contexte (outils/maturité/besoins) → panneaux verre comme les autres. */
  .v3ech .cv-side .tools,.v3ech .cv-side .mt-bar,.v3ech .cv-side .bs-box{background:var(--glass);border:1px solid var(--slab-brd);border-radius:24px;box-shadow:var(--shadow);backdrop-filter:blur(14px);padding:18px 20px;margin:0}
  @media(max-width:980px){.v3ech .layout{grid-template-columns:1fr}.v3ech .cv-side{position:static}}
