:root{
  --blue:#2563EB; --blue2:#3B82F6; --green:#34D399; --green2:#16A34A;
  --ink:#0F172A; --slate:#64748B; --slate2:#94A3B8; --line:#E2E8F0;
  --bg-blue:#EEF4FF; --bg-grn:#ECFDF5; --white:#FFFFFF;
  --radius:24px; --radius-sm:10px;
  --shadow-card:0 24px 70px -24px rgba(30,58,138,.30);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
}

/* ---------- Fond de marque (dégradé + grille + halos) ---------- */
.scene{
  position:relative; min-height:100vh; overflow:hidden;
  background:linear-gradient(135deg,var(--bg-blue) 0%,var(--bg-grn) 100%);
  display:flex; align-items:center; justify-content:center; padding:24px;
}
.scene__grid{
  position:absolute; inset:0; pointer-events:none;
  background-image:
    linear-gradient(to right, rgba(148,163,184,.10) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(148,163,184,.10) 1px, transparent 1px);
  background-size:72px 72px;
  -webkit-mask-image:radial-gradient(ellipse at center, #000 35%, transparent 80%);
          mask-image:radial-gradient(ellipse at center, #000 35%, transparent 80%);
}
.halo{position:absolute; border-radius:50%; filter:blur(100px); pointer-events:none}
.halo--1{width:560px;height:560px;left:-160px;top:-200px;background:rgba(59,130,246,.28)}
.halo--2{width:560px;height:560px;right:-160px;bottom:-200px;background:rgba(52,211,153,.24)}
.halo--3{width:360px;height:360px;right:-120px;top:-120px;background:rgba(37,99,235,.18)}

/* ---------- Carte ---------- */
.card{
  position:relative; z-index:1; width:440px; max-width:100%;
  background:rgba(255,255,255,.92); backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.9); border-radius:var(--radius);
  box-shadow:var(--shadow-card);
  padding:40px 40px 32px;
  display:flex; flex-direction:column; gap:22px;
}

/* ---------- Marque / logo ---------- */
.brand{display:flex; align-items:center; gap:12px}
.brand__logo{width:40px;height:40px;flex:0 0 40px}
.brand__name{font-size:16px;font-weight:700;line-height:1.2;color:var(--ink)}
.brand__name b{color:var(--blue);font-weight:700}
.brand__sub{font-size:12px;font-weight:500;color:var(--slate)}

/* ---------- Titres ---------- */
.head h1{margin:0 0 6px;font-size:26px;font-weight:700;color:var(--ink)}
.head p{margin:0;font-size:14px;color:var(--slate)}

/* ---------- Champs ---------- */
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:13px;font-weight:500;color:var(--ink)}
.field input{
  height:46px;border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:0 14px;font-size:14px;font-family:inherit;color:var(--ink);background:#fff;
  outline:none;transition:border-color .15s,box-shadow .15s;
}
.field input::placeholder{color:var(--slate2)}
.field input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.12)}

/* ---------- Bouton ---------- */
.btn{
  height:48px;border:0;border-radius:var(--radius-sm);cursor:pointer;
  font-size:15px;font-weight:600;font-family:inherit;color:#fff;
  background:linear-gradient(90deg,var(--blue),var(--green2));
  box-shadow:0 8px 18px -6px rgba(37,99,235,.35);
  display:flex;align-items:center;justify-content:center;gap:8px;
  transition:filter .15s,transform .02s;
}
.btn:hover{filter:brightness(1.05)}
.btn:active{transform:translateY(1px)}
.btn[disabled]{opacity:.6;cursor:default}
.btn--ghost{background:#fff;color:var(--ink);border:1px solid var(--line);box-shadow:none}

/* ---------- Encart 2FA / infos ---------- */
.hint{
  display:flex;align-items:center;gap:8px;
  background:var(--bg-blue);border-radius:var(--radius-sm);padding:10px 12px;
}
.hint .dot{width:8px;height:8px;border-radius:50%;background:var(--blue);flex:0 0 8px}
.hint span{font-size:12px;font-weight:500;color:var(--blue)}

/* ---------- Messages ---------- */
.alert{font-size:13px;font-weight:500;border-radius:var(--radius-sm);padding:10px 12px;display:none}
.alert--err{background:#FEE2E2;color:#991B1B;border:1px solid #FCA5A5}
.alert.show{display:block}

/* ---------- Pied ---------- */
.foot{font-size:11px;color:var(--slate2);text-align:center}
.foot a{color:var(--slate);text-decoration:none}

/* ---------- Placeholder app (M0) ---------- */
.app-card{width:520px;text-align:center;gap:16px;align-items:center}
.app-card .badge{display:inline-flex;align-items:center;gap:6px;background:var(--bg-grn);color:var(--green2);
  font-size:12px;font-weight:600;border-radius:99px;padding:6px 12px}
.kv{width:100%;text-align:left;font-size:14px;color:var(--slate);display:flex;flex-direction:column;gap:8px;
  background:var(--bg-blue);border-radius:12px;padding:14px 16px}
.kv b{color:var(--ink);font-weight:600}

/* ---------- Vérification 2FA : cases de code ---------- */
.codes{display:flex;gap:10px;justify-content:center}
.codes input{
  width:52px;height:58px;text-align:center;font-size:22px;font-weight:700;color:var(--ink);
  border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff;outline:none;
  transition:border-color .15s,box-shadow .15s;font-family:inherit;
}
.codes input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.link-center{font-size:13px;font-weight:500;color:var(--blue);text-align:center;text-decoration:none;cursor:pointer;background:none;border:0;font-family:inherit}
/* ---------- Activation 2FA (placeholder app) ---------- */
.twofa-box{width:100%;text-align:left;background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:12px}
.twofa-box .secret{font-family:var(--font-mono,monospace);font-size:13px;background:var(--bg-blue);color:var(--blue);border-radius:8px;padding:10px 12px;word-break:break-all}
.twofa-box input{height:44px;border:1px solid var(--line);border-radius:10px;padding:0 14px;font-size:15px;font-family:inherit;text-align:center;letter-spacing:4px}

/* ===================== APP SHELL (M2) ===================== */
:root{--amber-bg:#FEF3C7;--amber-ink:#925707;--red:#DC2626;--red-bg:#FEE2E2;--grey:#F1F5F9}
.app{display:flex;min-height:100vh;position:relative;z-index:1;width:100%}
.sidebar{width:248px;flex:0 0 248px;background:rgba(255,255,255,.82);border-right:1px solid var(--line);display:flex;flex-direction:column;padding:20px 16px;gap:4px}
.sidebar__brand{display:flex;align-items:center;gap:10px;padding:0 6px 14px}
.sidebar__brand svg{width:34px;height:34px;flex:0 0 34px}
.sidebar__brand .nm{font-size:15px;font-weight:700;color:var(--ink);line-height:1.1}
.sidebar__brand .nm b{color:var(--blue)}
.nav{display:flex;flex-direction:column;gap:4px}
.nav a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;font-size:13px;font-weight:500;color:var(--slate);text-decoration:none}
.nav a .ic{width:18px;height:18px;border-radius:6px;background:rgba(148,163,184,.45);flex:0 0 18px}
.nav a:hover{background:rgba(37,99,235,.06);color:var(--ink)}
.nav a.active{background:rgba(37,99,235,.10);color:var(--blue);font-weight:600}
.nav a.active .ic{background:var(--blue)}
.sidebar__spacer{flex:1}
.user-card{display:flex;align-items:center;gap:10px;background:var(--bg-blue);border-radius:12px;padding:10px;text-decoration:none}
.user-card .av{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--blue2),var(--green));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex:0 0 34px}
.user-card .nm{font-size:12px;font-weight:600;color:var(--ink)}
.user-card .rl{font-size:11px;color:var(--slate)}
.main{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,.6);border-bottom:1px solid var(--line);padding:15px 32px}
.topbar h1{margin:0;font-size:20px;font-weight:700;color:var(--ink)}
.topbar .sub{font-size:13px;color:var(--slate);margin-top:2px}
.topbar__actions{display:flex;align-items:center;gap:12px}
.search{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:9px 12px;color:var(--slate2);font-size:12px;width:220px}
.search .o{width:12px;height:12px;border:1.5px solid var(--slate2);border-radius:50%;flex:0 0 12px}
.icon-btn{width:38px;height:38px;border-radius:10px;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;text-decoration:none;font-size:14px}
.content{flex:1;padding:26px 32px;display:flex;flex-direction:column;gap:20px}

/* generic UI */
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{padding:8px 14px;border-radius:99px;font-size:12.5px;font-weight:600;border:1px solid var(--line);background:#fff;color:var(--slate);cursor:pointer;text-decoration:none;display:inline-block}
.chip.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.panel{background:rgba(255,255,255,.92);border:1px solid var(--line);border-radius:16px;box-shadow:0 18px 40px -20px rgba(15,23,42,.12);padding:18px 20px}
.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 18px;border-radius:10px;border:0;cursor:pointer;font-size:14px;font-weight:600;font-family:inherit;color:#fff;background:linear-gradient(90deg,var(--blue),var(--green2));box-shadow:0 8px 18px -6px rgba(37,99,235,.35);text-decoration:none}
.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 18px;border-radius:10px;border:1px solid var(--line);background:#fff;color:var(--ink);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;text-decoration:none}
.btn-danger{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 18px;border-radius:10px;border:1px solid var(--red);background:#fff;color:var(--red);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer}
.empty{text-align:center;color:var(--slate);padding:40px 0;font-size:14px}

/* table */
.table{width:100%;border-collapse:collapse}
.table th{text-align:left;font-size:11px;font-weight:600;color:var(--slate2);padding:0 8px 12px;border-bottom:1px solid var(--line)}
.table td{padding:13px 8px;border-bottom:1px solid var(--line);font-size:13px;color:var(--slate);vertical-align:middle}
.table tr:last-child td{border-bottom:0}
.table td.name{font-weight:600;color:var(--ink);font-size:13.5px}
.table tr.row-link{cursor:pointer}
.table tr.row-link:hover td{background:rgba(37,99,235,.04)}
.table .chev{color:var(--slate2);font-weight:700;text-align:right}

/* badges */
.badge{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:99px;font-size:11px;font-weight:600}
.badge .d{width:7px;height:7px;border-radius:50%}
.badge.limite{background:var(--amber-bg);color:#925707}
.badge.limite .d{background:var(--amber)}
.badge.haut{background:var(--red-bg);color:#991B1B}
.badge.haut .d{background:var(--red)}
.badge.minimal,.badge.ok{background:var(--bg-grn);color:var(--green2)}
.badge.minimal .d,.badge.ok .d{background:var(--green2)}
.badge.info{background:var(--bg-blue);color:var(--blue)}
.badge.info .d{background:var(--blue)}
.badge.neutral{background:var(--grey);color:var(--slate)}
.badge.neutral .d{background:var(--slate)}

/* indic banner */
.indic{display:flex;align-items:flex-start;gap:10px;background:var(--amber-bg);border:1px solid var(--amber);border-radius:12px;padding:12px 14px;font-size:12px;font-weight:500;color:#925707}
.indic .b{width:20px;height:20px;border-radius:50%;background:var(--amber);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex:0 0 20px}

/* ===== Questionnaire (wizard) ===== */
.stepper{display:flex;align-items:center;gap:0}
.step{display:flex;align-items:center;gap:8px}
.step .n{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;border:1px solid var(--line);background:#fff;color:var(--slate2)}
.step.active .n{background:linear-gradient(135deg,var(--blue),var(--green2));color:#fff;border:0}
.step.done .n{background:var(--green2);color:#fff;border:0}
.step .lb{font-size:13px;font-weight:500;color:var(--slate2)}
.step.active .lb,.step.done .lb{color:var(--ink)}
.step.active .lb{font-weight:600}
.step__line{flex:1;height:2px;background:var(--line);margin:0 8px;min-width:24px}
.q-title{font-size:16px;font-weight:700;color:var(--ink);margin:0}
.choices{display:flex;gap:14px;flex-wrap:wrap}
.choice{flex:1;min-width:220px;border:1px solid var(--line);border-radius:12px;padding:16px;cursor:pointer;background:#fff;display:flex;flex-direction:column;gap:6px}
.choice.sel{border:2px solid var(--blue);background:var(--bg-blue);padding:15px}
.choice .ct{display:flex;align-items:center;justify-content:space-between}
.choice .t{font-size:15px;font-weight:700;color:var(--ink)}
.choice.sel .t{color:var(--blue)}
.choice .d{font-size:12.5px;color:var(--slate)}
.choice .rd{width:20px;height:20px;border-radius:50%;border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center}
.choice.sel .rd{background:var(--blue);border-color:var(--blue);color:#fff;font-size:11px}
.fieldlbl{font-size:13px;font-weight:600;color:var(--ink);display:block;margin-bottom:7px}
textarea.input,input.input,select.input{width:100%;border:1px solid var(--line);border-radius:10px;padding:12px 14px;font-size:14px;font-family:inherit;color:var(--ink);background:#fff;outline:none}
textarea.input:focus,input.input:focus,select.input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.toggle-row{display:flex;align-items:center;justify-content:space-between;border:1px solid var(--line);border-radius:10px;padding:12px 14px;font-size:13px;color:var(--ink);font-weight:500}
.tg{width:40px;height:22px;border-radius:99px;background:var(--line);position:relative;cursor:pointer;flex:0 0 40px;transition:background .15s}
.tg.on{background:var(--green2)}
.tg .k{width:18px;height:18px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:left .15s}
.tg.on .k{left:20px}
.wizard-foot{display:flex;align-items:center;justify-content:space-between;gap:10px}

/* fiche */
.kv-list{display:flex;flex-direction:column}
.kv-list .r{display:flex;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px solid var(--line);font-size:13px}
.kv-list .r:last-child{border-bottom:0}
.kv-list .k{color:var(--slate);font-weight:500}
.kv-list .v{color:var(--ink);font-weight:600;text-align:right}
.cols2{display:flex;gap:16px;align-items:flex-start;flex-wrap:wrap}
.cols2>*{flex:1;min-width:280px}
.tag-soft{display:inline-flex;align-items:center;gap:6px;background:var(--grey);color:var(--slate);padding:5px 10px;border-radius:99px;font-size:11px;font-weight:600}

/* ===================== M6 — Dashboard / Coffre / Dossier ===================== */
.grid-stats{display:flex;gap:16px;flex-wrap:wrap}
.stat{flex:1;min-width:180px;background:rgba(255,255,255,.92);border:1px solid var(--line);border-radius:16px;box-shadow:0 18px 40px -20px rgba(15,23,42,.10);padding:18px}
.stat .chip{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:8px}
.stat .chip .d{width:10px;height:10px;border-radius:50%}
.stat .v{font-size:28px;font-weight:700;color:var(--ink);line-height:1}
.stat .l{font-size:12px;color:var(--slate);margin-top:4px}
.cols-dash{display:flex;gap:16px;flex-wrap:wrap;align-items:stretch}
.cols-dash>.panel{flex:1;min-width:300px}
.gauge{width:150px;height:150px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;flex:0 0 150px}
.gauge::before{content:'';position:absolute;inset:15px;background:#fff;border-radius:50%}
.gauge .val{position:relative;font-size:30px;font-weight:700;color:var(--ink)}
.legend{display:flex;flex-direction:column;gap:10px;flex:1}
.legend .r{display:flex;align-items:center;gap:8px;font-size:13px}
.legend .r .d{width:9px;height:9px;border-radius:50%}
.legend .r .k{flex:1;color:var(--slate)}
.legend .r .v{font-weight:600;color:var(--ink)}
.alert-row{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:10px;padding:11px 12px}
.alert-row .t{flex:1;font-size:12.5px;color:var(--ink)}

/* dropzone */
.dropzone{border:1.5px dashed var(--blue2);border-radius:14px;padding:28px;text-align:center;background:rgba(255,255,255,.6)}
.dropzone .ic{width:46px;height:46px;border-radius:12px;background:var(--bg-blue);color:var(--blue);display:flex;align-items:center;justify-content:center;font-size:20px;margin:0 auto 10px}
.dropzone .t1{font-size:14px;font-weight:600;color:var(--ink)}
.dropzone .t2{font-size:12px;color:var(--slate);margin-top:2px}
.file-ic{width:28px;height:28px;border-radius:7px;background:var(--bg-blue);color:var(--blue);display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;margin-right:10px;vertical-align:middle}

/* médaille label */
.medallion{width:150px;height:150px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;flex:0 0 150px;margin:0 auto}
.medallion::before{content:'';position:absolute;inset:13px;background:#fff;border-radius:50%}
.medallion .g{position:relative;font-size:44px;font-weight:700;color:var(--ink);line-height:1}
.medallion .s{position:relative;font-size:13px;font-weight:600;color:var(--green2);margin-top:2px}
.pill-amber{display:inline-flex;align-items:center;gap:6px;background:var(--amber-bg);color:#925707;border-radius:99px;padding:6px 12px;font-size:11.5px;font-weight:600}
.pill-amber .d{width:7px;height:7px;border-radius:50%;background:var(--amber)}
.sec-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--line);font-size:13px;color:var(--ink)}
.sec-row:last-child{border-bottom:0}
.sec-row .c{width:18px;height:18px;border-radius:50%;background:var(--green2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex:0 0 18px}

/* impression dossier PDF */
@media print{
  .scene__grid,.halo,.sidebar,.topbar,.no-print{display:none !important}
  .scene{background:#fff !important;padding:0 !important}
  .app,.main,.content{display:block !important;padding:0 !important}
  .panel{box-shadow:none !important;border:1px solid #ddd !important;break-inside:avoid}
  body{background:#fff !important}
}

/* ---------- Thème Module RGPD (violet) ---------- */
body[data-theme="rgpd"]{--blue:#7C3AED; --blue2:#8B5CF6; --violet:#7C3AED}
body[data-theme="rgpd"] .nav a.active{background:rgba(124,58,237,.10);color:#7C3AED}
body[data-theme="rgpd"] .nav a.active .ic{background:#7C3AED}
body[data-theme="rgpd"] .btn-primary{background:linear-gradient(90deg,#7C3AED,#8B5CF6);box-shadow:0 8px 18px -6px rgba(124,58,237,.35)}
body[data-theme="rgpd"] .chip.active{background:#7C3AED;border-color:#7C3AED}
body[data-theme="rgpd"] .halo--1{background:rgba(124,58,237,.22)}
body[data-theme="rgpd"] .halo--2{background:rgba(139,92,246,.18)}
body[data-theme="rgpd"] .user-card .av{background:linear-gradient(135deg,#8B5CF6,#7C3AED)}

/* ---------- Sélecteur de module (AI Act / RGPD) ---------- */
.module-switch{display:flex;gap:4px;background:rgba(15,23,42,.05);border:1px solid var(--line);border-radius:10px;padding:4px;margin:2px 0 12px}
.module-switch a{flex:1;text-align:center;font-size:12.5px;font-weight:700;padding:8px 6px;border-radius:7px;color:var(--slate);text-decoration:none;transition:background .12s}
.module-switch a:hover{color:var(--ink)}
.module-switch a.active{background:#fff;color:#2563EB;box-shadow:0 1px 3px rgba(15,23,42,.14)}
.module-switch a.active.rgpd{color:#7C3AED}

/* ---------- Encadré d'aide en haut de page ---------- */
.page-guide{background:rgba(37,99,235,.05);border:1px solid rgba(37,99,235,.16);border-radius:14px;margin-bottom:18px;overflow:hidden}
body[data-theme="rgpd"] .page-guide{background:rgba(124,58,237,.06);border-color:rgba(124,58,237,.2)}
.page-guide .pg-head{display:flex;align-items:center;gap:10px;width:100%;background:none;border:0;cursor:pointer;padding:13px 16px;font-family:inherit;font-size:13.5px;font-weight:700;color:var(--ink)}
.page-guide .pg-ico{font-size:16px}
.page-guide .pg-title{flex:1;text-align:left}
.page-guide .pg-chev{color:var(--slate2);transition:transform .15s}
.page-guide.collapsed .pg-chev{transform:rotate(-90deg)}
.page-guide .pg-body{padding:0 16px 14px 42px;font-size:13.5px;color:var(--ink);line-height:1.55}
.page-guide.collapsed .pg-body{display:none}
.page-guide .pg-body p{margin:0 0 8px}
.page-guide .pg-steps-label{font-size:12px;font-weight:700;color:var(--slate);text-transform:uppercase;letter-spacing:.02em;margin-bottom:2px}
.page-guide .pg-body ol{margin:0 0 8px;padding-left:18px}
.page-guide .pg-body li{margin-bottom:3px;color:var(--slate)}
.page-guide .pg-ex{color:var(--slate);font-size:12.5px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:8px 10px;margin:0}
