/* ─── RISQAI App — Page CSS ────────────────────────────────────────────────
   Niveau 3 du design system : styles spécifiques à risqai-app.html
   Cascade : tokens.css → components.css → pages/app.css
   ─────────────────────────────────────────────────────────────────────────── */

/* ── Alias de tokens manquants (non définis dans tokens.css) ────────────── */
:root {
  --blue:       var(--primary,       #1E40AF);
  --blue-light: var(--primary-light, #EFF6FF);
  --blue-mid:   var(--primary-mid,   #BFDBFE);
  --green:      var(--success,       #16A34A);
  --green-l:    var(--success-light, #F0FDF4);
  --amber:      #D97706;
  --amber-l:    #FFFBEB;
  --orange:     #EA580C;
  --orange-l:   #FFF7ED;
  --red:        var(--error,         #DC2626);
  --red-l:      var(--error-light,   #FEF2F2);
  --white:      #FFFFFF;
  --ink:        var(--text-primary,  #18181B);
  --ink-70:     var(--text-secondary,#52525B);
  --ink-40:     var(--text-muted,    #71717A);
  --ink-15:     rgba(24,24,27,.15);
  --sans:       var(--font-body,     'Inter',system-ui,sans-serif);
  --serif:      var(--font-heading,  'Sora',sans-serif);
  --r-md:       var(--radius-md,     8px);
  --r-lg:       var(--radius-lg,     12px);
}

/* ── Layout ─────────────────────────────────────────────────────────────────── */
.app-frame { display:flex; flex-direction:column; min-height:100vh; background:var(--bg,#F4F4F5); }
.main-content { display:flex; flex:1; overflow:hidden; }
.view { display:none; }

/* ── Topbar ─────────────────────────────────────────────────────────────────── */
.topbar { display:flex; align-items:center; gap:12px; height:var(--nav-height,64px); padding:0 24px; background:var(--surface); border-bottom:1px solid var(--border); position:sticky; top:0; z-index:30; }
.topbar-logo { display:flex; align-items:center; gap:10px; font-weight:700; font-family:var(--serif); font-size:18px; }
.logo-mark { display:grid; place-items:center; }
.logo-text { font-family:var(--serif); font-weight:700; }
.topbar-center { flex:1; }
.topbar-search { display:flex; align-items:center; gap:8px; max-width:360px; background:var(--bg); border:1px solid var(--border); border-radius:var(--radius-full); padding:8px 14px; font-size:14px; color:var(--ink-40); }
.topbar-right { display:flex; align-items:center; gap:12px; margin-left:auto; }
.topbar-alert-btn { position:relative; background:none; border:none; cursor:pointer; padding:6px; border-radius:var(--r-md); color:var(--ink-70); }
.topbar-alert-btn:hover { background:var(--bg); }
.alert-dot { position:absolute; top:4px; right:4px; width:8px; height:8px; border-radius:50%; background:var(--red); border:2px solid var(--surface); }
.nav-badge { display:inline-flex; align-items:center; justify-content:center; min-width:18px; height:18px; border-radius:9px; padding:0 5px; background:var(--red); color:#fff; font-size:11px; font-weight:600; }
.user-avatar { width:36px; height:36px; border-radius:50%; background:var(--blue); color:#fff; display:grid; place-items:center; font-size:14px; font-weight:600; cursor:pointer; }
.user-name { font-size:14px; font-weight:500; }
.user-plan { font-size:11px; font-weight:600; padding:2px 8px; border-radius:var(--radius-full); background:var(--blue-light); color:var(--blue); }

/* ── Sidebar ─────────────────────────────────────────────────────────────────── */
.sidebar { width:240px; flex:none; background:var(--surface); border-right:1px solid var(--border); padding:16px 8px; display:flex; flex-direction:column; gap:2px; overflow-y:auto; }
.sidebar-section { font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.07em; color:var(--ink-40); padding:12px 12px 6px; }
.sidebar-score-card { background:var(--blue-light); border-radius:var(--r-lg); padding:14px; margin:6px 4px 12px; }
.nav-item { display:flex; align-items:center; gap:10px; width:100%; padding:9px 12px; border-radius:var(--r-md); border:none; background:none; cursor:pointer; font-size:14px; font-weight:500; color:var(--ink-70); text-align:left; transition:background .15s,color .15s; }
.nav-item:hover { background:var(--bg); color:var(--ink); }
.nav-item.active { background:var(--blue-light); color:var(--blue); }
.nav-icon { font-size:16px; flex:none; }

/* ── Score sidebar ──────────────────────────────────────────────────────────── */
.ssc-ring-wrap { position:relative; width:72px; height:72px; margin:0 auto 10px; }
.ssc-ring { width:72px; height:72px; border-radius:50%; }
.ssc-inner { position:absolute; inset:8px; background:var(--surface); border-radius:50%; display:grid; place-items:center; }
.ssc-num { font-family:var(--serif); font-size:18px; font-weight:700; }
.ssc-label { font-size:12px; color:var(--ink-40); margin-top:4px; text-align:center; }
.ssc-risk { font-size:11px; font-weight:600; text-align:center; margin-top:4px; }

/* ── Panels ──────────────────────────────────────────────────────────────────── */
.panel { flex:1; overflow-y:auto; }
.page-inner { max-width:1000px; margin:0 auto; padding:28px 24px 60px; }
.page-header { margin-bottom:24px; }
.page-title { font-family:var(--serif); font-size:clamp(22px,3vw,30px); font-weight:700; margin:0 0 6px; }
.page-sub { font-size:14px; color:var(--ink-40); margin:0; }

/* ── Cards ──────────────────────────────────────────────────────────────────── */
.card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); padding:20px; box-shadow:var(--shadow-sm); }
.card-title { font-size:15px; font-weight:600; margin-bottom:14px; }

/* ── KPI Grid ───────────────────────────────────────────────────────────────── */
.kpi-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:14px; margin-bottom:22px; }
.kpi-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); padding:18px; box-shadow:var(--shadow-sm); }
.kpi-label { font-size:12px; color:var(--ink-40); margin-bottom:8px; text-transform:uppercase; letter-spacing:.05em; }
.kpi-value { font-family:var(--serif); font-size:28px; font-weight:700; line-height:1; }
.kpi-sub { font-size:12px; color:var(--ink-40); margin-top:6px; }
.kpi-trend { font-size:12px; font-weight:600; }

/* ── Dashboard ──────────────────────────────────────────────────────────────── */
.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
.db-score-donut { width:100px; height:100px; border-radius:50%; position:relative; flex:none; }
.db-score-inner { position:absolute; inset:10px; background:var(--surface); border-radius:50%; display:grid; place-items:center; text-align:center; }
.db-score-n { font-family:var(--serif); font-size:22px; font-weight:700; }
.db-score-max { font-size:11px; color:var(--ink-40); }
.db-action-item { display:flex; align-items:flex-start; gap:10px; padding:10px 0; border-top:1px solid var(--border); }
.db-action-item:first-child { border-top:0; }
.db-action-cb { width:18px; height:18px; border-radius:4px; border:2px solid var(--border); flex:none; cursor:pointer; }
.db-action-text { font-size:14px; }
.db-alert-item { display:flex; align-items:flex-start; gap:10px; padding:10px 0; border-top:1px solid var(--border); }
.db-alert-item:first-child { border-top:0; }
.db-adot { width:8px; height:8px; border-radius:50%; flex:none; margin-top:5px; }
.db-atext { font-size:14px; font-weight:500; }
.db-adate { font-size:12px; color:var(--ink-40); }
.progress-wrap { background:var(--bg); border-radius:999px; height:6px; overflow:hidden; }
.progress-fill { height:100%; border-radius:999px; background:var(--blue); transition:width .4s; }
.dim-rows { display:flex; flex-direction:column; gap:8px; }
.dim-row { display:flex; align-items:center; gap:10px; }
.dim-title { font-size:13px; color:var(--ink-70); min-width:140px; }
.dr-bg { flex:1; background:var(--bg); border-radius:999px; height:8px; overflow:hidden; }
.dr-fill { height:100%; border-radius:999px; }
.dr-pct { font-size:12px; color:var(--ink-40); min-width:36px; text-align:right; }
.dr-name { display:none; }

/* ── Tags & Badges ──────────────────────────────────────────────────────────── */
.tag { display:inline-flex; align-items:center; gap:5px; font-size:11px; font-weight:600; padding:3px 9px; border-radius:var(--radius-full); background:var(--bg); color:var(--ink-70); }
.tag-blue   { background:var(--blue-light); color:var(--blue); }
.tag-green  { background:var(--green-l); color:var(--green); }
.tag-orange { background:var(--orange-l); color:var(--orange); }
.tag-red    { background:var(--red-l); color:var(--red); }
.tag-gray   { background:var(--bg); color:var(--ink-40); }
.stat-pill  { padding:4px 12px; border-radius:var(--radius-full); font-size:12px; font-weight:600; }
.risk-badge { display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:600; padding:4px 10px; border-radius:var(--radius-full); }
.risk-low      { background:var(--green-l); color:var(--green); }
.risk-medium   { background:var(--amber-l); color:var(--amber); }
.risk-high     { background:var(--orange-l); color:var(--orange); }
.risk-critical { background:var(--red-l); color:var(--red); }
.pop-pill { display:inline-flex; padding:2px 8px; border-radius:var(--radius-full); background:var(--blue); color:#fff; font-size:10px; font-weight:700; margin-left:6px; vertical-align:middle; }
.stag { font-size:11px; font-weight:600; padding:2px 8px; border-radius:var(--radius-full); background:var(--bg); color:var(--ink-40); }

/* ── Buttons supplémentaires ────────────────────────────────────────────────── */
.btn-secondary { background:var(--bg); border:1px solid var(--border); color:var(--ink); padding:10px 18px; border-radius:var(--r-md); font:inherit; font-size:14px; font-weight:500; cursor:pointer; }
.btn-secondary:hover { border-color:var(--ink); }
.btn-danger { background:var(--red); color:#fff; border:none; padding:10px 18px; border-radius:var(--r-md); font:inherit; font-weight:600; cursor:pointer; }
.btn-lg { padding:13px 24px; font-size:16px; border-radius:var(--r-lg); }
.btn-xl { padding:16px 32px; font-size:18px; border-radius:var(--r-lg); }
.outline { background:transparent; border:2px solid currentColor; }
.ls { letter-spacing:.02em; }
.ls-blue { color:var(--blue); }
.ls-dark { color:var(--ink); }
.ls-white { color:#fff; }
.green { color:var(--green); }
.trend-up { color:var(--green); font-weight:600; }

/* ── Forms ──────────────────────────────────────────────────────────────────── */
.form-hint { font-size:12px; color:var(--ink-40); margin-top:4px; }
.form-select { width:100%; padding:10px 12px; border:1px solid var(--border); border-radius:var(--r-md); background:var(--surface); font:inherit; font-size:14px; color:var(--ink); cursor:pointer; }
.form-select:focus { outline:2px solid var(--blue); outline-offset:2px; }

/* ── Toggle ─────────────────────────────────────────────────────────────────── */
.toggle-row { display:flex; align-items:center; gap:12px; padding:12px 0; border-top:1px solid var(--border); }
.toggle-row:first-child { border-top:0; }
.toggle { position:relative; width:40px; height:22px; flex:none; }
.toggle input { opacity:0; width:0; height:0; position:absolute; }
.toggle-slider { position:absolute; inset:0; background:var(--border); border-radius:999px; cursor:pointer; transition:.2s; }
.toggle-slider::before { content:''; position:absolute; height:16px; width:16px; left:3px; bottom:3px; background:#fff; border-radius:50%; transition:.2s; }
.toggle input:checked + .toggle-slider { background:var(--blue); }
.toggle input:checked + .toggle-slider::before { transform:translateX(18px); }
.toggle-info { flex:1; }
.toggle-sub { font-size:12px; color:var(--ink-40); }

/* ── Registre ───────────────────────────────────────────────────────────────── */
.reg-toolbar { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:14px; }
.reg-search { display:flex; align-items:center; gap:8px; flex:1; min-width:180px; background:var(--surface); border:1px solid var(--border); border-radius:var(--r-md); padding:8px 12px; font-size:14px; }
.reg-search input { border:none; background:none; outline:none; font:inherit; flex:1; }
.reg-filter { padding:8px 12px; border:1px solid var(--border); border-radius:var(--r-md); font:inherit; font-size:13px; background:var(--surface); cursor:pointer; }
.reg-table-wrap { overflow-x:auto; border:1px solid var(--border); border-radius:var(--r-lg); }
.reg-table { width:100%; border-collapse:collapse; font-size:13.5px; }
.reg-table th { text-align:left; font-size:11.5px; font-weight:600; text-transform:uppercase; letter-spacing:.05em; color:var(--ink-40); padding:10px 12px; background:var(--bg); border-bottom:1px solid var(--border); }
.reg-table td { padding:10px 12px; border-top:1px solid var(--border); vertical-align:middle; }
.reg-table td[contenteditable="true"]:focus { background:var(--blue-light); outline:none; }
.reg-del { background:none; border:none; cursor:pointer; color:var(--ink-40); font-size:16px; padding:4px 8px; border-radius:var(--r-md); }
.reg-del:hover { color:var(--red); background:var(--red-l); }
.add-row-btn { width:100%; margin-top:10px; padding:10px; border:2px dashed var(--border); border-radius:var(--r-md); background:none; font:inherit; font-size:13.5px; color:var(--ink-40); cursor:pointer; }
.add-row-btn:hover { border-color:var(--blue); color:var(--blue); background:var(--blue-light); }

/* ── Documents ──────────────────────────────────────────────────────────────── */
.docs-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:14px; margin-bottom:24px; }
.doc-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); padding:18px; display:flex; align-items:center; gap:14px; box-shadow:var(--shadow-sm); }
.doc-ico { font-size:28px; flex:none; }
.doc-info { flex:1; }
.doc-name { font-size:14px; font-weight:600; margin-bottom:4px; }
.doc-desc { font-size:12px; color:var(--ink-40); }
.doc-meta { margin-top:6px; }
.doc-dl-btn { flex:none; background:var(--blue); color:#fff; border:none; border-radius:var(--r-md); padding:8px 14px; font:inherit; font-size:13px; font-weight:500; cursor:pointer; }
.doc-dl-btn:hover { background:var(--primary-hover,#1E3A8A); }
.doc-dl-btn:disabled { background:var(--border); cursor:progress; }

/* ── Checklist ──────────────────────────────────────────────────────────────── */
.cl-section { margin-bottom:28px; }
.cl-section-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; flex-wrap:wrap; gap:8px; }
.cl-section-title { font-size:15px; font-weight:600; }
.cl-section-freq { font-size:12px; color:var(--ink-40); }
.cl-progress-text { font-size:12px; color:var(--ink-40); }
.cl-items { display:flex; flex-direction:column; gap:1px; }
.cl-item { display:flex; align-items:center; gap:12px; padding:12px 14px; background:var(--surface); border:1px solid var(--border); border-radius:var(--r-md); cursor:pointer; transition:background .15s; }
.cl-item:hover { background:var(--bg); }
.cl-item.done .cl-item-text { text-decoration:line-through; opacity:.65; }
.cl-cb { width:20px; height:20px; border-radius:6px; border:2px solid var(--border); flex:none; display:grid; place-items:center; background:var(--surface); }
.cl-item.done .cl-cb { background:var(--blue); border-color:var(--blue); }
.cl-item-info { flex:1; }
.cl-item-text { font-size:14px; }
.cl-item-cat { font-size:11px; color:var(--ink-40); margin-top:3px; }

/* ── Alertes ─────────────────────────────────────────────────────────────────── */
.alert-card { display:flex; align-items:flex-start; gap:14px; padding:16px; background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); margin-bottom:10px; }
.alert-card.unread { border-left:3px solid var(--blue); }
.alert-card.critical { border-left-color:var(--red); }
.alert-card.warning { border-left-color:var(--orange); }
.alert-ico { width:40px; height:40px; border-radius:var(--r-md); display:grid; place-items:center; font-size:20px; flex:none; background:var(--blue-light); }
.alert-content { flex:1; }
.alert-title { font-size:14px; font-weight:600; margin-bottom:4px; }
.alert-body { font-size:13px; color:var(--ink-70); line-height:1.55; }
.alert-meta { display:flex; align-items:center; gap:8px; margin-top:8px; flex-wrap:wrap; }
.alert-mark-read { flex:none; background:none; border:1px solid var(--border); border-radius:var(--r-md); padding:5px 12px; font:inherit; font-size:12px; cursor:pointer; color:var(--ink-70); }
.alert-mark-read:hover { border-color:var(--blue); color:var(--blue); }

/* ── Chat assistant ──────────────────────────────────────────────────────────── */
.ast-layout { display:flex; height:calc(100vh - var(--nav-height,64px)); overflow:hidden; }
.ast-sidebar { width:260px; flex:none; border-right:1px solid var(--border); background:var(--surface); padding:14px; display:flex; flex-direction:column; gap:8px; overflow-y:auto; }
.ast-main { flex:1; display:flex; flex-direction:column; overflow:hidden; }
.ast-topbar { display:flex; align-items:center; gap:12px; padding:14px 20px; border-bottom:1px solid var(--border); }
.ast-agent { display:flex; align-items:center; gap:10px; }
.ast-avatar-wrap { position:relative; }
.ast-avatar { width:36px; height:36px; border-radius:50%; background:var(--blue-light); display:grid; place-items:center; font-size:18px; }
.ast-online-dot { position:absolute; bottom:0; right:0; width:10px; height:10px; border-radius:50%; background:var(--green); border:2px solid var(--surface); }
.ast-agent-name { font-weight:600; font-size:15px; }
.ast-agent-status { font-size:12px; color:var(--ink-40); }
.ast-ctx-strip { display:flex; align-items:center; gap:8px; padding:8px 20px; background:var(--bg); border-bottom:1px solid var(--border); font-size:13px; flex-wrap:wrap; }
.ast-ctx-label { color:var(--ink-40); }
.ast-sdot { width:8px; height:8px; border-radius:50%; flex:none; }
.ast-messages { flex:1; overflow-y:auto; padding:20px; display:flex; flex-direction:column; gap:16px; }
.ast-bw { display:flex; gap:10px; max-width:82%; }
.ast-bw.usr { align-self:flex-end; flex-direction:row-reverse; }
.ast-msg-av { width:32px; height:32px; border-radius:50%; background:var(--blue-light); display:grid; place-items:center; font-size:14px; flex:none; }
.ast-bubble { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); padding:12px 16px; font-size:14.5px; line-height:1.6; }
.ast-bw.usr .ast-bubble { background:var(--blue); color:#fff; border-color:var(--blue); }
.ast-ts { font-size:11px; color:var(--ink-40); text-align:right; margin-top:4px; }
.ast-typing { display:flex; gap:4px; align-items:center; padding:14px 16px; }
.ast-dot { width:7px; height:7px; border-radius:50%; background:var(--ink-40); animation:typing .9s infinite; }
.ast-dot:nth-child(2) { animation-delay:.2s; }
.ast-dot:nth-child(3) { animation-delay:.4s; }
@keyframes typing { 0%,60%,100%{opacity:.3;transform:scale(.8)} 30%{opacity:1;transform:scale(1)} }
.ast-input-area { border-top:1px solid var(--border); padding:14px 20px; background:var(--surface); }
.ast-input-row { display:flex; align-items:flex-end; gap:10px; }
.ast-ta { flex:1; resize:none; border:1px solid var(--border); border-radius:var(--r-lg); padding:10px 14px; font:inherit; font-size:14.5px; max-height:120px; overflow-y:auto; }
.ast-ta:focus { outline:2px solid var(--blue); outline-offset:2px; }
.ast-send { width:40px; height:40px; border-radius:50%; background:var(--blue); border:none; cursor:pointer; color:#fff; display:grid; place-items:center; flex:none; }
.ast-send:hover { background:var(--primary-hover,#1E3A8A); }
.ast-send:disabled { background:var(--border); cursor:not-allowed; }
.ast-sug-wrap { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:10px; }
.ast-sug-btn { background:var(--blue-light); border:1px solid var(--blue-mid,#BFDBFE); border-radius:var(--radius-full); padding:6px 12px; font:inherit; font-size:12.5px; color:var(--blue); cursor:pointer; }
.ast-sug-btn:hover { background:var(--blue); color:#fff; }
.ast-hint-text { font-size:12px; color:var(--ink-40); text-align:center; margin-top:6px; }
.idle { font-size:13px; color:var(--ink-40); }

/* ── Markdown assistant ─────────────────────────────────────────────────────── */
.ast-md { line-height:1.65; }
.md-h2 { font-size:15px; font-weight:700; margin:14px 0 6px; }
.md-h3 { font-size:14px; font-weight:600; margin:12px 0 4px; }
.md-bull,.md-num { display:flex; gap:8px; margin:4px 0; }
.md-bd { font-weight:600; }
.md-nb { background:var(--bg); border-radius:6px; padding:10px 12px; font-size:13px; font-family:monospace; margin:6px 0; }

/* ── Action cards ───────────────────────────────────────────────────────────── */
.acard-wrap { display:flex; flex-direction:column; gap:12px; }
.acard-head { display:flex; align-items:center; gap:10px; margin-bottom:6px; }
.acard-tool-name { font-weight:700; font-size:15px; }
.acard-body,.acard-section-label,.acard-explain,.acard-rule-text,.acard-hint,.acard-usage { font-size:13.5px; color:var(--ink-70); }
.acard-rule { background:var(--blue-light); border-radius:var(--r-md); padding:10px 12px; margin:8px 0; }
.acard-actions-list { display:flex; flex-direction:column; gap:6px; }
.acard-action-row { display:flex; gap:8px; font-size:13px; }
.acard-a-num { color:var(--blue); font-weight:700; min-width:18px; }
.acard-mention-box { background:var(--bg); border-radius:var(--r-md); padding:10px 12px; font-size:13px; font-style:italic; margin:8px 0; }
.acard-mention-copy { background:none; border:1px solid var(--border); border-radius:var(--r-md); padding:5px 12px; font:inherit; font-size:12px; cursor:pointer; }
.acard-footer { display:flex; gap:8px; flex-wrap:wrap; }
.acard-add-btn { background:var(--blue); color:#fff; border:none; border-radius:var(--r-md); padding:7px 14px; font:inherit; font-size:13px; font-weight:500; cursor:pointer; }

/* ── Actions / Risques ──────────────────────────────────────────────────────── */
.action-item { display:flex; align-items:flex-start; gap:10px; padding:12px 0; border-top:1px solid var(--border); }
.action-item:first-child { border-top:0; }
.ri-dot { width:8px; height:8px; border-radius:50%; flex:none; margin-top:5px; }
.risk-item { display:flex; gap:10px; padding:10px 0; border-top:1px solid var(--border); }
.risk-item:first-child { border-top:0; }
.risk-section-title { font-size:13px; font-weight:600; text-transform:uppercase; letter-spacing:.05em; color:var(--ink-40); margin:16px 0 8px; }
.risk-expose { display:flex; flex-direction:column; gap:2px; }

/* ── Quiz interne ───────────────────────────────────────────────────────────── */
.quiz-container { max-width:720px; margin:0 auto; padding:40px 24px 80px; }
.quiz-header { text-align:center; margin-bottom:32px; }
.quiz-title { font-family:var(--serif); font-size:28px; font-weight:700; margin-bottom:8px; }
.quiz-sub { color:var(--ink-70); font-size:15px; }
.quiz-prog-wrap { margin-bottom:28px; }
.quiz-prog-bg { height:6px; background:var(--bg); border-radius:999px; overflow:hidden; }
.quiz-prog-fill { height:100%; background:var(--blue); border-radius:999px; transition:width .4s; }
.quiz-step-lbl { font-size:12px; color:var(--ink-40); text-align:right; margin-top:6px; }
.q-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); padding:28px; box-shadow:var(--shadow-sm); margin-bottom:20px; }
.q-section-tag { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--blue); margin-bottom:10px; }
.q-text { font-size:17px; font-weight:600; margin-bottom:6px; }
.q-hint { font-size:13px; color:var(--ink-40); margin-bottom:18px; }
.q-opts { display:flex; flex-direction:column; gap:8px; }
.q-nav { display:flex; justify-content:space-between; gap:10px; }
.q-opt-check { width:18px; height:18px; border-radius:50%; border:2px solid var(--border); flex:none; display:grid; place-items:center; }

/* ── Résultats quiz ─────────────────────────────────────────────────────────── */
.results-container { max-width:760px; margin:0 auto; padding:40px 24px; }
.res-main-card { background:var(--surface); border:2px solid var(--border); border-radius:var(--r-lg); padding:32px; text-align:center; margin-bottom:24px; }
.res-top { display:flex; align-items:center; justify-content:center; gap:20px; flex-wrap:wrap; margin-bottom:20px; }
.res-circle { width:90px; height:90px; border-radius:50%; border:5px solid var(--orange); display:grid; place-items:center; }
.res-pct { font-family:var(--serif); font-size:32px; font-weight:700; }
.res-badge { display:inline-flex; align-items:center; gap:8px; padding:6px 16px; border-radius:var(--radius-full); font-weight:700; font-size:14px; }
.res-title { font-family:var(--serif); font-size:22px; font-weight:700; margin:8px 0; }
.res-info { font-size:15px; color:var(--ink-70); max-width:48ch; }
.res-cta-box { background:var(--blue-light); border-radius:var(--r-lg); padding:20px; text-align:center; margin-top:24px; }
.res-cta-text { font-size:15px; color:var(--blue); margin-bottom:12px; font-weight:500; }

/* ── Landing / Marketing ────────────────────────────────────────────────────── */
.hero { padding:80px 24px 60px; max-width:920px; margin:0 auto; text-align:center; }
.hero-eyebrow { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.12em; color:var(--blue); margin-bottom:16px; }
.hero-title { font-family:var(--serif); font-size:clamp(30px,5vw,52px); font-weight:800; line-height:1.05; margin-bottom:18px; }
.hero-body { font-size:18px; color:var(--ink-70); max-width:52ch; margin:0 auto 28px; }
.hero-actions { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.hero-proof { display:flex; gap:20px; justify-content:center; margin-top:20px; flex-wrap:wrap; font-size:13px; color:var(--ink-40); }
.hero-mockup { max-width:800px; margin:40px auto 0; }
.proof-item { display:flex; align-items:center; gap:6px; }
.proof-sep { color:var(--border); }
.prob-list { display:flex; flex-direction:column; gap:10px; max-width:600px; margin:0 auto; }
.prob-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.prob-item { display:flex; align-items:flex-start; gap:12px; background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); padding:16px; }
.prob-ico { font-size:22px; flex:none; }
.prob-t { font-size:14px; font-weight:600; margin-bottom:4px; }
.prob-d { font-size:13px; color:var(--ink-40); }
.proc-steps { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:16px; }
.proc-step { text-align:center; padding:20px 14px; }
.law-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); padding:20px; margin-bottom:12px; }
.law-row { display:flex; align-items:flex-start; gap:12px; }
.law-dot { width:10px; height:10px; border-radius:50%; background:var(--orange); flex:none; margin-top:4px; }
.law-tl { font-size:13px; font-weight:700; color:var(--ink-40); margin-bottom:4px; }
.law-ct { font-size:15px; font-weight:600; margin-bottom:6px; }
.law-desc { font-size:13px; color:var(--ink-70); }
.law-date { font-size:11px; font-weight:700; text-transform:uppercase; color:var(--orange); margin-bottom:4px; }
.mods-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:12px; }
.mod-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); padding:18px; }
.mod-ico { font-size:28px; margin-bottom:10px; }
.mod-t { font-size:14px; font-weight:600; margin-bottom:4px; }
.mod-d { font-size:12px; color:var(--ink-40); }
.mod-n { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.05em; color:var(--blue); margin-bottom:6px; }
.mkt-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); padding:20px; }
.mkt-n { font-size:28px; font-weight:800; font-family:var(--serif); color:var(--blue); }
.mkt-s { font-size:13px; color:var(--ink-40); }
.mkt-l { font-size:14px; margin-top:8px; }
.mkt-src { font-size:11px; color:var(--ink-40); margin-top:4px; }

/* ── Pricing ─────────────────────────────────────────────────────────────────── */
.pricing-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:14px; }
.pc { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); padding:22px; display:flex; flex-direction:column; }
.pc.feat { border-color:var(--blue); box-shadow:0 0 0 2px var(--blue-mid,#BFDBFE); }
.pc-tag { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:var(--ink-40); margin-bottom:6px; }
.pc-name { font-family:var(--serif); font-size:20px; font-weight:700; margin-bottom:4px; }
.pc-price { font-size:30px; font-weight:800; font-family:var(--serif); color:var(--blue); }
.pc-period { font-size:12px; color:var(--ink-40); margin-bottom:16px; }
.pc-feats { flex:1; display:flex; flex-direction:column; gap:7px; margin-bottom:18px; }
.pc-feat-item { display:flex; gap:8px; font-size:13px; }
.pc-check { color:var(--green); font-weight:700; flex:none; }
.pc-btn { width:100%; padding:11px; border-radius:var(--r-md); border:1px solid var(--blue); background:var(--blue); color:#fff; font:inherit; font-size:14px; font-weight:600; cursor:pointer; }
.pc-btn:hover { background:var(--primary-hover,#1E3A8A); }

/* ── Navigation landing ─────────────────────────────────────────────────────── */
.landing-nav { display:flex; align-items:center; justify-content:space-between; padding:0 32px; height:64px; background:var(--surface); border-bottom:1px solid var(--border); position:sticky; top:0; z-index:30; }
.lnav-logo { display:flex; align-items:center; gap:10px; font-weight:800; font-size:18px; font-family:var(--serif); }
.lnav-links { display:flex; align-items:center; gap:24px; }
.lnav-link { font-size:14px; color:var(--ink-70); background:none; border:none; cursor:pointer; }
.lnav-link:hover { color:var(--ink); }
.lnav-cta { display:flex; gap:10px; }

/* ── Settings ────────────────────────────────────────────────────────────────── */
.settings-grid { display:grid; grid-template-columns:200px 1fr; gap:20px; }
.settings-nav { display:flex; flex-direction:column; gap:2px; }
.settings-nav-item { padding:9px 12px; border-radius:var(--r-md); font-size:14px; cursor:pointer; color:var(--ink-70); border:none; background:none; text-align:left; }
.settings-nav-item.active { background:var(--blue-light); color:var(--blue); font-weight:500; }
.settings-panel { display:none; }
.settings-panel.active { display:block; }

/* ── Score heatmap ──────────────────────────────────────────────────────────── */
.hm-score-row { display:flex; align-items:center; justify-content:center; gap:16px; flex-wrap:wrap; margin-bottom:16px; }
.hm-circle { width:100px; height:100px; border-radius:50%; display:grid; place-items:center; }
.hm-inner { width:74px; height:74px; border-radius:50%; background:var(--surface); display:grid; place-items:center; text-align:center; }
.hm-n { font-family:var(--serif); font-size:26px; font-weight:800; display:block; }
.hm-d { font-size:11px; }
.hm-level-badge { display:inline-flex; padding:4px 12px; border-radius:var(--radius-full); font-size:13px; font-weight:700; }
.hm-badge { font-size:13px; font-weight:600; }
.hm-note { font-size:13px; color:var(--ink-40); max-width:48ch; margin:0 auto 16px; text-align:center; }
.hm-cta { display:flex; justify-content:center; gap:10px; flex-wrap:wrap; }
.hm-dims { display:flex; flex-direction:column; gap:8px; margin-top:16px; }
.hm-dim { display:flex; align-items:center; gap:10px; font-size:13px; }
.hm-dim-bar { flex:1; height:8px; background:var(--bg); border-radius:999px; overflow:hidden; }
.hm-dim-fill { height:100%; border-radius:999px; }
.hm-dim-name { min-width:130px; color:var(--ink-70); }
.hm-dim-pct { min-width:36px; text-align:right; color:var(--ink-40); }
.hm-tool { font-size:13px; }

/* ── Éléments divers ─────────────────────────────────────────────────────────── */
.trust-q { font-style:italic; font-size:16px; color:var(--ink-70); max-width:52ch; }
.trust-disc { font-size:12px; color:var(--ink-40); margin-top:8px; }
.sp-n { font-family:var(--serif); font-size:22px; font-weight:800; }
.sp-t { font-size:14px; font-weight:600; margin:4px 0 2px; }
.sp-d { font-size:13px; color:var(--ink-40); }
.ps-n { font-family:var(--serif); font-size:22px; font-weight:800; color:var(--blue); }
.ps-t { font-size:14px; font-weight:600; margin:4px 0 2px; }
.ps-d { font-size:13px; color:var(--ink-40); }
.stitle { font-family:var(--serif); font-size:20px; font-weight:700; margin-bottom:4px; }
.ssub { font-size:14px; color:var(--ink-40); }
.ht-accent { color:var(--blue); }
.tgt-tags { display:flex; gap:6px; flex-wrap:wrap; margin-top:8px; }
.tgt-tag { font-size:12px; padding:3px 10px; border-radius:var(--radius-full); background:var(--bg); color:var(--ink-70); }

/* ── Responsive ─────────────────────────────────────────────────────────────── */
@media (max-width:900px) {
  .sidebar { width:60px; }
  .nav-item span:not(.nav-icon) { display:none; }
  .sidebar-score-card,.sidebar-section { display:none; }
  .grid-2,.grid-4,.pricing-grid,.settings-grid { grid-template-columns:1fr; }
  .prob-grid { grid-template-columns:1fr; }
  .ast-sidebar { display:none; }
}
@media (max-width:600px) {
  .page-inner { padding:16px 14px 40px; }
  .topbar { padding:0 14px; }
  .topbar-search { display:none; }
  .docs-grid { grid-template-columns:1fr; }
  .kpi-grid { grid-template-columns:1fr 1fr; }
  .hero { padding:40px 16px 30px; }
}
@media (prefers-reduced-motion:reduce) {
  * { transition:none !important; animation:none !important; }
}
