    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    :root {
      --bg: #F7F6F3;
      --bg2: #F0EFEB;
      --surface: #FFFFFF;
      --surface-2: #F0EFEB;
      --t1: #0D0D0D;
      --t2: #3D3D3D;
      --t3: #6B6B6B;
      --accent: #6050DC;
      --accent-fg: #FFFFFF;
      --amber: #D97706;
      --border: rgba(0,0,0,0.07);
      --border-md: rgba(0,0,0,0.11);
      --r-sm: 8px;
      --r-md: 14px;
      --r-lg: 24px;
      --r-full: 9999px;
      --shadow-1: 0 1px 3px rgba(0,0,0,0.05), 0 1px 2px rgba(0,0,0,0.04);
      --shadow-2: 0 4px 16px rgba(0,0,0,0.07), 0 1px 4px rgba(0,0,0,0.05);
      --shadow-3: 0 16px 48px rgba(0,0,0,0.10), 0 4px 12px rgba(0,0,0,0.06);
      --nav-gradient: linear-gradient(to bottom, #000, #0d0b26 24%, #1e1a5e 61%, #2a24a0 88%, #3530d4);
      --green: #16a34a;
      --red: #EF4444;
      --orange: #D97706;
      /* Legacy aliases pour compatibilité */
      --blue: #6050DC;
      --blue-acc: #8B7FE8;
      --blue-bg: rgba(96,80,220,0.08);
      --green-em: #10B981;
      --green-acc: #34D399;
      --green-bg: rgba(16,185,129,0.08);
      --card: #FFFFFF;
      --radius: 14px;
      --yellow: #d97706;
      --purple: #7c3aed;
      --teal: #0d9488;
      --gradient: linear-gradient(to bottom, #000, #0d0b26 24%, #1e1a5e 61%, #2a24a0 88%, #3530d4);
      --btn-gradient: linear-gradient(to right, #000 0%, #0d0b26 25%, #1e1a5e 55%, #3530d4 100%);
      --shadow-card: 0 4px 16px rgba(0,0,0,0.07), 0 1px 4px rgba(0,0,0,0.05);
      --shadow-auth: 0 16px 48px rgba(0,0,0,0.10), 0 4px 12px rgba(0,0,0,0.06);
    }
    body { background:#F7F6F3; font-family:'Plus Jakarta Sans',-apple-system,sans-serif; background:var(--bg); color:var(--t1); min-height:100vh; }

    /* ANIMATIONS */
    @keyframes fadeInUp { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:translateY(0)} }
    @keyframes pulse-live { 0%,100%{opacity:1} 50%{opacity:0.3} }
    @keyframes spin { to{transform:rotate(360deg)} }

    /* SCREENS */
    .screen { display:none; }
    .screen.active { display:block; }

    /* AUTH */
    .auth-wrap {
      min-height:100vh; display:flex; align-items:center; justify-content:center;
      background:#F7F6F3;
    }
    .auth-card {
      background:#FFFFFF; border:1px solid rgba(0,0,0,0.07); border-radius:24px;
      padding:3rem 2.5rem; width:100%; max-width:420px;
      box-shadow:0 16px 48px rgba(0,0,0,0.10), 0 4px 12px rgba(0,0,0,0.06);
    }
    .auth-logo-wrap { display:flex; justify-content:center; margin-bottom:1.5rem; }
    .auth-picto { width:130px; height:130px; }
    .auth-subtitle { text-align:center; font-size:0.85rem; color:var(--t3); margin-bottom:2.5rem; letter-spacing:0.08em; text-transform:uppercase; }
    .auth-field { margin-bottom:1rem; }
    .auth-field label { display:block; font-size:0.78rem; color:var(--t3); margin-bottom:0.4rem; letter-spacing:0.04em; }
    .auth-field input {
      width:100%; background:#FFFFFF; border:1px solid var(--border);
      border-radius:10px; padding:0.85rem 1rem; color:var(--t1);
      font-family:inherit; font-size:0.95rem; outline:none; transition:border-color 0.2s;
    }
    .auth-field input:focus { border-color:rgba(96,80,220,0.5); box-shadow: 0 0 0 3px rgba(96,80,220,0.08); }
    .auth-field input::placeholder { color:var(--t3); }
    .auth-btn {
      width:100%; margin-top:0.5rem; padding:0.9rem; background:var(--btn-gradient); border:none;
      border-radius:10px; color:#fff; font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:0.95rem;
      font-weight:700; cursor:pointer; transition:opacity 0.2s, transform 0.1s, box-shadow 0.2s;
    }
    .auth-btn:hover { opacity:0.9; box-shadow:0 0 30px rgba(139,127,232,0.4); }
    .auth-btn:active { transform:scale(0.98); }
    .auth-btn.secondary { background:transparent; border:1px solid var(--border); color:var(--t2); margin-top:0.75rem; }
    .auth-msg { margin-top:1rem; text-align:center; font-size:0.85rem; min-height:1.2em; }
    .auth-msg.error { color:var(--red); }
    .auth-msg.success { color:var(--green); }
    .auth-link { display:block; text-align:center; margin-top:1.25rem; font-size:0.82rem; color:var(--t3); cursor:pointer; text-decoration:underline; text-underline-offset:3px; transition:color 0.2s; }
    .auth-link:hover { color:var(--blue); }
    .reset-link-box { background:rgba(96,80,220,0.08); border:1px solid rgba(96,80,220,0.2); border-radius:10px; padding:1rem; margin-top:1rem; word-break:break-all; font-size:0.75rem; color:var(--t2); line-height:1.6; display:none; }
    .reset-link-box strong { display:block; color:var(--blue); margin-bottom:0.4rem; font-size:0.8rem; }

    /* SIDEBAR */
    .sidebar {
      position:fixed; top:0; left:0; bottom:0; width:250px;
      background:linear-gradient(to bottom, #000, #0d0b26 24%, #1e1a5e 61%, #2a24a0 88%, #3530d4); z-index:100;
      display:flex; flex-direction:column;
      transition:width 0.25s cubic-bezier(0.4,0,0.2,1);
      overflow:hidden;
    }
    .sidebar.collapsed { width:72px; }
    .sidebar.collapsed .sidebar-nav { padding:0.25rem 0.5rem; }
    .sidebar.collapsed .sidebar-item { justify-content:center; padding:0; }
    .sidebar.collapsed .sidebar-divider { margin:0.25rem 0.5rem; }
    .sidebar-top { display:flex; flex-direction:column; align-items:center; padding:1.25rem 1rem 1rem; gap:0.5rem; flex-shrink:0; }
    .sidebar-top .sidebar-toggle-btn { order:-1; align-self:flex-end; }
    .sidebar-logo { height:62px; width:auto; flex-shrink:0; opacity:1; transition:opacity 0.15s; white-space:nowrap; overflow:hidden; max-width:200px; }
    .sidebar.collapsed .sidebar-logo { opacity:0; max-width:0; pointer-events:none; }
    .sidebar-toggle-btn { width:28px; height:28px; border-radius:8px; background:rgba(255,255,255,0.15); border:none; cursor:pointer; color:#fff; display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:background 0.2s, transform 0.25s; }
    .sidebar.collapsed .sidebar-toggle-btn { transform:rotate(180deg); }
    .sidebar-toggle-btn:hover { background:rgba(255,255,255,0.25); }
    .sidebar-toggle-btn svg { width:16px; height:16px; }
    .sidebar-nav { flex:1; padding:0.25rem 1.5rem; display:flex; flex-direction:column; gap:2px; overflow-y:auto; overflow-x:hidden; }
    .sidebar-item {
      display:flex; align-items:center; gap:12px; padding:0 18px; height:36px; border-radius:10px;
      background:none; border:none; cursor:pointer; width:100%;
      color:rgba(255,255,255,0.72); font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:0.875rem; font-weight:500;
      transition:background 0.15s, color 0.15s; white-space:nowrap; flex-shrink:0; text-align:left;
    }
    .sidebar-item:hover { background:rgba(255,255,255,0.1); color:#fff; }
    .sidebar-item.active { background:rgba(255,255,255,0.18); color:#fff; font-weight:700; }
    .sidebar-item svg { width:18px; height:18px; flex-shrink:0; }
    .sidebar-label { overflow:hidden; transition:opacity 0.15s, max-width 0.25s; max-width:200px; }
    .sidebar.collapsed .sidebar-label { opacity:0; max-width:0; }
    .sidebar-divider { height:1px; background:rgba(255,255,255,0.15); margin:0.25rem 1.5rem; flex-shrink:0; }
    .sidebar-footer { padding:0.5rem 1.5rem 0.75rem; flex-shrink:0; background:#000; border-top:1px solid rgba(255,255,255,0.08); }
    .sidebar-refresh-wrap { padding:0 1.5rem 0.25rem; }
    .sidebar-refresh-btn { display:flex; align-items:center; justify-content:center; gap:8px; width:100%; height:42px; border-radius:12px; border:none; cursor:pointer; background:rgba(255,255,255,0.13); color:#fff; font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:0.85rem; font-weight:600; letter-spacing:0.01em; transition:background 0.2s; white-space:nowrap; overflow:hidden; }
    .sidebar-refresh-btn:hover { background:rgba(255,255,255,0.22); }
    .sidebar-refresh-btn svg { width:18px; height:18px; flex-shrink:0; transition:transform 0.6s cubic-bezier(0.4,0,0.2,1); }
    #sidebar-refresh-btn.spinning svg { transform:rotate(360deg); }
    .sidebar-refresh-label { transition:opacity 0.15s, max-width 0.25s; max-width:120px; overflow:hidden; }
    .sidebar.collapsed .sidebar-refresh-label { opacity:0; max-width:0; }
    .sidebar-refresh-status { display:block; text-align:center; font-size:0.56rem; font-weight:700; text-transform:uppercase; letter-spacing:0.08em; padding:3px 0 0; white-space:nowrap; transition:all 0.3s; }
    .srs-ok    { color:rgba(74,222,128,0.85); }
    .srs-stale { color:rgba(255,255,255,0.35); }
    .sidebar.collapsed .sidebar-refresh-status { display:none; }
    .sidebar-overlay { display:none; }

    /* TOPBAR */
    .board-topbar {
      position:sticky; top:0; z-index:50;
      background:rgba(255,255,255,0.97); backdrop-filter:blur(20px);
      border-bottom:1px solid var(--border);
      padding:0 1.5rem; height:56px;
      display:flex; align-items:center; justify-content:space-between;
    }
    .board-topbar-left  { display:flex; align-items:center; gap:0.75rem; }
    .board-topbar-right { display:flex; align-items:center; gap:0.75rem; }
    .nav-site-btn { display:flex; align-items:center; gap:6px; padding:5px 12px; border-radius:20px; background:rgba(96,80,220,0.06); border:1px solid rgba(96,80,220,0.12); color:var(--blue); text-decoration:none; transition:background 0.2s; font-size:0.75rem; font-weight:600; font-family:inherit; }
    .nav-site-btn:hover { background:rgba(96,80,220,0.12); }
    .nav-wa-btn { display:flex; align-items:center; gap:6px; padding:5px 12px; border-radius:20px; background:#25D366; color:#fff; text-decoration:none; transition:opacity 0.2s; font-size:0.75rem; font-weight:700; font-family:inherit; white-space:nowrap; }
    .nav-wa-btn:hover { opacity:0.88; }
    .header-greeting { font-size:0.82rem; color:var(--t2); font-weight:500; }
    .live-badge { display:flex; align-items:center; gap:6px; font-size:0.75rem; color:var(--green); background:rgba(74,222,128,0.1); border:1px solid rgba(74,222,128,0.2); border-radius:20px; padding:0.3rem 0.75rem; }
    .live-dot { width:6px; height:6px; border-radius:50%; background:var(--green); animation:pulse-live 2s infinite; }
    .last-updated { font-size:0.75rem; color:var(--t3); }
    /* PRESENCE INDICATOR */
    .presence-badge { display:flex; align-items:center; gap:6px; font-size:0.73rem; font-weight:600; color:var(--blue); background:rgba(96,80,220,0.07); border:1px solid rgba(96,80,220,0.15); border-radius:20px; padding:0.25rem 0.7rem 0.25rem 0.5rem; opacity:0; transform:translateY(-4px) scale(0.95); transition:opacity 0.4s ease, transform 0.4s ease; pointer-events:none; }
    .presence-badge.visible { opacity:1; transform:translateY(0) scale(1); pointer-events:auto; }
    .presence-avatar { width:20px; height:20px; border-radius:50%; background:var(--accent); color:#fff; font-size:0.6rem; font-weight:700; display:flex; align-items:center; justify-content:center; line-height:1; }
    .presence-dot { width:7px; height:7px; border-radius:50%; background:var(--green); box-shadow:0 0 6px rgba(74,222,128,0.5); animation:pulse-presence 1.8s ease-in-out infinite; }
    @keyframes pulse-presence { 0%,100%{box-shadow:0 0 4px rgba(74,222,128,0.4)} 50%{box-shadow:0 0 12px rgba(74,222,128,0.8)} }
    .icon-btn { background:rgba(96,80,220,0.06); border:1px solid var(--border); border-radius:8px; padding:0.4rem 0.75rem; color:var(--t2); font-family:inherit; font-size:0.8rem; cursor:pointer; transition:background 0.2s; }
    .icon-btn:hover { background:rgba(96,80,220,0.1); }
    .sidebar-mobile-btn { display:none; align-items:center; justify-content:center; width:36px; height:36px; border-radius:10px; border:1px solid var(--border); background:rgba(96,80,220,0.06); color:var(--t2); cursor:pointer; }

    /* BOARD LAYOUT */
    .board-wrap { margin-left:250px; min-height:100vh; transition:margin-left 0.25s cubic-bezier(0.4,0,0.2,1); }
    .board-wrap.sidebar-collapsed { margin-left:72px; }
    main { max-width:1200px; margin:0 auto; padding:2rem 2rem 4rem; }

    /* PAGES */
    .page { display:none; animation:fadeInUp 0.25s ease both; }
    .page.active { display:block; }

    /* ── PAGE INVESTISSEMENTS ── */
    .summary-row { display:grid; grid-template-columns:1fr 1fr 1fr; gap:1rem; margin-bottom:2rem; }
    .summary-card { background:var(--card); border:1px solid var(--border); border-radius:var(--radius); padding:1.5rem 1.75rem; position:relative; overflow:hidden; box-shadow:var(--shadow-card); }
    .summary-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; border-radius:var(--radius) var(--radius) 0 0; }
    .summary-card.jb::before      { background:var(--blue); }
    .summary-card.maurice::before  { background:var(--green-em); }
    .summary-card.grand::before    { background:linear-gradient(90deg,var(--blue),var(--green-em)); }
    .summary-card.jb      { box-shadow:0 6px 24px -8px rgba(96,80,220,0.25); }
    .summary-card.maurice { box-shadow:0 6px 24px -8px rgba(16,185,129,0.25); }
    .summary-label { font-size:0.75rem; color:var(--t3); text-transform:uppercase; letter-spacing:0.08em; margin-bottom:0.6rem; }
    .summary-amount { font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:2.2rem; font-weight:700; letter-spacing:-0.03em; }
    .summary-card.jb .summary-amount      { color:var(--blue); }
    .summary-card.maurice .summary-amount { color:var(--green-em); }
    .summary-card.grand .summary-amount   { color:var(--t1); }
    .summary-sub { font-size:0.78rem; color:var(--t3); margin-top:0.3rem; }
    .comparison-section { background:var(--card); border:1px solid var(--border); border-radius:var(--radius); padding:1.5rem 1.75rem; margin-bottom:2rem; box-shadow:var(--shadow-card); }
    .comparison-title { font-size:0.75rem; color:var(--t3); text-transform:uppercase; letter-spacing:0.08em; margin-bottom:1rem; }
    .comparison-bar { height:16px; border-radius:16px; background:rgba(96,80,220,0.07); overflow:hidden; display:flex; margin-bottom:0.75rem; }
    .bar-jb      { height:100%; background:var(--blue);    transition:width 0.8s cubic-bezier(0.4,0,0.2,1); border-radius:16px 0 0 16px; }
    .bar-maurice { height:100%; background:var(--green-em); transition:width 0.8s cubic-bezier(0.4,0,0.2,1); border-radius:0 16px 16px 0; }
    .comparison-labels { display:flex; justify-content:space-between; }
    .cmp-label { display:flex; align-items:center; gap:8px; font-size:0.85rem; color:var(--t2); }
    .cmp-dot { width:8px; height:8px; border-radius:50%; }
    .cmp-label strong { font-size:1rem; color:var(--t1); }
    .cmp-sub { font-size:0.75rem; color:var(--t3); margin-top:2px; }
    .columns { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; }
    .column { background:var(--card); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-card); }
    .column-header { display:flex; align-items:center; gap:1rem; padding:1.5rem 1.75rem; border-bottom:1px solid var(--border); }
    .avatar { width:44px; height:44px; border-radius:12px; display:flex; align-items:center; justify-content:center; font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-weight:700; font-size:0.85rem; flex-shrink:0; }
    .jb-column .avatar      { background:var(--blue-bg);  color:var(--blue);    border:1px solid rgba(96,80,220,0.3); }
    .maurice-column .avatar { background:var(--green-bg); color:var(--green-em); border:1px solid rgba(16,185,129,0.3); }
    .col-name { font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-weight:600; font-size:1rem; }
    .col-role { font-size:0.78rem; color:var(--t3); margin-top:2px; }
    .entries { padding:1rem 1.75rem; }
    .entry-card { display:flex; align-items:flex-start; gap:1rem; padding:1.1rem 0; border-bottom:1px solid var(--border); animation:fadeInUp 0.3s ease both; }
    .entry-card:last-child { border-bottom:none; }
    .entry-icon { width:40px; height:40px; border-radius:12px; display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:0.75rem; font-weight:700; font-family:'Plus Jakarta Sans',-apple-system,sans-serif; }
    .entry-icon.heures      { background:rgba(96,80,220,0.15); color:var(--blue); }
    .entry-icon.tokens      { background:rgba(251,191,36,0.12); color:#FBB924; }
    .entry-icon.domaine     { background:rgba(74,222,128,0.12); color:var(--green); }
    .entry-icon.hebergement { background:rgba(251,146,60,0.12); color:#FB923C; }
    .entry-icon.autre       { background:rgba(96,80,220,0.06); color:var(--t2); }
    .entry-body { flex:1; min-width:0; }
    .entry-label { font-size:0.88rem; font-weight:500; color:var(--t1); }
    .entry-date  { font-size:0.72rem; color:var(--t3); margin-top:2px; }
    .entry-notes { font-size:0.75rem; color:var(--t3); margin-top:3px; line-height:1.4; }
    .entry-badge { display:inline-block; font-size:0.65rem; background:rgba(96,80,220,0.15); color:var(--blue); border-radius:4px; padding:1px 6px; margin-top:4px; font-weight:500; letter-spacing:0.04em; }
    .entry-amount { font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:1rem; font-weight:700; color:var(--t1); white-space:nowrap; text-align:right; }
    .entry-amount-wrap { display:flex; flex-direction:column; align-items:flex-end; gap:4px; }
    .invoice-link { display:inline-flex; align-items:center; gap:4px; font-size:0.7rem; font-weight:500; color:var(--green); background:rgba(16,185,129,0.1); border:1px solid rgba(16,185,129,0.2); border-radius:6px; padding:2px 7px; text-decoration:none; white-space:nowrap; transition:background 0.2s; }
    .invoice-link:hover { background:rgba(16,185,129,0.2); }
    .column-footer { display:flex; justify-content:space-between; align-items:center; padding:1.25rem 1.75rem; background:rgba(96,80,220,0.03); border-top:2px solid var(--border); }
    .footer-label { font-size:0.82rem; color:var(--t3); text-transform:uppercase; letter-spacing:0.06em; }
    .footer-total { font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:1.6rem; font-weight:700; }
    .jb-column      .footer-total { color:var(--blue); }
    .maurice-column .footer-total { color:var(--green-em); }

    /* ── SECTION TITLE ── */
    .section-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:1.5rem; flex-wrap:wrap; gap:0.75rem; }
    .section-title { font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:1.3rem; font-weight:700; letter-spacing:-0.02em; }
    .section-sub { font-size:0.82rem; color:var(--t3); margin-top:4px; }

    /* ── SANDBOX responsive ── */
    .sb-layout       { display:grid; grid-template-columns:320px 1fr; gap:1.25rem; align-items:start; }
    .sb-params-grid  { display:grid; grid-template-columns:1fr 1fr; gap:0.875rem; margin-bottom:1.25rem; }
    .sb-btn-row      { display:flex; gap:0.75rem; }

    /* ── PAGE BOITE A IDEES ── */
    .themes-section { margin-top:0.5rem; }
    .themes-title { font-size:0.7rem; font-weight:700; text-transform:uppercase; letter-spacing:0.08em; color:var(--t3); margin-bottom:1rem; }
    .themes-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:0.75rem; }
    .theme-card {
      background:rgba(96,80,220,0.03); border:1px solid var(--border); border-radius:12px;
      padding:0.9rem 1rem; display:flex; align-items:flex-start; gap:0.75rem;
      cursor:pointer; transition:border-color 0.15s, background 0.15s;
    }
    .theme-card:hover { border-color:rgba(96,80,220,0.4); background:rgba(96,80,220,0.06); }
    .theme-icon { width:22px; height:22px; line-height:1; flex-shrink:0; margin-top:1px; color:var(--blue); display:flex; align-items:center; justify-content:center; }
    .theme-icon svg { width:22px; height:22px; }
    .theme-label { font-size:0.82rem; font-weight:600; color:var(--t1); margin-bottom:0.2rem; }
    .theme-desc { font-size:0.75rem; color:var(--t3); line-height:1.5; }
    .idea-form-card {
      background:var(--card); border:1px solid var(--border); border-radius:var(--radius);
      padding:1.75rem; margin-bottom:2rem; box-shadow:var(--shadow-card);
    }
    .idea-form-title { font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:1rem; font-weight:600; margin-bottom:1rem; }
    .idea-textarea {
      width:100%; background:#FFFFFF; border:1px solid var(--border);
      border-radius:10px; padding:1rem; color:var(--t1); font-family:'Plus Jakarta Sans',-apple-system,sans-serif;
      font-size:0.9rem; outline:none; resize:vertical; min-height:220px;
      transition:border-color 0.2s; line-height:1.6;
    }
    .idea-textarea:focus { border-color:rgba(96,80,220,0.4); }
    .idea-textarea::placeholder { color:var(--t3); }
    .idea-form-footer { display:flex; align-items:center; justify-content:space-between; margin-top:1rem; gap:1rem; }
    .idea-form-hint { font-size:0.78rem; color:var(--t3); }
    .btn-primary {
      background:var(--btn-gradient); border:none; border-radius:10px; color:#fff;
      font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:0.88rem; font-weight:700;
      padding:0.7rem 1.5rem; cursor:pointer; transition:opacity 0.2s, transform 0.1s, box-shadow 0.2s;
    }
    .btn-primary:hover { opacity:0.9; box-shadow:0 0 20px rgba(139,127,232,0.35); }
    .btn-primary:active { transform:scale(0.98); }
    .btn-primary:disabled { opacity:0.5; cursor:default; }
    .btn-secondary {
      background:rgba(96,80,220,0.06); border:1px solid var(--border); border-radius:10px;
      color:var(--t2); font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:0.85rem;
      padding:0.65rem 1.25rem; cursor:pointer; transition:background 0.2s;
    }
    .btn-secondary:hover { background:rgba(96,80,220,0.1); }
    .idea-msg { font-size:0.82rem; margin-top:0.75rem; min-height:1em; }
    .idea-msg.error { color:var(--red); }
    .idea-msg.success { color:var(--green); }

    /* Upload zone */
    .upload-zone { border:2px dashed var(--border); border-radius:10px; padding:14px 16px; text-align:center; cursor:pointer; transition:border-color 0.2s,background 0.2s; margin-top:10px; }
    .upload-zone:hover,.upload-zone.dragover { border-color:var(--accent); background:rgba(96,80,220,0.03); }
    .upload-zone-label { font-size:0.75rem; color:var(--t3); line-height:1.6; }
    .upload-zone-label strong { color:var(--accent); font-weight:600; }
    .file-chips { display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; min-height:4px; }
    .file-chip { display:inline-flex; align-items:center; gap:4px; padding:3px 8px 3px 10px; background:var(--surface-2); border:1px solid var(--border); border-radius:6px; font-size:0.72rem; color:var(--t2); }
    .file-chip-remove { cursor:pointer; color:var(--t3); font-size:1rem; line-height:1; padding:0 1px; margin-left:2px; }
    .file-chip-remove:hover { color:var(--red); }
    /* URL zone */
    .url-zone-label { font-size:0.72rem; font-weight:600; color:var(--t2); margin-top:12px; margin-bottom:4px; letter-spacing:0.02em; }
    .url-textarea { width:100%; background:#fff; border:1px solid var(--border); border-radius:10px; padding:0.7rem 0.9rem; font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:0.8rem; color:var(--t1); outline:none; resize:vertical; min-height:64px; transition:border-color 0.2s; line-height:1.6; }
    .url-textarea:focus { border-color:rgba(96,80,220,0.4); }
    .url-textarea::placeholder { color:var(--t3); }
    /* Badges sur les idea-cards pour fichiers/urls */
    .idea-attach-badge { display:inline-flex; align-items:center; gap:3px; padding:2px 7px; background:var(--surface-2); border:1px solid var(--border); border-radius:9999px; font-size:0.65rem; color:var(--t3); }
    /* MD download button */
    .btn-dl-md { padding:0.28rem 0.7rem; font-size:0.7rem; font-weight:600; background:rgba(96,80,220,0.09); color:var(--accent); border:1px solid rgba(96,80,220,0.2); border-radius:7px; cursor:pointer; white-space:nowrap; transition:background 0.15s; }
    .btn-dl-md:hover { background:rgba(96,80,220,0.16); }

    /* ── Veille du jour ── */
    .veille-cat-chip { display:inline-flex;align-items:center;padding:4px 12px;border-radius:9999px;font-size:0.72rem;font-weight:600;cursor:pointer;transition:all 0.15s;border:1.5px solid var(--border);color:var(--t3);background:transparent;user-select:none; }
    .veille-cat-chip:hover { border-color:var(--accent);color:var(--accent); }
    .veille-cat-chip.selected { background:var(--accent);border-color:var(--accent);color:#fff; }
    .veille-card { background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px 16px;margin-bottom:8px;border-left:3px solid var(--border);transition:box-shadow 0.15s; }
    .veille-card:hover { box-shadow:var(--shadow-card); }
    .veille-card.imp-critique { border-left-color:#ef4444; }
    .veille-card.imp-haute    { border-left-color:#f97316; }
    .veille-card.imp-normale  { border-left-color:#60a5fa; }
    .veille-card.imp-faible   { border-left-color:#9ca3af; }
    .veille-card.suspended    { opacity:0.45;border-left-color:#9ca3af !important;filter:grayscale(0.4); }
    .veille-card-header { display:flex;align-items:flex-start;gap:10px;margin-bottom:8px; }
    .veille-card-title { font-size:0.88rem;font-weight:700;color:var(--t1);flex:1;line-height:1.35; }
    .veille-card-meta  { font-size:0.68rem;color:var(--t3);margin-top:2px; }
    .veille-card-actions { display:flex;gap:5px;margin-top:10px;padding-top:8px;border-top:1px solid var(--border); }
    /* Collapsible frames */
    .vf-frame { border:1px solid var(--border);border-radius:14px;margin-bottom:16px;overflow:hidden; }
    .vf-frame-header { display:flex;align-items:center;gap:10px;padding:13px 18px;cursor:pointer;background:var(--card);user-select:none;transition:background 0.15s; }
    .vf-frame-header:hover { background:var(--bg); }
    .vf-frame-title { font-size:0.82rem;font-weight:700;color:var(--t1);flex:1; }
    .vf-frame-count { font-size:0.7rem;font-weight:600;color:var(--t3);background:var(--bg);padding:2px 8px;border-radius:9999px;border:1px solid var(--border); }
    .vf-frame-arrow { font-size:0.7rem;color:var(--t3);transition:transform 0.2s; }
    .vf-frame.open .vf-frame-arrow { transform:rotate(180deg); }
    .vf-frame-body { display:none;padding:16px 18px;border-top:1px solid var(--border);background:var(--bg); }
    .vf-frame.open .vf-frame-body { display:block; }
    /* ── Strategy / To Do cards ── */
    .strategy-card { background:var(--card);border:1px solid var(--border);border-radius:14px;padding:1.1rem 1.3rem;margin-bottom:10px;transition:box-shadow 0.15s; }
    .strategy-card:hover { box-shadow:0 2px 12px rgba(0,0,0,0.07); }
    .strategy-card.is-done { opacity:0.55; }
    .urgence-badge { display:inline-flex;align-items:center;font-size:0.63rem;font-weight:800;text-transform:uppercase;letter-spacing:0.08em;padding:2px 8px;border-radius:5px; }
    .urgence-critique { background:rgba(239,68,68,0.12);color:#EF4444; }
    .urgence-haute    { background:rgba(245,158,11,0.12);color:#F59E0B; }
    .urgence-normale  { background:rgba(16,185,129,0.1);color:#10B981; }
    .urgence-faible   { background:rgba(148,163,184,0.15);color:#94A3B8; }
    .effort-faible  { color:#10B981;font-weight:700; }
    .effort-moyen   { color:#F59E0B;font-weight:700; }
    .effort-eleve   { color:#EF4444;font-weight:700; }
    .strat-label { font-size:0.62rem;font-weight:800;text-transform:uppercase;letter-spacing:0.08em;color:var(--t3);margin-bottom:4px; }
    .strat-text  { font-size:0.82rem;color:var(--t2);line-height:1.6; }
    .strat-meta-row { display:flex;flex-wrap:wrap;gap:1rem;margin-top:10px;padding-top:10px;border-top:1px solid var(--border); }
    .strat-meta-item { font-size:0.73rem;color:var(--t3); }
    .strat-meta-item strong { color:var(--t2); }
    .strat-actions-list { margin-top:8px;display:flex;flex-direction:column;gap:4px; }
    .strat-action-item { font-size:0.77rem;color:var(--t2);display:flex;gap:7px;align-items:flex-start; }
    .strat-action-item::before { content:'→';color:var(--accent);flex-shrink:0;font-weight:700;margin-top:1px; }
    .strat-agent-chip { font-size:0.63rem;font-weight:700;background:linear-gradient(135deg,rgba(96,80,220,0.1),rgba(139,127,232,0.08));color:var(--accent);border-radius:5px;padding:2px 7px;border:1px solid rgba(96,80,220,0.15); }
    .todo-filter-bar { display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:1.25rem; }
    .todo-filter-tabs { display:flex;background:var(--bg);border:1px solid var(--border);border-radius:9px;padding:2px;gap:2px; }
    .todo-filter-tab { font-size:0.75rem;font-weight:600;padding:5px 14px;border-radius:7px;border:none;cursor:pointer;background:none;color:var(--t3);font-family:'Plus Jakarta Sans',-apple-system,sans-serif;transition:all 0.15s; }
    .todo-filter-tab.active { background:var(--card);color:var(--t1);box-shadow:0 1px 3px rgba(0,0,0,0.08); }
    .todo-filter-sel { font-size:0.75rem;padding:6px 10px;border:1px solid var(--border);border-radius:8px;background:var(--card);color:var(--t2);font-family:'Plus Jakarta Sans',-apple-system,sans-serif;cursor:pointer;outline:none; }
    .btn-strategy { display:inline-flex;align-items:center;gap:5px;font-size:0.72rem;font-weight:700;padding:5px 11px;border-radius:8px;border:none;cursor:pointer;background:var(--btn-gradient);color:#fff;font-family:'Plus Jakarta Sans',-apple-system,sans-serif;transition:opacity 0.15s;white-space:nowrap; }
    .btn-strategy:hover { opacity:0.88; }
    .btn-strategy:disabled { opacity:0.5;cursor:not-allowed; }
    .btn-magic-todo { display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:0.85rem;font-weight:700;padding:13px 20px;border-radius:12px;border:none;cursor:pointer;background:var(--btn-gradient);color:#fff;font-family:'Plus Jakarta Sans',-apple-system,sans-serif;transition:all 0.2s;white-space:nowrap;box-shadow:0 4px 16px rgba(96,80,220,0.3); }
    .btn-magic-todo:hover { opacity:0.9;box-shadow:0 6px 24px rgba(96,80,220,0.45);transform:translateY(-1px); }
    /* ── Magic modal ── */
    .magic-modal-overlay { position:fixed;inset:0;background:rgba(20,10,50,0.5);backdrop-filter:blur(8px);z-index:1000;display:none;align-items:center;justify-content:center;padding:1rem; }
    .magic-modal-overlay.open { display:flex; }
    .magic-modal { background:var(--card);border:1px solid var(--border);border-radius:18px;padding:0;width:100%;max-width:620px;box-shadow:0 20px 64px rgba(0,0,0,0.18);max-height:90vh;display:flex;flex-direction:column;overflow:hidden; }
    .magic-modal-header { padding:1.5rem 1.75rem 0;flex-shrink:0; }
    .magic-modal-body { padding:0 1.75rem;overflow-y:auto;flex:1; }
    .magic-modal-footer { padding:1.25rem 1.75rem;border-top:1px solid var(--border);flex-shrink:0;background:var(--bg); }
    .magic-disclaimer { background:rgba(239,68,68,0.06);border:1px solid rgba(239,68,68,0.18);border-radius:10px;padding:12px 14px;margin:14px 0;display:flex;gap:10px;align-items:flex-start; }
    .magic-disclaimer svg { flex-shrink:0;margin-top:1px; }
    .magic-disclaimer p { font-size:0.78rem;color:#B91C1C;line-height:1.55;font-weight:500; }
    .magic-section { margin-bottom:16px; }
    .magic-section-title { font-size:0.65rem;font-weight:800;text-transform:uppercase;letter-spacing:0.08em;color:var(--t3);margin-bottom:8px; }
    .magic-agent-row { display:flex;gap:8px;align-items:flex-start;padding:8px 10px;background:var(--bg);border-radius:8px;margin-bottom:6px; }
    .magic-agent-name { font-size:0.72rem;font-weight:800;color:var(--accent);min-width:80px;flex-shrink:0; }
    .magic-agent-task { font-size:0.78rem;color:var(--t2);line-height:1.5; }
    .magic-impact { font-size:0.78rem;color:var(--t2);line-height:1.6;padding:8px 10px;background:rgba(217,119,6,0.06);border:1px solid rgba(217,119,6,0.15);border-radius:8px; }
    .magic-action-check { display:flex;align-items:flex-start;gap:8px;padding:8px 0;border-bottom:1px solid var(--border); }
    .magic-action-check:last-child { border-bottom:none; }
    .magic-action-check input[type="checkbox"] { width:16px;height:16px;margin-top:2px;accent-color:var(--accent);cursor:pointer;flex-shrink:0; }
    .magic-action-check label { font-size:0.8rem;color:var(--t1);line-height:1.5;cursor:pointer; }
    /* Slide toggle (red/green) */
    .slide-toggle-wrap { display:flex;align-items:center;gap:10px; }
    .slide-toggle-label { font-size:0.72rem;font-weight:700;color:var(--t3);transition:color 0.2s; }
    .slide-toggle-label.unlocked { color:var(--green); }
    .slide-toggle { position:relative;width:48px;height:26px;cursor:pointer; }
    .slide-toggle input { opacity:0;width:0;height:0;position:absolute; }
    .slide-toggle-track { position:absolute;inset:0;background:#EF4444;border-radius:13px;transition:background 0.25s; }
    .slide-toggle input:checked + .slide-toggle-track { background:var(--green); }
    .slide-toggle-knob { position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;box-shadow:0 1px 4px rgba(0,0,0,0.2);transition:transform 0.25s; }
    .slide-toggle input:checked ~ .slide-toggle-knob { transform:translateX(22px); }
    /* Launch button */
    .btn-launch-agents { display:inline-flex;align-items:center;gap:7px;font-size:0.85rem;font-weight:700;padding:10px 22px;border-radius:10px;border:none;cursor:not-allowed;background:#D1D5DB;color:#9CA3AF;font-family:'Plus Jakarta Sans',-apple-system,sans-serif;transition:all 0.25s; }
    .btn-launch-agents.armed { cursor:pointer;background:var(--btn-gradient);color:#fff;box-shadow:0 4px 20px rgba(96,80,220,0.35); }
    .btn-launch-agents.armed:hover { box-shadow:0 6px 28px rgba(96,80,220,0.5);transform:translateY(-1px); }
    /* Magic phases */
    .magic-phases { margin-top:16px; }
    .magic-phase { display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--border);opacity:0.35;transition:opacity 0.3s; }
    .magic-phase:last-child { border-bottom:none; }
    .magic-phase.active { opacity:1; }
    .magic-phase.done { opacity:0.7; }
    .magic-phase-icon { width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--bg);border:2px solid var(--border);transition:all 0.3s; }
    .magic-phase.active .magic-phase-icon { border-color:var(--accent);background:rgba(96,80,220,0.08); }
    .magic-phase.done .magic-phase-icon { border-color:var(--green);background:rgba(22,163,74,0.08); }
    .magic-phase.failed .magic-phase-icon { border-color:var(--red);background:rgba(239,68,68,0.08); }
    .magic-phase-title { font-size:0.78rem;font-weight:700;color:var(--t1);margin-bottom:2px; }
    .magic-phase-detail { font-size:0.72rem;color:var(--t3);line-height:1.5; }
    .magic-phase.active .magic-phase-title { color:var(--accent); }
    .magic-phase.done .magic-phase-title { color:var(--green); }
    .magic-phase.failed .magic-phase-title { color:var(--red); }
    /* Audit report rendered */
    .magic-audit-report { background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin-top:10px;font-size:0.78rem;color:var(--t2);line-height:1.7;max-height:280px;overflow-y:auto;white-space:pre-wrap; }
    .magic-team-card { background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin-top:8px; }
    .magic-team-lead { font-size:0.72rem;font-weight:800;color:var(--accent);margin-bottom:6px; }
    .magic-team-mission { font-size:0.78rem;color:var(--t2);line-height:1.5;margin-bottom:8px; }
    .magic-step-row { display:flex;align-items:flex-start;gap:8px;padding:4px 0;font-size:0.73rem; }
    .magic-step-owner { font-weight:700;color:var(--accent);min-width:70px;flex-shrink:0; }
    .magic-step-desc { color:var(--t2); }
    .magic-step-check { color:var(--t3);font-style:italic;margin-left:auto;flex-shrink:0;font-size:0.67rem; }
    /* Audit archive cards */
    .audit-archive-card { background:var(--card);border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin-bottom:8px;cursor:pointer;transition:box-shadow 0.15s; }
    .audit-archive-card:hover { box-shadow:var(--shadow-card); }
    .audit-status-badge { display:inline-flex;align-items:center;font-size:0.6rem;font-weight:800;text-transform:uppercase;letter-spacing:0.06em;padding:2px 7px;border-radius:5px; }
    .audit-status-done    { background:rgba(22,163,74,0.1);color:#16a34a; }
    .audit-status-ready   { background:rgba(96,80,220,0.1);color:var(--accent); }
    .audit-status-failed  { background:rgba(239,68,68,0.1);color:#EF4444; }
    .audit-status-auditing,.audit-status-planning { background:rgba(245,158,11,0.1);color:#F59E0B; }
    /* Rapport archive cards */
    .rapport-card { background:var(--card);border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin-bottom:8px;cursor:pointer;transition:box-shadow 0.15s; }
    .rapport-card:hover { box-shadow:var(--shadow-card); }
    .rapport-card-header { display:flex;align-items:center;gap:8px;margin-bottom:6px; }
    .rapport-card-date { font-size:0.78rem;font-weight:700;color:var(--t1); }
    .rapport-card-meta { font-size:0.65rem;color:var(--t3);margin-left:auto; }
    .rapport-card-preview { font-size:0.75rem;color:var(--t2);line-height:1.55;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden; }
    /* Rapport full-read modal */
    .rapport-modal-body { max-height:65vh;overflow-y:auto;font-size:0.82rem;color:var(--t2);line-height:1.75;white-space:pre-wrap;margin-top:12px; }
    .vca-btn { display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:6px;font-size:0.68rem;font-weight:600;cursor:pointer;border:1px solid var(--border);background:transparent;color:var(--t2);transition:all 0.15s; }
    .vca-btn:hover { background:var(--bg);color:var(--t1); }
    .vca-btn.danger:hover { background:rgba(239,68,68,0.08);color:#ef4444;border-color:rgba(239,68,68,0.3); }
    .vca-btn.warn:hover { background:rgba(249,115,22,0.08);color:#f97316;border-color:rgba(249,115,22,0.3); }
    .vca-btn.success:hover { background:rgba(16,185,129,0.08);color:#10b981;border-color:rgba(16,185,129,0.3); }
    /* Edit modal */
    .veille-modal-overlay { position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem; }
    .veille-modal { background:var(--card);border-radius:16px;padding:24px;width:100%;max-width:520px;box-shadow:0 20px 60px rgba(0,0,0,0.25); }
    .veille-modal h3 { font-size:1rem;font-weight:700;margin-bottom:16px;color:var(--t1); }
    .veille-modal label { font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:0.07em;color:var(--t3);display:block;margin-bottom:4px;margin-top:12px; }
    .veille-modal input, .veille-modal textarea, .veille-modal select { width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-size:0.85rem;background:var(--bg);color:var(--t1);outline:none;box-sizing:border-box; }
    .veille-modal textarea { resize:vertical;min-height:70px; }
    .veille-modal-footer { display:flex;gap:8px;justify-content:flex-end;margin-top:16px; }
    .veille-imp-badge { font-size:0.6rem;font-weight:700;padding:2px 7px;border-radius:9999px;white-space:nowrap;flex-shrink:0; }
    .ib-critique { background:rgba(239,68,68,0.12);color:#ef4444; }
    .ib-haute    { background:rgba(249,115,22,0.12);color:#f97316; }
    .ib-normale  { background:rgba(96,165,250,0.12);color:#60a5fa; }
    .ib-faible   { background:rgba(156,163,175,0.12);color:#9ca3af; }
    .veille-cat-badge { font-size:0.6rem;font-weight:700;padding:2px 7px;border-radius:9999px;background:rgba(96,80,220,0.1);color:var(--accent);white-space:nowrap;flex-shrink:0; }
    .veille-resume { font-size:0.8rem;color:var(--t2);line-height:1.6;margin-bottom:6px; }
    .veille-impact { font-size:0.75rem;color:var(--t2);background:rgba(96,80,220,0.05);border-left:2px solid var(--accent);padding:5px 8px;border-radius:0 6px 6px 0;margin-bottom:6px; }
    .veille-actions { display:flex;flex-wrap:wrap;gap:5px;margin-top:6px; }
    .veille-action-item { font-size:0.68rem;padding:2px 8px;background:var(--surface-2);border:1px solid var(--border);border-radius:6px;color:var(--t2); }
    .veille-day-header { font-size:0.68rem;font-weight:800;text-transform:uppercase;letter-spacing:0.1em;color:var(--t3);margin:16px 0 8px;padding-bottom:4px;border-bottom:1px solid var(--border); }
    /* ── Form sections redesign ── */
    .form-section { margin-top:16px; }
    .form-sec-header {
      display:flex; align-items:center; gap:8px;
      padding:7px 12px 7px 10px;
      background:linear-gradient(90deg,rgba(96,80,220,0.08) 0%,rgba(96,165,250,0.04) 100%);
      border-left:3px solid var(--accent);
      border-radius:0 8px 8px 0;
      margin-bottom:8px;
    }
    .fsh-icon { font-size:1rem; line-height:1; flex-shrink:0; }
    .fsh-text { font-size:0.72rem; font-weight:800; color:var(--t1); text-transform:uppercase; letter-spacing:0.09em; }
    .fsh-hint { font-size:0.64rem; color:var(--t3); margin-left:auto; font-weight:400; }
    .form-sec-header.fsh-blue  { border-left-color:#60a5fa; background:linear-gradient(90deg,rgba(96,165,250,0.09) 0%,rgba(34,211,238,0.04) 100%); }
    .form-sec-header.fsh-teal  { border-left-color:#22d3ee; background:linear-gradient(90deg,rgba(34,211,238,0.09) 0%,rgba(96,165,250,0.04) 100%); }
    .form-sec-header.fsh-grad  { border-left-color:#a78bfa; background:linear-gradient(90deg,rgba(167,139,250,0.09) 0%,rgba(96,80,220,0.04) 100%); }
    /* Upload zone redesigned */
    .upload-zone-v2 {
      border:2px dashed rgba(96,165,250,0.35);
      border-radius:12px; padding:20px 16px;
      text-align:center; cursor:pointer;
      background:linear-gradient(135deg,rgba(96,165,250,0.04) 0%,rgba(96,80,220,0.03) 100%);
      transition:border-color 0.2s,background 0.2s,transform 0.15s;
      position:relative; overflow:hidden;
    }
    .upload-zone-v2::before {
      content:''; position:absolute; inset:0;
      background:linear-gradient(135deg,rgba(96,165,250,0.0) 0%,rgba(96,80,220,0.05) 100%);
      opacity:0; transition:opacity 0.2s;
    }
    .upload-zone-v2:hover,.upload-zone-v2.dragover { border-color:rgba(96,165,250,0.7); transform:translateY(-1px); }
    .upload-zone-v2:hover::before,.upload-zone-v2.dragover::before { opacity:1; }
    .uz-icons { display:flex; justify-content:center; gap:10px; margin-bottom:10px; }
    .uz-icon-pill {
      display:inline-flex; align-items:center; gap:5px;
      padding:4px 10px; border-radius:9999px;
      font-size:0.68rem; font-weight:700;
      border:1px solid; white-space:nowrap;
    }
    .uz-icon-pdf  { background:rgba(239,68,68,0.08); color:#ef4444; border-color:rgba(239,68,68,0.2); }
    .uz-icon-word { background:rgba(59,130,246,0.08); color:#3b82f6; border-color:rgba(59,130,246,0.2); }
    .uz-icon-img  { background:rgba(168,85,247,0.08); color:#a855f7; border-color:rgba(168,85,247,0.2); }
    .uz-main { font-size:0.82rem; font-weight:700; color:var(--t1); margin-bottom:3px; }
    .uz-main strong { color:#60a5fa; }
    .uz-sub { font-size:0.63rem; color:var(--t3); }
    /* URL zone */
    .url-zone-v2 {
      border:1.5px solid rgba(34,211,238,0.25);
      border-radius:12px; overflow:hidden;
      background:linear-gradient(135deg,rgba(34,211,238,0.03) 0%,rgba(96,165,250,0.02) 100%);
    }
    .url-textarea-v2 {
      width:100%; background:transparent; border:none;
      padding:10px 14px; font-family:'Plus Jakarta Sans',-apple-system,sans-serif;
      font-size:0.8rem; color:var(--t1); outline:none; resize:vertical;
      min-height:72px; line-height:1.6; box-sizing:border-box;
    }
    .url-textarea-v2::placeholder { color:var(--t3); }
    /* Category chips */
    .cat-grid { display:flex; flex-wrap:wrap; gap:7px; }
    .cat-chip {
      display:inline-flex; align-items:center; gap:5px;
      padding:5px 13px; border-radius:9999px;
      border:1.5px solid; font-size:0.72rem; font-weight:600;
      cursor:pointer; transition:all 0.15s; user-select:none;
      background:transparent;
    }
    .cat-chip:hover { transform:translateY(-1px); filter:brightness(1.1); }
    .cat-chip.selected { color:#fff !important; border-color:transparent !important; box-shadow:0 2px 8px rgba(0,0,0,0.15); }
    /* Agents footer */
    .form-agents-row { display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
    .form-agent-pill { display:inline-flex; align-items:center; gap:4px; padding:2px 8px; border-radius:9999px; font-size:0.63rem; font-weight:700; }
    .fap-luna  { background:rgba(139,127,232,0.12); color:#8B7FE8; }
    .fap-musk  { background:rgba(96,165,250,0.12); color:#60a5fa; }
    .fap-darwin{ background:rgba(52,211,153,0.12); color:#34d399; }

    .ideas-list-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:1rem; }
    .ideas-list-title { font-size:0.75rem; color:var(--t3); text-transform:uppercase; letter-spacing:0.08em; }

    .idea-card {
      background:var(--card); border:1px solid var(--border); border-radius:var(--radius);
      padding:1.25rem 1.5rem; margin-bottom:0.75rem;
      animation:fadeInUp 0.25s ease both; box-shadow:var(--shadow-card);
    }
    .idea-card-header { display:flex; align-items:flex-start; gap:1rem; margin-bottom:0.75rem; }
    .idea-avatar {
      width:36px; height:36px; border-radius:10px; display:flex; align-items:center;
      justify-content:center; font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-weight:700;
      font-size:0.75rem; flex-shrink:0;
      background:var(--blue-bg); color:var(--blue); border:1px solid rgba(96,80,220,0.25);
    }
    .idea-meta { flex:1; min-width:0; }
    .idea-author { font-size:0.82rem; font-weight:600; color:var(--t1); }
    .idea-date   { font-size:0.72rem; color:var(--t3); margin-top:2px; }
    .idea-content { font-size:0.88rem; color:var(--t2); line-height:1.6; margin-bottom:0.75rem; }
    .idea-footer { display:flex; align-items:center; gap:0.5rem; flex-wrap:wrap; }

    /* Status / score / category badges */
    .badge {
      display:inline-flex; align-items:center; gap:4px;
      font-size:0.7rem; font-weight:600; border-radius:6px;
      padding:2px 8px; letter-spacing:0.03em;
    }
    .badge-pending  { background:rgba(96,80,220,0.06); color:var(--t3); }
    .badge-green    { background:rgba(74,222,128,0.12); color:var(--green); border:1px solid rgba(74,222,128,0.2); }
    .badge-red      { background:rgba(255,107,107,0.12); color:var(--red); border:1px solid rgba(255,107,107,0.2); }
    .badge-blue     { background:var(--blue-bg); color:var(--blue-acc); border:1px solid rgba(96,80,220,0.2); }
    .badge-orange   { background:rgba(251,146,60,0.12); color:var(--orange); border:1px solid rgba(251,146,60,0.2); }
    .badge-yellow   { background:rgba(251,185,36,0.12); color:var(--yellow); border:1px solid rgba(251,185,36,0.2); }
    .badge-purple   { background:rgba(167,139,250,0.12); color:var(--purple); border:1px solid rgba(167,139,250,0.2); }
    .badge-teal     { background:rgba(45,212,191,0.12); color:var(--teal); border:1px solid rgba(45,212,191,0.2); }
    .badge-gray     { background:rgba(96,80,220,0.05); color:var(--t3); border:1px solid var(--border); }
    /* Palette catégories — déclinaison bleue (général) + orange (vigilance) */
    .badge-b1 { background:rgba(15,23,96,0.12);  color:#0f1760; border:1px solid rgba(15,23,96,0.22); }
    .badge-b2 { background:rgba(29,78,216,0.12);  color:#1d4ed8; border:1px solid rgba(29,78,216,0.22); }
    .badge-b3 { background:rgba(37,99,235,0.10);  color:#2563eb; border:1px solid rgba(37,99,235,0.20); }
    .badge-b4 { background:rgba(59,130,246,0.10); color:#3b82f6; border:1px solid rgba(59,130,246,0.22); }
    .badge-b5 { background:rgba(96,165,250,0.12); color:#1d66d0; border:1px solid rgba(96,165,250,0.28); }
    .badge-b6 { background:rgba(147,197,253,0.15);color:#1e4fa3; border:1px solid rgba(147,197,253,0.35); }
    .badge-b7 { background:rgba(191,219,254,0.18);color:#1d4ed8; border:1px solid rgba(191,219,254,0.40); }
    .badge-o1 { background:rgba(194,65,12,0.10);  color:#c2410c; border:1px solid rgba(194,65,12,0.22); }
    .badge-o2 { background:rgba(251,146,60,0.12); color:#ea580c; border:1px solid rgba(251,146,60,0.25); }

    .score-badge {
      font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:0.78rem; font-weight:700;
      border-radius:8px; padding:3px 10px; min-width:42px; text-align:center;
    }
    .score-high   { background:rgba(74,222,128,0.15); color:var(--green); border:1px solid rgba(74,222,128,0.25); }
    .score-mid    { background:rgba(251,185,36,0.12); color:var(--yellow); border:1px solid rgba(251,185,36,0.2); }
    .score-low    { background:rgba(255,107,107,0.12); color:var(--red); border:1px solid rgba(255,107,107,0.2); }
    .score-none   { background:rgba(96,80,220,0.05); color:var(--t3); }

    .idea-analysis { font-size:0.82rem; color:var(--t2); line-height:1.6; margin-top:0.75rem; padding:0.75rem 1rem; border-left:3px solid var(--blue); background:rgba(59,130,246,0.06); border-radius:0 8px 8px 0; }
    .agents-analysis { border-left:none; background:none; padding:0; display:flex; flex-direction:column; gap:0.5rem; }
    .agent-analysis-card { background:var(--surface); border:1px solid var(--border-md); border-radius:10px; padding:0.75rem 1rem; }
    .agent-analysis-header { display:flex; align-items:center; gap:0.4rem; margin-bottom:0.4rem; flex-wrap:wrap; }
    /* ── VERDICT STRUCTURÉ ── */
    .verdict-block { margin-top:0.75rem; border-radius:12px; overflow:hidden; border:1px solid rgba(96,80,220,0.18); background:rgba(96,80,220,0.04); }
    .verdict-header { padding:0.55rem 0.9rem; background:rgba(96,80,220,0.1); display:flex; align-items:center; gap:0.5rem; }
    .verdict-label { font-size:0.65rem; font-weight:800; letter-spacing:0.1em; text-transform:uppercase; color:var(--blue); }
    .verdict-titre { padding:0.7rem 0.9rem 0.3rem; font-size:0.9rem; font-weight:700; color:var(--t1); line-height:1.35; }
    .verdict-body { padding:0 0.9rem 0.75rem; display:flex; flex-direction:column; gap:0.5rem; }
    .verdict-row { display:flex; flex-direction:column; gap:0.15rem; }
    .verdict-row-label { font-size:0.62rem; font-weight:700; text-transform:uppercase; letter-spacing:0.07em; color:var(--t3); }
    .verdict-row-text { font-size:0.8rem; color:var(--t2); line-height:1.55; }
    .verdict-agents { padding:0 0.9rem 0.6rem; display:flex; flex-wrap:wrap; gap:0.35rem; }
    .verdict-agent-pill { font-size:0.65rem; font-weight:700; padding:0.2rem 0.6rem; border-radius:999px; display:inline-flex; align-items:center; gap:0.3rem; }
    .verdict-agent-pill.go   { background:rgba(16,185,129,0.12); color:#10b981; border:1px solid rgba(16,185,129,0.25); }
    .verdict-agent-pill.watch{ background:rgba(217,119,6,0.12); color:#d97706; border:1px solid rgba(217,119,6,0.25); }
    .verdict-agent-pill.no   { background:rgba(239,68,68,0.10); color:#ef4444; border:1px solid rgba(239,68,68,0.22); }
    .verdict-toggle { font-size:0.7rem; color:var(--blue); cursor:pointer; padding:0 0.9rem 0.6rem; display:inline-block; }
    .verdict-toggle:hover { text-decoration:underline; }
    .verdict-agents-detail { display:none; margin:0 0.9rem 0.6rem; display:flex; flex-direction:column; gap:0.4rem; }
    .verdict-block.agents-expanded .verdict-agents-detail { display:flex; }
    .agent-emoji { font-size:1rem; }
    .agent-name { font-size:0.8rem; font-weight:700; color:var(--t1); }
    .agent-role { font-size:0.72rem; color:var(--t3); flex:1; }
    .agent-score { font-size:0.78rem; font-weight:700; color:var(--accent); }
    .agent-verdict { font-size:0.68rem; font-weight:700; color:#fff; padding:2px 7px; border-radius:20px; letter-spacing:0.05em; }
    .agent-analyse { font-size:0.8rem; color:var(--t2); line-height:1.55; margin:0; }
    .btn-analyze { margin-left:auto; padding:0.3rem 0.75rem; font-size:0.75rem; font-weight:600; background:var(--accent); color:#fff; border:none; border-radius:8px; cursor:pointer; white-space:nowrap; transition:opacity 0.2s; display:flex; align-items:center; gap:6px; }
    .btn-analyze:hover { opacity:0.85; }
    .btn-analyze:disabled { opacity:0.6; cursor:default; }
    .idea-analysis-label { font-size:0.7rem; font-weight:600; text-transform:uppercase; letter-spacing:0.05em; color:var(--blue); margin-bottom:0.3rem; }
    .idea-analysis-short { }
    .idea-analysis-full  { display:none; }
    .idea-analysis.expanded .idea-analysis-short { display:none; }
    .idea-analysis.expanded .idea-analysis-full  { display:block; }
    .idea-toggle { font-size:0.72rem; color:var(--blue); cursor:pointer; margin-top:0.4rem; display:inline-block; }
    .idea-toggle:hover { text-decoration:underline; }
    .idea-status-row { display:flex; align-items:center; gap:0.5rem; margin-top:0.5rem; flex-wrap:wrap; }
    .badge-analysed  { background:rgba(16,185,129,0.15); color:#10b981; }
    .badge-archived  { background:rgba(107,114,128,0.15); color:#6b7280; }
    .badge-pending   { background:rgba(245,158,11,0.15);  color:#f59e0b; }
    /* Podium */
    .podium-section { margin-bottom:2rem; }
    .podium-title { font-size:0.7rem; font-weight:700; text-transform:uppercase; letter-spacing:0.08em; color:var(--t3); margin-bottom:0.75rem; }
    .podium-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:0.75rem; }
    .podium-card { background:var(--card); border:1px solid var(--border); border-radius:12px; padding:1rem 1.25rem; display:flex; flex-direction:column; gap:0.25rem; box-shadow:var(--shadow-card); }
    .podium-rank { display:inline-flex; align-items:center; justify-content:center; width:30px; height:30px; border-radius:50%; font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-weight:900; font-size:0.85rem; color:#fff; }
    .podium-rank.rank-0 { background:linear-gradient(135deg,#fbbf24,#d97706); box-shadow:0 2px 8px rgba(251,191,36,0.4); }
    .podium-rank.rank-1 { background:linear-gradient(135deg,#d1d5db,#9ca3af); box-shadow:0 2px 8px rgba(156,163,175,0.4); }
    .podium-rank.rank-2 { background:linear-gradient(135deg,#cd7f32,#a16207); box-shadow:0 2px 8px rgba(161,98,7,0.3); }
    .podium-name { font-size:0.9rem; font-weight:600; color:var(--t1); }
    .podium-stat { font-size:0.75rem; color:var(--t3); }
    /* Charts */
    .charts-row { display:grid; grid-template-columns:1fr 1fr; gap:1.25rem; margin-bottom:0.5rem; }
    /* charts-row mobile → géré dans bloc responsive consolidé */
    .chart-card { background:var(--card); border:1px solid var(--border); border-radius:12px; padding:1.25rem 1.5rem; box-shadow:var(--shadow-card); min-height:350px; }
    .chart-title { font-size:0.7rem; font-weight:700; text-transform:uppercase; letter-spacing:0.08em; color:var(--t3); margin-bottom:1rem; }
    .chart-wrap { position:relative; height:260px; }
    .chart-card-full { grid-column:1/-1; }
    /* ── SYSTÈME DE FILTRES ÉLABORÉ ── */
    .filter-panel { background:rgba(96,80,220,0.03); border:1px solid var(--border); border-radius:var(--radius); padding:1.25rem 1.5rem; margin-bottom:1.5rem; }
    .filter-search-row { display:flex; gap:0.75rem; align-items:center; margin-bottom:1rem; }
    .filter-search-wrap { position:relative; flex:1; }
    .filter-search-wrap svg { position:absolute; left:0.75rem; top:50%; transform:translateY(-50%); opacity:0.4; pointer-events:none; }
    .filter-search-main { width:100%; background:#FFFFFF; border:1px solid var(--border); border-radius:10px; padding:0.55rem 0.75rem 0.55rem 2.25rem; color:var(--t1); font-family:inherit; font-size:0.9rem; outline:none; transition:border-color 0.2s; box-sizing:border-box; }
    .filter-search-main:focus { border-color:var(--blue); }
    .filter-chips-row { display:flex; gap:1.25rem; flex-wrap:wrap; align-items:flex-start; margin-bottom:0.9rem; }
    .filter-chips-group { display:flex; flex-direction:column; gap:0.35rem; }
    .filter-chips-label { font-size:0.65rem; font-weight:700; text-transform:uppercase; letter-spacing:0.07em; color:var(--t3); }
    .filter-chips { display:flex; gap:0.35rem; flex-wrap:wrap; }
    .chip { background:rgba(96,80,220,0.05); border:1px solid var(--border); border-radius:20px; padding:0.25rem 0.75rem; font-size:0.75rem; font-weight:500; color:var(--t2); cursor:pointer; transition:all 0.15s; font-family:inherit; white-space:nowrap; }
    .chip:hover { border-color:rgba(96,80,220,0.3); color:var(--t1); }
    .chip.active { background:var(--blue); border-color:var(--blue); color:#fff; }
    .chip.chip-green.active { background:#10b981; border-color:#10b981; }
    .chip.chip-yellow.active { background:#f59e0b; border-color:#f59e0b; color:#000; }
    .chip.chip-red.active { background:#ef4444; border-color:#ef4444; }
    .filter-selects-row { display:flex; gap:0.75rem; flex-wrap:wrap; align-items:center; }
    .filter-select { background:#FFFFFF; border:1px solid var(--border); border-radius:8px; padding:0.35rem 0.65rem; color:var(--t2); font-family:inherit; font-size:0.8rem; outline:none; }
    .filter-input  { background:#FFFFFF; border:1px solid var(--border); border-radius:8px; padding:0.35rem 0.65rem; color:var(--t1); font-family:inherit; font-size:0.8rem; outline:none; width:150px; }
    .filter-results-row { display:flex; align-items:center; justify-content:space-between; margin-top:0.9rem; padding-top:0.75rem; border-top:1px solid var(--border); }
    .filter-count { font-size:0.78rem; color:var(--t3); }
    .filter-count strong { color:var(--t1); }
    .filter-reset { background:none; border:1px solid var(--border); border-radius:8px; padding:0.25rem 0.75rem; font-size:0.75rem; color:var(--t3); cursor:pointer; font-family:inherit; transition:all 0.15s; }
    .filter-reset:hover { border-color:var(--red); color:var(--red); }
    .active-chips-row { display:flex; gap:0.4rem; flex-wrap:wrap; margin-top:0.65rem; }
    .active-chip { background:rgba(59,130,246,0.15); border:1px solid rgba(59,130,246,0.35); border-radius:20px; padding:0.2rem 0.6rem; font-size:0.7rem; color:var(--blue); display:flex; align-items:center; gap:0.3rem; cursor:pointer; }
    .active-chip:hover { background:rgba(239,68,68,0.15); border-color:rgba(239,68,68,0.35); color:var(--red); }
    .chip.chip-contrib.active { background:var(--purple,#8b5cf6); border-color:var(--purple,#8b5cf6); color:#fff; }
    /* ── BADGE DÉCISION / CONTRIBUTION ── */
    .decision-badge { display:inline-flex; align-items:center; gap:0.35rem; font-size:0.72rem; font-weight:700; padding:0.3rem 0.75rem; border-radius:20px; margin-top:0.5rem; }
    .decision-retained { background:rgba(16,185,129,0.15); color:#10b981; border:1px solid rgba(16,185,129,0.3); }
    .decision-partial   { background:rgba(245,158,11,0.15); color:#f59e0b; border:1px solid rgba(245,158,11,0.3); }
    .decision-weak      { background:rgba(100,116,139,0.15); color:#94a3b8; border:1px solid rgba(100,116,139,0.2); }
    .decision-rejected  { background:rgba(239,68,68,0.12); color:#ef4444; border:1px solid rgba(239,68,68,0.25); }
    .decision-pending   { background:rgba(148,163,184,0.08); color:var(--t3); border:1px solid var(--border); }
    /* Liste complète filtrée */
    .all-ideas-header { margin-bottom:0.5rem; }
    .all-ideas-filters { display:flex; gap:0.5rem; flex-wrap:wrap; }

    /* ── PAGE RESUME IDEES ── */
    .top10-grid { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin-bottom:2.5rem; }
    .top10-card {
      background:var(--card); border:1px solid var(--border); border-radius:var(--radius);
      padding:1.25rem 1.5rem; display:flex; gap:1rem; align-items:flex-start;
      animation:fadeInUp 0.2s ease both; box-shadow:var(--shadow-card);
    }
    .top10-rank {
      font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-weight:800; font-size:1.4rem;
      color:var(--t3); width:32px; flex-shrink:0; line-height:1;
    }
    .top10-rank.rank-1 { color:var(--yellow); }
    .top10-rank.rank-2 { color:var(--t2); }
    .top10-rank.rank-3 { color:var(--orange); }
    .top10-body { flex:1; min-width:0; }
    .top10-content { font-size:0.86rem; color:var(--t1); line-height:1.5; margin-bottom:0.5rem; }
    .top10-meta { font-size:0.75rem; color:var(--t3); }

    .category-section { margin-bottom:2.5rem; }
    .category-head { display:flex; align-items:center; gap:0.75rem; margin-bottom:1rem; }
    .category-label { font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:0.95rem; font-weight:600; }
    .category-count { font-size:0.78rem; color:var(--t3); }

    /* ── HOME DASHBOARD ── */
    #page-resume-projet.active { display:flex !important; flex-direction:column; height:calc(100vh - 6rem); }
    .home-body { flex:1; display:grid; grid-template-rows:auto 1fr 1fr; gap:0.75rem; min-height:0; }
    .home-kpi-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:0.75rem; }
    /* home-kpi-grid tablet → géré dans bloc responsive consolidé */
    .home-kpi-card {
      background:linear-gradient(to bottom, #000 0%, #0d0b26 25%, #1e1a5e 55%, #3530d4 100%);
      border-radius:var(--r-md); padding:1.1rem 1.25rem 1rem;
      position:relative; overflow:hidden; cursor:pointer;
      transition:transform 0.18s,box-shadow 0.18s;
      box-shadow:0 6px 20px rgba(53,48,212,0.2),0 1px 4px rgba(0,0,0,0.1);
    }
    .home-kpi-card::after {
      content:''; position:absolute; top:-40%; right:-5%;
      width:130px; height:130px; border-radius:50%;
      background:radial-gradient(circle,rgba(139,127,232,0.22) 0%,transparent 70%);
      pointer-events:none;
    }
    .home-kpi-card:hover { transform:translateY(-2px); box-shadow:0 10px 30px rgba(53,48,212,0.3),0 2px 6px rgba(0,0,0,0.12); }
    .home-kpi-icon { position:absolute; bottom:0.75rem; right:1rem; opacity:0.08; }
    .home-kpi-label { font-size:0.62rem; font-weight:700; color:rgba(255,255,255,0.48); letter-spacing:0.1em; text-transform:uppercase; margin-bottom:0.5rem; }
    .home-kpi-value { font-size:2rem; font-weight:900; color:#fff; line-height:1; margin-bottom:0.25rem; font-variant-numeric:tabular-nums; letter-spacing:-0.02em; }
    .home-kpi-sub { font-size:0.67rem; color:rgba(255,255,255,0.42); }
    .home-kpi-badge { display:inline-block; margin-top:0.45rem; background:rgba(255,255,255,0.13); border:1px solid rgba(255,255,255,0.14); border-radius:99px; padding:2px 8px; font-size:0.62rem; font-weight:700; color:rgba(255,255,255,0.9); }
    .home-row-2 { display:grid; grid-template-columns:1fr 1fr; gap:0.75rem; min-height:0; }
    .home-row-3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:0.75rem; min-height:0; }
    /* home-row-3 tablet → géré dans bloc responsive consolidé */
    .home-panel { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-md); overflow:hidden; display:flex; flex-direction:column; min-height:0; }
    .home-panel-stripe { height:3px; background:linear-gradient(to right, #000 0%, #1e1a5e 55%, #3530d4 100%); flex-shrink:0; }
    .home-panel-head { display:flex; align-items:center; justify-content:space-between; padding:0.625rem 1rem; flex-shrink:0; }
    .home-panel-title { font-size:0.75rem; font-weight:700; color:var(--t1); display:flex; align-items:center; gap:0.4rem; }
    .home-panel-title svg { color:var(--accent); flex-shrink:0; }
    .home-nav-btn { background:none; border:1px solid var(--border); border-radius:var(--r-sm); padding:3px 9px; font-size:0.65rem; color:var(--t3); cursor:pointer; transition:all 0.15s; display:flex; align-items:center; gap:3px; font-family:inherit; font-weight:600; }
    .home-nav-btn:hover { border-color:var(--accent); color:var(--accent); background:rgba(96,80,220,0.05); }
    .home-panel-body { padding:0 1rem 0.5rem; flex:1; overflow:hidden; }
    .home-item { display:flex; align-items:center; gap:0.625rem; padding:0.42rem 0; border-bottom:1px solid var(--border); }
    .home-item:last-child { border-bottom:none; }
    .home-item-badge { flex-shrink:0; padding:2px 7px; border-radius:99px; font-size:0.6rem; font-weight:700; letter-spacing:0.03em; }
    .home-item-text { flex:1; min-width:0; }
    .home-item-title { font-size:0.78rem; font-weight:600; color:var(--t1); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
    .home-item-meta { font-size:0.64rem; color:var(--t3); }
    .home-phase-bar { background:rgba(0,0,0,0.07); border-radius:99px; height:5px; overflow:hidden; margin:0.3rem 0 0.2rem; }
    .home-phase-fill { height:100%; border-radius:99px; background:linear-gradient(to right, #1e1a5e, #3530d4); transition:width 0.8s ease; }
    .home-empty { font-size:0.75rem; color:var(--t3); text-align:center; padding:1rem 0; }

    /* ── PAGE AVANCEMENT ── */
    .progress-phase-card {
      background:linear-gradient(135deg, rgba(96,80,220,0.14), rgba(139,127,232,0.06));
      border:1px solid rgba(96,80,220,0.3); border-radius:var(--radius);
      padding:1.75rem; margin-bottom:2rem;
    }
    .phase-label { font-size:0.72rem; color:var(--blue-acc); text-transform:uppercase; letter-spacing:0.1em; margin-bottom:0.5rem; }
    .phase-title { font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:1.5rem; font-weight:700; margin-bottom:0.5rem; }
    .phase-content { font-size:0.88rem; color:var(--t2); line-height:1.6; }

    .progress-section-title {
      font-size:0.72rem; color:var(--t3); text-transform:uppercase; letter-spacing:0.1em;
      margin:2rem 0 1rem; padding-bottom:0.5rem; border-bottom:1px solid var(--border);
    }

    .agent-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:0.75rem; }
    .agent-card {
      background:var(--card); border:1px solid var(--border); border-radius:12px;
      padding:1rem 1.25rem; box-shadow:var(--shadow-card);
    }
    .agent-card-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:0.5rem; }
    .agent-name { font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-weight:700; font-size:0.88rem; }
    .agent-role { font-size:0.75rem; color:var(--t3); margin-bottom:0.5rem; }
    .agent-desc { font-size:0.78rem; color:var(--t2); line-height:1.5; }

    .milestone-list { display:flex; flex-direction:column; gap:0.75rem; }
    .milestone-card {
      background:var(--card); border:1px solid var(--border); border-radius:12px;
      padding:1.1rem 1.5rem; display:flex; align-items:flex-start; gap:1.25rem; box-shadow:var(--shadow-card);
    }
    .milestone-dot { width:10px; height:10px; border-radius:50%; flex-shrink:0; margin-top:4px; }
    .milestone-body { flex:1; }
    .milestone-title { font-size:0.88rem; font-weight:600; color:var(--t1); margin-bottom:4px; }
    .milestone-content { font-size:0.78rem; color:var(--t3); line-height:1.5; }

    .metrics-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:1rem; }
    .metric-card { background:var(--card); border:1px solid var(--border); border-radius:12px; padding:1.25rem 1.5rem; box-shadow:var(--shadow-card); }
    .metric-title { font-size:0.78rem; color:var(--t3); text-transform:uppercase; letter-spacing:0.06em; margin-bottom:0.75rem; }
    .metric-values { font-size:0.82rem; color:var(--t2); line-height:1.8; }
    .metric-values strong { color:var(--t1); font-weight:600; }

    .blocker-card {
      background:rgba(255,107,107,0.05); border:1px solid rgba(255,107,107,0.2);
      border-radius:12px; padding:1.1rem 1.5rem; margin-bottom:0.75rem;
      display:flex; gap:1rem;
    }
    .blocker-icon { font-size:1.1rem; flex-shrink:0; line-height:1.4; }
    .blocker-title { font-size:0.88rem; font-weight:600; color:var(--red); margin-bottom:4px; }
    .blocker-content { font-size:0.78rem; color:var(--t2); line-height:1.5; }

    /* Status dot colors */
    .dot-termine  { background:var(--green); }
    .dot-en_cours { background:var(--blue); }
    .dot-bloque   { background:var(--red); }
    .dot-a_venir  { background:var(--t3); }

    /* ── PAGE EQUIPE ── */
    .org-wrap { padding: 8px 0 32px; }
    .org-section-title { font-size:0.7rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--t3); margin: 28px 0 10px; }
    /* Couche humaine */
    .org-human-row { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-bottom:0; }
    .org-human-card { display:flex; align-items:center; gap:12px; background:var(--card); border:1.5px solid var(--border); border-radius:14px; padding:14px 20px; min-width:220px; position:relative; }
    .org-human-card.jb { border-color:var(--primary); }
    .org-human-card.investor { border-color:#22c55e; }
    .org-human-avatar { width:42px; height:42px; border-radius:50%; background:linear-gradient(135deg,#6050DC,#8B7FE8); display:flex; align-items:center; justify-content:center; font-weight:800; font-size:1rem; color:#fff; flex-shrink:0; }
    .org-human-avatar.inv { background:linear-gradient(135deg,#059669,#34d399); }
    .org-human-name { font-weight:700; font-size:0.9rem; color:var(--t1); line-height:1.2; }
    .org-human-role { font-size:0.72rem; color:var(--t3); margin-top:2px; }
    .org-human-badge { position:absolute; top:8px; right:10px; font-size:0.62rem; font-weight:700; padding:2px 7px; border-radius:9999px; }
    .org-badge-owner  { background:rgba(96,80,220,0.15); color:var(--primary); }
    .org-badge-invest { background:rgba(34,197,94,0.12); color:#22c55e; }
    /* Connecteur vertical */
    .org-vline { width:2px; height:28px; background:var(--border); margin:0 auto; }
    .org-vline-sm { height:16px; }
    /* CEO / Direction */
    .org-ceo-row { display:flex; justify-content:center; }
    .org-ceo-card { background:linear-gradient(135deg,rgba(96,80,220,0.18),rgba(139,127,232,0.10)); border:1.5px solid rgba(96,80,220,0.4); border-radius:14px; padding:12px 28px; text-align:center; min-width:200px; }
    .org-ceo-name { font-weight:800; font-size:0.95rem; color:var(--primary); }
    .org-ceo-role { font-size:0.72rem; color:var(--t3); margin-top:2px; }
    .org-luna-card { background:rgba(139,127,232,0.08); border:1.5px solid rgba(139,127,232,0.3); border-radius:14px; padding:12px 28px; text-align:center; min-width:240px; }
    .org-luna-name { font-weight:800; font-size:0.9rem; color:#8B7FE8; }
    .org-luna-role { font-size:0.7rem; color:var(--t3); margin-top:2px; line-height:1.4; }
    /* Connecteur horizontal */
    .org-hline-wrap { display:flex; justify-content:center; align-items:flex-start; gap:0; position:relative; margin-bottom:0; }
    .org-hline-wrap::before { content:''; position:absolute; top:0; left:calc(100% / 14); right:calc(100% / 14); height:2px; background:var(--border); }
    /* ── DIRECTEURS — Système de connexions hiérarchiques ── */
    .org-dir-section { position:relative; }
    /* Tronc vertical (vline) + barre horizontale + tiges verticales */
    .org-dir-stems {
      display:grid;
      grid-template-columns:repeat(5,1fr);
      height:36px;
      position:relative;
    }
    /* org-dir-stems → géré dans bloc responsive consolidé */
/* Barre horizontale reliant toutes les tiges */
    .org-dir-stems::before {
      content:'';
      position:absolute;
      top:0;
      left:calc(100%/10);
      right:calc(100%/10);
      height:2px;
      background:var(--border);
    }
    /* org-dir-stems::before → géré dans bloc responsive consolidé */
    /* Tige verticale individuelle */
    .org-dir-stem { position:relative; display:flex; justify-content:center; }
    .org-dir-stem::after {
      content:'';
      position:absolute;
      top:0; width:2px; height:100%;
      background:var(--border);
    }
    /* Grille directeurs */
    .org-directors-grid {
      display:grid;
      grid-template-columns:repeat(5,1fr);
      gap:10px;
    }
    /* org-directors-grid → géré dans bloc responsive consolidé */
    /* Carte directeur — fond sombre, barre accent gauche */
    .org-director-card {
      background:var(--card);
      border:1px solid var(--border);
      border-radius:12px;
      overflow:hidden;
      position:relative;
      transition:border-color 0.2s,transform 0.15s;
    }
    .org-director-card:hover { transform:translateY(-2px); }
    /* Barre accent colorée gauche */
    .org-dir-accent {
      position:absolute;
      left:0; top:0; bottom:0;
      width:3px;
      border-radius:12px 0 0 12px;
    }
    .org-dir-inner { padding:10px 10px 10px 14px; }
    /* Badge titre (CPO / CTO …) */
    .org-dir-badge {
      display:inline-block;
      font-size:0.56rem;
      font-weight:900;
      letter-spacing:0.16em;
      text-transform:uppercase;
      padding:2px 7px;
      border-radius:9999px;
      margin-bottom:5px;
    }
    .org-dir-name  { font-size:0.95rem; font-weight:800; color:var(--t1); line-height:1.1; }
    .org-dir-persona { font-size:0.58rem; color:var(--t3); font-style:italic; margin-top:1px; }
    .org-dir-domain { font-size:0.62rem; color:var(--t2); margin-top:5px; line-height:1.35; }
    .org-dir-sep { height:1px; background:var(--border); margin:8px 0 7px; }
    .org-dir-team-label { font-size:0.54rem; color:var(--t3); text-transform:uppercase; letter-spacing:0.1em; margin-bottom:5px; }
    .org-dir-chips { display:flex; flex-wrap:wrap; gap:3px; }
    .org-dir-chip { font-size:0.62rem; font-weight:600; padding:2px 7px; border-radius:9999px; }
    /* Palettes par directeur */
    .acc-violet  { background:#a78bfa; }
    .acc-blue    { background:#60a5fa; }
    .acc-pink    { background:#f472b6; }
    .acc-cyan    { background:#22d3ee; }
    .acc-emerald { background:#34d399; }
    .acc-amber   { background:#fbbf24; }
    .bdg-violet  { background:rgba(167,139,250,0.15); color:#a78bfa; }
    .bdg-blue    { background:rgba(96,165,250,0.15);  color:#60a5fa; }
    .bdg-pink    { background:rgba(244,114,182,0.15); color:#f472b6; }
    .bdg-cyan    { background:rgba(34,211,238,0.15);  color:#22d3ee; }
    .bdg-emerald { background:rgba(52,211,153,0.15);  color:#34d399; }
    .bdg-amber   { background:rgba(251,191,36,0.15);  color:#fbbf24; }
    .chp-violet  { background:rgba(167,139,250,0.10); color:#a78bfa; border:1px solid rgba(167,139,250,0.22); }
    .chp-blue    { background:rgba(96,165,250,0.10);  color:#60a5fa; border:1px solid rgba(96,165,250,0.22);  }
    .chp-pink    { background:rgba(244,114,182,0.10); color:#f472b6; border:1px solid rgba(244,114,182,0.22); }
    .chp-cyan    { background:rgba(34,211,238,0.10);  color:#22d3ee; border:1px solid rgba(34,211,238,0.22);  }
    .chp-emerald { background:rgba(52,211,153,0.10);  color:#34d399; border:1px solid rgba(52,211,153,0.22);  }
    .chp-amber   { background:rgba(251,191,36,0.10);  color:#fbbf24; border:1px solid rgba(251,191,36,0.22);  }
    /* Agent list inside director cards */
    .org-dir-agents-list { display:flex; flex-direction:column; gap:3px; margin-top:4px; }
    .org-dir-agent-row   { display:flex; align-items:center; gap:7px; }
    .org-dir-agent-badge { font-size:0.58rem; font-weight:800; letter-spacing:0.07em; padding:2px 6px; border-radius:9999px; white-space:nowrap; flex-shrink:0; }
    .org-dir-agent-fn    { font-size:0.61rem; color:var(--t3); line-height:1.3; }
    .org-dir-agent-frozen .org-dir-agent-badge,
    .org-dir-agent-frozen .org-dir-agent-fn { opacity:0.38; }
    .org-dir-agent-frozen .org-dir-agent-fn::after { content:' · P2'; font-size:0.55rem; opacity:0.7; }
    /* Bord hover coloré */
    .hov-violet:hover  { border-color:rgba(167,139,250,0.4); }
    .hov-blue:hover    { border-color:rgba(96,165,250,0.4);  }
    .hov-pink:hover    { border-color:rgba(244,114,182,0.4); }
    .hov-cyan:hover    { border-color:rgba(34,211,238,0.4);  }
    .hov-emerald:hover { border-color:rgba(52,211,153,0.4);  }
    .hov-amber:hover   { border-color:rgba(251,191,36,0.4);  }
    /* Pôles (conservés pour rétro-compat) */
    .org-pole { border-radius:12px; overflow:hidden; border:1px solid var(--border); }
    .org-pole-header { padding:9px 12px; font-size:0.68rem; font-weight:800; letter-spacing:0.06em; text-transform:uppercase; }
    .org-pole-agents { padding:8px; display:flex; flex-direction:column; gap:5px; background:var(--card); }
    .org-agent { display:flex; align-items:center; gap:8px; padding:6px 8px; border-radius:8px; background:rgba(255,255,255,0.03); cursor:default; transition:background 0.15s; }
    .org-agent:hover { background:rgba(255,255,255,0.07); }
    .org-agent-name { font-size:0.78rem; font-weight:700; color:var(--t1); flex:1; }
    .org-agent-role { font-size:0.65rem; color:var(--t3); line-height:1.3; }

    /* ── TEAM PAGE — NOUVELLES CLASSES ── */
    /* Conseil LUNA/MUSK — 2 cartes séparées */
    .conseil-row { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
    .conseil-card { flex:1; min-width:200px; max-width:310px; border-radius:14px; padding:14px 18px; text-align:center; }
    .conseil-luna { background:rgba(139,127,232,0.08); border:1.5px solid rgba(139,127,232,0.35); }
    .conseil-musk { background:rgba(96,165,250,0.08); border:1.5px solid rgba(96,165,250,0.35); }
    .conseil-name { font-weight:800; font-size:0.95rem; }
    .conseil-luna .conseil-name { color:#8B7FE8; }
    .conseil-musk .conseil-name { color:#60a5fa; }
    .conseil-tag { font-size:0.52rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; padding:2px 7px; border-radius:9999px; display:inline-block; margin-bottom:6px; }
    .conseil-luna .conseil-tag { background:rgba(139,127,232,0.15); color:#8B7FE8; }
    .conseil-musk .conseil-tag { background:rgba(96,165,250,0.15); color:#60a5fa; }
    .conseil-mandate { font-size:0.68rem; color:var(--t3); margin-top:5px; line-height:1.45; }
    /* HERODOTE transversal */
    .herodote-band { display:flex; justify-content:center; margin:12px 0 4px; }
    .herodote-card { display:inline-flex; align-items:center; gap:10px; padding:8px 16px; background:rgba(201,168,76,0.07); border:1.5px dashed rgba(201,168,76,0.45); border-radius:11px; }
    .herodote-tag { font-size:0.52rem; font-weight:800; letter-spacing:0.1em; text-transform:uppercase; padding:2px 7px; border-radius:9999px; background:rgba(201,168,76,0.18); color:#C9A84C; white-space:nowrap; }
    .herodote-name { font-weight:800; font-size:0.82rem; color:#C9A84C; }
    .herodote-sep { width:1px; height:14px; background:rgba(201,168,76,0.3); }
    .herodote-desc { font-size:0.65rem; color:var(--t3); }
    /* Agent rows — layout lisible, 1 ligne par agent, zéro troncature */
    .agent-rows { display:flex; flex-direction:column; gap:2px; margin-top:7px; }
    .agent-row { display:flex; align-items:center; gap:7px; padding:5px 9px; border-radius:7px; border-left:2px solid; }
    .agent-row.st-actif { border-left-color:#10b981; background:rgba(16,185,129,0.05); }
    .agent-row.st-gele  { border-left-color:#9ca3af; background:rgba(156,163,175,0.04); opacity:0.75; }
    .agent-row.st-creer { border-left-color:#d97706; background:rgba(217,119,6,0.04); border-left-style:dashed; }
    .agent-row.st-outil { border-left-color:#60a5fa; background:rgba(96,165,250,0.05); }
    .agent-row.st-corp { border-left-color:#818cf8; background:rgba(129,140,248,0.06); border-left-width:2.5px; }
    .ar-name { font-size:0.71rem; font-weight:800; color:var(--t1); min-width:76px; flex-shrink:0; letter-spacing:0.02em; line-height:1; }
    .ar-badge { font-size:0.48rem; font-weight:700; padding:1px 5px; border-radius:9999px; letter-spacing:0.06em; text-transform:uppercase; white-space:nowrap; flex-shrink:0; }
    .ar-badge.actif { background:rgba(16,185,129,0.14); color:#10b981; }
    .ar-badge.gele  { background:rgba(156,163,175,0.15); color:#9ca3af; }
    .ar-badge.creer { background:rgba(217,119,6,0.13); color:#d97706; }
    .ar-badge.outil { background:rgba(96,165,250,0.13); color:#60a5fa; }
    .ar-badge.corp { background:rgba(129,140,248,0.14); color:#818cf8; }
    .ar-sep { width:1px; height:10px; background:var(--border); flex-shrink:0; }
    .ar-role { font-size:0.59rem; color:var(--t3); flex:1; min-width:0; line-height:1.35; }
    /* Sub-section label inside director */
    .agent-sub-label { font-size:0.55rem; font-weight:800; letter-spacing:0.12em; text-transform:uppercase; color:var(--t3); margin-top:10px; margin-bottom:2px; padding-left:2px; }
    /* Legend */
    .team-legend { display:flex; gap:14px; flex-wrap:wrap; align-items:center; margin-top:20px; padding:10px 14px; background:var(--surface-2); border-radius:10px; border:1px solid var(--border); }
    .tl-item { display:flex; align-items:center; gap:5px; font-size:0.65rem; color:var(--t3); }
    .tl-dot { width:7px; height:7px; border-radius:50%; flex-shrink:0; }
    .tl-bar { width:14px; height:2px; border-radius:1px; flex-shrink:0; }
    .tl-dash { width:14px; height:2px; border-radius:1px; flex-shrink:0; border-top:2px dashed; }
    .org-agent-dot { width:7px; height:7px; border-radius:50%; flex-shrink:0; }
    .dot-actif    { background:#22c55e; }
    .dot-livré    { background:#3b82f6; }
    .dot-pause    { background:#f59e0b; }
    .dot-archive  { background:#6b7280; }
    .dot-lead     { background:#ec4899; }
    /* HERODOTE centré */
    .org-herodote-row { display:flex; justify-content:center; margin-top:4px; }
    .org-herodote-card { border-radius:12px; overflow:hidden; border:1.5px solid rgba(99,102,241,0.5); max-width:280px; width:100%; }
    .org-herodote-header { background:rgba(99,102,241,0.18); color:#818cf8; padding:9px 14px; font-size:0.68rem; font-weight:800; letter-spacing:0.06em; text-transform:uppercase; display:flex; align-items:center; justify-content:space-between; }
    .org-herodote-badge { font-size:0.58rem; background:rgba(99,102,241,0.3); padding:2px 8px; border-radius:9999px; letter-spacing:0.08em; }
    .org-herodote-body { background:var(--card); padding:8px 14px; font-size:0.72rem; color:var(--t3); line-height:1.4; }
    .org-transversal { text-align:center; font-size:0.7rem; color:var(--t3); font-style:italic; padding:8px; border-top:1px dashed var(--border); border-bottom:1px dashed var(--border); margin:16px 0; }
    /* Sidebar catégories — masquées */
    .sidebar-cat { display:none; }

    /* ── CABINET AUDIT MCKINSEY ── */
    .audit-cabinet { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-bottom:16px; }
    /* audit-cabinet → géré dans bloc responsive consolidé */
    .audit-card { background:var(--card); border:1px solid rgba(167,139,250,0.3); border-top:3px solid rgba(167,139,250,0.7); border-radius:12px; padding:14px 16px; display:flex; flex-direction:column; gap:4px; position:relative; }
    .audit-role { font-size:0.52rem; font-weight:800; letter-spacing:0.12em; text-transform:uppercase; color:#a78bfa; }
    .audit-name { font-size:1.05rem; font-weight:800; color:var(--t1); line-height:1; }
    .audit-persona { font-size:0.62rem; color:var(--t3); font-style:italic; margin-bottom:2px; }
    .audit-mandate { font-size:0.62rem; color:var(--t2); line-height:1.45; flex:1; }
    .audit-badge { margin-top:8px; font-size:0.5rem; font-weight:800; letter-spacing:0.1em; text-transform:uppercase; padding:2px 8px; border-radius:9999px; background:rgba(167,139,250,0.12); color:#a78bfa; align-self:flex-start; }

    /* ── PÔLE DEV ── */
    .dev-director-band { display:flex; justify-content:center; margin:10px 0 12px; }
    .dev-dir-card { display:flex; align-items:stretch; border-radius:14px; overflow:hidden; border:1.5px solid rgba(52,211,153,0.4); max-width:520px; width:100%; background:rgba(52,211,153,0.05); }
    .dev-dir-accent { width:4px; background:linear-gradient(180deg,#34d399,#059669); flex-shrink:0; }
    .dev-dir-inner { padding:12px 18px; flex:1; display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
    .dev-dir-badge { font-size:0.52rem; font-weight:800; letter-spacing:0.12em; text-transform:uppercase; padding:2px 8px; border-radius:9999px; background:rgba(52,211,153,0.18); color:#34d399; flex-shrink:0; }
    .dev-dir-name { font-size:1rem; font-weight:800; color:#34d399; flex-shrink:0; }
    .dev-dir-persona { font-size:0.65rem; color:var(--t3); font-style:italic; flex-shrink:0; }
    .dev-dir-domain { font-size:0.65rem; color:var(--t2); flex:1; min-width:200px; }
    /* 6 spécialistes — grille 3 colonnes */
    .dev-specialists-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; margin-bottom:16px; }
    /* dev-specialists-grid → géré dans bloc responsive consolidé */
    .dev-spec-card { background:var(--card); border:1px solid var(--border); border-top:2px solid rgba(52,211,153,0.5); border-radius:10px; padding:12px 14px; display:flex; flex-direction:column; gap:3px; }
    .dev-spec-role { font-size:0.52rem; font-weight:800; letter-spacing:0.12em; text-transform:uppercase; color:#34d399; margin-bottom:2px; }
    .dev-spec-name { font-size:0.88rem; font-weight:800; color:var(--t1); line-height:1; }
    .dev-spec-persona { font-size:0.6rem; color:var(--t3); font-style:italic; margin-bottom:3px; }
    .dev-spec-mandate { font-size:0.61rem; color:var(--t2); line-height:1.45; }

    /* ── ORG HIERARCHY — Classes oh-* ── */
    :root {
      --oh-violet: #a78bfa;
      --oh-blue:   #60a5fa;
      --oh-pink:   #f472b6;
      --oh-amber:  #fbbf24;
      --oh-cyan:   #22d3ee;
      --oh-orange: #f97316;
      --oh-green:  #34d399;
      --oh-purple: #c084fc;
      --oh-gold:   #C9A84C;
      --oh-emerald:#10b981;
      --oh-indigo: #818cf8;
      --oh-rose:   #fb7185;
      --oh-slate:  #94a3b8;
    }
    .oh-org-container { padding: 4px 0 32px; display:flex; flex-direction:column; align-items:center; gap:0; width:100%; }

    /* ── Connecteur vertical entre niveaux ── */
    .oh-connector { width:2px; height:28px; background:var(--border-md); flex-shrink:0; }

    /* ── Niveaux ── */
    .oh-level { width:100%; display:flex; flex-direction:column; align-items:center; gap:10px; }
    .oh-level-label { font-size:0.6rem; font-weight:800; letter-spacing:0.12em; text-transform:uppercase; color:var(--t3); margin-bottom:2px; align-self:flex-start; }

    /* ── Fondateurs ── */
    .oh-founders-row { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; width:100%; }
    .oh-founder-card { display:flex; align-items:center; gap:12px; background:var(--surface); border:1.5px solid var(--border); border-radius:14px; padding:12px 20px; min-width:220px; position:relative; flex:1; max-width:340px; }
    .oh-founder-card.oh-fc-jb { border-color:rgba(96,80,220,0.45); }
    .oh-founder-card.oh-fc-mb { border-color:rgba(52,211,153,0.45); }
    .oh-founder-avatar { width:40px; height:40px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:800; font-size:0.95rem; color:#fff; flex-shrink:0; }
    .oh-founder-avatar.av-jb { background:linear-gradient(135deg,#6050DC,#8B7FE8); }
    .oh-founder-avatar.av-mb { background:linear-gradient(135deg,#059669,#34d399); }
    .oh-founder-name { font-weight:800; font-size:0.88rem; color:var(--t1); line-height:1.2; }
    .oh-founder-role { font-size:0.68rem; color:var(--t3); margin-top:2px; line-height:1.35; }
    .oh-founder-pct { position:absolute; top:8px; right:10px; font-size:0.62rem; font-weight:800; padding:2px 8px; border-radius:9999px; }
    .oh-founder-pct.pct-jb { background:rgba(96,80,220,0.12); color:#6050DC; }
    .oh-founder-pct.pct-mb { background:rgba(34,197,94,0.12); color:#22c55e; }

    /* ── Boss card (Claude Code) ── */
    .oh-boss-card { background:linear-gradient(135deg,rgba(201,168,76,0.12),rgba(96,80,220,0.08)); border:1.5px solid rgba(201,168,76,0.5); border-radius:14px; padding:12px 32px; text-align:center; max-width:480px; width:100%; }
    .oh-boss-name { font-weight:800; font-size:0.98rem; color:var(--oh-gold); line-height:1.2; }
    .oh-boss-role { font-size:0.68rem; color:var(--t3); margin-top:3px; line-height:1.4; }

    /* ── Transversal row (HERODOTE + Audit) ── */
    .oh-transversal-row { display:flex; gap:10px; justify-content:center; flex-wrap:wrap; width:100%; }
    .oh-herodote-pill { display:inline-flex; align-items:center; gap:8px; padding:7px 14px; background:rgba(201,168,76,0.06); border:1.5px dashed rgba(201,168,76,0.45); border-radius:10px; }
    .oh-herodote-tag { font-size:0.48rem; font-weight:800; letter-spacing:0.1em; text-transform:uppercase; padding:2px 6px; border-radius:9999px; background:rgba(201,168,76,0.16); color:var(--oh-gold); white-space:nowrap; }
    .oh-herodote-name { font-weight:800; font-size:0.78rem; color:var(--oh-gold); }
    .oh-herodote-sep { width:1px; height:12px; background:rgba(201,168,76,0.3); }
    .oh-herodote-desc { font-size:0.62rem; color:var(--t3); line-height:1.35; }

    /* ── Audit McKinsey pills ── */
    .oh-audit-pills { display:inline-flex; align-items:center; gap:6px; padding:7px 12px; background:rgba(192,132,252,0.05); border:1.5px dashed rgba(192,132,252,0.35); border-radius:10px; flex-wrap:wrap; }
    .oh-audit-label { font-size:0.48rem; font-weight:800; letter-spacing:0.1em; text-transform:uppercase; padding:2px 6px; border-radius:9999px; background:rgba(192,132,252,0.14); color:var(--oh-purple); white-space:nowrap; }
    .oh-audit-name { font-weight:700; font-size:0.72rem; color:var(--oh-purple); padding:1px 6px; background:rgba(192,132,252,0.08); border-radius:6px; }

    /* ── Conseil LUNA / MUSK ── */
    .oh-conseil-row { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; width:100%; }
    .oh-conseil-card { flex:1; min-width:200px; max-width:320px; border-radius:14px; padding:14px 18px; text-align:center; }
    .oh-conseil-luna { background:rgba(139,127,232,0.07); border:1.5px solid rgba(139,127,232,0.35); }
    .oh-conseil-musk { background:rgba(96,165,250,0.07); border:1.5px solid rgba(96,165,250,0.35); }
    .oh-conseil-tag { font-size:0.5rem; font-weight:800; letter-spacing:0.1em; text-transform:uppercase; padding:2px 7px; border-radius:9999px; display:inline-block; margin-bottom:6px; }
    .oh-conseil-luna .oh-conseil-tag { background:rgba(139,127,232,0.14); color:#8B7FE8; }
    .oh-conseil-musk .oh-conseil-tag { background:rgba(96,165,250,0.14); color:#60a5fa; }
    .oh-conseil-name { font-weight:800; font-size:1rem; }
    .oh-conseil-luna .oh-conseil-name { color:#8B7FE8; }
    .oh-conseil-musk .oh-conseil-name { color:#60a5fa; }
    .oh-conseil-mandate { font-size:0.65rem; color:var(--t3); margin-top:5px; line-height:1.45; }

    /* ── Grille 5 directeurs ── */
    .oh-directors-row { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; width:100%; }
    /* oh-directors-row → géré dans bloc responsive consolidé */

    .oh-dir-card { background:var(--surface); border:1px solid var(--border); border-radius:12px; overflow:hidden; position:relative; transition:border-color 0.2s, transform 0.15s; }
    .oh-dir-card:hover { transform:translateY(-2px); }
    .oh-dir-stripe { position:absolute; left:0; top:0; bottom:0; width:3px; border-radius:12px 0 0 12px; }
    .oh-dir-inner { padding:10px 10px 10px 14px; }
    .oh-dir-badge { display:inline-block; font-size:0.54rem; font-weight:900; letter-spacing:0.16em; text-transform:uppercase; padding:2px 7px; border-radius:9999px; margin-bottom:5px; }
    .oh-dir-name   { font-size:0.95rem; font-weight:800; color:var(--t1); line-height:1.1; }
    .oh-dir-persona { font-size:0.57rem; color:var(--t3); font-style:italic; margin-top:1px; }
    .oh-dir-domain { font-size:0.61rem; color:var(--t2); margin-top:5px; line-height:1.35; }
    .oh-dir-sep    { height:1px; background:var(--border); margin:8px 0 6px; }

    /* Couleurs par pôle — stripe + badge */
    .oh-d-violet .oh-dir-stripe { background:var(--oh-violet); }
    .oh-d-violet .oh-dir-badge  { background:rgba(167,139,250,0.14); color:var(--oh-violet); }
    .oh-d-violet:hover           { border-color:rgba(167,139,250,0.4); }

    .oh-d-blue .oh-dir-stripe { background:var(--oh-blue); }
    .oh-d-blue .oh-dir-badge  { background:rgba(96,165,250,0.14); color:var(--oh-blue); }
    .oh-d-blue:hover           { border-color:rgba(96,165,250,0.4); }

    .oh-d-pink .oh-dir-stripe { background:var(--oh-pink); }
    .oh-d-pink .oh-dir-badge  { background:rgba(244,114,182,0.14); color:var(--oh-pink); }
    .oh-d-pink:hover           { border-color:rgba(244,114,182,0.4); }

    .oh-d-amber .oh-dir-stripe { background:var(--oh-amber); }
    .oh-d-amber .oh-dir-badge  { background:rgba(251,191,36,0.14); color:var(--oh-amber); }
    .oh-d-amber:hover           { border-color:rgba(251,191,36,0.4); }

    .oh-d-cyan .oh-dir-stripe { background:var(--oh-cyan); }
    .oh-d-cyan .oh-dir-badge  { background:rgba(34,211,238,0.14); color:var(--oh-cyan); }
    .oh-d-cyan:hover           { border-color:rgba(34,211,238,0.4); }

    .oh-d-emerald .oh-dir-stripe { background:var(--oh-emerald); }
    .oh-d-emerald .oh-dir-badge  { background:rgba(16,185,129,0.14); color:var(--oh-emerald); }
    .oh-d-emerald:hover           { border-color:rgba(16,185,129,0.4); }

    .oh-d-indigo .oh-dir-stripe { background:var(--oh-indigo); }
    .oh-d-indigo .oh-dir-badge  { background:rgba(129,140,248,0.14); color:var(--oh-indigo); }
    .oh-d-indigo:hover           { border-color:rgba(129,140,248,0.4); }

    .oh-d-rose .oh-dir-stripe { background:var(--oh-rose); }
    .oh-d-rose .oh-dir-badge  { background:rgba(251,113,133,0.14); color:var(--oh-rose); }
    .oh-d-rose:hover           { border-color:rgba(251,113,133,0.4); }

    /* ── Pôles spécialisés (Vente + Dev) ── */
    .oh-poles-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; width:100%; }
    /* oh-poles-row → géré dans bloc responsive consolidé */

    .oh-pole-card { border-radius:14px; overflow:hidden; border:1px solid var(--border); }
    .oh-pole-header { padding:10px 14px; display:flex; align-items:center; gap:10px; }
    .oh-pole-badge  { font-size:0.5rem; font-weight:800; letter-spacing:0.12em; text-transform:uppercase; padding:2px 8px; border-radius:9999px; flex-shrink:0; }
    .oh-pole-dir-name { font-size:0.92rem; font-weight:800; }
    .oh-pole-dir-persona { font-size:0.6rem; font-style:italic; flex:1; }
    .oh-pole-dir-domain  { font-size:0.6rem; color:var(--t3); margin-top:1px; line-height:1.3; }
    .oh-pole-agents { padding:8px 12px 12px; display:flex; flex-direction:column; gap:4px; background:var(--surface); }

    .oh-pole-vente .oh-pole-header { background:rgba(249,115,22,0.07); border-bottom:1px solid rgba(249,115,22,0.18); }
    .oh-pole-vente .oh-pole-badge  { background:rgba(249,115,22,0.16); color:var(--oh-orange); }
    .oh-pole-vente .oh-pole-dir-name { color:var(--oh-orange); }
    .oh-pole-vente { border-color:rgba(249,115,22,0.3); }

    .oh-pole-dev .oh-pole-header { background:rgba(52,211,153,0.07); border-bottom:1px solid rgba(52,211,153,0.18); }
    .oh-pole-dev .oh-pole-badge  { background:rgba(52,211,153,0.16); color:var(--oh-green); }
    .oh-pole-dev .oh-pole-dir-name { color:var(--oh-green); }
    .oh-pole-dev { border-color:rgba(52,211,153,0.3); }

    /* Agents dans les pôles — reprend les .agent-row existants + surcharge légère */
    .oh-pole-agents .agent-row { border-radius:6px; }
    .oh-pole-vente .agent-row  { border-left-color:var(--oh-orange); background:rgba(249,115,22,0.04); }
    .oh-pole-dev .agent-row    { border-left-color:var(--oh-green); background:rgba(52,211,153,0.04); }

    /* ── Légende org ── */
    .oh-legend { display:flex; gap:12px; flex-wrap:wrap; align-items:center; margin-top:24px; padding:10px 14px; background:var(--surface-2); border-radius:10px; border:1px solid var(--border); width:100%; }
    .oh-leg-item { display:flex; align-items:center; gap:5px; font-size:0.63rem; color:var(--t3); }
    .oh-leg-dot  { width:7px; height:7px; border-radius:50%; flex-shrink:0; }
    .oh-leg-bar  { width:14px; height:2px; border-radius:1px; flex-shrink:0; }

    /* ── Chief of Staff pill ── */
    .oh-cos-pill { display:flex; flex-direction:column; gap:6px; padding:9px 14px; background:rgba(148,163,184,0.06); border:1.5px solid rgba(148,163,184,0.35); border-radius:10px; min-width:200px; }
    .oh-cos-header { display:flex; align-items:center; gap:8px; }
    .oh-cos-tag { font-size:0.48rem; font-weight:800; letter-spacing:0.1em; text-transform:uppercase; padding:2px 6px; border-radius:9999px; background:rgba(129,140,248,0.16); color:#818cf8; white-space:nowrap; }
    .oh-cos-name { font-weight:800; font-size:0.78rem; color:var(--oh-slate); }
    .oh-cos-sep { width:1px; height:12px; background:rgba(148,163,184,0.3); }
    .oh-cos-desc { font-size:0.6rem; color:var(--t3); line-height:1.35; }
    .oh-cos-agents { display:flex; gap:6px; flex-wrap:wrap; margin-top:2px; }
    .oh-cos-agent { font-size:0.58rem; font-weight:700; color:#818cf8; padding:2px 7px; background:rgba(129,140,248,0.08); border-radius:6px; display:inline-flex; align-items:center; gap:4px; }
    .oh-cos-role { font-weight:400; color:var(--t3); font-size:0.52rem; }

    /* ── Decision weight badge ── */
    .oh-dir-pct { position:absolute; top:6px; right:8px; font-size:0.5rem; font-weight:800; padding:1px 6px; border-radius:9999px; opacity:0.8; }
    .oh-d-pink .oh-dir-pct    { background:rgba(244,114,182,0.12); color:var(--oh-pink); }
    .oh-d-violet .oh-dir-pct  { background:rgba(167,139,250,0.12); color:var(--oh-violet); }
    .oh-d-blue .oh-dir-pct    { background:rgba(96,165,250,0.12); color:var(--oh-blue); }
    .oh-d-emerald .oh-dir-pct { background:rgba(16,185,129,0.12); color:var(--oh-emerald); }
    .oh-d-amber .oh-dir-pct   { background:rgba(251,191,36,0.12); color:var(--oh-amber); }
    .oh-d-cyan .oh-dir-pct    { background:rgba(34,211,238,0.12); color:var(--oh-cyan); }
    .oh-d-indigo .oh-dir-pct  { background:rgba(129,140,248,0.12); color:var(--oh-indigo); }
    .oh-d-rose .oh-dir-pct    { background:rgba(251,113,133,0.12); color:var(--oh-rose); }

    /* ── Interactions / Flux section ── */
    .oh-flows { width:100%; margin-top:8px; }
    .oh-flows-title { font-size:0.6rem; font-weight:800; letter-spacing:0.12em; text-transform:uppercase; color:var(--t3); margin-bottom:8px; }
    .oh-flows-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; }
    .oh-flow-card { background:var(--surface); border:1px solid var(--border); border-radius:10px; padding:9px 12px; }
    .oh-flow-pair { font-size:0.68rem; font-weight:800; color:var(--t1); margin-bottom:3px; }
    .oh-flow-desc { font-size:0.56rem; color:var(--t3); line-height:1.4; }
    .oh-flow-arrow { color:var(--oh-gold); margin:0 4px; }

    /* ── New pole colors ── */
    .oh-pole-mktg .oh-pole-header { background:rgba(244,114,182,0.07); border-bottom:1px solid rgba(244,114,182,0.18); }
    .oh-pole-mktg .oh-pole-badge  { background:rgba(244,114,182,0.16); color:var(--oh-pink); }
    .oh-pole-mktg .oh-pole-dir-name { color:var(--oh-pink); }
    .oh-pole-mktg { border-color:rgba(244,114,182,0.3); }
    .oh-pole-mktg .agent-row { border-left-color:var(--oh-pink); background:rgba(244,114,182,0.04); }

    .oh-pole-cs .oh-pole-header { background:rgba(16,185,129,0.07); border-bottom:1px solid rgba(16,185,129,0.18); }
    .oh-pole-cs .oh-pole-badge  { background:rgba(16,185,129,0.16); color:var(--oh-emerald); }
    .oh-pole-cs .oh-pole-dir-name { color:var(--oh-emerald); }
    .oh-pole-cs { border-color:rgba(16,185,129,0.3); }
    .oh-pole-cs .agent-row { border-left-color:var(--oh-emerald); background:rgba(16,185,129,0.04); }

    /* ── Agent sub-sections in director cards ── */
    .agent-sub-label { font-size:0.5rem; font-weight:800; letter-spacing:0.1em; text-transform:uppercase; color:var(--t3); margin:6px 0 3px 2px; }
    .oh-dir-agents-scroll { max-height:240px; overflow-y:auto; }

    /* ── Hierarchy lines — connecteur top → children ── */
    .oh-h-connector { position:relative; width:100%; display:flex; justify-content:center; }
    .oh-h-connector::before { content:''; position:absolute; top:0; left:10%; right:10%; height:1px; background:var(--border-md); }
    .oh-h-stems { display:grid; height:24px; position:relative; width:100%; }
    .oh-h-stems-5 { grid-template-columns:repeat(5,1fr); }
    .oh-h-stems-2 { grid-template-columns:repeat(2,1fr); }
    /* oh-h-stems-5 → géré dans bloc responsive consolidé */
    .oh-h-stem { display:flex; justify-content:center; }
    .oh-h-stem::after { content:''; width:2px; height:100%; background:var(--border-md); display:block; }

    /* ── PAGE ARCHITECTURE — Design CHANEL × JOBS ── */

    /* Phase timeline */
    .arch-phases { display:grid; grid-template-columns:1fr 48px 1fr 48px 1fr; align-items:center; gap:0; margin-bottom:32px; }
    .arch-phase { background:var(--card); border:1px solid var(--border); border-radius:16px; padding:22px 24px; }
    .arch-phase-active  { border-color:rgba(34,197,94,0.5);  background:linear-gradient(135deg,rgba(34,197,94,0.07) 0%,transparent 60%); }
    .arch-phase-next    { border-color:rgba(96,165,250,0.35); }
    .arch-phase-future  { border-color:rgba(167,139,250,0.2); opacity:0.7; }
    .arch-phase-tag { font-size:0.6rem; font-weight:900; letter-spacing:0.16em; text-transform:uppercase; padding:3px 10px; border-radius:9999px; display:inline-block; margin-bottom:10px; }
    .arch-phase-active  .arch-phase-tag { background:rgba(34,197,94,0.18);  color:#22c55e; }
    .arch-phase-next    .arch-phase-tag { background:rgba(96,165,250,0.14);  color:#60a5fa; }
    .arch-phase-future  .arch-phase-tag { background:rgba(167,139,250,0.12); color:#a78bfa; }
    .arch-phase-name    { font-size:1.1rem; font-weight:800; color:var(--t1); margin-bottom:3px; line-height:1.2; }
    .arch-phase-timing  { font-size:0.72rem; color:var(--t3); margin-bottom:12px; }
    .arch-phase-kpis    { display:flex; flex-direction:column; gap:6px; }
    .arch-phase-kpi     { font-size:0.72rem; color:var(--t2); display:flex; gap:8px; align-items:baseline; }
    .arch-phase-kpi::before { content:'→'; color:var(--t3); font-size:0.65rem; flex-shrink:0; }
    .arch-phase-conn    { display:flex; align-items:center; justify-content:center; }
    .arch-phase-conn-arrow { width:32px; height:2px; background:var(--border); position:relative; }
    .arch-phase-conn-arrow::after { content:''; position:absolute; right:-2px; top:-5px; border:6px solid transparent; border-left:9px solid var(--border); }

    /* Swim lane — header + body */
    .arch-layer { border-radius:14px; overflow:hidden; margin-bottom:14px; border:1px solid var(--border); }
    .arch-layer-head { display:flex; align-items:center; gap:12px; padding:13px 20px; border-bottom:1px solid var(--border); }
    .arch-layer-num { font-size:0.72rem; font-weight:900; width:28px; height:28px; border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
    .arch-layer-title { font-size:0.82rem; font-weight:800; text-transform:uppercase; letter-spacing:0.1em; flex:1; }
    .arch-layer-phase-badge { font-size:0.62rem; font-weight:700; padding:3px 10px; border-radius:9999px; }
    .arch-layer-agents { font-size:0.65rem; color:var(--t3); }
    .arch-layer-body { padding:18px 20px; background:rgba(0,0,0,0.12); }

    /* Flow — horizontal scroll, nodes bien dimensionnés */
    .arch-flow { display:flex; align-items:stretch; gap:0; overflow-x:auto; padding-bottom:6px; scrollbar-width:thin; scrollbar-color:var(--border) transparent; }
    .arch-flow::-webkit-scrollbar { height:4px; }
    .arch-flow::-webkit-scrollbar-track { background:transparent; }
    .arch-flow::-webkit-scrollbar-thumb { background:var(--border); border-radius:2px; }

    /* Nodes */
    .arch-node { background:var(--card); border:1px solid var(--border); border-radius:12px; padding:14px 16px; min-width:175px; max-width:210px; flex-shrink:0; display:flex; flex-direction:column; }
    .arch-node-critical { border-color:rgba(239,68,68,0.5); background:rgba(239,68,68,0.05); }
    .arch-node-active   { border-color:rgba(34,197,94,0.4); }
    .arch-node-frozen   { opacity:0.42; }
    .arch-node-label    { font-size:0.82rem; font-weight:800; color:var(--t1); line-height:1.25; margin-bottom:5px; }
    .arch-node-sub      { font-size:0.7rem; color:var(--t3); line-height:1.45; flex:1; }
    .arch-node-agent    { font-size:0.6rem; font-weight:700; letter-spacing:0.06em; padding:3px 8px; border-radius:9999px; margin-top:10px; display:inline-block; align-self:flex-start; }
    .arch-node-latency  { font-size:0.88rem; font-weight:900; color:#f59e0b; margin-top:8px; }

    /* Arrows */
    .arch-conn { display:flex; align-items:center; padding:0 4px; flex-shrink:0; }
    .arch-conn-body { width:22px; height:2px; background:var(--border); position:relative; }
    .arch-conn-body::after { content:''; position:absolute; right:-1px; top:-4px; border:5px solid transparent; border-left:7px solid var(--border); }
    .arch-conn-critical { background:rgba(239,68,68,0.55); }
    .arch-conn-critical::after { border-left-color:rgba(239,68,68,0.55); }

    /* Inter-layer divider */
    .arch-inter-layer { display:flex; align-items:center; gap:12px; padding:2px 24px; margin:-2px 0; }
    .arch-inter-line  { width:2px; height:18px; background:var(--border); }
    .arch-inter-arrow { font-size:0.7rem; color:var(--t3); }
    .arch-inter-label { font-size:0.68rem; color:var(--t3); font-style:italic; }

    /* Voice pipeline box */
    .arch-pipeline-wrap  { position:relative; border:2px dashed rgba(239,68,68,0.35); border-radius:14px; padding:20px 16px 14px; }
    .arch-pipeline-label { position:absolute; top:-13px; left:18px; background:rgba(239,68,68,0.14); color:#ef4444; font-size:0.62rem; font-weight:900; padding:3px 12px; border-radius:9999px; letter-spacing:0.12em; text-transform:uppercase; }
    .arch-pipeline-total { position:absolute; top:-13px; right:18px; background:var(--card); color:#f59e0b; font-size:0.68rem; font-weight:800; padding:3px 12px; border-radius:9999px; border:1px solid rgba(245,158,11,0.35); }
    .arch-orch-label     { font-size:0.68rem; color:var(--t3); text-align:center; margin-top:12px; font-style:italic; }

    /* Behavioral — 4 cards S1→S4 */
    .arch-behavior-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
    .arch-beh-card  { background:rgba(0,0,0,0.18); border:1px solid var(--border); border-radius:12px; padding:16px 18px; }
    .arch-beh-week  { font-size:0.62rem; font-weight:900; letter-spacing:0.12em; text-transform:uppercase; margin-bottom:6px; display:block; }
    .arch-beh-title { font-size:0.88rem; font-weight:800; color:var(--t1); margin-bottom:8px; }
    .arch-beh-mech  { font-size:0.72rem; color:var(--t3); line-height:1.5; margin-bottom:12px; }
    .arch-beh-agents { display:flex; gap:4px; flex-wrap:wrap; }
    .arch-beh-agent  { font-size:0.6rem; font-weight:700; padding:2px 8px; border-radius:9999px; }

    /* Data — 5 tiles */
    .arch-data-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:10px; }
    .arch-data-node { background:rgba(0,0,0,0.18); border:1px solid var(--border); border-radius:12px; padding:14px 15px; }
    .arch-data-icon { font-size:1.3rem; margin-bottom:7px; display:block; }
    .arch-data-name { font-size:0.82rem; font-weight:800; }
    .arch-data-role { font-size:0.68rem; color:var(--t3); margin-top:5px; line-height:1.5; }
    .arch-data-agent { font-size:0.6rem; font-weight:700; padding:2px 8px; border-radius:9999px; margin-top:10px; display:inline-block; }

    /* Economics — 5 KPI cards */
    .arch-eco-grid  { display:grid; grid-template-columns:repeat(5,1fr); gap:10px; }
    .arch-eco-card  { background:rgba(0,0,0,0.18); border:1px solid var(--border); border-radius:12px; padding:18px 14px; text-align:center; }
    .arch-eco-value { font-size:1.6rem; font-weight:900; line-height:1; letter-spacing:-0.02em; }
    .arch-eco-label { font-size:0.72rem; color:var(--t3); margin-top:6px; line-height:1.4; }
    .arch-eco-sub   { font-size:0.63rem; color:var(--t3); opacity:0.65; margin-top:4px; line-height:1.3; }

    /* Tag pill inline */
    .arch-pill { font-size:0.65rem; padding:3px 10px; border-radius:9999px; font-weight:700; }

    /* Colors */
    .c-green{color:#22c55e;} .c-blue{color:#60a5fa;} .c-violet{color:#a78bfa;}
    .c-pink{color:#f472b6;}  .c-amber{color:#fbbf24;}.c-red{color:#ef4444;}
    .c-cyan{color:#22d3ee;}  .c-emerald{color:#34d399;}
    .bg-green{background:rgba(34,197,94,0.15);}   .bg-blue{background:rgba(96,165,250,0.15);}
    .bg-violet{background:rgba(167,139,250,0.15);} .bg-pink{background:rgba(244,114,182,0.15);}
    .bg-amber{background:rgba(251,191,36,0.15);}   .bg-red{background:rgba(239,68,68,0.15);}
    .bg-cyan{background:rgba(34,211,238,0.15);}    .bg-emerald{background:rgba(52,211,153,0.15);}

    /* arch grids tablet → géré dans bloc responsive consolidé */

    /* ── ARCHITECTURE PAGE — Corrections contraste light mode ── */
    /* Layer body : remplace rgba(0,0,0,0.12) opaque par teinte lavande légère */
    .arch-layer-body  { background: #F0EFEB; }
    /* Inner cards : blanc pur avec bordure visible */
    .arch-beh-card    { background: #FFFFFF; border-color: rgba(96,80,220,0.18); }
    .arch-data-node   { background: #FFFFFF; border-color: rgba(96,80,220,0.18); }
    .arch-eco-card    { background: #FFFFFF; border-color: rgba(96,80,220,0.18); }
    /* Texte corps : t2 au lieu de t3 pour meilleur contraste */
    .arch-node-sub    { color: var(--t2); }
    .arch-data-role   { color: var(--t2); }
    .arch-eco-label   { color: var(--t2); }
    .arch-eco-sub     { color: var(--t3); opacity: 1; }
    .arch-beh-mech    { color: var(--t2); }
    .arch-layer-agents{ color: var(--t2); }
    .arch-inter-label { color: var(--t2); }
    .arch-orch-label  { color: var(--t2); }
    /* Flèches : couleur visible */
    .arch-conn-body        { background: var(--t3); }
    .arch-conn-body::after { border-left-color: var(--t3); }
    .arch-phase-conn-arrow        { background: var(--t3); }
    .arch-phase-conn-arrow::after { border-left-color: var(--t3); }
    .arch-inter-line { background: rgba(96,80,220,0.2); }
    /* Pipeline voix */
    .arch-pipeline-total { background: var(--card); }
    .arch-node-latency   { color: #b45309; }
    /* Frozen : opacité plus élevée + légèrement désaturé */
    .arch-node-frozen { opacity: 0.55; filter: saturate(0.6); }

    /* Classes utilitaires inline → réutilisables */
    .arch-seq-bar   { margin-top:16px; padding:12px 16px; background:rgba(96,80,220,0.04); border:1px solid rgba(96,80,220,0.12); border-radius:10px; display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
    .arch-seq-bar span { font-size:0.72rem; }
    .arch-seq-label { font-size:0.68rem !important; font-weight:700; color:var(--t3); }
    .arch-seq-step  { color:var(--t1); }
    .arch-seq-sep   { color:var(--t3); }
    .arch-tag-row   { margin-top:14px; display:flex; gap:8px; flex-wrap:wrap; }
    .arch-tag-item  { padding:8px 14px; background:rgba(96,80,220,0.04); border:1px solid rgba(96,80,220,0.12); border-radius:10px; font-size:0.72rem; color:var(--t2); }
    .arch-rls-bar   { margin-top:14px; padding:10px 16px; background:rgba(220,38,38,0.05); border:1px solid rgba(220,38,38,0.18); border-radius:10px; font-size:0.72rem; color:var(--t2); }
    .arch-guardrail-bar { margin-top:14px; padding:10px 16px; background:rgba(16,185,129,0.05); border:1px solid rgba(16,185,129,0.2); border-radius:10px; font-size:0.72rem; color:var(--t2); }

    /* ── PAGE ROADMAP ── */
    .rdm-wrap { position:relative; padding-left:52px; padding-bottom:48px; }
    .rdm-spine { position:absolute; left:22px; top:0; bottom:0; width:2px; background:var(--border); }

    /* Phase banners */
    .rdm-phase-banner { margin-left:-52px; padding:16px 24px 16px 76px; border-radius:14px; position:relative; margin-bottom:12px; margin-top:4px; }
    .rdm-phase-icon { position:absolute; left:9px; top:50%; transform:translateY(-50%); z-index:2; width:28px; height:28px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:0.78rem; font-weight:900; }
    .rdm-phase-tag { font-size:0.58rem; font-weight:900; letter-spacing:0.15em; text-transform:uppercase; padding:2px 9px; border-radius:9999px; display:inline-block; margin-bottom:5px; }
    .rdm-phase-name { font-size:1rem; font-weight:800; color:var(--t1); line-height:1.2; }
    .rdm-phase-timing { font-size:0.7rem; color:var(--t3); margin-top:2px; }
    .rdm-phase-kpis { display:flex; gap:14px; flex-wrap:wrap; margin-top:7px; }
    .rdm-phase-kpi { font-size:0.68rem; color:var(--t2); display:flex; align-items:center; gap:5px; }
    .rdm-phase-kpi::before { content:'→'; color:var(--t3); font-size:0.62rem; }
    .rdm-ph0 { background:rgba(124,58,237,0.05); border:1px solid rgba(124,58,237,0.15); }
    .rdm-ph0 .rdm-phase-tag  { background:rgba(124,58,237,0.12); color:#7c3aed; }
    .rdm-ph0 .rdm-phase-icon { background:rgba(124,58,237,0.12); color:#7c3aed; border:2px solid rgba(124,58,237,0.28); }
    .rdm-ph1 { background:rgba(96,80,220,0.05); border:1px solid rgba(96,80,220,0.2); }
    .rdm-ph1 .rdm-phase-tag  { background:rgba(96,80,220,0.12); color:var(--blue); }
    .rdm-ph1 .rdm-phase-icon { background:rgba(96,80,220,0.12); color:var(--blue); border:2px solid rgba(96,80,220,0.3); }
    .rdm-ph2 { background:rgba(14,116,144,0.04); border:1px solid rgba(14,116,144,0.18); }
    .rdm-ph2 .rdm-phase-tag  { background:rgba(14,116,144,0.12); color:#0e7490; }
    .rdm-ph2 .rdm-phase-icon { background:rgba(14,116,144,0.12); color:#0e7490; border:2px solid rgba(14,116,144,0.3); }
    .rdm-ph3 { background:rgba(22,163,74,0.04); border:1px solid rgba(22,163,74,0.16); }
    .rdm-ph3 .rdm-phase-tag  { background:rgba(22,163,74,0.12); color:#15803d; }
    .rdm-ph3 .rdm-phase-icon { background:rgba(22,163,74,0.12); color:#15803d; border:2px solid rgba(22,163,74,0.28); }

    /* Items */
    .rdm-item { position:relative; margin-bottom:8px; }
    .rdm-dot { position:absolute; left:-37px; top:16px; width:12px; height:12px; border-radius:50%; z-index:1; }
    .rdm-dot-done     { background:#16a34a; box-shadow:0 0 0 3px rgba(22,163,74,0.14); }
    .rdm-dot-active   { background:var(--blue); box-shadow:0 0 0 4px rgba(96,80,220,0.16), 0 0 0 7px rgba(96,80,220,0.06); }
    .rdm-dot-soon     { background:#fff; border:2px solid rgba(96,165,250,0.75); }
    .rdm-dot-upcoming { background:#fff; border:2px solid var(--border); }

    /* Gate */
    .rdm-gate { margin:20px -52px; padding:15px 24px 15px 76px; position:relative; background:rgba(217,119,6,0.05); border:1px solid rgba(217,119,6,0.28); border-radius:14px; }
    .rdm-gate-diamond { position:absolute; left:15px; top:50%; transform:translateY(-50%) rotate(45deg); width:15px; height:15px; border-radius:3px; background:rgba(217,119,6,0.18); border:2px solid #d97706; z-index:2; }
    .rdm-gate-title { font-size:0.88rem; font-weight:800; color:#92400e; margin-bottom:6px; }
    .rdm-gate-conds { display:flex; gap:8px; flex-wrap:wrap; }
    .rdm-gate-cond { font-size:0.68rem; background:rgba(217,119,6,0.1); color:#78350f; border:1px solid rgba(217,119,6,0.22); border-radius:9999px; padding:3px 10px; font-weight:600; }

    /* Today marker */
    .rdm-today { margin:16px -52px; padding:10px 24px 10px 76px; background:rgba(220,38,38,0.05); border:1px solid rgba(220,38,38,0.28); border-radius:12px; position:relative; display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
    .rdm-today-pulse { position:absolute; left:15px; top:50%; transform:translate(-50%,-50%); width:16px; height:16px; border-radius:50%; background:#dc2626; box-shadow:0 0 0 4px rgba(220,38,38,0.18); z-index:2; }
    .rdm-today-label { font-size:0.68rem; font-weight:900; color:#dc2626; text-transform:uppercase; letter-spacing:0.14em; }
    .rdm-today-date  { font-size:0.88rem; font-weight:700; color:#dc2626; }
    .rdm-today-sub   { font-size:0.68rem; color:var(--t3); margin-left:auto; }

    /* Cards */
    .rdm-card { background:var(--card); border:1px solid var(--border); border-radius:12px; padding:12px 16px 12px 19px; position:relative; overflow:hidden; }
    .rdm-card::before { content:''; position:absolute; left:0; top:0; bottom:0; width:3px; border-radius:2px 0 0 2px; }
    .rdm-card-done::before    { background:#16a34a; }
    .rdm-card-done            { background:rgba(22,163,74,0.02); }
    .rdm-card-active::before  { background:var(--blue); }
    .rdm-card-active          { border-color:rgba(96,80,220,0.22); background:rgba(96,80,220,0.025); box-shadow:0 0 0 3px rgba(96,80,220,0.05); }
    .rdm-card-soon::before    { background:rgba(96,165,250,0.8); }
    .rdm-card-upcoming        { opacity:0.85; }
    .rdm-card-upcoming::before{ background:rgba(156,163,175,0.5); }
    .rdm-head { display:flex; align-items:center; gap:7px; margin-bottom:4px; flex-wrap:wrap; }
    .rdm-date   { font-size:0.6rem; font-weight:700; color:var(--t3); letter-spacing:0.08em; text-transform:uppercase; }
    .rdm-cbadge { font-size:0.57rem; font-weight:800; padding:2px 7px; border-radius:9999px; letter-spacing:0.05em; text-transform:uppercase; }
    .rdm-sbadge { font-size:0.59rem; font-weight:700; padding:2px 7px; border-radius:9999px; }
    .rdm-sb-done   { background:rgba(22,163,74,0.12);  color:#15803d; }
    .rdm-sb-active { background:rgba(96,80,220,0.12);  color:var(--blue); }
    .rdm-sb-soon   { background:rgba(59,130,246,0.12); color:#2563eb; }
    .rdm-sb-later  { background:rgba(156,163,175,0.14);color:#6b7280; }
    .rdm-title  { font-size:0.87rem; font-weight:700; color:var(--t1); line-height:1.3; margin-bottom:3px; }
    .rdm-desc   { font-size:0.7rem; color:var(--t2); line-height:1.45; }
    .rdm-agents { display:flex; gap:4px; flex-wrap:wrap; margin-top:7px; }
    .rdm-a      { font-size:0.57rem; font-weight:700; padding:2px 7px; border-radius:9999px; }

    /* Category left border */
    .rdm-strategy::before  { background:#7c3aed !important; }
    .rdm-product::before   { background:var(--blue) !important; }
    .rdm-tech::before      { background:#0e7490 !important; }
    .rdm-marketing::before { background:#db2777 !important; }
    .rdm-brand::before     { background:#0d9488 !important; }
    .rdm-finance::before   { background:#d97706 !important; }
    .rdm-legal::before     { background:#0369a1 !important; }
    .rdm-cognitive::before { background:#059669 !important; }

    /* Category badges */
    .rdm-bs  { background:rgba(124,58,237,0.1);  color:#7c3aed; }
    .rdm-bp  { background:rgba(96,80,220,0.1);   color:var(--blue); }
    .rdm-bt  { background:rgba(14,116,144,0.1);  color:#0e7490; }
    .rdm-bm  { background:rgba(219,39,119,0.1);  color:#db2777; }
    .rdm-bbr { background:rgba(13,148,136,0.1);  color:#0d9488; }
    .rdm-bf  { background:rgba(217,119,6,0.1);   color:#d97706; }
    .rdm-bl  { background:rgba(3,105,161,0.1);   color:#0369a1; }
    .rdm-bc  { background:rgba(5,150,105,0.1);   color:#059669; }

    /* rdm timeline mobile → géré dans bloc responsive consolidé */

    /* ── PAGE INFRA v2 — Services Tiers ── */
    .svc-legend-bar { display:flex; gap:18px; flex-wrap:wrap; padding:10px 16px; background:rgba(96,80,220,0.03); border:1px solid var(--border); border-radius:10px; margin-bottom:1.5rem; align-items:center; }
    .svc-legend-item { display:flex; align-items:center; gap:5px; font-size:0.61rem; color:var(--t2); }
    .svc-legend-sym { font-weight:900; font-size:0.8rem; }
    .svc-legend-dot { width:8px; height:8px; border-radius:50%; display:inline-block; }
    .svc-section { margin-bottom:2rem; }
    .svc-section-head { display:flex; align-items:center; gap:10px; margin-bottom:12px; }
    .svc-section-label { font-size:0.62rem; font-weight:800; text-transform:uppercase; letter-spacing:0.12em; }
    .svc-section-line { flex:1; height:1px; background:var(--border); }
    .svc-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(215px,1fr)); gap:11px; }
    .svc-card { background:var(--card); border:1px solid var(--border); border-radius:13px; padding:14px; position:relative; transition:transform 0.15s,box-shadow 0.15s; overflow:hidden; }
    .svc-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; border-radius:13px 13px 0 0; }
    .svc-card:hover { transform:translateY(-2px); box-shadow:0 4px 18px rgba(96,80,220,0.07); }
    .svc-header { display:flex; align-items:flex-start; gap:10px; margin-bottom:9px; }
    .svc-logo { width:38px; height:38px; border-radius:10px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
    .svc-logo svg { width:20px; height:20px; }
    .svc-meta { flex:1; min-width:0; }
    .svc-name { font-size:0.85rem; font-weight:800; color:var(--t1); line-height:1.2; }
    .svc-status { font-size:0.52rem; font-weight:700; padding:2px 7px; border-radius:9999px; white-space:nowrap; display:inline-block; margin-top:3px; }
    .svc-desc { font-size:0.67rem; color:var(--t2); line-height:1.45; margin-bottom:9px; }
    .svc-conns { display:flex; flex-direction:column; gap:2px; margin-bottom:9px; }
    .svc-conn { display:flex; align-items:flex-start; gap:5px; font-size:0.6rem; line-height:1.4; }
    .svc-conn-sym { font-size:0.72rem; font-weight:900; flex-shrink:0; width:16px; margin-top:1px; }
    .sc-cont  { color:#16a34a; }
    .sc-pont  { color:#d97706; }
    .sc-indir { color:#9ca3af; }
    .svc-conn-body { flex:1; }
    .svc-conn-to   { font-weight:700; color:var(--t1); }
    .svc-conn-label { color:var(--t3); font-size:0.57rem; }
    .svc-footer { display:flex; gap:5px; flex-wrap:wrap; align-items:center; padding-top:8px; border-top:1px solid var(--border); }
    .svc-sec { font-size:0.57rem; font-weight:700; padding:2px 7px; border-radius:9999px; }
    .svc-sec-a { background:rgba(22,163,74,0.1); color:#16a34a; }
    .svc-sec-b { background:rgba(245,158,11,0.1); color:#d97706; }
    .svc-sla { font-size:0.57rem; padding:2px 7px; border-radius:9999px; background:rgba(96,80,220,0.05); color:var(--t3); border:1px solid var(--border); }
    .svc-agent-tag { font-size:0.56rem; font-weight:700; padding:1px 6px; border-radius:9999px; background:rgba(96,80,220,0.06); color:var(--t3); border:1px solid rgba(96,80,220,0.12); }
    /* Accent couleur par catégorie */
    .svc-devops::before { background:#60a5fa; }
    .svc-db::before     { background:#a78bfa; }
    .svc-voice::before  { background:#f472b6; }
    .svc-email::before  { background:#fbbf24; }
    .svc-pay::before    { background:#22c55e; }
    .svc-ai::before     { background:#34d399; }
    .svc-legal::before  { background:#fb923c; }
    /* Logo bg */
    .svc-logo-devops { background:rgba(96,165,250,0.1);  color:#60a5fa; }
    .svc-logo-db     { background:rgba(167,139,250,0.1); color:#a78bfa; }
    .svc-logo-voice  { background:rgba(244,114,182,0.1); color:#f472b6; }
    .svc-logo-email  { background:rgba(251,191,36,0.1);  color:#fbbf24; }
    .svc-logo-pay    { background:rgba(34,197,94,0.1);   color:#22c55e; }
    .svc-logo-ai     { background:rgba(52,211,153,0.1);  color:#34d399; }
    .svc-logo-legal  { background:rgba(251,146,60,0.1);  color:#fb923c; }
    /* Status badges */
    .st-actif { background:rgba(34,197,94,0.15); color:#22c55e; }
    .st-p1    { background:rgba(245,158,11,0.15); color:#f59e0b; }
    .st-p2    { background:rgba(99,102,241,0.15); color:#818cf8; }
    /* Orchestrator */
    .svc-orchestrator { border:1px dashed var(--border); border-radius:14px; padding:14px 14px 8px; position:relative; margin-bottom:2rem; }
    .svc-orch-label { position:absolute; top:-10px; left:14px; font-size:0.58rem; font-weight:800; background:var(--bg); padding:0 8px; color:var(--t3); text-transform:uppercase; letter-spacing:0.1em; }
    .svc-orch-tabs { display:flex; gap:6px; margin-bottom:12px; flex-wrap:wrap; }
    .svc-orch-active { background:rgba(244,114,182,0.12); color:#f472b6; border:1px solid rgba(244,114,182,0.25); font-size:0.62rem; font-weight:700; padding:3px 10px; border-radius:9999px; }
    .svc-orch-next   { background:rgba(99,102,241,0.1); color:#818cf8; border:1px solid rgba(99,102,241,0.2); font-size:0.62rem; font-weight:700; padding:3px 10px; border-radius:9999px; }
    /* Matrix */
    .svc-matrix-wrap { margin-top:1.5rem; padding-top:1.5rem; border-top:1px solid var(--border); }
    .svc-matrix-title { font-size:0.7rem; font-weight:800; color:var(--t2); text-transform:uppercase; letter-spacing:0.1em; margin-bottom:12px; }
    .svc-matrix { width:100%; border-collapse:collapse; font-size:0.66rem; }
    .svc-matrix th { text-align:left; padding:7px 10px; font-size:0.59rem; font-weight:700; color:var(--t3); text-transform:uppercase; letter-spacing:0.05em; border-bottom:1px solid var(--border); white-space:nowrap; }
    .svc-matrix td { padding:7px 10px; border-bottom:1px solid var(--border); color:var(--t2); vertical-align:middle; }
    .svc-matrix tr:last-child td { border-bottom:none; }
    .svc-matrix tr:hover td { background:rgba(96,80,220,0.015); }
    .mx-from  { font-weight:800; color:var(--t1); white-space:nowrap; }
    .mx-cont  { color:#16a34a; font-weight:800; }
    .mx-pont  { color:#d97706; font-weight:800; }
    .mx-indir { color:#9ca3af; font-weight:700; }

    /* ── PAGE ADMIN ── */
    /* Whitelist */
    .wl-table { width:100%; border-collapse:collapse; font-size:0.85rem; }
    .wl-table th { text-align:left; padding:10px 14px; font-size:0.75rem; font-weight:600; color:var(--t3); text-transform:uppercase; letter-spacing:0.04em; border-bottom:1px solid var(--border); white-space:nowrap; }
    .wl-table td { padding:11px 14px; border-bottom:1px solid var(--border); vertical-align:middle; }
    .wl-table tr:last-child td { border-bottom:none; }
    .wl-table tr:hover td { background:var(--hover); }
    .wl-badge { display:inline-block; padding:3px 10px; border-radius:9999px; font-size:0.72rem; font-weight:600; }
    .wl-badge-pending   { background:rgba(245,158,11,0.12); color:#f59e0b; }
    .wl-badge-confirmed { background:rgba(34,197,94,0.12);  color:#22c55e; }
    .wl-filter-btn { padding:6px 14px; border-radius:9999px; border:1px solid var(--border); background:transparent; color:var(--t2); font-size:0.82rem; cursor:pointer; transition:all 0.15s; }
    .wl-filter-btn:hover  { border-color:var(--primary); color:var(--primary); }
    .wl-filter-btn.active { background:var(--primary); border-color:var(--primary); color:#fff; font-weight:600; }
    /* /Whitelist */
    .admin-section { background:var(--card); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; margin-bottom:2rem; box-shadow:var(--shadow-card); }
    .admin-section-head { padding:1.25rem 1.5rem; border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; }
    .admin-section-title { font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:0.95rem; font-weight:600; }
    .user-table { width:100%; border-collapse:collapse; }
    .user-table th { font-size:0.72rem; color:var(--t3); text-transform:uppercase; letter-spacing:0.06em; padding:0.75rem 1.5rem; text-align:left; border-bottom:1px solid var(--border); font-weight:500; }
    .user-table td { padding:1rem 1.5rem; border-bottom:1px solid rgba(96,80,220,0.06); font-size:0.85rem; vertical-align:middle; }
    .user-table tr:last-child td { border-bottom:none; }
    .user-table tr:hover td { background:rgba(96,80,220,0.03); }
    .role-chip { display:inline-block; font-size:0.7rem; font-weight:600; border-radius:5px; padding:2px 8px; }
    .role-super_admin { background:rgba(251,185,36,0.15); color:var(--yellow); }
    .role-admin { background:var(--blue-bg); color:var(--blue-acc); }
    .role-user { background:rgba(96,80,220,0.06); color:var(--t3); }
    .page-chips { display:flex; flex-wrap:wrap; gap:4px; }
    .page-chip { font-size:0.68rem; background:rgba(96,80,220,0.05); color:var(--t3); border-radius:4px; padding:2px 6px; }
    .tbl-actions { display:flex; gap:0.5rem; }
    .btn-edit   { background:var(--blue-bg); border:1px solid rgba(96,80,220,0.2); border-radius:6px; color:var(--blue-acc); font-size:0.75rem; padding:4px 10px; cursor:pointer; transition:background 0.2s; }
    .btn-edit:hover { background:rgba(96,80,220,0.15); }
    .btn-del    { background:rgba(255,107,107,0.08); border:1px solid rgba(255,107,107,0.2); border-radius:6px; color:var(--red); font-size:0.75rem; padding:4px 10px; cursor:pointer; transition:background 0.2s; }
    .btn-del:hover { background:rgba(255,107,107,0.15); }
    .btn-hist   { background:rgba(96,80,220,0.04); border:1px solid var(--border); border-radius:6px; color:var(--t3); font-size:0.85rem; padding:3px 8px; cursor:pointer; transition:background 0.2s, color 0.2s; }
    .btn-hist:hover { background:rgba(96,80,220,0.1); color:var(--t1); }
    .log-list { display:flex; flex-direction:column; gap:0.5rem; max-height:360px; overflow-y:auto; margin-top:0.5rem; }
    .log-item { display:flex; align-items:center; gap:0.75rem; padding:0.6rem 0.75rem; background:rgba(96,80,220,0.03); border:1px solid var(--border); border-radius:8px; font-size:0.82rem; }
    .log-num  { font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:0.7rem; color:var(--t3); width:22px; text-align:right; flex-shrink:0; }
    .log-date { color:var(--t1); font-weight:500; }
    .log-time { color:var(--t3); font-size:0.75rem; }

    /* Admin form */
    .admin-form { padding:1.5rem; }
    .form-grid { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
    .form-field { margin-bottom:0; }
    .form-field.full { grid-column:1/-1; }
    .form-field label { display:block; font-size:0.75rem; color:var(--t3); margin-bottom:0.4rem; letter-spacing:0.03em; }
    .form-field input, .form-field select {
      width:100%; background:#FFFFFF; border:1px solid var(--border);
      border-radius:8px; padding:0.7rem 0.9rem; color:var(--t1);
      font-family:inherit; font-size:0.88rem; outline:none; transition:border-color 0.2s;
    }
    .form-field select option { background:#FFFFFF; color:#0D0D0D; }
    .form-field input:focus, .form-field select:focus { border-color:rgba(96,80,220,0.5); box-shadow: 0 0 0 3px rgba(96,80,220,0.08); }
    .form-field input::placeholder { color:var(--t3); }
    .checkboxes { display:flex; flex-wrap:wrap; gap:0.75rem; margin-top:0.25rem; }
    .cb-item { display:flex; align-items:center; gap:6px; cursor:pointer; }
    .cb-item input[type=checkbox] { width:15px; height:15px; accent-color:var(--blue); cursor:pointer; }
    .cb-item span { font-size:0.82rem; color:var(--t2); }
    .form-actions { display:flex; gap:0.75rem; margin-top:1.25rem; }
    .admin-msg { font-size:0.82rem; margin-top:0.75rem; min-height:1em; }
    .admin-msg.error { color:var(--red); }
    .admin-msg.success { color:var(--green); }

    /* SOFIA IA */
    .wezeer-tab-pills { display:flex; gap:0.5rem; margin-bottom:1.5rem; }
    .wezeer-pill { background:rgba(96,80,220,0.06); border:1px solid var(--border); border-radius:20px; padding:0.5rem 1.25rem; font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:0.82rem; font-weight:500; color:var(--t3); cursor:pointer; transition:all 0.2s; }
    .wezeer-pill:hover { background:rgba(96,80,220,0.12); }
    .wezeer-pill.active { background:var(--btn-gradient); color:#fff; border-color:transparent; box-shadow:0 2px 12px rgba(96,80,220,0.25); }
    .wezeer-prompt-area { width:100%; min-height:400px; background:#FFFFFF; border:1px solid var(--border); border-radius:10px; padding:1rem; font-family:'JetBrains Mono','Fira Code','Courier New',monospace; font-size:0.85rem; color:var(--t1); resize:vertical; outline:none; line-height:1.6; transition:border-color 0.2s; }
    .wezeer-prompt-area:focus { border-color:rgba(96,80,220,0.5); box-shadow: 0 0 0 3px rgba(96,80,220,0.08); }
    .wezeer-meta { font-size:0.75rem; color:var(--t3); margin-top:0.75rem; }
    .wezeer-actions { display:flex; gap:0.75rem; margin-top:1.25rem; }
    .wezeer-test-wrap { margin-top:1.5rem; background:var(--card); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
    /* SOFIA COST TABLE */
    .wezeer-live-dot { display:inline-block; width:7px; height:7px; background:#10B981; border-radius:50%; margin-left:0.5rem; vertical-align:middle; animation:pulse-live 1.5s ease-in-out infinite; }
    .wezeer-usage-table { width:100%; border-collapse:collapse; font-size:0.84rem; }
    .wezeer-usage-table th { text-align:left; font-weight:600; color:var(--t3); font-size:0.72rem; text-transform:uppercase; letter-spacing:0.04em; padding:0.5rem 0.75rem; border-bottom:2px solid var(--border); }
    .wezeer-usage-table td { padding:0.75rem; border-bottom:1px solid var(--border); color:var(--t1); font-variant-numeric:tabular-nums; }
    .wezeer-usage-table th:not(:first-child), .wezeer-usage-table td:not(:first-child) { text-align:right; }
    .wezeer-usage-total td { font-weight:700; color:var(--blue); background:var(--blue-bg); border-bottom:none; }
    .wezeer-usage-mode { display:inline-block; padding:0.2rem 0.65rem; border-radius:20px; font-size:0.74rem; font-weight:600; }
    .wezeer-usage-mode.avant    { background:rgba(96,80,220,0.1);   color:#6050DC; }
    .wezeer-usage-mode.pendant  { background:rgba(239,68,68,0.1);   color:#dc2626; }
    .wezeer-usage-mode.apres    { background:rgba(16,185,129,0.1);  color:#059669; }

    /* RAG KNOWLEDGE BASE */
    .rag-table { width:100%; border-collapse:collapse; font-size:0.84rem; }
    .rag-table th { text-align:left; font-weight:600; color:var(--t3); font-size:0.72rem; text-transform:uppercase; letter-spacing:0.04em; padding:0.5rem 0.75rem; border-bottom:2px solid var(--border); white-space:nowrap; }
    .rag-table td { padding:0.7rem 0.75rem; border-bottom:1px solid var(--border); color:var(--t1); vertical-align:top; }
    .rag-table tr:last-child td { border-bottom:none; }
    .rag-table tr:hover td { background:var(--blue-bg); }
    .rag-intent { display:inline-block; padding:0.18rem 0.6rem; border-radius:20px; font-size:0.72rem; font-weight:600; background:rgba(96,80,220,0.08); color:#6050DC; }
    .rag-dot { display:inline-block; width:8px; height:8px; border-radius:50%; vertical-align:middle; }
    .rag-dot.ok { background:#10B981; }
    .rag-dot.missing { background:#d1d5db; }
    .rag-content-preview { font-size:0.78rem; color:var(--t3); max-width:380px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; margin-top:0.2rem; }
    .rag-actions { display:flex; gap:0.4rem; }
    .rag-btn { border:none; border-radius:7px; padding:0.3rem 0.65rem; font-size:0.75rem; font-weight:600; cursor:pointer; transition:opacity 0.2s; font-family:'Plus Jakarta Sans',-apple-system,sans-serif; }
    .rag-btn:hover { opacity:0.78; }
    .rag-btn.edit { background:rgba(96,80,220,0.1); color:#6050DC; }
    .rag-btn.embed { background:rgba(16,185,129,0.12); color:#059669; }
    .rag-btn.del { background:rgba(220,38,38,0.1); color:#dc2626; }
    .rag-empty { text-align:center; padding:2.5rem; color:var(--t3); font-size:0.88rem; }
    .modal-field textarea { width:100%; background:#FFFFFF; border:1px solid var(--border); border-radius:10px; padding:0.8rem 1rem; color:var(--t1); font-family:'JetBrains Mono','Fira Code','Courier New',monospace; font-size:0.82rem; outline:none; resize:vertical; line-height:1.6; transition:border-color 0.2s; }
    .modal-field textarea:focus { border-color:rgba(96,80,220,0.5); box-shadow: 0 0 0 3px rgba(96,80,220,0.08); }
    .modal-field select { width:100%; background:#FFFFFF; border:1px solid var(--border); border-radius:10px; padding:0.8rem 1rem; color:var(--t1); font-family:inherit; font-size:0.9rem; outline:none; appearance:none; cursor:pointer; }

    /* MODAL */
    .modal-overlay { display:none; position:fixed; inset:0; background:rgba(20,10,50,0.45); backdrop-filter:blur(8px); z-index:500; align-items:center; justify-content:center; }
    .modal-overlay.open { display:flex; }
    .modal-box { background:var(--card); border:1px solid var(--border); border-radius:18px; padding:2rem 2.25rem; width:100%; max-width:420px; box-shadow:0 16px 48px rgba(0,0,0,0.10), 0 4px 12px rgba(0,0,0,0.06); max-height:90vh; overflow-y:auto; }
    .modal-title { font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:1.1rem; font-weight:700; margin-bottom:1.5rem; }
    .modal-field { margin-bottom:1rem; }
    .modal-field label { display:block; font-size:0.78rem; color:var(--t3); margin-bottom:0.4rem; }
    .modal-field input { width:100%; background:#FFFFFF; border:1px solid var(--border); border-radius:10px; padding:0.8rem 1rem; color:var(--t1); font-family:inherit; font-size:0.9rem; outline:none; transition:border-color 0.2s; }
    .modal-field input:focus { border-color:rgba(96,80,220,0.5); box-shadow: 0 0 0 3px rgba(96,80,220,0.08); }
    .modal-actions { display:flex; gap:0.75rem; margin-top:1.5rem; }
    .modal-actions button { flex:1; padding:0.8rem; border-radius:10px; font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:0.9rem; font-weight:600; cursor:pointer; border:none; transition:opacity 0.2s; }
    .modal-actions .btn-primary-modal { background:var(--btn-gradient); color:#fff; }
    .modal-actions .btn-cancel  { background:rgba(96,80,220,0.06); color:var(--t2); }
    .modal-actions button:hover { opacity:0.85; }
    .modal-msg { margin-top:0.75rem; font-size:0.82rem; text-align:center; min-height:1em; }
    .modal-msg.error   { color:var(--red); }
    .modal-msg.success { color:var(--green); }

    /* EMPTY STATE */
    .empty-state { padding:3rem 1.5rem; text-align:center; color:var(--t3); font-size:0.88rem; }
    .empty-state strong { display:block; font-size:1rem; color:var(--t2); margin-bottom:0.5rem; }

    /* LOADER */
    .loader { display:inline-block; width:16px; height:16px; border:2px solid rgba(96,80,220,0.2); border-top-color:var(--blue-acc); border-radius:50%; animation:spin 0.6s linear infinite; vertical-align:middle; margin-right:6px; }

    /* COUT USER PAGE */
    .cost-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:1rem; margin-bottom:1.5rem; }
    .cost-card { background:var(--card); border:1px solid var(--border); border-radius:var(--radius); padding:1.25rem 1.5rem; box-shadow:var(--shadow-card); }
    .cost-card-label { font-size:0.72rem; color:var(--t3); text-transform:uppercase; letter-spacing:0.06em; margin-bottom:0.4rem; }
    .cost-card-value { font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:1.6rem; font-weight:800; color:var(--t1); }
    .cost-card-sub { font-size:0.78rem; color:var(--t3); margin-top:0.25rem; }
    .cost-card.highlight { border-color:rgba(96,80,220,0.35); background:linear-gradient(135deg,rgba(96,80,220,0.04),rgba(139,127,232,0.06)); }
    .cost-breakdown { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; margin-bottom:1.5rem; }
    .cost-breakdown-card { background:var(--card); border:1px solid var(--border); border-radius:var(--radius); padding:1.5rem; box-shadow:var(--shadow-card); }
    .cost-breakdown-title { font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:0.95rem; font-weight:700; margin-bottom:1rem; }
    .cost-bar-row { display:flex; align-items:center; gap:0.75rem; margin-bottom:0.75rem; }
    .cost-bar-label { font-size:0.78rem; color:var(--t2); width:140px; flex-shrink:0; }
    .cost-bar-track { flex:1; height:24px; background:rgba(96,80,220,0.06); border-radius:6px; position:relative; overflow:hidden; }
    .cost-bar-fill { height:100%; border-radius:6px; transition:width 0.4s ease; display:flex; align-items:center; padding-left:8px; }
    .cost-bar-val { font-size:0.72rem; font-weight:600; color:#fff; white-space:nowrap; }
    .cost-bar-val-out { font-size:0.72rem; font-weight:600; color:var(--t2); margin-left:8px; white-space:nowrap; }
    .cost-sim { background:var(--card); border:1px solid var(--border); border-radius:var(--radius); padding:1.5rem; box-shadow:var(--shadow-card); margin-bottom:1.5rem; }
    .cost-sim-title { font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:0.95rem; font-weight:700; margin-bottom:1rem; }
    .sim-row { display:grid; grid-template-columns:180px 1fr 60px; align-items:center; gap:0.75rem; margin-bottom:0.75rem; }
    .sim-label { font-size:0.82rem; color:var(--t2); }
    .sim-slider { -webkit-appearance:none; width:100%; height:6px; background:rgba(96,80,220,0.12); border-radius:3px; outline:none; }
    .sim-slider::-webkit-slider-thumb { -webkit-appearance:none; width:18px; height:18px; border-radius:50%; background:var(--blue); cursor:pointer; border:2px solid #fff; box-shadow:0 1px 4px rgba(0,0,0,0.2); }
    .sim-val { font-size:0.82rem; font-weight:600; color:var(--t1); text-align:right; font-variant-numeric:tabular-nums; }
    .cost-profiles { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; margin-bottom:1.5rem; }
    .profile-card { background:var(--card); border:1px solid var(--border); border-radius:var(--radius); padding:1.25rem; box-shadow:var(--shadow-card); text-align:center; cursor:pointer; transition:border-color 0.2s, box-shadow 0.2s; }
    .profile-card:hover { border-color:rgba(96,80,220,0.3); }
    .profile-card.active { border-color:var(--blue); box-shadow:0 0 0 2px rgba(96,80,220,0.15); }
    .profile-name { font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:0.88rem; font-weight:700; margin-bottom:0.25rem; }
    .profile-desc { font-size:0.72rem; color:var(--t3); margin-bottom:0.75rem; line-height:1.4; }
    .profile-cost { font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:1.3rem; font-weight:800; color:var(--blue); }
    .profile-cost-sub { font-size:0.72rem; color:var(--t3); }
    .cost-comparison { background:var(--card); border:1px solid var(--border); border-radius:var(--radius); padding:1.5rem; box-shadow:var(--shadow-card); margin-bottom:1.5rem; }
    .cost-table { width:100%; border-collapse:collapse; font-size:0.82rem; }
    .cost-table th { text-align:left; font-size:0.72rem; color:var(--t3); text-transform:uppercase; letter-spacing:0.06em; padding:0.6rem 0.75rem; border-bottom:1px solid var(--border); }
    .cost-table td { padding:0.6rem 0.75rem; border-bottom:1px solid rgba(96,80,220,0.06); color:var(--t2); }
    .cost-table tr:last-child td { border-bottom:none; }
    .cost-table .row-total td { font-weight:700; color:var(--t1); border-top:2px solid var(--border); }
    .cost-text-badge { display:inline-block; background:rgba(16,185,129,0.1); color:var(--green-em); font-size:0.7rem; font-weight:600; border-radius:4px; padding:2px 6px; }

    /* ── PAGE PROFIL ── */
    .profil-header { display:flex; align-items:center; gap:1.5rem; margin-bottom:2rem; }
    .profil-avatar-wrap { position:relative; cursor:pointer; }
    .profil-avatar {
      width:80px; height:80px; border-radius:50%; display:flex; align-items:center; justify-content:center;
      font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-weight:800; font-size:1.6rem; color:#fff;
      background:var(--gradient); border:3px solid rgba(96,80,220,0.2);
      overflow:hidden; transition:opacity 0.2s;
    }
    .profil-avatar img { width:100%; height:100%; object-fit:cover; }
    .profil-avatar-wrap:hover .profil-avatar { opacity:0.85; }
    .profil-avatar-edit {
      position:absolute; bottom:0; right:0; width:26px; height:26px; border-radius:50%;
      background:var(--card); border:2px solid var(--border); display:flex; align-items:center; justify-content:center;
      box-shadow:0 2px 6px rgba(0,0,0,0.1);
    }
    .profil-avatar-edit svg { width:12px; height:12px; color:var(--t2); }
    .profil-info h2 { font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:1.4rem; font-weight:700; margin-bottom:0.25rem; }
    .profil-info .profil-email { font-size:0.85rem; color:var(--t3); }
    .profil-info .profil-role { margin-top:0.4rem; }

    .profil-sections { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; }
    .profil-section {
      background:var(--card); border:1px solid var(--border); border-radius:var(--radius);
      box-shadow:var(--shadow-card); overflow:hidden;
    }
    .profil-section.full { grid-column:1/-1; }
    .profil-section-head {
      padding:1.25rem 1.5rem; border-bottom:1px solid var(--border);
      display:flex; align-items:center; gap:0.75rem;
    }
    .profil-section-icon { width:32px; height:32px; border-radius:10px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
    .profil-section-icon.identity { background:var(--blue-bg); color:var(--blue); }
    .profil-section-icon.security { background:rgba(255,107,107,0.08); color:var(--red); }
    .profil-section-icon.prefs    { background:rgba(16,185,129,0.08); color:var(--green-em); }
    .profil-section-icon svg { width:16px; height:16px; }
    .profil-section-title { font-family:'Plus Jakarta Sans',-apple-system,sans-serif; font-size:0.95rem; font-weight:600; }
    .profil-section-body { padding:1.5rem; }

    .profil-field { margin-bottom:1.25rem; }
    .profil-field:last-child { margin-bottom:0; }
    .profil-field label { display:block; font-size:0.75rem; color:var(--t3); margin-bottom:0.4rem; letter-spacing:0.03em; }
    .profil-field input {
      width:100%; background:#FFFFFF; border:1px solid var(--border);
      border-radius:8px; padding:0.7rem 0.9rem; color:var(--t1);
      font-family:inherit; font-size:0.88rem; outline:none; transition:border-color 0.2s;
    }
    .profil-field input:focus { border-color:rgba(96,80,220,0.5); box-shadow: 0 0 0 3px rgba(96,80,220,0.08); }
    .profil-field input:disabled { background:rgba(96,80,220,0.03); color:var(--t3); cursor:not-allowed; }
    .profil-field .profil-field-hint { font-size:0.72rem; color:var(--t3); margin-top:0.3rem; }

    .profil-save-row { display:flex; align-items:center; gap:1rem; margin-top:1rem; }
    .profil-msg { font-size:0.82rem; min-height:1em; }
    .profil-msg.error { color:var(--red); }
    .profil-msg.success { color:var(--green); }

    .profil-toggle-row {
      display:flex; align-items:center; justify-content:space-between;
      padding:1rem 0; border-bottom:1px solid rgba(96,80,220,0.06);
    }
    .profil-toggle-row:last-child { border-bottom:none; }
    .profil-toggle-label { font-size:0.88rem; color:var(--t1); }
    .profil-toggle-desc { font-size:0.75rem; color:var(--t3); margin-top:2px; }
    .toggle-switch {
      position:relative; width:44px; height:24px; flex-shrink:0;
    }
    .toggle-switch input { opacity:0; width:0; height:0; }
    .toggle-track {
      position:absolute; inset:0; background:rgba(96,80,220,0.12); border-radius:12px;
      cursor:pointer; transition:background 0.2s;
    }
    .toggle-track::after {
      content:''; position:absolute; top:2px; left:2px; width:20px; height:20px;
      background:#fff; border-radius:50%; box-shadow:0 1px 3px rgba(0,0,0,0.15);
      transition:transform 0.2s;
    }
    .toggle-switch input:checked + .toggle-track { background:var(--blue); }
    .toggle-switch input:checked + .toggle-track::after { transform:translateX(20px); }

    .profil-login-table { width:100%; border-collapse:collapse; }
    .profil-login-table th {
      font-size:0.72rem; color:var(--t3); text-transform:uppercase; letter-spacing:0.06em;
      padding:0.6rem 1rem; text-align:left; border-bottom:1px solid var(--border); font-weight:500;
    }
    .profil-login-table td { padding:0.7rem 1rem; border-bottom:1px solid rgba(96,80,220,0.06); font-size:0.82rem; color:var(--t2); }
    .profil-login-table tr:last-child td { border-bottom:none; }
    .profil-login-table tr:hover td { background:rgba(96,80,220,0.03); }

    /* ═══════════════════════════════════════════════════════════
       RESPONSIVE CONSOLIDÉ — 3 breakpoints propres
       • --bp-lg : 1100px  (grands écrans → tablet paysage)
       • --bp-md :  768px  (tablet portrait → mobile)
       • --bp-sm :  480px  (mobile compact)
       ═══════════════════════════════════════════════════════════ */
    .main-nav { display:none; }

    /* ── TABLET (≤ 1100px) ── */
    @media (max-width: 1100px) {
      /* Org / équipe */
      .org-dir-stems         { grid-template-columns: repeat(3,1fr); }
      .org-dir-stems::before { left: calc(100% / 6); right: calc(100% / 6); }
      .org-directors-grid    { grid-template-columns: repeat(3,1fr); }
      .oh-directors-row      { grid-template-columns: repeat(3,1fr); }
      .oh-h-stems-5          { grid-template-columns: repeat(3,1fr); }
      /* Architecture */
      .arch-phases           { grid-template-columns: 1fr; }
      .arch-phase-conn       { display: none; }
      .arch-eco-grid         { grid-template-columns: repeat(3,1fr); }
      .arch-behavior-grid    { grid-template-columns: repeat(2,1fr); }
      .arch-data-grid        { grid-template-columns: repeat(3,1fr); }
    }

    /* ── MOBILE (≤ 768px) ── */
    @media (max-width: 768px) {
      /* Sidebar : drawer overlay */
      .sidebar {
        transform: translateX(-100%);
        transition: transform 0.3s cubic-bezier(0.22,1,0.36,1), width 0.25s cubic-bezier(0.4,0,0.2,1);
        width: 250px;
      }
      .sidebar.mobile-open   { transform: translateX(0); }
      .sidebar-overlay       { display: none; position: fixed; inset: 0; background: rgba(20,10,50,0.4); z-index: 99; }
      .sidebar-overlay.open  { display: block; }
      .sidebar-mobile-btn    { display: flex; }
      .board-wrap            { margin-left: 0 !important; }

      /* Topbar */
      .last-updated          { display: none; }
      .header-greeting       { display: none; }
      .board-topbar          { padding: 0 1rem; height: 52px; }
      .icon-btn              { padding: 0.35rem 0.6rem; font-size: 0.72rem; }
      .nav-site-btn          { display: none; }

      /* Layout */
      main { padding: 1rem 0.875rem 5rem; }

      /* Touch targets min 44px */
      .sidebar-item          { height: 44px; }
      .auth-btn              { padding: 1rem; min-height: 44px; }

      /* Auth */
      .auth-card             { margin: 1rem; padding: 2rem 1.25rem; border-radius: 16px; }
      .modal-box             { margin: 1rem; padding: 1.5rem; }

      /* Grilles → 1 colonne */
      .summary-row           { grid-template-columns: 1fr; }
      .columns               { grid-template-columns: 1fr; }
      .top10-grid            { grid-template-columns: 1fr; }
      .agent-grid            { grid-template-columns: 1fr; }
      .metrics-grid          { grid-template-columns: 1fr; }
      .form-grid             { grid-template-columns: 1fr; }
      .form-field.full       { grid-column: 1; }
      .cost-breakdown        { grid-template-columns: 1fr; }
      .cost-profiles         { grid-template-columns: 1fr; }
      .charts-row            { grid-template-columns: 1fr; }
      .home-kpi-grid         { grid-template-columns: repeat(2,1fr); }
      .home-row-3            { grid-template-columns: 1fr; }
      .dev-specialists-grid  { grid-template-columns: repeat(2,1fr); }
      .audit-cabinet         { grid-template-columns: 1fr; }
      .oh-poles-row          { grid-template-columns: 1fr; }
      .org-dir-stems         { grid-template-columns: repeat(2,1fr); }
      .org-dir-stems::before { left: 25%; right: 25%; }
      .org-directors-grid    { grid-template-columns: repeat(2,1fr); }
      .oh-directors-row      { grid-template-columns: repeat(2,1fr); }
      .oh-h-stems-5          { grid-template-columns: repeat(2,1fr); }
      .oh-flows-grid         { grid-template-columns: 1fr; }

      /* Typographie */
      .summary-amount        { font-size: 1.8rem; }

      /* Divers */
      .comparison-labels     { flex-direction: column; gap: 0.5rem; }
      .column-header         { padding: 1.25rem; }
      .entries               { padding: 0.75rem 1rem; }
      .column-footer         { padding: 1rem 1.25rem; }
      .sim-row               { grid-template-columns: 120px 1fr 50px; }
      .profil-header         { flex-direction: column; text-align: center; }
      .profil-sections       { grid-template-columns: 1fr; }
      .profil-section.full   { grid-column: 1; }

      /* Tables : scroll horizontal */
      .user-table            { font-size: 0.78rem; }
      .user-table th,
      .user-table td         { padding: 0.65rem 0.75rem; }
      .table-wrap            { overflow-x: auto; -webkit-overflow-scrolling: touch; }

      /* Roadmap timeline */
      .rdm-wrap              { padding-left: 36px; }
      .rdm-spine,
      .rdm-phase-icon        { left: 8px; }
      .rdm-dot               { left: -26px; }
      .rdm-phase-banner,
      .rdm-gate,
      .rdm-today             { margin-left: -36px; padding-left: 52px; }
      .rdm-gate-diamond      { left: 9px; }
      .rdm-today-pulse       { left: 9px; }
    }

    /* ── SANDBOX responsive ── */
    @media (max-width: 1100px) {
      .sb-layout { grid-template-columns: 280px 1fr; }
    }
    @media (max-width: 768px) {
      .sb-layout      { grid-template-columns: 1fr; }
      .sb-params-grid { grid-template-columns: 1fr; }
      .sb-btn-row     { flex-direction: column; }
    }

    /* ── MOBILE COMPACT (≤ 480px) ── */
    @media (max-width: 480px) {
      main                   { padding: 0.875rem 0.625rem 5rem; }
      .board-topbar          { height: 48px; padding: 0 0.75rem; }
      .home-kpi-grid         { grid-template-columns: 1fr; }
      .dev-specialists-grid  { grid-template-columns: 1fr; }
      .org-dir-stems         { grid-template-columns: 1fr; }
      .org-dir-stems::before { display: none; }
      .org-directors-grid    { grid-template-columns: 1fr; }
      .oh-directors-row      { grid-template-columns: 1fr; }
      .oh-h-stems-5          { grid-template-columns: 1fr; }
      .arch-eco-grid         { grid-template-columns: repeat(2,1fr); }
      .arch-data-grid        { grid-template-columns: repeat(2,1fr); }
      .summary-amount        { font-size: 1.6rem; }
      .auth-card             { margin: 0.5rem; padding: 1.5rem 1rem; }
      .podium-grid           { grid-template-columns: 1fr 1fr; }
      .sim-row               { grid-template-columns: 1fr 1fr 44px; }
      .filter-chips-row      { gap: 0.75rem; }
    }
