/* style.css — CyberVeille Pro — Dark theme cybersec */

/* ── Reset & Tokens ─────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:       #0d1117;
  --surface:  #161b22;
  --surface2: #21262d;
  --border:   #30363d;
  --text:     #e6edf3;
  --text2:    #8b949e;
  --accent:   #58a6ff;
  --ok:       #3fb950;    /* LOW */
  --warn:     #f0883e;    /* MEDIUM */
  --err:      #f85149;    /* HIGH */
  --radius:   8px;
  --font:     "JetBrains Mono", "Fira Code", "Consolas", monospace;
  /* Surfaces élevées — dropdowns, modals, cards flottantes */
  --card:     #21262d;   /* = surface2 — fond opaque pour éléments flottants */
  --card1:    #21262d;   /* variante primaire card */
  --card2:    #161b22;   /* variante secondaire card (plus sombre, = surface) */
  --card-bg:  #21262d;   /* fond de panneau/carte */
}

html { font-size: 15px; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ── Demo bar ───────────────────────────────────────────────────────────── */
/* ── Open source top bar ────────────────────────────────────────────────── */
.oss-bar {
  display: flex; align-items: center; gap: .75rem; flex-wrap: wrap;
  background: #0d1117;
  border-bottom: 1px solid #30363d;
  padding: .35rem 1rem;
  font-size: .73rem; color: #8b949e;
}
.oss-bar-text { display: flex; align-items: center; gap: .5rem; flex: 1; }
.oss-badge {
  display: inline-flex; align-items: center;
  background: rgba(63,185,80,.12); color: #3fb950;
  border: 1px solid rgba(63,185,80,.3);
  border-radius: 10px; padding: .1rem .5rem;
  font-size: .68rem; font-weight: 700; letter-spacing: .02em;
  white-space: nowrap;
}
.oss-bar-actions { display: flex; align-items: center; gap: .4rem; }
.oss-btn {
  display: inline-flex; align-items: center; gap: .3rem;
  padding: .2rem .6rem; border-radius: 6px;
  font-size: .72rem; font-weight: 600; text-decoration: none;
  white-space: nowrap; transition: opacity .15s;
}
.oss-btn:hover { opacity: .8; }
.oss-btn-github {
  background: #21262d; color: #e6edf3;
  border: 1px solid #30363d;
}
.oss-btn-deploy {
  background: #000; color: #fff;
  border: 1px solid #333;
}
.oss-dismiss {
  background: none; border: none; color: #484f58; cursor: pointer;
  font-size: .8rem; padding: .1rem .3rem; margin-left: .25rem;
  border-radius: 4px;
}
.oss-dismiss:hover { color: #8b949e; }

/* ── Demo mode bar ──────────────────────────────────────────────────────── */
#demo-bar {
  background: #0d1b2e;
  border-bottom: 1px solid #1f4068;
  padding: .4rem 1rem;
  font-size: .78rem;
  color: #79c0ff;
  display: flex; align-items: center; gap: .75rem; flex-wrap: wrap;
}
.demo-bar-link {
  display: inline-flex; align-items: center; gap: .25rem;
  padding: .15rem .5rem; border-radius: 5px;
  font-size: .72rem; font-weight: 600; text-decoration: none;
  white-space: nowrap; transition: opacity .15s;
  background: #21262d; color: #e6edf3; border: 1px solid #30363d;
}
.demo-bar-link:hover { opacity: .8; }
.demo-bar-link-deploy { background: #000; color: #fff; border-color: #333; }

/* ── Nav bar ────────────────────────────────────────────────────────────── */
.navbar {
  position: sticky; top: 0; z-index: 100;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  padding: .6rem 1rem;
  display: flex; align-items: center; gap: .75rem; flex-wrap: wrap;
}

.navbar-brand {
  display: flex; flex-direction: column; align-items: flex-start; gap: 0;
  white-space: nowrap; margin-right: auto;
}
.navbar-brand-name {
  font-size: 1.15rem; font-weight: 700; color: var(--accent); line-height: 1.2;
}
.navbar-brand-name > span { color: var(--err); }
.navbar-brand-sub {
  font-size: 0.72rem; font-weight: 400; color: var(--muted);
  letter-spacing: 0.04em; opacity: 0.8; line-height: 1;
}

.search-input {
  background: var(--surface2);
  border: 1px solid var(--border);
  color: var(--text);
  border-radius: var(--radius);
  padding: .4rem .75rem;
  font-family: var(--font);
  font-size: .85rem;
  width: 220px;
  transition: border-color .2s;
}
.search-input:focus { outline: none; border-color: var(--accent); }
.search-input::placeholder { color: var(--text2); }

/* ── Search input wrapper + hint ─────────────────────────────────────────── */
.search-input-wrapper {
  display: flex;
  flex-direction: column;
  position: relative;
}

/* ── Search quick-filter chips ──────────────────────────────────────────── */
.search-chips {
  display: flex; flex-wrap: wrap; gap: .3rem;
  margin-top: .3rem;
  transition: opacity .15s ease;
}
.search-chip {
  display: inline-flex; align-items: center;
  font-size: .62rem; font-weight: 600;
  padding: .15rem .5rem;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--surface2, var(--bg2));
  color: var(--text2);
  cursor: pointer;
  transition: all .12s ease;
  white-space: nowrap;
}
.search-chip:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: rgba(88,166,255,.08);
}
.search-chip.active {
  border-color: var(--accent);
  color: var(--accent);
  background: rgba(88,166,255,.15);
}
/* Result count badge on active chip — driven by data-count attribute set in _syncSearchChips() */
.search-chip[data-count]::after {
  content: ' · ' attr(data-count);
  font-size: .58rem;
  font-weight: 700;
  opacity: .75;
}
/* Dim chips only when the search INPUT itself is focused (not when a chip button is focused) */
#search-input:focus ~ .search-chips {
  opacity: .3;
  pointer-events: none;
}

/* ── Recent searches panel ─────────────────────────────────────────────────── */
.recent-searches-panel {
  display: flex;
  flex-direction: column;
  gap: .3rem;
  margin-top: .3rem;
  max-height: 150px;
  overflow-y: auto;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: .3rem;
  pointer-events: auto;
}

.recent-search-btn {
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--text2);
  border-radius: 4px;
  padding: .3rem .5rem;
  font-family: var(--font);
  font-size: .75rem;
  cursor: pointer;
  text-align: left;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: background .1s, color .1s, border-color .1s;
}
.recent-search-btn:hover {
  background: var(--surface2);
  color: var(--accent);
  border-color: var(--accent);
}

.recent-search-item {
  display: flex;
  align-items: center;
  gap: .3rem;
  width: 100%;
}

.recent-search-item .recent-search-btn {
  flex: 1;
  margin: 0;
}

.recent-search-remove {
  background: none;
  border: none;
  color: var(--text2);
  cursor: pointer;
  font-size: .7rem;
  padding: .2rem .3rem;
  opacity: .5;
  flex-shrink: 0;
  transition: color .1s, opacity .1s;
  display: none;
}

.recent-search-item:hover .recent-search-remove {
  display: inline-block;
  opacity: .8;
}

.recent-search-remove:hover {
  opacity: 1;
  color: var(--err);
}

.recent-searches-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: .2rem;
  border-bottom: 1px solid var(--border);
  margin-bottom: .3rem;
  font-size: .7rem;
  opacity: .7;
}

.recent-searches-label {
  font-weight: 600;
  color: var(--text2);
}

.recent-searches-clear {
  background: none;
  border: none;
  color: var(--text2);
  cursor: pointer;
  font-size: .8rem;
  padding: 0;
  opacity: .6;
  transition: color .1s, opacity .1s;
}
.recent-searches-clear:hover {
  opacity: 1;
  color: var(--err);
}

.btn {
  background: var(--surface2);
  border: 1px solid var(--border);
  color: var(--text);
  border-radius: var(--radius);
  padding: .4rem .8rem;
  font-family: var(--font);
  font-size: .8rem;
  cursor: pointer;
  transition: background .2s, border-color .2s;
  white-space: nowrap;
}
.btn:hover { background: var(--border); }
.btn.active { background: var(--accent); color: #000; border-color: var(--accent); }

/* Séparateurs de groupe dans la navbar */
.nav-sep {
  width: 1px;
  height: 1.3rem;
  background: var(--border);
  flex-shrink: 0;
  align-self: center;
  margin: 0 .05rem;
  opacity: .7;
}
@media (max-width: 860px) {
  .nav-sep { display: none; }
}

/* Incidents — vue d'analyse principale, légèrement accentuée */
.btn-incidents-hero:not(.active) {
  border-color: rgba(88,166,255,.35);
  color: var(--accent);
}
.btn-incidents-hero:not(.active):hover {
  background: rgba(88,166,255,.08);
  border-color: var(--accent);
}

/* Top Priorities — CTA principal, amber discret */
.btn-top-prio:not(.active) {
  border-color: rgba(245,158,11,.4);
  color: #f59e0b;
}
.btn-top-prio:not(.active):hover {
  background: rgba(245,158,11,.09);
  border-color: #f59e0b;
}

/* ── Dropdown groups navbar (Analytics, Tools) ─ Sprint UI clarity ──── */
.nav-menu {
  position: relative;
  display: inline-flex;
  align-items: center;
}
.nav-menu-trigger {
  display: inline-flex; align-items: center; gap: .2rem;
}
/* Highlight trigger when one of its sub-panels is open */
.nav-menu-trigger.active {
  background: rgba(88,166,255,.1);
  border-color: rgba(88,166,255,.4);
  color: var(--accent);
}
.nav-menu-popover {
  position: absolute;
  top: calc(100% + 7px);
  left: 0;
  z-index: 300;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 8px 28px rgba(0,0,0,.45);
  padding: .3rem;
  min-width: 175px;
  display: flex; flex-direction: column; gap: .05rem;
}
.nav-menu-item {
  display: flex; align-items: center; gap: .45rem;
  padding: .38rem .65rem; font-size: .8rem; font-family: var(--font);
  border-radius: 5px; border: none; cursor: pointer;
  background: none; color: var(--text);
  text-align: left; width: 100%; white-space: nowrap;
  transition: background .1s, color .1s;
}
.nav-menu-item:hover { background: var(--surface2); color: var(--accent); }
.nav-menu-item.active { color: var(--accent); font-weight: 600; }
.nav-menu-sep {
  height: 1px; background: var(--border);
  margin: .25rem .4rem;
}

.select-filter {
  background: var(--surface2);
  border: 1px solid var(--border);
  color: var(--text);
  border-radius: var(--radius);
  padding: .4rem .6rem;
  font-family: var(--font);
  font-size: .8rem;
  cursor: pointer;
}
.select-filter:focus { outline: none; border-color: var(--accent); }

/* ── Filtres secondaires (ligne collapsible sous la navbar) ──────────────── */
.secondary-filters-row {
  display: none;
  width: 100%;
  background: var(--surface2);
  border-top: 1px solid var(--border);
  padding: .45rem 1rem;
  gap: .5rem;
  flex-wrap: wrap;
  align-items: center;
  order: 99; /* toujours en dernier dans le flex navbar */
}
.secondary-filters-row.sf-open { display: flex; }

/* Séparateur vertical dans la ligne secondaire */
.sf-sep {
  width: 1px; height: 1.4rem;
  background: var(--border); align-self: center; flex-shrink: 0;
}

/* Bouton Real risk dans la ligne secondaire */
.sf-risk-btn { flex-shrink: 0; }

.btn-secondary-filters { position: relative; }
.sf-active-badge {
  position: absolute; top: -4px; right: -4px;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--accent); border: 2px solid var(--surface2);
}

/* ── Status bar ─────────────────────────────────────────────────────────── */
.statusbar {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  padding: .35rem 1rem;
  display: flex; align-items: center; gap: 1rem;
  font-size: .75rem; color: var(--text2);
}
.statusbar .dot { display: inline-block; width: 8px; height: 8px;
  border-radius: 50%; background: var(--ok); margin-right: .3rem; }

/* ── Statusbar — feed health dot ─────────────────────────────────────────── */
.sb-health {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  cursor: pointer;
  opacity: 0.75;
  transition: opacity 0.15s ease;
  white-space: nowrap;
}
.sb-health:hover { opacity: 1; }

.sb-health-dot {
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--text3, #6e7681);
  flex-shrink: 0;
  transition: background 0.3s ease;
}
.sb-health-ok   .sb-health-dot { background: var(--ok, #2dce89); }
.sb-health-warn .sb-health-dot { background: #f0883e; }
.sb-health-error .sb-health-dot { background: #f85149; }

/* ── KPI summary bar ───────────────────────────────────────────────────── */
.kpi-bar {
  display: flex; align-items: center; gap: .5rem;
  padding: .35rem 1rem;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  overflow-x: auto;
}
.kpi-cell {
  display: inline-flex; align-items: center; gap: .3rem;
  padding: .2rem .55rem;
  border-radius: 6px;
  background: var(--surface2, var(--bg2));
  border: 1px solid var(--border);
  font-size: .72rem;
  white-space: nowrap;
}
.kpi-value { font-weight: 700; color: var(--text); }
.kpi-label { color: var(--text2); font-weight: 400; }
.kpi-alert {
  border-color: rgba(248,81,73,.4);
  background: rgba(248,81,73,.08);
}
.kpi-alert .kpi-value { color: var(--err, #f85149); }
.kpi-warn {
  border-color: rgba(240,136,62,.4);
  background: rgba(240,136,62,.08);
}
.kpi-warn .kpi-value { color: var(--warn, #f0883e); }

/* ── SLA Policy fields (Settings → Policy tab) ──────────────────────────── */
.sla-fields    { display: flex; flex-direction: column; gap: .6rem; margin: .75rem 0 1rem; }
.sla-field     { display: flex; align-items: center; gap: .75rem; }
.sla-label     { width: 7rem; font-size: .8rem; font-weight: 600; color: var(--text1); flex-shrink: 0; }
.sla-input-row { display: flex; align-items: center; gap: .4rem; }
.sla-input     { width: 4.5rem; text-align: center; }
.sla-unit      { font-size: .78rem; color: var(--text2); }

/* ── Watchlist Scope Bar ─────────────────────────────────────────────────── */
.scope-bar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .3rem .45rem;
  padding: .22rem 1rem;
  font-size: .68rem;
  color: var(--text2);
  border-bottom: 1px solid var(--border);
  min-height: 0;
}
.scope-eye    { opacity: .7; margin-right: .1rem; }
.scope-prefix { font-weight: 600; color: var(--text2); margin-right: .15rem; }
.scope-term {
  padding: .1rem .45rem;
  border-radius: 8px;
  background: var(--surface2, rgba(139,148,158,.1));
  color: var(--text2);
  white-space: nowrap;
}
.scope-more   { color: var(--text2); opacity: .65; }

/* ── New since last visit — bouton navbar ────────────────────────────────── */
.btn-nsv {
  color: #2dce89;
  border-color: rgba(45,206,137,.4);
  font-weight: 600;
}
.btn-nsv:hover {
  background: rgba(45,206,137,.12);
  border-color: rgba(45,206,137,.7);
}

/* ── New since last visit — badge statusbar ──────────────────────────────── */
.nsv-badge {
  display: inline-flex; align-items: center; gap: .35rem;
  background: rgba(45,206,137,.12);
  border: 1px solid rgba(45,206,137,.35);
  color: #2dce89;
  border-radius: 4px;
  padding: .1rem .45rem;
  font-size: .72rem; font-weight: 600;
  cursor: pointer;
  animation: nsvIn .2s ease;
  transition: background .12s, border-color .12s;
  user-select: none;
}
.nsv-badge:hover {
  background: rgba(45,206,137,.22);
  border-color: rgba(45,206,137,.55);
}
@keyframes nsvIn {
  from { opacity: 0; transform: translateY(-3px); }
  to   { opacity: 1; transform: translateY(0); }
}
.nsv-btn {
  background: none; border: none; color: inherit;
  cursor: pointer; font-size: .7rem; padding: 0 .1rem;
  opacity: .75; line-height: 1; transition: opacity .12s;
}
.nsv-btn:hover { opacity: 1; }

/* ── Bandeau contextuel NSV (au-dessus du feed, quand vue active) ─────────── */
#nsv-context-bar {
  display: none;
  align-items: center;
  gap: .6rem;
  padding: .45rem 1rem;
  background: rgba(45,206,137,.07);
  border-bottom: 1px solid rgba(45,206,137,.18);
  color: #2dce89;
  font-size: .8rem;
}
.nsv-ctx-icon  { font-size: .9rem; flex-shrink: 0; }
.nsv-ctx-label { flex: 1; }
.nsv-ctx-back  {
  background: none;
  border: 1px solid rgba(45,206,137,.35);
  color: #2dce89;
  border-radius: 4px;
  padding: .2rem .65rem;
  cursor: pointer;
  font-size: .75rem;
  white-space: nowrap;
  transition: background .12s, border-color .12s;
}
.nsv-ctx-back:hover {
  background: rgba(45,206,137,.14);
  border-color: rgba(45,206,137,.55);
}

/* ── New since last visit — badge sur les cartes ─────────────────────────── */
.badge-new {
  background: rgba(45,206,137,.16);
  color: #2dce89;
  border: 1px solid rgba(45,206,137,.4);
  font-weight: 700; letter-spacing: .02em;
  animation: nsvIn .25s ease;
}

/* Accent visuel discret sur les cartes nouvelles (bordure gauche verte) */
.card-new {
  border-left: 3px solid rgba(45,206,137,.55) !important;
}

.card-read {
  opacity: 0.68;
}

/* ── Articles revus (triage) ───────────────────────────────────────────── */
.card-reviewed {
  opacity: 0.55;
  border-left: 3px solid rgba(63,185,80,.4) !important;
}
.card-reviewed .card-title a {
  text-decoration: line-through;
  text-decoration-color: rgba(63,185,80,.5);
}
.card-reviewed:hover {
  opacity: 0.8;
}

/* Bouton ✓ reviewed sur la carte */
.btn-reviewed {
  background: none; border: none; cursor: pointer;
  color: var(--text2); font-size: 1rem; padding: 0 .2rem;
  line-height: 1; transition: color .15s, transform .1s;
}
.btn-reviewed:hover { color: var(--ok); transform: scale(1.2); }
.btn-reviewed.reviewed { color: #3fb950; }

/* Bouton "Mark as reviewed" dans le dropdown Actions */
.qa-actions-item-reviewed { color: var(--text2); }
.qa-actions-item-reviewed.qa-reviewed-active { color: #3fb950; font-weight: 600; }

/* ── CVE Link badge (status bar) ────────────────────────────────────────── */
.cve-link-badge {
  display: inline-flex; align-items: center; gap: .3rem;
  background: rgba(163,113,247,.12);
  border: 1px solid rgba(163,113,247,.45);
  color: #a371f7;
  border-radius: 4px;
  padding: .1rem .45rem;
  font-size: .72rem; font-weight: 600;
  margin-left: .25rem;
  animation: cveLinkIn .15s ease;
}
@keyframes cveLinkIn {
  from { opacity: 0; transform: translateY(-3px); }
  to   { opacity: 1; transform: translateY(0);    }
}
.cve-link-badge-close {
  background: none; border: none; color: #a371f7;
  cursor: pointer; font-size: .75rem; padding: 0 .1rem;
  opacity: .65; line-height: 1; transition: opacity .12s;
}
.cve-link-badge-close:hover { opacity: 1; }

/* ── Main layout ────────────────────────────────────────────────────────── */
.main { flex: 1; padding: 1rem; max-width: 1400px; margin: 0 auto; width: 100%; }

/* ── Feed grid ──────────────────────────────────────────────────────────── */
#feed-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: .75rem;
}

/* ── Article card ───────────────────────────────────────────────────────── */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 4px solid var(--border);
  border-radius: var(--radius);
  padding: .85rem 1rem;
  display: flex; flex-direction: column; gap: .5rem;
  transition: border-color .15s, transform .1s;
}
.card:hover { transform: translateY(-1px); border-color: var(--accent); }

.crit-high   { border-left-color: var(--err);  }
.crit-medium { border-left-color: var(--warn); }
.crit-low    { border-left-color: var(--ok);   }

/* Priority-level visual differentiation — stronger than criticality alone */
.priority-critical_now {
  border-left-width: 5px;
  background: linear-gradient(90deg, rgba(248,81,73,.05) 0%, transparent 35%);
  box-shadow: inset 4px 0 8px -4px rgba(248,81,73,.2);
}
.priority-investigate {
  border-left-width: 4px;
  background: linear-gradient(90deg, rgba(240,136,62,.03) 0%, transparent 25%);
}
.priority-low {
  opacity: .75;
}
.priority-low:hover { opacity: 1; }

.card-header {
  display: flex; align-items: center; gap: .5rem; flex-wrap: wrap;
}

.card-time {
  margin-left: auto; font-size: .72rem; color: var(--text2);
}

.card-title { font-size: .9rem; font-weight: 600; line-height: 1.4; }
.card-title a { color: var(--text); }
.card-title a:hover { color: var(--accent); text-decoration: none; }

.card-desc { font-size: .78rem; color: var(--text2); line-height: 1.5; }

/* ── Badges ─────────────────────────────────────────────────────────────── */
.badge {
  display: inline-flex; align-items: center; gap: .2rem;
  font-size: .7rem; font-weight: 700; padding: .15rem .45rem;
  border-radius: 4px; white-space: nowrap;
}
.badge-high   { background: rgba(248,81,73,.18);  color: var(--err);  border: 1px solid rgba(248,81,73,.4); }
.badge-medium { background: rgba(240,136,62,.18); color: var(--warn); border: 1px solid rgba(240,136,62,.4); }
.badge-low    { background: rgba(63,185,80,.18);  color: var(--ok);   border: 1px solid rgba(63,185,80,.4); }
.badge-source { background: var(--surface2); color: var(--text2); border: 1px solid var(--border); }

/* ── Bouton étoile ──────────────────────────────────────────────────────── */
.btn-star {
  background: none; border: none; cursor: pointer;
  color: var(--text2); font-size: 1rem; padding: 0 .2rem;
  line-height: 1; transition: color .15s, transform .1s;
}
.btn-star:hover { color: var(--warn); transform: scale(1.2); }
.btn-star.starred { color: #f1c40f; }

/* ── NVD / CVSS badges ──────────────────────────────────────────────────── */
.card-nvd { min-height: 0; }

/* ── Pipeline bridges strip (card list view) ────────────────────────────── */
.card-pipeline { display: flex; flex-wrap: wrap; gap: .35rem; margin-top: .5rem; }

.nvd-row {
  display: flex; align-items: center; gap: .4rem;
  flex-wrap: wrap; margin-top: .1rem;
  padding-top: .4rem;
  border-top: 1px solid var(--border);
}

.nvd-link {
  font-size: .7rem; color: var(--text2);
  margin-left: auto; white-space: nowrap;
}
.nvd-link:hover { color: var(--accent); }

/* Scores CVSS colorés */
.cvss-critical { background: rgba(248,81,73,.25);  color: #ff6b6b; border: 1px solid rgba(248,81,73,.5); font-weight:700; }
.cvss-high     { background: rgba(240,136,62,.22); color: #f0883e; border: 1px solid rgba(240,136,62,.45); }
.cvss-medium   { background: rgba(210,153,34,.2);  color: #e3b341; border: 1px solid rgba(210,153,34,.4); }
.cvss-low      { background: rgba(63,185,80,.18);  color: var(--ok); border: 1px solid rgba(63,185,80,.4); }
.cvss-na       { background: var(--surface2);      color: var(--text2); border: 1px solid var(--border); }

/* ── Tags canal et notice sécurité ─────────────────────────────────────── */
.channel-tag {
  font-size: .65rem; font-weight: 700; padding: .1em .4em;
  border-radius: 3px; margin-left: .3rem; vertical-align: middle;
}
.tag-recommended {
  background: rgba(63,185,80,.2); color: var(--ok);
  border: 1px solid rgba(63,185,80,.4);
}

.security-notice {
  background: rgba(210,153,34,.1);
  border: 1px solid rgba(210,153,34,.35);
  border-left: 3px solid var(--warn);
  border-radius: var(--radius);
  padding: .6rem .85rem;
  font-size: .78rem; color: var(--text2);
  line-height: 1.5; margin-bottom: .75rem;
}
.security-notice strong { color: var(--warn); }
.security-notice a { color: var(--accent); }

.settings-prod-notice {
  background: rgba(63,185,80,.1);
  border: 1px solid rgba(63,185,80,.35);
  border-left: 3px solid var(--ok);
  border-radius: var(--radius);
  padding: .6rem .85rem;
  font-size: .78rem; color: var(--text2);
  line-height: 1.5; margin-bottom: .75rem;
}
.settings-prod-notice strong { color: var(--ok); }

/* CWE et severity tags */
.badge-severity { background: rgba(88,166,255,.12); color: #79c0ff; border: 1px solid rgba(88,166,255,.3); }
.badge-cwe      { background: rgba(139,90,248,.12); color: #d2a8ff; border: 1px solid rgba(139,90,248,.3);
                  font-size: .65rem; }

/* ── Spinner ────────────────────────────────────────────────────────────── */
#spinner {
  display: none; position: fixed; inset: 0;
  background: rgba(13,17,23,.7);
  z-index: 999; align-items: center; justify-content: center;
  flex-direction: column; gap: 1rem; font-size: .9rem; color: var(--text2);
}
.spin {
  width: 40px; height: 40px;
  border: 3px solid var(--border);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: spin .8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ── Toasts ─────────────────────────────────────────────────────────────── */
#toast-area {
  position: fixed; bottom: 1.5rem; right: 1.5rem;
  display: flex; flex-direction: column; gap: .5rem; z-index: 1000;
}
.toast {
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: var(--radius); padding: .65rem 1rem;
  display: flex; align-items: center; gap: .75rem;
  font-size: .8rem; min-width: 280px; max-width: 380px;
  animation: slideIn .2s ease;
  box-shadow: 0 4px 20px rgba(0,0,0,.4);
}
.toast-success { border-left: 3px solid var(--ok); }
.toast-error   { border-left: 3px solid var(--err); }
.toast-warning { border-left: 3px solid var(--warn); }
.toast button  { background: none; border: none; cursor: pointer;
  color: var(--text2); font-size: .9rem; margin-left: auto; }
@keyframes slideIn { from { opacity:0; transform: translateX(20px); } to { opacity:1; } }

/* ── Modal Paramètres ───────────────────────────────────────────────────── */
.modal-overlay {
  position: fixed; inset: 0; z-index: 2000;
  background: rgba(0,0,0,.7);
  align-items: center; justify-content: center;
  animation: fadeIn .15s ease;
}
@keyframes fadeIn { from { opacity:0; } to { opacity:1; } }

.modal-box {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  width: min(680px, 95vw);
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: 0 20px 60px rgba(0,0,0,.6);
  animation: slideUp .2s ease;
}
@keyframes slideUp { from { transform: translateY(20px); opacity:0; } to { transform: none; opacity:1; } }

.modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.1rem 1.25rem .75rem;
  border-bottom: 1px solid var(--border);
}
.modal-header h2 { font-size: 1rem; margin: 0; }
.modal-close {
  background: none; border: none; cursor: pointer;
  color: var(--text2); font-size: 1.1rem; padding: .2rem;
  line-height: 1; transition: color .15s;
}
.modal-close:hover { color: var(--err); }

.modal-footer {
  display: flex; justify-content: flex-end; gap: .6rem;
  padding: .9rem 1.25rem;
  border-top: 1px solid var(--border);
}

/* ── Utility classes — extracted from repeated inline styles ─────────── */
.integration-actions {
  display: flex; align-items: center; gap: .75rem;
  flex-wrap: wrap; padding: .5rem 0 0;
}
.btn-sm {
  font-size: .75rem; padding: .3rem .6rem;
}

/* ── How It Works modal ─────────────────────────────────────────────────── */
.how-modal-box {
  max-width: 500px;
  width: min(500px, 95vw);
}
.how-modal-content {
  padding: 1.25rem 1.5rem;
  overflow-y: auto;
  max-height: calc(70vh - 110px);
  font-size: .92rem;
  line-height: 1.65;
}
.how-intro {
  color: var(--text2);
  margin: 0 0 1.1rem;
  font-size: .9rem;
}
.how-modal-content h3 {
  margin: 1.2rem 0 .5rem;
  font-size: .95rem;
  font-weight: 700;
  color: var(--accent, #58a6ff);
}
.how-modal-content h3:first-of-type { margin-top: 0; }
.how-modal-content ul,
.how-modal-content ol {
  margin: 0 0 .6rem 1.1rem;
  padding: 0;
}
.how-modal-content li { margin: .3rem 0; }
.how-modal-content p { margin: .5rem 0 0; color: var(--text2); font-size: .88rem; }
.how-modal-content kbd {
  background: var(--surface2, var(--bg2));
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: .05rem .35rem;
  font-size: .8rem;
  font-family: monospace;
}

.btn-primary {
  background: var(--accent); color: #000; border-color: var(--accent); font-weight: 600;
}
.btn-primary:hover { background: #79c0ff; }

/* Jira push button */
.btn-jira {
  background: rgba(0,82,204,.12);
  border-color: rgba(76,154,255,.35);
  color: #4c9aff;
  font-weight: 600;
}
.btn-jira:hover:not(:disabled) {
  background: rgba(0,82,204,.22);
  border-color: #4c9aff;
  color: #79c0ff;
}
.btn-jira:disabled { cursor: not-allowed; }

/* Settings — Integrations info box */
.settings-info-box {
  background: rgba(88,166,255,.05);
  border-color: rgba(88,166,255,.18) !important;
}
.settings-howto-list {
  margin: .4rem 0 0 1.1rem; padding: 0;
  font-size: .78rem; color: var(--text2); line-height: 1.7;
}
.settings-howto-list strong { color: var(--text); }

.btn-test {
  font-size: .75rem; padding: .3rem .7rem;
  border-color: var(--border); color: var(--text2);
}
.btn-test:hover { border-color: var(--accent); color: var(--accent); }

/* Lignes de paramètres */
.settings-group { padding: .75rem 1.25rem; border-bottom: 1px solid var(--border); }
.settings-group:last-of-type { border-bottom: none; }
.settings-row    { padding: .75rem 1.25rem; border-bottom: 1px solid var(--border); }
.settings-row-inline {
  display: flex; gap: 1rem; padding: .75rem 1.25rem;
  border-bottom: 1px solid var(--border); flex-wrap: wrap;
}

.settings-label {
  display: block; font-size: .75rem; color: var(--text2);
  text-transform: uppercase; letter-spacing: .05em;
  margin-bottom: .35rem; margin-top: .5rem;
}
.settings-label:first-child { margin-top: 0; }

.settings-input {
  width: 100%; background: var(--surface2);
  border: 1px solid var(--border);
  color: var(--text); border-radius: var(--radius);
  padding: .4rem .7rem; font-family: var(--font); font-size: .82rem;
  transition: border-color .2s;
}
.settings-input:focus { outline: none; border-color: var(--accent); }

.settings-hint {
  font-size: .73rem; color: var(--text2); margin: .4rem 0 .6rem;
  line-height: 1.5;
}

/* SWP endpoint drill-down */
.swp-bucket       { display:flex; align-items:center; gap:.45rem; padding:.28rem .2rem; cursor:pointer; border-radius:3px; user-select:none; }
.swp-bucket:hover { background:var(--hover-bg,rgba(255,255,255,.05)); }
.swp-bucket-chevron { font-size:.62rem; color:#8b949e; width:10px; transition:transform .15s; }
.swp-bucket--open .swp-bucket-chevron { transform:rotate(90deg); }
.swp-bucket-label { font-size:.75rem; color:var(--text2); flex:1; }
.swp-bucket-count { font-size:.78rem; font-weight:600; }
.swp-ep-list  { display:none; padding:.1rem 0 .3rem 1.35rem; }
.swp-bucket--open + .swp-ep-list { display:block; }
.swp-ep-item  { font-size:.7rem; color:#8b949e; padding:.06rem 0; }
.swp-ep-item::before { content:"· "; }
.swp-ep-age   { margin-left:.4rem; font-size:.65rem; color:#484f58; }
.swp-ep-more  { font-style:italic; }
.settings-hint a { color: var(--accent); }
.settings-hint code {
  background: var(--surface2); padding: .05em .3em;
  border-radius: 3px; font-size: .9em;
}
.settings-hint-inline { font-size: .7rem; font-weight: 400; color: var(--text2); }

/* ── Historique des alertes (onglet Alertes) ── */
.ah-header      { display:flex; align-items:center; gap:.5rem; margin-bottom:.5rem; flex-wrap:wrap; }
.ah-count-badge { font-size:.7rem; color:var(--text2); opacity:.7; }
.ah-clear-btn   { font-size:.7rem; padding:.2rem .55rem; margin-left:auto; color:var(--text2);
                  border-color:var(--border); }
.ah-clear-btn:hover { border-color:var(--err,#f85149); color:var(--err,#f85149); }
.ah-filter-bar  { display:flex; gap:.35rem; margin-bottom:.5rem; flex-wrap:wrap; }
.ah-filter-btn  { font-size:.7rem; padding:.18rem .5rem; border-radius:10px;
                  border:1px solid var(--border); background:transparent;
                  color:var(--text2); cursor:pointer; }
.ah-filter-btn:hover { border-color:var(--accent); color:var(--text); }
.ah-filter-btn.active { background:var(--accent); border-color:var(--accent);
                        color:#000; font-weight:600; }
.ah-entry       { padding:.35rem .1rem; border-bottom:1px solid var(--border); }
.ah-entry:last-child { border-bottom:none; }
.ah-entry-err   { background:rgba(248,81,73,.04); }
.ah-row         { display:flex; align-items:center; gap:.45rem; flex-wrap:wrap; font-size:.72rem; }
.ah-icon        { font-size:.75rem; flex-shrink:0; }
.ah-ts          { color:var(--text2); white-space:nowrap; min-width:6rem; }
.ah-channel     { font-weight:600; color:var(--text); }
.ah-reason      { color:var(--text2); font-family:var(--font); font-size:.68rem; }
.ah-count       { color:var(--text2); font-size:.68rem; margin-left:auto; white-space:nowrap; }
.ah-err         { color:var(--err,#f85149); font-size:.67rem; width:100%; margin-top:.1rem;
                  white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ah-titles      { padding-left:1.4rem; margin-top:.15rem; }
.ah-title       { display:block; font-size:.67rem; color:var(--text2); opacity:.75;
                  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
                  max-width:100%; }
.ah-empty       { font-size:.75rem; color:var(--text2); opacity:.6; padding:.5rem 0; text-align:center; }

/* Radio group */
.radio-group { display: flex; flex-direction: column; gap: .5rem; margin-top: .4rem; }
.radio-label {
  display: flex; align-items: center; gap: .5rem;
  font-size: .83rem; cursor: pointer;
}
.radio-label input { accent-color: var(--accent); }

/* Toggle switch */
.toggle-label {
  display: flex; align-items: center; gap: .75rem;
  font-size: .85rem; cursor: pointer; user-select: none;
}
.toggle-label input[type="checkbox"] { display: none; }
.toggle-track {
  width: 38px; height: 20px; background: var(--surface2);
  border: 1px solid var(--border); border-radius: 12px;
  position: relative; flex-shrink: 0; transition: background .2s, border-color .2s;
}
.toggle-thumb {
  position: absolute; top: 2px; left: 2px;
  width: 14px; height: 14px; border-radius: 50%;
  background: var(--text2); transition: transform .2s, background .2s;
}
.toggle-label input:checked + .toggle-track {
  background: rgba(88,166,255,.25); border-color: var(--accent);
}
.toggle-label input:checked + .toggle-track .toggle-thumb {
  transform: translateX(18px); background: var(--accent);
}

/* ── Pipeline badges ─────────────────────────────────────────────────────── */

/* CISA KEV — exploité activement */
.badge-kev {
  background: rgba(248,81,73,.22); color: #ff6b6b;
  border: 1px solid rgba(248,81,73,.5);
  font-weight: 700; letter-spacing: .03em;
  animation: kev-pulse 2s ease infinite;
}
@keyframes kev-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(248,81,73,.0); }
  50%       { box-shadow: 0 0 6px 2px rgba(248,81,73,.35); }
}

/* EPSS — probabilité d'exploitation */
.badge-epss {
  background: rgba(88,166,255,.14); color: #79c0ff;
  border: 1px solid rgba(88,166,255,.35);
}

/* Trending — 3+ sources */
.badge-trending {
  background: rgba(240,136,62,.18); color: #f0883e;
  border: 1px solid rgba(240,136,62,.4);
  font-weight: 700;
}

/* Multi-sources (2x) */
.badge-sources {
  background: var(--surface2); color: var(--text2);
  border: 1px solid var(--border);
}

/* Watchlist — correspond à un terme surveillé */
.badge-watchlist {
  background: rgba(139,90,248,.18); color: #d2a8ff;
  border: 1px solid rgba(139,90,248,.4);
  font-weight: 700;
}

/* ATT&CK tactic */
.badge-attack {
  background: rgba(210,153,34,.15); color: #e3b341;
  border: 1px solid rgba(210,153,34,.35);
  font-size: .65rem;
}

/* ── Score bar composite ─────────────────────────────────────────────────── */
.score-bar-wrap {
  display: flex; align-items: center; gap: .5rem;
  height: 6px; position: relative;
  background: var(--surface2);
  border-radius: 3px; overflow: visible;
}
.score-bar {
  height: 6px; border-radius: 3px;
  transition: width .4s ease;
  min-width: 2px;
}
.score-bar-high   { background: var(--err); }
.score-bar-medium { background: var(--warn); }
.score-bar-low    { background: var(--ok); }
.score-label {
  position: absolute; right: 0; top: -2px;
  font-size: .65rem; color: var(--text2);
  line-height: 1; white-space: nowrap;
  transform: translateX(calc(100% + 4px));
}

/* ── Tags de l'article ──────────────────────────────────────────────────── */
.card-tags {
  display: flex; flex-wrap: wrap; gap: .3rem;
  margin-top: .1rem;
}
/* Secondary-context badges in card-tags — signal chips above are the primary read;
   tags are supporting detail. Subtle de-emphasis keeps density scannable. */
.card-tags .badge {
  font-size: .65rem;
  font-weight: 600;
  opacity: .82;
}

/* ── Watchlist modal ─────────────────────────────────────────────────────── */
.watchlist-items {
  display: flex; flex-wrap: wrap; gap: .4rem;
  margin: .5rem 0; min-height: 32px;
}
.watchlist-tag {
  display: inline-flex; align-items: center; gap: .3rem;
  background: rgba(139,90,248,.15); color: #d2a8ff;
  border: 1px solid rgba(139,90,248,.35);
  border-radius: 4px; padding: .15rem .45rem;
  font-size: .75rem;
}
.watchlist-tag button {
  background: none; border: none; cursor: pointer;
  color: #d2a8ff; font-size: .8rem; padding: 0; line-height: 1;
  opacity: .7; transition: opacity .15s;
}
.watchlist-tag button:hover { opacity: 1; }
.watchlist-add-row {
  display: flex; gap: .5rem; margin-top: .4rem;
}
.watchlist-add-row input {
  flex: 1;
}

/* ── Dashboard Statistiques ─────────────────────────────────────────────── */
.stats-panel {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
}
.stats-panel-inner {
  max-width: 1400px; margin: 0 auto;
  padding: 1rem 1.2rem 1.2rem;
  display: flex; flex-direction: column; gap: 1rem;
}

/* KPI cards */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
  gap: .6rem;
}
.kpi-card {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: .75rem .8rem;
  display: flex; flex-direction: column; gap: .2rem;
  transition: border-color .2s;
}
.kpi-card:hover { border-color: var(--accent); }
.kpi-value {
  font-size: 1.6rem; font-weight: 700; line-height: 1;
  color: var(--text);
}
.kpi-label {
  font-size: .68rem; color: var(--text2); letter-spacing: .04em;
}
.kpi-high   .kpi-value { color: var(--err); }
.kpi-medium .kpi-value { color: var(--warn); }
.kpi-kev    .kpi-value { color: #ff6b6b; }
.kpi-watch  .kpi-value { color: #d2a8ff; }

/* Charts grid */
.charts-grid {
  display: grid;
  grid-template-columns: 220px 1fr 1fr;
  gap: .8rem;
}
.charts-grid-2 {
  grid-template-columns: 1fr 1fr;
}
.chart-card {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: .85rem 1rem;
}
.chart-title {
  font-size: .72rem; color: var(--text2);
  letter-spacing: .06em; text-transform: uppercase;
  margin-bottom: .6rem; font-weight: 600;
}
.chart-wrap { position: relative; height: 160px; }
.chart-wrap-sm { height: 180px; }

/* ATT&CK bars */
.attack-list { display: flex; flex-direction: column; gap: .4rem; }
.attack-row {
  display: grid; grid-template-columns: 110px 1fr 28px;
  align-items: center; gap: .5rem;
}
.attack-label { font-size: .72rem; color: var(--text2); white-space: nowrap; }
.attack-bar-track {
  height: 6px; background: var(--surface);
  border-radius: 3px; overflow: hidden;
}
.attack-bar {
  height: 100%; border-radius: 3px;
  background: #e3b341;
  transition: width .4s ease;
}
.attack-count { font-size: .7rem; color: var(--text2); text-align: right; }

/* ATT&CK drill-down — interactive rows */
.attack-row         { cursor: pointer; border-radius: 4px; padding: .15rem .3rem; margin: -.15rem -.3rem; transition: background .15s; }
.attack-row:hover   { background: var(--hover-bg, rgba(255,255,255,.06)); }
.attack-row--active .attack-label { color: #e3b341; font-weight: 600; }
.attack-row--active .attack-bar   { background: #f0883e; }
.attack-row--active .attack-count { color: #e3b341; font-weight: 600; }

/* ATT&CK active-filter badge (mirrors .cve-link-badge layout) */
.attack-filter-badge       { display: inline-flex; align-items: center; gap: .3rem; padding: .15rem .55rem; border-radius: 12px; background: rgba(227,179,65,.12); border: 1px solid rgba(227,179,65,.3); font-size: .72rem; color: #e3b341; vertical-align: middle; }
.attack-filter-badge-close { background: none; border: none; cursor: pointer; color: #8b949e; font-size: .75rem; padding: 0 .1rem; line-height: 1; }
.attack-filter-badge-close:hover { color: var(--text, #e6edf3); }

/* Top CVEs */
.cve-list { display: flex; flex-direction: column; gap: .4rem; }
.cve-row { display: flex; align-items: center; gap: .4rem; flex-wrap: wrap; }
.cve-id { font-size: .75rem; color: var(--accent); font-weight: 600; }

/* Responsive stats */
@media (max-width: 900px) {
  .charts-grid { grid-template-columns: 1fr 1fr; }
  .charts-grid-2 { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .charts-grid { grid-template-columns: 1fr; }
  .kpi-grid { grid-template-columns: repeat(4, 1fr); }
}

/* ── Barre Risque Réel ───────────────────────────────────────────────────── */
.risk-filter-bar {
  background: linear-gradient(90deg, #0d1117 0%, #111820 100%);
  border-bottom: 1px solid var(--border);
  padding: .5rem 1rem;
  display: flex;
  flex-direction: column;
  gap: .3rem;
  animation: slidein .2s ease;
}

.risk-filter-inner {
  display: flex; align-items: center; gap: .65rem; flex-wrap: wrap;
}

.risk-filter-label {
  font-size: .75rem; font-weight: 700; color: var(--text2);
  text-transform: uppercase; letter-spacing: .06em;
  white-space: nowrap; flex-shrink: 0;
}

/* Pills container */
.risk-pills {
  display: flex; align-items: center; gap: .4rem; flex-wrap: wrap; flex: 1;
}

/* Pill de base */
.risk-pill {
  padding: .28rem .7rem; border-radius: 20px;
  font-size: .76rem; font-weight: 600; cursor: pointer;
  border: 1px solid var(--border);
  background: var(--surface2); color: var(--text2);
  transition: all .15s; white-space: nowrap;
  line-height: 1.3;
}
.risk-pill:hover { color: var(--text); border-color: var(--text2); }

/* Pills actives */
.risk-pill.risk-pill-active { color: #fff; }

/* Couleurs par type */
.risk-pill-kev.risk-pill-active      { background: #4a0000; border-color: var(--err); color: #fca5a5; }
.risk-pill-epss.risk-pill-active     { background: #2a1a00; border-color: #f0883e;    color: #fdba74; }
.risk-pill-watchlist.risk-pill-active{ background: #0a001a; border-color: #d2a8ff;    color: #d2a8ff; }
.risk-pill-trending.risk-pill-active { background: #2a1200; border-color: #fb923c;    color: #fb923c; }
.risk-pill-ioc.risk-pill-active      { background: #001a10; border-color: var(--ok);  color: #6ee7b7; }
.risk-pill-zero_day.risk-pill-active { background: #1a0d1a; border-color: #c084fc;    color: #c084fc; }

/* Hover coloré selon type (avant activation) */
.risk-pill-kev:hover       { border-color: var(--err); }
.risk-pill-epss:hover      { border-color: #f0883e; }
.risk-pill-watchlist:hover { border-color: #d2a8ff; }
.risk-pill-trending:hover  { border-color: #fb923c; }
.risk-pill-ioc:hover       { border-color: var(--ok); }
.risk-pill-zero_day:hover  { border-color: #c084fc; }

/* Pill EPSS avec input inline */
.risk-pill-wrap {
  display: flex; align-items: center; gap: 0;
  border-radius: 20px; overflow: hidden;
  border: 1px solid var(--border);
  background: var(--surface2);
  transition: border-color .15s;
}
.risk-pill-wrap:has(.risk-pill-active) {
  border-color: #f0883e; background: #2a1a00;
}
.risk-pill-wrap .risk-pill {
  border: none; border-radius: 0; background: transparent;
  padding-right: .3rem;
}
.risk-pill-sep {
  font-size: .72rem; color: var(--text2); padding: 0 .2rem; white-space: nowrap;
}
.risk-epss-input {
  width: 2.6rem; border: none; background: transparent;
  color: var(--text); font-size: .76rem; font-weight: 700;
  text-align: center; outline: none; padding: .28rem 0;
}
.risk-epss-input:focus { background: var(--surface); border-radius: 3px; }
.risk-pill-pct {
  font-size: .72rem; color: var(--text2); padding-right: .5rem;
}

/* ── EPSS preset buttons ─────────────────────────────────────────────── */
.risk-epss-group {
  display: flex;
  align-items: center;
  gap: .3rem;
}
.risk-epss-presets {
  display: flex;
  gap: 2px;
}
.risk-epss-preset {
  font-size: .68rem;
  padding: .18rem .4rem;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--surface2);
  color: var(--text2);
  cursor: pointer;
  white-space: nowrap;
  transition: border-color .12s, color .12s, background .12s;
}
.risk-epss-preset:hover {
  border-color: #f0883e;
  color: var(--text);
}
.risk-epss-preset-active {
  background: #2a1a00;
  border-color: #f0883e;
  color: #fdba74;
  font-weight: 600;
}

/* Fin de ligne : compteur + clear */
.risk-filter-end {
  display: flex; align-items: center; gap: .6rem; margin-left: auto; flex-shrink: 0;
}
.risk-result-count {
  font-size: .76rem; color: var(--accent); font-weight: 600;
}
.risk-clear-btn {
  background: none; border: 1px solid var(--border); border-radius: 20px;
  color: var(--text2); font-size: .72rem; padding: .2rem .6rem;
  cursor: pointer; transition: all .15s;
}
.risk-clear-btn:hover { border-color: var(--err); color: var(--err); }

/* Ligne de description des filtres actifs */
.risk-desc-row {
  display: flex; align-items: center;
  padding: .2rem .05rem;
  font-size: .73rem; color: var(--text2);
  border-top: 1px solid var(--border);
}
.risk-desc-text strong { color: var(--text); }

/* Badge sur le bouton navbar */
#risk-nav-badge {
  display: none;
  background: var(--err); color: #fff;
  font-size: .6rem; font-weight: 700;
  border-radius: 50%; width: 1.1rem; height: 1.1rem;
  align-items: center; justify-content: center;
  margin-left: .25rem; vertical-align: middle;
}

/* Responsive */
@media (max-width: 720px) {
  .risk-filter-inner { flex-direction: column; align-items: flex-start; }
  .risk-filter-end { margin-left: 0; }
}

/* Badge résumé IOC dans card-tags (rangée principale signaux) */
.badge-ioc-summary {
  background: rgba(121,192,255,.10);
  color: #79c0ff;
  border: 1px solid rgba(121,192,255,.3);
  cursor: default;
}

/* ── Threat actor badge — card-tags et bloc analyst status ──────────────── */
.badge-actor {
  background: rgba(255,163,72,.12);
  color: #ffb347;
  border: 1px solid rgba(255,163,72,.35);
  cursor: default;
  font-size: .75rem;
}

/* Rangée threat actor dans le bloc analyst status */
.es-actor-row {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding-top: .25rem;
}

.es-actor-icon {
  font-size: 1rem;
  flex-shrink: 0;
  opacity: .75;
}

.es-actor-input {
  flex: 1;
  background: var(--bg-card, #161b22);
  border: 1px solid var(--border, #30363d);
  border-radius: 4px;
  color: var(--text, #c9d1d9);
  font-size: .85rem;
  padding: .3rem .6rem;
  outline: none;
  transition: border-color .15s;
}

.es-actor-input:focus {
  border-color: #ffb347;
  background: var(--bg-card-hover, #1c2128);
}

/* ── IOC Badges (cartes) ─────────────────────────────────────────────────── */
.card-iocs {
  display: flex; flex-wrap: wrap; gap: .3rem;
  margin-top: .35rem; padding-top: .35rem;
  border-top: 1px solid var(--border);
}

/* Badge IOC générique */
.badge-ioc {
  font-size: .68rem; padding: .15rem .4rem; border-radius: 3px;
  cursor: pointer; font-family: monospace;
  transition: filter .12s, transform .1s;
  user-select: none;
}
.badge-ioc:hover { filter: brightness(1.3); transform: scale(1.04); }
.badge-ioc:active { transform: scale(.97); }

/* Types */
.badge-ioc-hash   { background: #1a1400; color: #e3b341; border: 1px solid #e3b341; }
.badge-ioc-ip     { background: #001220; color: #58a6ff; border: 1px solid #58a6ff; }
.badge-ioc-domain { background: #0a0020; color: #d2a8ff; border: 1px solid #d2a8ff; }
.badge-ioc-url    { background: #001a0a; color: #3fb950; border: 1px solid #3fb950; }
.badge-ioc-more   {
  background: var(--surface2); color: var(--text2);
  border: 1px dashed var(--border); cursor: default;
  font-size: .68rem; padding: .15rem .4rem; border-radius: 3px;
}

/* ── IOC Panel (modal) ───────────────────────────────────────────────────── */
.art-ioc-panel      { display: flex; flex-direction: column; gap: .6rem; }
.art-ioc-group      { display: flex; flex-direction: column; gap: .25rem; }
.art-ioc-group-label {
  font-size: .68rem; font-weight: 700; color: var(--text2);
  text-transform: uppercase; letter-spacing: .06em; margin-bottom: .1rem;
}

.art-ioc-row {
  display: flex; align-items: center; gap: .4rem;
  padding: .2rem .35rem; border-radius: 4px;
  background: var(--surface2);
  transition: background .12s;
}
.art-ioc-row:hover { background: #1c2230; }

.art-ioc-type {
  font-size: .65rem; font-weight: 700; white-space: nowrap;
  min-width: 4rem; text-align: right; padding-right: .3rem;
  border-right: 1px solid var(--border);
}
.art-ioc-hash   { color: #e3b341; }
.art-ioc-ip     { color: #58a6ff; }
.art-ioc-domain { color: #d2a8ff; }
.art-ioc-url    { color: #3fb950; }

.art-ioc-val {
  flex: 1; font-family: monospace; font-size: .72rem; color: var(--text);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  min-width: 0;
}

.art-ioc-copy-btn {
  background: none; border: none; cursor: pointer;
  font-size: .8rem; padding: 0 .2rem; color: var(--text2);
  opacity: .6; transition: opacity .12s;
  flex-shrink: 0;
}
.art-ioc-copy-btn:hover { opacity: 1; }

/* IOC action buttons row (Deep scan + Reputation) */
.art-ioc-actions {
  display: flex;
  gap: .5rem;
  margin-top: .75rem;
  flex-wrap: wrap;
}
.art-ioc-deep-btn {
  font-size: .8rem;
  padding: .3rem .75rem;
  background: var(--bg2);
  border: 1px solid var(--border);
  color: var(--text2);
  border-radius: 6px;
  cursor: pointer;
  transition: background .15s, color .15s;
}
.art-ioc-deep-btn:hover:not(:disabled) {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
.art-ioc-deep-btn:disabled {
  opacity: .55;
  cursor: default;
}

/* Small note below deep scan result */
.art-ioc-deep-note {
  margin-top: .5rem;
  font-size: .75rem;
  color: var(--text3, var(--text2));
  opacity: .7;
}

/* IOC Reputation badges (Option C — OTX lookup) */
.rep-malicious {
  background: rgba(239,68,68,.18);
  color: #f87171;
  border: 1px solid rgba(239,68,68,.35);
  font-size: .7rem;
  padding: .1rem .4rem;
  border-radius: 4px;
  white-space: nowrap;
}
.rep-suspicious {
  background: rgba(245,158,11,.18);
  color: #fbbf24;
  border: 1px solid rgba(245,158,11,.35);
  font-size: .7rem;
  padding: .1rem .4rem;
  border-radius: 4px;
  white-space: nowrap;
}
.rep-clean {
  background: rgba(63,185,80,.15);
  color: #4ade80;
  border: 1px solid rgba(63,185,80,.3);
  font-size: .7rem;
  padding: .1rem .4rem;
  border-radius: 4px;
}
.rep-unknown {
  background: var(--bg3, var(--bg2));
  color: var(--text2);
  border: 1px solid var(--border);
  font-size: .7rem;
  padding: .1rem .4rem;
  border-radius: 4px;
}
.uh-confirmed {
  background: rgba(249,115,22,.15);
  color: #fb923c;
  border: 1px solid rgba(249,115,22,.35);
  font-size: .7rem;
  padding: .1rem .4rem;
  border-radius: 4px;
  white-space: nowrap;
}

/* ThreatFox IOC badges */
.tf-match {
  background: rgba(239,68,68,.15);
  color: #f87171;
  border: 1px solid rgba(239,68,68,.3);
  font-size: .7rem;
  padding: .1rem .4rem;
  border-radius: 4px;
  white-space: nowrap;
  cursor: default;
}
.tf-no-match {
  background: var(--bg3, var(--bg2));
  color: var(--text2);
  border: 1px solid var(--border);
  font-size: .7rem;
  padding: .1rem .4rem;
  border-radius: 4px;
}
.tf-unknown {
  background: var(--bg3, var(--bg2));
  color: var(--text2);
  border: 1px solid var(--border);
  font-size: .7rem;
  padding: .1rem .4rem;
  border-radius: 4px;
}


/* ── Modal Détail Article ────────────────────────────────────────────────── */

/* Curseur pointer sur les cartes (hors liens/boutons) */
.card { cursor: pointer; }
.card a, .card button { cursor: auto; }

/* Overlay */
.art-modal-overlay {
  position: fixed; inset: 0; z-index: 500;
  display: flex; align-items: center; justify-content: center;
  background: rgba(0,0,0,.72);
  backdrop-filter: blur(4px);
  padding: 1rem;
}

/* Boîte principale */
.art-modal-box {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  width: min(900px, 100%);
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 24px 64px rgba(0,0,0,.6);
  overflow: hidden;
}

/* Zone scrollable */
.art-modal-scroll {
  overflow-y: auto;
  flex: 1;
  padding: 1.5rem;
  scroll-behavior: smooth;
}

/* Bouton fermer */
.art-modal-close-btn {
  position: absolute; top: .75rem; right: .75rem;
  z-index: 10;
  background: var(--surface2); border: 1px solid var(--border);
  color: var(--text2); border-radius: 50%;
  width: 2rem; height: 2rem;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; font-size: 1rem; line-height: 1;
  transition: background .15s, color .15s;
}
.art-modal-close-btn:hover { background: var(--err); color: #fff; border-color: var(--err); }

/* Bloquer le scroll du body quand modal ouverte */
body.modal-open { overflow: hidden; }

/* ── En-tête du modal ── */
.art-modal-head {
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--border);
  margin-bottom: 1rem;
}
.art-modal-badges {
  display: flex; flex-wrap: wrap; gap: .4rem; margin-bottom: .65rem;
}
.art-modal-title {
  font-size: 1.1rem; font-weight: 700; color: var(--text);
  line-height: 1.4; margin-bottom: .5rem;
}
.art-modal-sub {
  display: flex; flex-wrap: wrap; gap: 1rem;
  font-size: .78rem; color: var(--text2);
}
.art-modal-sub strong { color: var(--accent); }

/* ── Corps 2 colonnes ── */
.art-modal-body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
}
.art-modal-left, .art-modal-right { display: flex; flex-direction: column; gap: 1rem; }

/* ── Sections ── */
.art-modal-section { /* conteneur */ }
.art-modal-section-title {
  font-size: .72rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .08em; color: var(--text2);
  border-bottom: 1px solid var(--border); padding-bottom: .3rem;
  margin-bottom: .6rem;
}

/* ── Métriques ── */
.art-metrics { display: flex; flex-direction: column; gap: .55rem; }

.art-metric-row {
  display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; min-height: 1.5rem;
}
.art-metric-label {
  font-size: .74rem; color: var(--text2); width: 6.5rem; flex-shrink: 0;
}
.art-metric-bar-wrap {
  flex: 1; min-width: 60px; height: 6px;
  background: var(--surface2); border-radius: 3px; overflow: hidden;
}
.art-metric-bar {
  height: 100%; border-radius: 3px;
  transition: width .5s ease;
}
.art-bar-err  { background: var(--err); }
.art-bar-warn { background: var(--warn); }
.art-bar-ok   { background: var(--ok); }
.art-metric-val { font-size: .74rem; color: var(--text); white-space: nowrap; }
.art-metric-val small { color: var(--text2); font-size: .7rem; }
.art-metric-hint { font-size: .7rem; color: var(--text2); margin-top: .15rem; }
.art-metric-na { font-size: .74rem; color: var(--text2); font-style: italic; }
.art-metric-vector {
  font-size: .65rem; color: var(--text2); font-family: monospace;
  background: var(--surface2); padding: 1px 4px; border-radius: 3px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 140px;
}

/* CVSS badge colors */
.badge-cvss-critical { background:#4a0000; color:#f87171; border:1px solid #f87171; }
.badge-cvss-high     { background:#3a1800; color:#f0883e; border:1px solid #f0883e; }
.badge-cvss-medium   { background:#2a2000; color:#e3b341; border:1px solid #e3b341; }
.badge-cvss-low      { background:#001a0a; color:#3fb950; border:1px solid #3fb950; }

/* ── CVEs ── */
.art-cve-list { display: flex; flex-direction: column; gap: .35rem; }
.art-cve-row  { display: flex; align-items: center; gap: .4rem; flex-wrap: wrap; }
.art-cve-id {
  font-size: .78rem; font-weight: 700; color: var(--accent);
  font-family: monospace;
}
.art-cve-id:hover { text-decoration: underline; }

/* ── ATT&CK ── */
.art-attack-list { display: flex; flex-direction: column; gap: .5rem; }
.art-attack-group { /* conteneur par tactique */ }
.art-attack-tactic-label {
  font-size: .68rem; color: var(--text2); margin-bottom: .25rem;
  font-style: italic;
}
.art-attack-techniques { display: flex; flex-wrap: wrap; gap: .3rem; }

/* ── Watchlist ── */
.art-watchlist-matches { display: flex; flex-wrap: wrap; gap: .35rem; }

/* ── Description ── */
.art-modal-desc {
  font-size: .82rem; color: var(--text2); line-height: 1.6;
  white-space: pre-wrap; word-break: break-word;
}

/* ── Articles similaires ── */
.art-similar-list { display: flex; flex-direction: column; gap: .5rem; }
.art-similar-item {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: .55rem .7rem;
  cursor: pointer;
  transition: border-color .15s, background .15s;
}
.art-similar-item:hover { border-color: var(--accent); background: #1c2230; }
.art-similar-meta {
  display: flex; align-items: center; gap: .4rem; margin-bottom: .3rem;
}
.art-similar-source { font-size: .7rem; color: var(--text2); }
.art-similar-date   { font-size: .68rem; color: var(--text2); margin-left: auto; }
.art-similar-title  { font-size: .78rem; color: var(--text); line-height: 1.4; }

/* Badge xs (petite version) */
.art-badge-xs { font-size: .6rem !important; padding: 0 .25rem !important; }

/* ── Pied de page modal ── */
.art-modal-footer {
  display: flex; align-items: center; gap: .6rem; flex-wrap: wrap;
  padding: .85rem 1.5rem;
  border-top: 1px solid var(--border);
  background: var(--surface);
  flex-shrink: 0;
}
.art-modal-ioc-btn  { font-size: .82rem; }
.art-modal-open-btn { margin-left: auto; font-size: .82rem; }

/* ── Pipeline bridges ── */
.art-modal-pipeline {
  display: flex; align-items: center; gap: .5rem; flex-wrap: wrap;
  padding: .6rem 1.5rem;
  border-top: 1px solid var(--border);
  background: rgba(88,166,255,.03);
}
.pipeline-bridge-label {
  font-size: .68rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .07em; color: var(--text-muted); margin-right: .25rem;
}
.pipeline-bridge-btn {
  font-size: .72rem; font-weight: 700;
  padding: 3px 10px; border-radius: 6px; text-decoration: none;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  color: var(--text-secondary);
  transition: border-color .15s, color .15s, background .15s;
}
.pipeline-bridge-btn:hover {
  background: rgba(88,166,255,.08);
  border-color: rgba(88,166,255,.3);
  color: #58a6ff;
}
.pipeline-link {
  font-size: .72rem; font-weight: 800; text-decoration: none;
  padding: 2px 8px; border-radius: 5px;
  background: rgba(88,166,255,.15);
  border: 1px solid rgba(88,166,255,.45);
  color: #79b8ff;
  transition: background .15s, border-color .15s, box-shadow .15s;
  white-space: nowrap;
  display: inline-flex; align-items: center;
}
.pipeline-link:hover {
  background: rgba(88,166,255,.28);
  border-color: rgba(88,166,255,.7);
  box-shadow: 0 0 6px rgba(88,166,255,.25);
}

/* ── Responsive modal ── */
@media (max-width: 720px) {
  .art-modal-body { grid-template-columns: 1fr; }
  .art-modal-box  { max-height: 95vh; }
  .art-modal-scroll { padding: 1rem; }
  .art-modal-footer { padding: .75rem 1rem; gap: .4rem; }
  .art-modal-open-btn { margin-left: 0; }
}
/* Sprint 23 : les quick actions sont dans le dropdown — plus besoin de réduire chaque bouton */
@media (max-width: 540px) {
  .art-modal-footer { gap: .35rem; }
  .qa-incident-actions .qa-btn-sm { font-size: .65rem; padding: .18rem .45rem; }
}

/* ── État vide ──────────────────────────────────────────────────────────── */
.empty-state {
  grid-column: 1/-1; text-align: center;
  padding: 4rem 1rem; color: var(--text2);
}
.empty-icon { font-size: 3rem; margin-bottom: 1rem; }

/* État vide enrichi — version contextuelle */
.empty-state-rich {
  padding: 3rem 1.5rem 3.5rem;
  background: rgba(255,255,255,.015);
  border: 1px solid var(--border);
  border-radius: 10px;
  margin: 1rem;
}
.empty-title {
  font-size: 1rem; font-weight: 600; color: var(--text); margin: .5rem 0 .4rem;
}
.empty-hint {
  font-size: .82rem; color: var(--text2); margin: 0 auto .9rem; max-width: 380px;
}
.empty-actions {
  display: flex; flex-wrap: wrap; justify-content: center; gap: .5rem; margin-top: .5rem;
}
.ob-reset-btn {
  font-size: .78rem; padding: .28rem .75rem;
  border-radius: 6px; border: 1px solid var(--border);
  background: transparent; color: var(--text2); cursor: pointer; font-family: var(--font);
  transition: all .15s;
}
.ob-reset-btn:hover { color: var(--accent); border-color: var(--accent); }
.ob-reset-persona { border-color: rgba(248,81,73,.4); color: #f85149; }
.ob-reset-persona:hover { border-color: #f85149; background: rgba(248,81,73,.08); color: #f85149; }

/* ── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 640px) {
  .navbar { gap: .4rem; }
  .search-input { width: 100%; }
  #feed-grid { grid-template-columns: 1fr; }
}

/* ── PWA — Bannières install / offline / update ─────────────────────────── */
#pwa-install-banner,
#pwa-update-banner {
  display: flex; align-items: center; justify-content: space-between;
  gap: .75rem; flex-wrap: wrap;
  padding: .55rem 1.1rem;
  background: linear-gradient(90deg, #1a3a6e 0%, #1a56db22 100%);
  border-bottom: 1px solid #1a56db;
  font-size: .82rem; color: var(--text);
  animation: slidein .25s ease;
}
#pwa-update-banner { background: linear-gradient(90deg, #2d1a00 0%, #f0883e22 100%); border-color: #f0883e; }

@keyframes slidein {
  from { transform: translateY(-100%); opacity: 0; }
  to   { transform: translateY(0);     opacity: 1; }
}

.pwa-banner-text  { flex: 1; min-width: 0; }
.pwa-banner-actions { display: flex; align-items: center; gap: .5rem; flex-shrink: 0; }
.pwa-btn          { padding: .28rem .75rem; font-size: .78rem; }
.pwa-dismiss      {
  background: none; border: none; color: var(--text2); cursor: pointer;
  font-size: 1rem; padding: 0 .25rem; line-height: 1;
  transition: color .15s;
}
.pwa-dismiss:hover { color: var(--text); }

/* Barre hors-ligne */
#pwa-offline-bar {
  display: flex; align-items: center; gap: 1rem;
  padding: .45rem 1.1rem;
  background: #1a1000; border-bottom: 1px solid #f0883e;
  font-size: .8rem; color: #f0883e;
}
.pwa-offline-hint { color: var(--text2); font-size: .75rem; }

/* ── Barre Profil d'exposition ──────────────────────────────────────────── */
.profile-bar {
  background: rgba(255,255,255,.025);
  border-bottom: 1px solid var(--border);
  padding: .32rem 1rem;
  display: flex;
  align-items: center;
  gap: .6rem;
  font-size: .78rem;
  position: relative;
  /* z-index: 50 — au-dessus des barres sans stacking context (persona-bar, risk-filter, statusbar)
     mais sous la navbar (z-index: 100). Le dropdown hérite de ce contexte. */
  z-index: 50;
}

.prb-label {
  font-size: .68rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; color: var(--text2); flex-shrink: 0;
}

/* Pill profil actif + dropdown */
.prb-pill-wrap { position: relative; }

.prb-active-pill {
  display: inline-flex; align-items: center; gap: .35rem;
  padding: .22rem .6rem .22rem .4rem;
  border-radius: 20px; border: 1px solid var(--accent);
  background: rgba(88,166,255,.08); color: var(--text);
  cursor: pointer; font-family: var(--font); font-size: .78rem; font-weight: 600;
  transition: all .15s; white-space: nowrap;
}
.prb-active-pill:hover { background: rgba(88,166,255,.15); }
.prb-badge { font-size: .95rem; line-height: 1; }
.prb-name  { max-width: 140px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.prb-desc  { font-size: .68rem; color: var(--text2); max-width: 120px;
             overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.prb-arrow { font-size: .6rem; color: var(--text2); }

/* Dropdown */
.prb-dropdown {
  position: absolute; top: calc(100% + 6px); left: 0;
  min-width: 230px; max-width: 300px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 8px; padding: .3rem 0;
  /* Ombre renforcée sur fond sombre — donne le "float" visuel */
  box-shadow: 0 16px 40px rgba(0,0,0,.7), 0 0 0 1px rgba(255,255,255,.04);
  z-index: 100;
}
.prb-option {
  display: flex; align-items: center; gap: .5rem;
  width: 100%; text-align: left;
  padding: .42rem .8rem;
  background: transparent; border: none; color: var(--text2);
  cursor: pointer; font-family: var(--font); font-size: .8rem;
  transition: background .1s;
}
.prb-option:hover         { background: rgba(255,255,255,.06); color: var(--text); }
.prb-option-active        { color: var(--accent) !important; }
.prb-option-name          { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.prb-check                { color: var(--accent); font-size: .75rem; flex-shrink: 0; }
.prb-option-new           { color: var(--text2); font-size: .76rem; font-style: italic; }
.prb-option-new:hover     { color: var(--accent); }
.prb-sep {
  height: 1px; background: var(--border); margin: .25rem .5rem;
}

/* Bouton Gérer */
.prb-manage-btn {
  padding: .2rem .5rem; border-radius: 5px;
  font-size: .75rem; border: 1px solid var(--border);
  background: transparent; color: var(--text2);
  cursor: pointer; font-family: var(--font); transition: all .15s;
}
.prb-manage-btn:hover { color: var(--text); border-color: var(--text2); }

/* Sprint 24 — Structure 2 lignes + dropdown 3 sections */
.prb-wrapper { display: flex; flex-direction: column; gap: 2px; }
.prb-line1   { display: flex; align-items: center; gap: 4px; }

/* Ligne 2 : vue persona active (absente si aucune vue sélectionnée) */
.prb-persona-line {
  display: flex; align-items: center; gap: 3px;
  padding: 0 2px; font-size: .68rem; color: var(--text2);
  white-space: nowrap; overflow: hidden; max-width: 240px;
}
.prb-persona-line-label { flex-shrink: 0; }
.prb-persona-line-icon  { flex-shrink: 0; font-size: .82rem; }
.prb-persona-line-name  {
  color: var(--accent); font-weight: 500;
  overflow: hidden; text-overflow: ellipsis;
}

/* Label de section dans le dropdown */
.prb-dd-section-label {
  padding: 5px 10px 2px; font-size: .61rem;
  text-transform: uppercase; letter-spacing: .06em;
  color: var(--text2); user-select: none; cursor: default;
  pointer-events: none;
}

/* Section B : action Créer — visuellement distincte */
.prb-option-create           { color: var(--accent); font-weight: 600; }
.prb-option-create:hover     { background: rgba(88,166,255,.08); color: var(--accent) !important; }

/* Section C : gestion — ton secondaire */
.prb-option-manage           { color: var(--text2); font-size: .76rem; }
.prb-option-manage:hover     { color: var(--text) !important; }

/* Modal overlay */
.prb-modal-overlay {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(0,0,0,.6);
  display: flex; align-items: center; justify-content: center;
}
.prb-modal-box {
  background: var(--card); border: 1px solid var(--border);
  border-radius: 12px; padding: 1.5rem;
  width: min(420px, 95vw); box-shadow: 0 16px 48px rgba(0,0,0,.5);
}
.prb-modal-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 1.1rem;
}
.prb-modal-header h3 { margin: 0; font-size: .95rem; font-weight: 700; color: var(--text); }
.prb-modal-close {
  background: transparent; border: none; color: var(--text2);
  font-size: .9rem; cursor: pointer; padding: .1rem .3rem;
  border-radius: 4px; transition: color .15s;
}
.prb-modal-close:hover { color: var(--err); }

.prb-field-label {
  display: block; font-size: .72rem; font-weight: 600; color: var(--text2);
  text-transform: uppercase; letter-spacing: .04em; margin: .9rem 0 .3rem;
}
.prb-field-label:first-child { margin-top: 0; }
.prb-input {
  width: 100%; box-sizing: border-box;
  padding: .45rem .65rem; border-radius: 6px;
  border: 1px solid var(--border); background: var(--bg);
  color: var(--text); font-family: var(--font); font-size: .85rem;
  outline: none; transition: border-color .15s;
}
.prb-input:focus { border-color: var(--accent); }
.prb-field-hint  { font-size: .72rem; color: var(--text2); margin: .6rem 0 0; }

/* Badge picker */
.prb-badge-picker {
  display: flex; flex-wrap: wrap; gap: .4rem; margin-top: .2rem;
}
.prb-badge-opt {
  width: 2.1rem; height: 2.1rem; border-radius: 6px;
  border: 2px solid transparent; background: rgba(255,255,255,.05);
  cursor: pointer; font-size: 1.1rem;
  display: flex; align-items: center; justify-content: center;
  transition: all .12s;
}
.prb-badge-opt:hover  { border-color: var(--accent); }
.prb-badge-sel        { border-color: var(--accent); background: rgba(88,166,255,.15); }

.prb-modal-footer {
  display: flex; justify-content: flex-end; gap: .5rem;
  margin-top: 1.2rem; padding-top: .9rem; border-top: 1px solid var(--border);
}
.prb-delete-btn { color: var(--err) !important; border-color: rgba(248,81,73,.4) !important;
                  margin-right: auto; }
.prb-delete-btn:hover { background: rgba(248,81,73,.1) !important; }

/* ── Barre Vues Métier / Persona Presets ────────────────────────────────── */
.persona-bar {
  background: linear-gradient(90deg, #0d1117 0%, #111820 100%);
  border-bottom: 1px solid var(--border);
  padding: .42rem 1rem;
  display: flex;
  align-items: center;
  gap: .65rem;
  flex-wrap: wrap;
  animation: slidein .2s ease;
}

.pbar-label {
  font-size: .72rem; font-weight: 700; color: var(--text2);
  text-transform: uppercase; letter-spacing: .07em;
  white-space: nowrap; flex-shrink: 0;
}

.pbar-pills {
  display: flex; align-items: center; gap: .35rem; flex-wrap: wrap; flex: 1;
}

.pbar-pill {
  padding: .24rem .65rem; border-radius: 20px;
  font-size: .75rem; font-weight: 600; cursor: pointer;
  border: 1px solid var(--border);
  background: var(--surface2); color: var(--text2);
  font-family: var(--font);
  transition: all .15s; white-space: nowrap;
}
.pbar-pill:hover        { color: var(--text); border-color: var(--accent); }
.pbar-pill.pbar-active  {
  background: rgba(88,166,255,.18); color: var(--accent);
  border-color: var(--accent); box-shadow: 0 0 0 1px rgba(88,166,255,.25);
}

.pbar-reset {
  margin-left: auto; flex-shrink: 0;
  padding: .22rem .55rem; border-radius: 5px;
  font-size: .7rem; font-weight: 600; cursor: pointer;
  border: 1px solid var(--border);
  background: transparent; color: var(--text2);
  font-family: var(--font);
  transition: all .15s;
}
.pbar-reset:hover { color: var(--err); border-color: var(--err); }

/* ── Quick Actions — Boutons de sortie opérationnelle ───────────────────── */

/* Bouton générique — hérite du look .btn, variante sobre */
.qa-btn {
  display: inline-flex; align-items: center; gap: .3rem;
  padding: .28rem .7rem;
  border-radius: 6px;
  font-size: .75rem; font-weight: 600;
  border: 1px solid var(--border);
  background: transparent; color: var(--text2);
  cursor: pointer; font-family: var(--font);
  transition: all .15s; white-space: nowrap;
}
.qa-btn:hover {
  color: var(--accent); border-color: var(--accent);
  background: rgba(88,166,255,.07);
}

/* Version compacte pour les panneaux incidents */
.qa-btn-sm {
  padding: .2rem .55rem; font-size: .7rem;
}

/* Conteneur des boutons dans le panneau incident */
.qa-incident-actions {
  display: flex; flex-wrap: wrap; gap: .4rem; align-items: center;
  padding: .5rem .75rem;
  border-bottom: 1px solid var(--border);
  background: rgba(255,255,255,.02);
}

/* ── Sprint 23 : Rationalisation UX — menu déroulant d'actions ──────────── */

/* Conteneur position:relative pour le popover absolu */
.qa-actions-menu {
  position: relative; display: inline-flex; flex-shrink: 0;
}

/* Déclencheur "⚡ Actions ▾" ou "···" */
.qa-actions-trigger {
  white-space: nowrap;
}
.qa-actions-trigger.qa-actions-open {
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  border-color: var(--accent); color: var(--accent);
}

/* Popover liste d'actions — s'ouvre vers le haut par défaut (footer article) */
.qa-actions-popover {
  position: absolute;
  bottom: calc(100% + 6px); left: 0;
  background: var(--card1, var(--card)); border: 1px solid var(--border);
  border-radius: 8px; padding: .3rem;
  min-width: 210px; max-width: 260px;
  box-shadow: 0 6px 28px rgba(0,0,0,.55);
  z-index: 600;
  display: flex; flex-direction: column; gap: .1rem;
}

/* Dans le panneau incident, le popover s'ouvre vers le bas (actions en haut du détail) */
.qa-incident-actions .qa-actions-popover {
  bottom: auto; top: calc(100% + 4px);
}

/* Item d'action dans le popover */
.qa-actions-item {
  display: flex; align-items: center; gap: .45rem;
  padding: .38rem .65rem; font-size: .79rem; line-height: 1.3;
  border-radius: 5px; border: none; cursor: pointer;
  background: transparent; color: var(--text1);
  text-align: left; width: 100%; white-space: nowrap;
  transition: background .11s;
}
.qa-actions-item:hover              { background: var(--card2, var(--surface)); }
.qa-actions-item-ticket             { color: #f59e0b; }
.qa-actions-item-ticket:hover       { background: rgba(245,158,11,.1); }
.qa-actions-item-share              { color: #34d399; }
.qa-actions-item-share:hover        { background: rgba(52,211,153,.1); }

/* Séparateur dans le popover */
.qa-actions-sep {
  height: 1px; background: var(--border); margin: .2rem .3rem;
}

/* Responsive — footer article : single-line on desktop, wrap on mobile */
@media (min-width: 481px) {
  .art-modal-footer { flex-wrap: nowrap; }
}
@media (max-width: 480px) {
  .art-modal-footer { flex-wrap: wrap; }
  /* Le popover s'aligne à droite pour éviter les débordements hors-écran */
  #art-qa-popover {
    left: auto; right: 0;
  }
}
/* Le bouton "···" incident reste compact */
.qa-inc-more-trigger {
  padding: .2rem .55rem; letter-spacing: .05em; font-size: .8rem;
}
/* Supprime l'overflow horizontal du panneau incidents sur mobile */
@media (max-width: 540px) {
  .qa-incident-actions { gap: .25rem; }
  .qa-actions-item     { font-size: .75rem; padding: .3rem .5rem; }
}

/* ── Sprint 22 : Partage enrichi — bouton + modal ───────────────────────── */

/* Bouton Partager — teal, distinct du ticket (amber) et des autres actions */
.qa-btn-share {
  color: #34d399;
  border-color: rgba(52,211,153,.3);
}
.qa-btn-share:hover {
  background: rgba(52,211,153,.1);
  border-color: rgba(52,211,153,.6);
  color: #6ee7b7;
}

/* Modal de partage — overlay */
.qa-share-modal {
  position: fixed; inset: 0; z-index: 1250;
  background: rgba(0,0,0,.65); backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  padding: 1rem;
}

/* Boîte du modal */
.qa-share-box {
  background: var(--card1, var(--card)); border: 1px solid var(--border);
  border-radius: 10px; width: 100%; max-width: 580px;
  display: flex; flex-direction: column;
  box-shadow: 0 8px 32px rgba(0,0,0,.45);
  max-height: 90vh; overflow: hidden;
}

/* En-tête avec titre, onglets, bouton fermer */
.qa-share-header {
  display: flex; align-items: center; gap: .6rem; flex-wrap: wrap;
  padding: .7rem 1rem; border-bottom: 1px solid var(--border);
}
.qa-share-title {
  font-weight: 700; font-size: .88rem; color: var(--text1);
  white-space: nowrap; margin-right: .15rem;
}
.qa-share-tabs {
  display: flex; gap: .3rem; flex: 1; min-width: 0;
}
.qa-share-tab {
  background: var(--card2, var(--surface)); border: 1px solid var(--border);
  color: var(--text2); border-radius: 6px; padding: .25rem .6rem;
  font-size: .76rem; cursor: pointer; transition: all .15s; white-space: nowrap;
}
.qa-share-tab:hover         { color: var(--text1); border-color: var(--accent); }
.qa-share-tab-active {
  background: color-mix(in srgb, var(--accent) 14%, var(--card2, var(--surface)));
  border-color: var(--accent); color: var(--text1); font-weight: 600;
}
.qa-share-close {
  margin-left: auto; background: none; border: none; cursor: pointer;
  color: var(--text2); font-size: 1rem; padding: .2rem .35rem;
  border-radius: 4px; transition: color .15s; flex-shrink: 0;
}
.qa-share-close:hover { color: var(--text1); }

/* Zone de prévisualisation du texte */
.qa-share-preview {
  margin: 0; padding: .85rem 1rem;
  font-family: 'Fira Mono', 'Consolas', 'Courier New', monospace;
  font-size: .74rem; color: var(--text1); background: var(--card2, var(--surface));
  white-space: pre-wrap; word-break: break-word; line-height: 1.55;
  overflow-y: auto; max-height: 280px;
  border-bottom: 1px solid var(--border);
}

/* Pied de modal */
.qa-share-footer {
  display: flex; gap: .6rem; justify-content: flex-end; flex-wrap: wrap;
  padding: .65rem 1rem;
}

/* Responsive mobile */
@media (max-width: 540px) {
  .qa-share-header { gap: .4rem; }
  .qa-share-tabs   { flex-wrap: wrap; }
  .qa-share-tab    { font-size: .7rem; padding: .2rem .45rem; }
  .qa-share-preview { max-height: 200px; font-size: .7rem; }
  .qa-share-footer { padding: .5rem .75rem; }
}

/* ── Sprint 20 : Profile Panel — dashboard profil actif ─────────────────── */

.profile-panel {
  background: var(--card);
  border-bottom: 1px solid var(--border);
}
.pp-inner {
  max-width: 1200px; margin: 0 auto;
  padding: .9rem 1.5rem 1rem;
}
.pp-empty-panel {
  text-align: center; padding: 1.5rem; color: var(--text2); font-size: .82rem;
}

/* En-tête profil */
.pp-header {
  display: flex; align-items: center; justify-content: space-between;
  gap: .75rem; margin-bottom: .85rem; flex-wrap: wrap;
}
.pp-header-left  { display: flex; align-items: center; gap: .65rem; flex: 1; min-width: 0; }
.pp-header-right { display: flex; align-items: center; gap: .5rem; flex-shrink: 0; }
.pp-badge   { font-size: 1.55rem; flex-shrink: 0; line-height: 1; }
.pp-meta    { display: flex; flex-direction: column; gap: .08rem; min-width: 0; }
.pp-name    { font-size: .92rem; font-weight: 700; color: var(--text); }
.pp-desc    { font-size: .73rem; color: var(--text2);
              white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 340px; }
.pp-wl-pill { font-size: .67rem; padding: .18rem .5rem;
              background: rgba(88,166,255,.1); color: var(--accent);
              border-radius: 10px; white-space: nowrap; }
.pp-close   { background: none; border: none; cursor: pointer; font-size: .95rem;
              color: var(--text2); padding: .2rem .35rem; border-radius: 4px; line-height: 1; }
.pp-close:hover { color: var(--text); background: var(--hover); }

/* KPI row */
.pp-kpi-row {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: .5rem; margin-bottom: .85rem;
}
.pp-kpi {
  background: var(--card2); border: 1px solid var(--border);
  border-radius: 7px; padding: .5rem .65rem; text-align: center;
  transition: border-color .15s, background .15s;
}
.pp-kpi-accent { border-color: var(--accent);              background: rgba(88,166,255,.06); }
.pp-kpi-warn   { border-color: rgba(245,158,11,.4);        background: rgba(245,158,11,.06); }
.pp-kpi-danger { border-color: rgba(248,81,73,.4);         background: rgba(248,81,73,.06);  }
.pp-kpi-val    { display: block; font-size: 1.45rem; font-weight: 700; color: var(--text); line-height: 1.1; }
.pp-kpi-lbl    { display: block; font-size: .63rem; color: var(--text2); margin-top: .1rem; }

/* Sections */
.pp-section       { margin-bottom: .8rem; }
.pp-section-title {
  font-size: .66rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: .06em; color: var(--text2); margin-bottom: .4rem;
}

/* Barres termes watchlist */
.pp-term-list { display: flex; flex-direction: column; gap: .22rem; }
.pp-term-row  {
  display: grid; grid-template-columns: 140px 1fr 28px;
  align-items: center; gap: .5rem; font-size: .75rem;
}
.pp-term-label    { color: var(--text); font-weight: 500;
                    white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pp-term-bar-wrap { height: 5px; background: var(--border); border-radius: 3px; overflow: hidden; }
.pp-term-bar      { height: 100%; background: var(--accent); border-radius: 3px; transition: width .35s; }
.pp-term-count    { font-size: .67rem; color: var(--text2); text-align: right; }

/* Articles du profil */
.pp-article-list { display: flex; flex-direction: column; gap: .28rem; }
.pp-article-row  {
  display: flex; align-items: flex-start; justify-content: space-between; gap: .5rem;
  padding: .4rem .65rem; cursor: pointer;
  background: var(--card2); border: 1px solid var(--border); border-radius: 6px;
  transition: border-color .15s, background .15s;
}
.pp-article-row:hover { border-color: var(--accent); background: rgba(88,166,255,.04); }
.pp-article-row:focus-visible { outline: 2px solid var(--accent); outline-offset: 1px; }
.pp-art-crit  { font-size: .85rem; flex-shrink: 0; margin-top: .1rem; }
.pp-art-info  { display: flex; flex-direction: column; gap: .08rem; flex: 1; min-width: 0; }
.pp-art-title { font-size: .78rem; font-weight: 600; color: var(--text);
                white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 420px; }
.pp-art-wl    { font-size: .64rem; color: var(--text2); }
.pp-art-right { display: flex; align-items: center; gap: .3rem; flex-shrink: 0; }
.pp-art-prio  { font-size: .6rem; font-weight: 700; padding: .1rem .35rem;
                border-radius: 3px; white-space: nowrap; }
.pp-prio-critical  { background: rgba(248,81,73,.15);   color: #f85149; }
.pp-prio-investigate{ background: rgba(245,158,11,.15); color: #f59e0b; }
.pp-prio-watch     { background: rgba(88,166,255,.12);  color: var(--accent); }
.pp-art-score { font-size: .63rem; color: var(--text2);
                background: var(--card); border: 1px solid var(--border);
                padding: .1rem .3rem; border-radius: 3px; }

/* Actions rapides */
.pp-actions {
  display: flex; gap: .45rem; flex-wrap: wrap;
  margin-top: .75rem; padding-top: .75rem; border-top: 1px solid var(--border);
}
.pp-action-btn { font-size: .76rem; padding: .28rem .7rem; }

/* Empty states */
.pp-empty-state  { text-align: center; padding: 1.5rem 1rem; color: var(--text2); }
.pp-empty-icon   { font-size: 1.8rem; margin-bottom: .45rem; }
.pp-empty-state p{ font-size: .82rem; margin: .3rem 0; }
.pp-empty-hint   { font-size: .74rem !important; color: var(--text2); }
.pp-empty-cta    { font-size: .75rem; margin-top: .65rem; }
.pp-no-hits {
  font-size: .77rem; color: var(--text2); padding: .55rem .85rem;
  background: var(--card2); border: 1px solid var(--border);
  border-radius: 6px; margin-bottom: .75rem;
}

/* Sprint 21 — Indicateur vue persona active dans le dashboard profil */
.pp-persona-indicator {
  display: flex; align-items: center; gap: .4rem;
  background: color-mix(in srgb, var(--accent) 8%, var(--card2));
  border: 1px solid color-mix(in srgb, var(--accent) 30%, transparent);
  border-radius: 6px; padding: .35rem .65rem;
  margin-top: .5rem; font-size: .77rem;
}
.pp-persona-icon  { font-size: .95rem; flex-shrink: 0; }
.pp-persona-name  { font-weight: 600; color: var(--text1); white-space: nowrap; }
.pp-persona-desc  {
  color: var(--text2); overflow: hidden; text-overflow: ellipsis;
  white-space: nowrap; flex: 1; min-width: 0;
}
.pp-action-btn-save {
  border-color: color-mix(in srgb, var(--accent) 45%, transparent);
}

/* Responsive */
@media (max-width: 720px) {
  .pp-inner { padding: .75rem 1rem .85rem; }
  .pp-kpi-row { grid-template-columns: repeat(2, 1fr); }
  .pp-term-row { grid-template-columns: 100px 1fr 26px; }
}
@media (max-width: 480px) {
  .pp-art-title { max-width: 200px; }
  .pp-desc      { max-width: 180px; }
}

/* ── Sprint 18 : Ticket-Ready — bouton + modal ───────────────────────────── */

/* Bouton Préparer ticket — amber, distinct des autres actions rapides */
.qa-btn-ticket {
  background: rgba(245,158,11,.1);
  color: #f59e0b;
  border-color: rgba(245,158,11,.3);
}
.qa-btn-ticket:hover {
  background: rgba(245,158,11,.22);
  border-color: #f59e0b;
  color: #fbbf24;
}

/* Modal ticket overlay */
.qa-ticket-modal {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.65);
  display: flex; align-items: center; justify-content: center;
  z-index: 1200;
  padding: 1rem; box-sizing: border-box;
}
.qa-ticket-box {
  background: var(--card); border: 1px solid var(--border);
  border-radius: 10px;
  width: 100%; max-width: 680px; max-height: 90vh;
  display: flex; flex-direction: column; overflow: hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
}

/* En-tête */
.qa-ticket-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: .8rem 1.1rem; border-bottom: 1px solid var(--border);
  background: var(--card2); flex-shrink: 0;
}
.qa-ticket-header-left {
  display: flex; align-items: center; gap: .6rem; min-width: 0;
}
.qa-ticket-title {
  font-size: .88rem; font-weight: 700; color: var(--text); white-space: nowrap;
}
.qa-ticket-meta {
  font-size: .7rem; font-weight: 700; padding: .15rem .5rem;
  border-radius: 4px; white-space: nowrap;
  background: rgba(245,158,11,.15); color: #f59e0b;
}
.qa-ticket-meta-critical { background: rgba(248,81,73,.15); color: #f85149; }
.qa-ticket-meta-high     { background: rgba(245,158,11,.15); color: #f59e0b; }
.qa-ticket-meta-medium   { background: rgba(88,166,255,.12); color: var(--accent); }
.qa-ticket-meta-low      { background: rgba(63,185,80,.12);  color: #3fb950; }
.qa-ticket-close {
  background: none; border: none; cursor: pointer;
  font-size: 1rem; color: var(--text2); padding: .25rem .4rem;
  border-radius: 4px; flex-shrink: 0; line-height: 1;
}
.qa-ticket-close:hover { color: var(--text); background: var(--hover); }

/* Zone texte éditable */
.qa-ticket-textarea {
  flex: 1; resize: none;
  background: var(--bg); border: none; border-bottom: 1px solid var(--border);
  padding: .9rem 1.1rem;
  font-family: 'JetBrains Mono', ui-monospace, 'Cascadia Code', monospace;
  font-size: .74rem; line-height: 1.6; color: var(--text);
  outline: none; overflow-y: auto; min-height: 280px; tab-size: 2;
}
.qa-ticket-textarea:focus { background: rgba(255,255,255,.02); }

/* Pied de page */
.qa-ticket-footer {
  display: flex; gap: .5rem; padding: .75rem 1.1rem;
  background: var(--card2); flex-shrink: 0; flex-wrap: wrap;
}

/* ── Persona bar — hint + bouton tour ───────────────────────────────────── */
.pbar-hint {
  font-size: .68rem; color: var(--text2); opacity: .75;
  flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  display: none; /* masqué sur mobile, visible sur desktop */
}
@media (min-width: 900px) { .pbar-hint { display: block; } }

.pbar-tour {
  flex-shrink: 0;
  width: 1.4rem; height: 1.4rem;
  border-radius: 50%; font-size: .7rem; font-weight: 700;
  border: 1px solid var(--border);
  background: transparent; color: var(--text2); cursor: pointer;
  font-family: var(--font); transition: all .15s;
  display: flex; align-items: center; justify-content: center;
}
.pbar-tour:hover { color: var(--accent); border-color: var(--accent); }

/* ── Onboarding Card — guide de démarrage rapide ────────────────────────── */
#onboarding-card.ob-card {
  margin: .75rem 1rem;
  padding: 1rem 1.25rem 1rem;
  border: 1px solid rgba(88,166,255,.2);
  border-radius: 10px;
  background: linear-gradient(135deg, rgba(88,166,255,.04) 0%, rgba(31,111,235,.03) 100%);
  opacity: 0;
  max-height: 700px;
  overflow: hidden;
  transition: opacity .25s ease, max-height .3s ease, margin .3s ease,
              padding .3s ease;
}

.ob-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: .65rem;
}
.ob-brand {
  display: flex; flex-direction: column; gap: .15rem;
}
.ob-tag {
  font-size: .75rem; font-weight: 700; color: var(--accent);
  letter-spacing: .03em; text-transform: uppercase;
}
.ob-tagline {
  font-size: .72rem; color: var(--text2); letter-spacing: .01em;
}
.ob-close {
  background: transparent; border: none; color: var(--text2);
  font-size: .85rem; cursor: pointer; padding: .1rem .3rem;
  border-radius: 4px; transition: color .15s; flex-shrink: 0;
}
.ob-close:hover { color: var(--err); }

/* Pipeline Signal → Priorité → Incident → Action */
.ob-pipeline {
  display: flex; align-items: center; gap: .5rem;
  flex-wrap: wrap;
  margin-bottom: .75rem;
}
.ob-step {
  display: flex; flex-direction: column; align-items: center;
  padding: .45rem .65rem;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.03);
  cursor: default;
  min-width: 5.5rem; flex: 1;
  text-align: center;
  transition: border-color .15s;
}
.ob-step:hover { border-color: var(--accent); }
.ob-step-icon  { font-size: 1.2rem; line-height: 1.4; }
.ob-step-label { font-size: .75rem; font-weight: 700; color: var(--text); margin-top: .1rem; }
.ob-step-sub   { font-size: .65rem; color: var(--text2); margin-top: .05rem; white-space: nowrap; }
.ob-arrow      { color: var(--text2); font-size: .9rem; flex-shrink: 0; }

/* 6 différenciateurs clés */
.ob-differentiators {
  display: flex; flex-wrap: wrap; gap: .3rem;
  margin-bottom: .75rem;
}
.ob-diff-chip {
  font-size: .68rem; font-weight: 600;
  padding: .18rem .55rem;
  border-radius: 20px;
  border: 1px solid var(--border);
  color: var(--text2);
  background: rgba(255,255,255,.03);
  white-space: nowrap; cursor: default;
  transition: border-color .15s, color .15s;
}
.ob-diff-chip:hover  { border-color: var(--text2); color: var(--text); }
.ob-diff-hot         { border-color: rgba(248,81,73,.35); color: #e07070; }
.ob-diff-hot:hover   { border-color: rgba(248,81,73,.7); color: #f85149; }

/* Parcours démo 3 clics */
.ob-demo-guide {
  display: flex; align-items: center; flex-wrap: wrap; gap: .4rem;
  padding: .45rem .65rem;
  border-radius: 8px;
  background: rgba(88,166,255,.05);
  border: 1px solid rgba(88,166,255,.12);
  margin-bottom: .75rem;
}
.ob-demo-label {
  font-size: .7rem; font-weight: 700; color: var(--accent);
  white-space: nowrap; flex-shrink: 0;
}
.ob-demo-steps {
  display: flex; align-items: center; flex-wrap: wrap; gap: .3rem;
}
.ob-demo-step {
  display: flex; align-items: center; gap: .25rem;
  font-size: .7rem; color: var(--text2);
}
.ob-demo-num {
  font-size: .78rem; font-weight: 700; color: var(--accent);
}
.ob-demo-sep {
  color: var(--text2); font-size: .75rem; opacity: .5; flex-shrink: 0;
}

/* Boutons CTA */
.ob-actions {
  display: flex; flex-wrap: wrap; gap: .45rem;
}
.ob-cta {
  padding: .28rem .75rem;
  border-radius: 6px; font-size: .76rem; font-weight: 600;
  border: 1px solid var(--border);
  background: transparent; color: var(--text2);
  cursor: pointer; font-family: var(--font);
  transition: all .15s; white-space: nowrap;
}
.ob-cta:hover          { color: var(--text); border-color: var(--text2); }
.ob-cta-primary        { border-color: rgba(248,81,73,.5); color: #f85149; }
.ob-cta-primary:hover  { background: rgba(248,81,73,.08); border-color: #f85149; color: #f85149; }
.ob-cta-ok             { margin-left: auto; color: var(--text2); }
.ob-cta-ok:hover       { color: var(--accent); border-color: var(--accent); }

/* Hint flottant "étape suivante" */
.ob-hint {
  position: fixed; bottom: 1.25rem; right: 1.25rem;
  z-index: 9000;
  max-width: 320px;
  display: none;
}
.ob-hint-inner {
  display: flex; align-items: flex-start; gap: .5rem;
  background: #1c2230;
  border: 1px solid rgba(88,166,255,.25);
  border-radius: 10px;
  padding: .75rem 1rem;
  box-shadow: 0 8px 24px rgba(0,0,0,.5);
}
.ob-hint-content {
  font-size: .75rem; color: var(--text2); line-height: 1.55; flex: 1;
}
.ob-hint-content strong { color: var(--text); }
.ob-hint-close {
  background: transparent; border: none; color: var(--text2);
  font-size: .8rem; cursor: pointer; padding: 0 .15rem;
  flex-shrink: 0; line-height: 1;
  transition: color .15s;
}
.ob-hint-close:hover { color: var(--err); }

@media (max-width: 600px) {
  .ob-pipeline    { gap: .3rem; }
  .ob-step        { min-width: 4rem; padding: .35rem .4rem; }
  .ob-step-sub    { display: none; }
  .ob-arrow       { display: none; }
  .ob-cta-ok      { margin-left: 0; }
  .ob-hint        { max-width: calc(100vw - 2.5rem); }
  .ob-demo-guide  { gap: .25rem; }
}

/* ── Persona Picker Overlay — first-run experience (v30) ────────────────── */
.ob-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.82);
  backdrop-filter: blur(4px);
  z-index: 9999;
  display: flex; align-items: center; justify-content: center;
  padding: 1rem;
  opacity: 0; transition: opacity .25s ease;
}
.ob-overlay.ob-visible { opacity: 1; }

.ob-picker {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 2rem 2rem 1.5rem;
  max-width: 680px; width: 100%;
  max-height: 90vh; overflow-y: auto;
  box-shadow: 0 24px 48px rgba(0,0,0,.55);
}

.ob-picker-header { text-align: center; margin-bottom: 1.5rem; }
.ob-picker-brand  {
  font-size: 1rem; font-weight: 700; color: var(--accent);
  margin-bottom: .2rem; letter-spacing: .01em;
}
.ob-picker-tagline {
  font-size: .72rem; color: var(--text2); margin-bottom: .9rem;
}
.ob-picker-title {
  font-size: 1.05rem; font-weight: 700; color: var(--text);
}
.ob-picker-sub {
  font-size: .75rem; color: var(--text2); margin-top: .3rem;
}

.ob-persona-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .7rem;
  margin-bottom: 1rem;
}

.ob-persona-card {
  background: var(--bg);
  border: 1.5px solid var(--border);
  border-radius: 10px;
  padding: .9rem .75rem .75rem;
  cursor: pointer;
  transition: border-color .15s, background .15s, transform .12s;
  display: flex; flex-direction: column; gap: .3rem;
  text-align: left; width: 100%;
}
.ob-persona-card:hover {
  border-color: var(--accent);
  background: rgba(88,166,255,.06);
  transform: translateY(-2px);
}
.ob-persona-card:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.ob-persona-icon { font-size: 1.5rem; line-height: 1; margin-bottom: .1rem; }
.ob-persona-name { font-size: .82rem; font-weight: 700; color: var(--text); }
.ob-persona-desc { font-size: .68rem; color: var(--text2); line-height: 1.4; }
.ob-persona-kws  { display: flex; flex-wrap: wrap; gap: .2rem; margin-top: .25rem; }
.ob-persona-kw   {
  font-size: .6rem; font-weight: 600;
  padding: .1rem .35rem; border-radius: 10px;
  background: rgba(88,166,255,.1); color: var(--accent);
  border: 1px solid rgba(88,166,255,.2);
  white-space: nowrap;
}

.ob-picker-skip {
  display: block; text-align: center; width: 100%;
  font-size: .73rem; color: var(--text2);
  cursor: pointer; margin-top: .35rem; padding: .5rem;
  background: transparent; border: none;
  text-decoration: underline; text-underline-offset: 3px;
  transition: color .15s;
}
.ob-picker-skip:hover { color: var(--text); }

@media (max-width: 560px) {
  .ob-persona-grid { grid-template-columns: 1fr 1fr; }
  .ob-picker { padding: 1.25rem 1rem 1rem; }
}
@media (max-width: 380px) {
  .ob-persona-grid { grid-template-columns: 1fr; }
}

/* ── SLA countdown badge ─────────────────────────────────────────────────── */
.card-sla-row {
  padding: .18rem .75rem .1rem;
}

.card-sla {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  font-size: .72rem;
  font-weight: 700;
  padding: .12rem .5rem;
  border-radius: 3px;
  letter-spacing: .03em;
  cursor: default;
}

/* ≥ 3 days — green, informational */
.sla-ok {
  color: #3fb950;
  background: rgba(63,185,80,.08);
  border: 1px solid rgba(63,185,80,.22);
}

/* 1-2 days — amber, attention */
.sla-urgent {
  color: #f0883e;
  background: rgba(240,136,62,.12);
  border: 1px solid rgba(240,136,62,.38);
}

/* Due today — red solid */
.sla-today {
  color: #f85149;
  background: rgba(248,81,73,.14);
  border: 1px solid rgba(248,81,73,.45);
  animation: sla-pulse 2s ease-in-out infinite;
}

/* Overdue — full red background */
.sla-overdue {
  color: #fff;
  background: rgba(248,81,73,.7);
  border: 1px solid #f85149;
  animation: sla-pulse 1.5s ease-in-out infinite;
}

@keyframes sla-pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: .65; }
}

/* ── j/k article navigation focus ring ──────────────────────────────────── */
.card-nav-focus {
  outline: 2px solid var(--accent, #58a6ff);
  outline-offset: 3px;
  box-shadow: 0 0 0 5px rgba(88,166,255,.12);
}

/* ── Morning Brief — print area ──────────────────────────────────────────── */
#mb-print-area { display: none; }

@media print {
  body.mb-printing > *:not(#mb-print-area) { display: none !important; }
  #mb-print-area {
    display: block !important;
    font-family: 'Courier New', monospace;
    font-size: 10pt;
    line-height: 1.6;
    white-space: pre-wrap;
    word-break: break-word;
    color: #111;
    padding: 1.5cm;
    margin: 0;
  }
}

/* ── PDF / Print ────────────────────────────────────────────────────────── */
/* En mode écran : cacher le conteneur rapport */
#pdf-report { display: none; }

@media print {
  /* Cacher TOUT sauf le rapport — uniquement quand PDFReport.generate() déclenche l'impression.
     Sans cette classe (ex : Ctrl+P direct), le contenu normal s'imprime et #pdf-report reste caché. */
  body.printing-report > *:not(#pdf-report) { display: none !important; }
  body.printing-report #pdf-report { display: block !important; }

  /* Reset print */
  * { box-sizing: border-box; -webkit-print-color-adjust: exact; print-color-adjust: exact; }
  body { background: #fff; color: #111; font-family: Arial, Helvetica, sans-serif; font-size: 11pt; margin: 0; }
  a { color: #1a0dab; }
  page { size: A4; margin: 15mm 12mm; }

  /* ── EN-TÊTE ── */
  .rpt-header {
    text-align: center; padding: 12pt 0 8pt; border-bottom: 2pt solid #1a56db; margin-bottom: 12pt;
  }
  .rpt-logo { font-size: 18pt; font-weight: 700; color: #1a56db; }
  .rpt-subtitle { font-size: 9pt; font-weight: 400; color: #6b7280; letter-spacing: 0.04em; margin: 1pt 0 4pt; }
  .rpt-title { font-size: 14pt; font-weight: 600; margin: 2pt 0; }
  .rpt-period { font-size: 10pt; color: #444; }
  .rpt-generated { font-size: 8pt; color: #777; margin-top: 3pt; }

  /* ── SECTIONS ── */
  .rpt-section { margin-bottom: 14pt; page-break-inside: avoid; }
  .rpt-section-half { page-break-inside: avoid; }
  .rpt-section-title { font-size: 12pt; font-weight: 700; border-bottom: 1pt solid #ccc; padding-bottom: 3pt; margin-bottom: 6pt; }
  .rpt-empty { font-size: 9pt; color: #666; font-style: italic; }

  /* ── KPI ROW ── */
  .rpt-kpi-row { display: flex; gap: 6pt; flex-wrap: wrap; margin-bottom: 8pt; }
  .rpt-kpi { flex: 1; min-width: 60pt; border: 1pt solid #ddd; border-radius: 4pt; padding: 5pt 4pt; text-align: center; }
  .rpt-kpi-high  { background: #fff1f0; border-color: #f85149; }
  .rpt-kpi-medium{ background: #fff8f0; border-color: #f0883e; }
  .rpt-kpi-low   { background: #f0fff4; border-color: #3fb950; }
  .rpt-kpi-kev   { background: #fff0f8; border-color: #d2a8ff; }
  .rpt-kpi-val { font-size: 16pt; font-weight: 700; display: block; line-height: 1.1; }
  .rpt-kpi-lbl { font-size: 7pt; color: #555; display: block; margin-top: 2pt; }

  /* ── SUMMARY BOX ── */
  .rpt-summary-box {
    background: #fff8e1; border: 1pt solid #f0883e; border-radius: 4pt;
    padding: 6pt 8pt; font-size: 9pt; line-height: 1.5; margin-top: 6pt;
  }

  /* ── TABLES ── */
  .rpt-table { width: 100%; border-collapse: collapse; font-size: 8.5pt; }
  .rpt-table th {
    background: #1a56db; color: #fff; text-align: left;
    padding: 4pt 5pt; font-size: 8pt;
  }
  .rpt-table td { padding: 3pt 5pt; border-bottom: .5pt solid #e0e0e0; vertical-align: top; }
  .rpt-table tr:nth-child(even) td { background: #f8f8f8; }
  .rpt-score   { font-weight: 700; color: #f85149; width: 30pt; }
  .rpt-source  { width: 70pt; }
  .rpt-date    { width: 45pt; color: #555; }
  .rpt-title-cell { max-width: 160pt; }
  .rpt-tags    { width: 80pt; }
  .rpt-center  { text-align: center; }
  .rpt-small   { font-size: 8pt; color: #555; }
  .rpt-cve-id  { font-weight: 700; color: #1a56db; }

  /* ── BADGES ── */
  .rpt-badge { display: inline-block; border-radius: 3pt; padding: 0 3pt; font-size: 7pt; font-weight: 600; margin: 0 1pt; }
  .rpt-badge-kev    { background: #ffe4e6; color: #b91c1c; border: .5pt solid #f87171; }
  .rpt-badge-cve    { background: #eff6ff; color: #1d4ed8; border: .5pt solid #93c5fd; }
  .rpt-badge-attack { background: #faf5ff; color: #7c3aed; border: .5pt solid #c4b5fd; }
  .rpt-badge-trend  { background: #fff7ed; border: .5pt solid #fdba74; }

  /* ── MINI-BARS ── */
  .rpt-minibar-track { background: #e5e7eb; border-radius: 3pt; height: 7pt; width: 100%; }
  .rpt-minibar       { background: #f85149; height: 7pt; border-radius: 3pt; }
  .rpt-minibar-blue  { background: #1a56db; }

  /* ── POSTURE ── */
  .rpt-posture-row { display: flex; align-items: center; gap: 8pt; margin-bottom: 8pt; }
  .rpt-posture-lbl { font-size: 9pt; font-weight: 600; }
  .rpt-posture {
    display: inline-block; border-radius: 4pt; padding: 2pt 8pt;
    font-size: 10pt; font-weight: 700; letter-spacing: .5pt;
  }
  .rpt-posture-critical { background: #ffe4e6; color: #b91c1c; border: 1pt solid #f87171; }
  .rpt-posture-high     { background: #fff1f0; color: #c2410c; border: 1pt solid #f97316; }
  .rpt-posture-moderate { background: #fefce8; color: #92400e; border: 1pt solid #fcd34d; }
  .rpt-posture-low      { background: #f0fff4; color: #166534; border: 1pt solid #86efac; }

  /* ── KPI supplémentaires ── */
  .rpt-kpi-critical   { background: #fff1f0; border-color: #f85149; }
  .rpt-kpi-investigate{ background: #fff7ed; border-color: #f97316; }

  /* ── TOP 3 BOX ── */
  .rpt-top3-box {
    background: #f0f4ff; border: 1pt solid #a5b4fc; border-radius: 4pt;
    padding: 6pt 8pt; font-size: 9pt; margin-top: 6pt;
  }
  .rpt-top3-list { margin: 4pt 0 0 12pt; padding: 0; line-height: 1.7; }
  .rpt-top3-list li { margin-bottom: 2pt; }

  /* ── BADGES priorité ── */
  .rpt-badge-critical_now { background: #ffe4e6; color: #b91c1c; border: .5pt solid #f87171; }
  .rpt-badge-investigate  { background: #fff7ed; color: #c2410c; border: .5pt solid #fdba74; }
  .rpt-badge-watch        { background: #fefce8; color: #92400e; border: .5pt solid #fde68a; }
  .rpt-badge-low          { background: #f0fdf4; color: #166534; border: .5pt solid #86efac; }
  .rpt-badge-epss         { background: #eff6ff; color: #1d4ed8; border: .5pt solid #93c5fd; }
  .rpt-badge-ioc          { background: #fdf4ff; color: #7e22ce; border: .5pt solid #d8b4fe; }
  .rpt-badge-wl           { background: #fff0f8; color: #9d174d; border: .5pt solid #f9a8d4; }

  /* ── ROW highlights ── */
  .rpt-row-critical td { background: #fff1f0 !important; }
  .rpt-row-kev td      { background: #fff8f0 !important; }

  /* ── DIVERS ── */
  .rpt-dim { color: #aaa; font-size: 8pt; }

  /* ── PIED DE PAGE ── */
  .rpt-footer {
    margin-top: 14pt; padding-top: 6pt; border-top: 1pt solid #ccc;
    font-size: 8pt; color: #777; text-align: center; line-height: 1.6;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   GESTIONNAIRE DE FLUX RSS — Modal Paramètres, onglet Flux RSS
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Onglets du modal Paramètres ─────────────────────────────────────────── */
.modal-box-lg { width: min(720px, 95vw); }

.settings-tabs {
  display: flex;
  border-bottom: 1px solid var(--border);
  margin: -.2rem 0 1.2rem;
  gap: 0;
}
.settings-tab {
  padding: .55rem 1.2rem;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--text2);
  cursor: pointer;
  font-family: var(--font);
  font-size: .84rem;
  font-weight: 500;
  transition: color .15s, border-color .15s;
  white-space: nowrap;
}
.settings-tab:hover { color: var(--text); }
.settings-tab-active { color: var(--accent); border-bottom-color: var(--accent); }

.settings-tab-pane { animation: fadeInSlide .15s ease; }
@keyframes fadeInSlide { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; } }

/* Badge compteur sur l'onglet Flux RSS */
#fm-active-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  background: var(--accent);
  color: #000;
  border-radius: 9px;
  font-size: .68rem;
  font-weight: 700;
  padding: 0 5px;
  margin-left: 5px;
  vertical-align: middle;
}
#fm-active-badge:empty { display: none; }

/* ── Barre de stats + filtres ────────────────────────────────────────────── */
.fm-stats-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: .75rem;
  flex-wrap: wrap;
  gap: .5rem;
}
.fm-count-stats { color: var(--text2); font-size: .8rem; }

.fm-filter-pills { display: flex; gap: .35rem; flex-wrap: wrap; }
.fm-filter-pill {
  padding: .22rem .65rem;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--surface2);
  color: var(--text2);
  font-family: var(--font);
  font-size: .75rem;
  cursor: pointer;
  transition: background .15s, color .15s, border-color .15s;
}
.fm-filter-pill:hover { border-color: var(--accent); color: var(--accent); }
.fm-filter-active {
  background: rgba(88, 166, 255, .12);
  border-color: var(--accent);
  color: var(--accent);
}

/* ── Liste des flux ──────────────────────────────────────────────────────── */
.fm-feed-list {
  display: flex;
  flex-direction: column;
  gap: .4rem;
  max-height: 380px;
  overflow-y: auto;
  margin-bottom: .9rem;
  padding-right: .3rem;
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
}
.fm-feed-list::-webkit-scrollbar { width: 5px; }
.fm-feed-list::-webkit-scrollbar-track { background: transparent; }
.fm-feed-list::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }

.fm-feed-item {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  flex-shrink: 0;
  transition: border-color .15s, background .15s;
}
.fm-feed-item:hover { border-color: var(--accent); background: rgba(88,166,255,.04); }
.fm-feed-disabled { opacity: .45; }

/* ── Ligne principale ─ layout 3 colonnes : [icône] [info] [actions] ───── */
.fm-feed-main {
  display: grid;
  grid-template-columns: 2.2rem 1fr auto;
  align-items: center;
  gap: .6rem;
  padding: .6rem .8rem;
}

/* Icône — fond pill pour la rendre visible même si l'emoji est petit */
.fm-feed-icon {
  font-size: 1.1rem;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  background: rgba(255,255,255,.06);
  border-radius: 6px;
  border: 1px solid var(--border);
  flex-shrink: 0;
}

/* Colonne info */
.fm-feed-info { min-width: 0; }

.fm-feed-name {
  font-size: .86rem;
  font-weight: 600;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: .4rem;
  flex-wrap: wrap;
  line-height: 1.3;
}
.fm-feed-url {
  font-size: .73rem;
  color: var(--text2);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
  margin-top: .15rem;
  font-family: monospace;
  letter-spacing: -.01em;
}
.fm-feed-meta {
  display: flex;
  align-items: center;
  gap: .35rem;
  margin-top: .25rem;
  flex-wrap: wrap;
}
.fm-meta-sep  { color: var(--border); font-size: .75rem; }
.fm-meta-item { font-size: .72rem; color: var(--text2); }

/* Pastille statut */
.fm-status {
  font-size: .7rem;
  font-weight: 700;
  padding: .12rem .45rem;
  border-radius: 4px;
  letter-spacing: .01em;
}
.fm-status-ok      { background: rgba(63,185,80,.15); color: #3fb950; border: 1px solid rgba(63,185,80,.3); }
.fm-status-error   { background: rgba(248,81,73,.15);  color: #f85149; border: 1px solid rgba(248,81,73,.3); }
.fm-status-unknown { background: rgba(139,148,158,.1); color: #8b949e; border: 1px solid rgba(139,148,158,.2); }

/* Badges défaut / custom */
.fm-badge-default {
  font-size: .63rem;
  font-weight: 600;
  padding: .1rem .36rem;
  border-radius: 4px;
  background: rgba(88, 166, 255, .12);
  color: var(--accent);
  border: 1px solid rgba(88, 166, 255, .3);
  white-space: nowrap;
}
.fm-badge-custom {
  font-size: .63rem;
  font-weight: 600;
  padding: .1rem .36rem;
  border-radius: 4px;
  background: rgba(63, 185, 80, .12);
  color: #3fb950;
  border: 1px solid rgba(63, 185, 80, .3);
  white-space: nowrap;
}

/* ── Colonne actions (droite) ─────────────────────────────────────────────── */
.fm-feed-actions {
  display: flex;
  align-items: center;
  gap: .4rem;
  flex-shrink: 0;
}
.fm-btn {
  padding: .32rem .48rem;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 5px;
  color: var(--text2);
  cursor: pointer;
  font-size: .8rem;
  line-height: 1;
  transition: background .15s, border-color .15s, color .15s;
  white-space: nowrap;
}
.fm-btn:hover         { background: var(--surface2); border-color: #555e6a; color: var(--text); }
.fm-btn:disabled      { opacity: .4; cursor: default; }
.fm-btn-danger        { color: #8b949e; }
.fm-btn-danger:hover  { background: rgba(248,81,73,.12); border-color: #f85149; color: #f85149; }

/* ── Toggle ON/OFF ─────────────────────────────────────────────────────────── */
.fm-toggle-wrap  { display: flex; align-items: center; cursor: pointer; padding: .1rem; }
.fm-toggle-input { display: none; }
.fm-toggle-track {
  width: 38px;
  height: 20px;
  background: rgba(139,148,158,.3);
  border: 1px solid rgba(139,148,158,.4);
  border-radius: 10px;
  position: relative;
  transition: background .2s, border-color .2s;
  flex-shrink: 0;
}
.fm-toggle-input:checked + .fm-toggle-track {
  background: rgba(88,166,255,.35);
  border-color: var(--accent);
}
.fm-toggle-thumb {
  position: absolute;
  top: 2px;
  left: 2px;
  width: 14px;
  height: 14px;
  background: #8b949e;
  border-radius: 50%;
  transition: transform .2s, background .2s;
  box-shadow: 0 1px 3px rgba(0,0,0,.5);
}
.fm-toggle-input:checked + .fm-toggle-track .fm-toggle-thumb {
  transform: translateX(18px);
  background: var(--accent);
}

/* ── Ligne d'erreur ──────────────────────────────────────────────────────── */
.fm-error-row {
  padding: .38rem .75rem .45rem 2.5rem;
  font-size: .73rem;
  color: var(--err);
  background: rgba(248, 81, 73, .07);
  border-top: 1px solid rgba(248, 81, 73, .2);
}

/* ── Formulaire d'édition inline ─────────────────────────────────────────── */
.fm-edit-row {
  padding: .65rem .75rem;
  background: var(--bg);
  border-top: 1px solid var(--border);
}
.fm-edit-grid {
  display: grid;
  grid-template-columns: 1fr 2fr auto 56px;
  gap: .4rem;
  margin-bottom: .45rem;
}
@media (max-width: 540px) { .fm-edit-grid { grid-template-columns: 1fr; } }
.fm-edit-actions { display: flex; gap: .4rem; }
.fm-edit-errors  { margin-bottom: .4rem; }
.fm-err-item     { font-size: .75rem; color: var(--err); padding: .15rem 0; }

/* ── État vide ───────────────────────────────────────────────────────────── */
.fm-empty {
  padding: 1.5rem;
  text-align: center;
  color: #6e7681;
  font-size: .83rem;
  font-style: italic;
}

/* ── Panneau d'ajout ─────────────────────────────────────────────────────── */
.fm-add-panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 7px;
  padding: .85rem .9rem;
  margin-top: .5rem;
}
.fm-section-title {
  font-size: .85rem;
  font-weight: 600;
  color: var(--text);
  margin: 0 0 .65rem;
}
.fm-add-grid {
  display: grid;
  grid-template-columns: 1fr 2fr auto 56px;
  gap: .4rem;
  margin-bottom: .5rem;
  align-items: start;
}
@media (max-width: 600px) { .fm-add-grid { grid-template-columns: 1fr; } }
.fm-icon-input { text-align: center; }

.fm-error-panel {
  display: flex;
  flex-direction: column;
  gap: .15rem;
  margin-bottom: .5rem;
}

/* ── Pied de l'onglet Flux ───────────────────────────────────────────────── */
.fm-footer-actions {
  display: flex;
  gap: .5rem;
  justify-content: flex-end;
  margin-top: .85rem;
  flex-wrap: wrap;
  border-top: 1px solid var(--border);
  padding-top: .85rem;
}

/* ── KPI digest (2e rangée Stats) ────────────────────────────────────────── */
.kpi-section-label {
  font-size: .68rem; font-weight: 700; color: var(--text2);
  text-transform: uppercase; letter-spacing: .6px;
  padding: .1rem 0 .1rem .1rem;
  border-left: 2px solid var(--border);
}
.kpi-sub {
  font-size: .65rem; color: var(--text2); margin-top: .1rem;
  min-height: .9rem; /* évite le saut de hauteur quand vide */
}

/* ── Panneau Briefing ─────────────────────────────────────────────────────── */

.briefing-panel {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
}

/* En-tête du panneau */
.bp-header {
  display: flex; align-items: center; gap: 1rem; flex-wrap: wrap;
  margin-bottom: .85rem;
}
.bp-title-h3 {
  font-size: .95rem; font-weight: 700; color: var(--text);
  white-space: nowrap;
}
.bp-meta {
  font-size: .72rem; color: var(--text2); flex: 1;
}

/* États de chargement */
.bp-state {
  padding: 1.5rem; text-align: center;
  font-size: .85rem; color: var(--text2);
  border: 1px dashed var(--border); border-radius: var(--radius);
}
.bp-loading { color: var(--accent); }
.bp-error   { color: var(--err); }
.bp-empty   { color: var(--text2); }

/* Carte article top */
.bp-card {
  border: 1px solid var(--border);
  border-left-width: 3px;
  border-radius: var(--radius);
  background: var(--surface2);
  padding: .85rem 1rem;
  margin-bottom: .75rem;
  display: flex; flex-direction: column; gap: .45rem;
}
.bp-card-head {
  display: flex; align-items: baseline; gap: .6rem; flex-wrap: wrap;
  font-size: .75rem;
}
.bp-rank   { color: var(--text2); font-weight: 700; }
.bp-crit   { font-weight: 700; font-size: .8rem; }
.bp-src    { color: var(--text2); margin-right: auto; }
.bp-score-line { font-size: .72rem; color: var(--text2); }
.bp-score-line strong { color: var(--accent); }
.bp-bd     { color: var(--text2); font-size: .68rem; }

/* Titre */
.bp-title-row { font-size: .88rem; line-height: 1.4; }
.bp-title-row a { color: var(--accent); }
.bp-title-row a:hover { text-decoration: underline; }

/* Badges signaux */
.bp-signals { display: flex; gap: .4rem; flex-wrap: wrap; }
.bp-badge {
  font-size: .68rem; padding: .15rem .45rem;
  border-radius: 4px; font-weight: 600; white-space: nowrap;
}
.bp-kev   { background: #3d1a1a; color: var(--err);    border: 1px solid var(--err); }
.bp-epss  { background: #1a2a3d; color: #79c0ff;       border: 1px solid #79c0ff; }
.bp-cvss  { background: #2d1f0a; color: var(--warn);   border: 1px solid var(--warn); }
.bp-trend { background: #2d1a00; color: #ffa657;       border: 1px solid #ffa657; }
.bp-group { background: var(--surface); color: var(--text2); border: 1px solid var(--border); }

/* Étiquettes de sélection */
.bp-reasons { display: flex; gap: .3rem; flex-wrap: wrap; font-size: .72rem; }
.bp-reason {
  background: #0d2036; color: #79c0ff;
  border-radius: 4px; padding: .1rem .4rem;
  border: 1px solid #1f4068;
}

/* Clé de sujet */
.bp-topic {
  font-size: .72rem; color: var(--text2);
}
.bp-topic code {
  color: #d2a8ff; background: #1e1530;
  padding: .1rem .3rem; border-radius: 3px; font-size: .7rem;
}

/* Pourquoi important */
.bp-why {
  font-size: .78rem; color: var(--text2);
  background: var(--surface); border-left: 3px solid var(--border);
  padding: .5rem .75rem; border-radius: 0 4px 4px 0;
}

/* Watchpoints */
.bp-watchpoints {
  margin: 0; padding-left: 1.2rem;
  font-size: .75rem; color: var(--text2);
  display: flex; flex-direction: column; gap: .2rem;
}
.bp-watchpoints li { list-style: disc; }

/* Section rest */
.bp-rest { margin-top: 1rem; }
.bp-rest-h4 {
  font-size: .8rem; font-weight: 600; color: var(--text2);
  text-transform: uppercase; letter-spacing: .5px;
  margin-bottom: .5rem;
}
.bp-rest-table {
  width: 100%; border-collapse: collapse;
  font-size: .75rem; font-family: var(--font);
}
.bp-rest-table td {
  padding: .35rem .5rem;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}
.bp-rt-rank  { color: var(--text2); white-space: nowrap; width: 2.5rem; }
.bp-rt-title { word-break: break-word; }
.bp-rt-title a { color: var(--accent); }
.bp-rt-src   { color: var(--text2); white-space: nowrap; }
.bp-rt-ds    { color: var(--accent); white-space: nowrap; font-weight: 600; text-align: right; }

@media (max-width: 600px) {
  .bp-card-head { flex-direction: column; gap: .25rem; }
  .bp-rt-src, .bp-rt-ds { display: none; }
}

/* ── Panneau Santé / Ops ──────────────────────────────────────────────────── */

.health-panel {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
}

/* Grille de sections côte à côte */
.health-panel .stats-panel-inner {
  display: flex; flex-direction: column; gap: .75rem;
}
#health-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: .75rem;
}

/* Bandeau résumé */
.hp-summary {
  grid-column: 1 / -1;
  border: 1px solid var(--border); border-radius: var(--radius);
  padding: .75rem 1rem; margin-bottom: .25rem;
}
.hp-summary-ok   { border-color: var(--ok);  background: rgba(22,163,74,.07); }
.hp-summary-warn { border-color: var(--warn); background: rgba(245,158,11,.07); }
.hp-sum-status   { display: block; font-weight: 700; font-size: .85rem; margin-bottom: .45rem; }
.hp-sum-ok   { color: var(--ok); }
.hp-sum-warn { color: var(--warn); }
.hp-sum-grid {
  display: grid; grid-template-columns: max-content 1fr;
  gap: .2rem .75rem; align-items: baseline;
}
.hp-sum-lbl  { font-size: .72rem; color: var(--text2); white-space: nowrap; }
.hp-sum-val  { font-size: .78rem; color: var(--text); }
.hp-sum-cause { color: var(--warn); }

/* Section */
.hp-section {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: .75rem 1rem;
  display: flex; flex-direction: column; gap: .35rem;
}
.hp-section-head {
  font-size: .72rem; font-weight: 700;
  color: var(--text2); text-transform: uppercase; letter-spacing: .5px;
  margin-bottom: .2rem; padding-bottom: .35rem;
  border-bottom: 1px solid var(--border);
}

/* Ligne clé / valeur */
.hp-row {
  display: flex; justify-content: space-between; align-items: center;
  gap: .5rem; font-size: .78rem; flex-wrap: wrap;
}
.hp-lbl  { color: var(--text2); white-space: nowrap; }

/* Valeurs spéciales */
.hp-code { color: #d2a8ff; font-family: var(--font); font-size: .75rem; }
.hp-ts   { color: var(--text); }
.hp-null { color: var(--text2); opacity: .5; }
.hp-reason-txt { color: var(--warn); font-size: .75rem; word-break: break-word; }
.hp-val-err    { color: var(--err); }

/* Pills */
.hp-pill {
  font-size: .68rem; padding: .15rem .5rem;
  border-radius: 4px; font-weight: 600; white-space: nowrap;
}
.hp-ok   { background: #0d2d12; color: var(--ok);  border: 1px solid var(--ok); }
.hp-no   { background: #2d0d0d; color: var(--err); border: 1px solid var(--err); }
.hp-warn { background: #2d1a00; color: var(--warn); border: 1px solid var(--warn); }
.hp-err  { background: #2d0d0d; color: var(--err); border: 1px solid var(--err); }

/* Warnings */
.hp-warnings {
  margin: .25rem 0 0; padding-left: 1.1rem;
  font-size: .75rem; color: var(--warn);
  display: flex; flex-direction: column; gap: .2rem;
}
.hp-warnings li { list-style: disc; }

/* États loading/error */
.hp-state {
  grid-column: 1 / -1;
  padding: 1.5rem; text-align: center;
  font-size: .85rem; border: 1px dashed var(--border);
  border-radius: var(--radius);
}
.hp-loading { color: var(--accent); }
.hp-error   { color: var(--err); }

/* Feeds en erreur */
.hp-row-ok    { color: var(--ok); font-size: .78rem; padding: .3rem 0;
                display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; }
.hp-null-row  { color: var(--text2); font-size: .78rem; opacity: .6; padding: .3rem 0; }
.hp-feed-total     { font-size: .72rem; color: var(--text2); }
.hp-feed-total-row { font-size: .72rem; color: var(--text2); padding: .25rem 0 .1rem;
                     border-top: 1px solid var(--border); margin-top: .2rem; }
.hp-err-count {
  display: inline-block; background: var(--err); color: #fff;
  font-size: .62rem; padding: .05rem .35rem;
  border-radius: 20px; margin-left: .35rem; vertical-align: middle;
}
.hp-feed-err-row {
  display: flex; gap: .5rem; align-items: baseline;
  padding: .25rem 0; border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}
.hp-feed-err-row:last-child { border-bottom: none; }
.hp-feed-name  { font-size: .78rem; font-weight: 600; white-space: nowrap; min-width: 9rem; }
.hp-feed-id    { font-size: .68rem; color: var(--text2); font-family: var(--font); opacity: .75; }
.hp-feed-err-msg { font-size: .73rem; color: var(--err); word-break: break-all; }

/* Historique des runs */
.hp-hist-table {
  width: 100%; border-collapse: collapse; font-size: .73rem;
  margin-top: .35rem;
}
.hp-hist-table tr { border-bottom: 1px solid var(--border); }
.hp-hist-table tr:last-child { border-bottom: none; }
.hp-hist-table td { padding: .25rem .3rem; vertical-align: top; }
.hp-hist-last td  { background: rgba(255,255,255,.03); }
.hp-hist-ts    { white-space: nowrap; color: var(--text2); font-size: .7rem; }
.hp-hist-slot  { display: inline-block; font-size: .64rem; color: var(--text2); opacity: .6;
                 font-family: var(--font); margin-top: .1rem; }
.hp-hist-stats { color: var(--text2); }
.hp-hist-feeds-ok   { color: var(--ok);   font-weight: 600; font-size: .7rem; margin-right: .3rem; }
.hp-hist-feeds-warn { color: var(--warn); font-weight: 600; font-size: .7rem; margin-right: .3rem; }
.hp-hist-reason { color: var(--warn); font-size: .7rem; }
.hp-pill-sm    { font-size: .62rem; padding: .1rem .35rem; }

/* Historique des briefings envoyés */
.hp-bh-list    { display: flex; flex-direction: column; gap: .5rem; margin-top: .35rem; }
.hp-bh-card    { border: 1px solid var(--border); border-radius: var(--radius); padding: .55rem .7rem; }
.hp-bh-card-last { border-color: var(--accent); background: rgba(56,139,253,.05); }
.hp-bh-head    { display: flex; align-items: baseline; gap: .6rem; flex-wrap: wrap; margin-bottom: .35rem; }
.hp-bh-ts      { font-size: .7rem; color: var(--text2); white-space: nowrap; }
.hp-bh-count   { font-size: .75rem; white-space: nowrap; }
.hp-bh-slot    { font-size: .62rem; color: var(--text2); opacity: .7; font-family: var(--font);
                 padding: .1rem .3rem; margin-left: .3rem; background: var(--surface2);
                 border-radius: 3px; white-space: nowrap; vertical-align: middle; }
.hp-bh-subj    { font-size: .72rem; color: var(--text2); flex: 1; min-width: 0;
                 cursor: pointer; user-select: none; }
.hp-bh-subj:hover { color: var(--text); }
.hp-bh-copy-icon { font-size: .68rem; opacity: .4; margin-left: .2rem; }
.hp-bh-subj.hp-bh-copied .hp-bh-copy-icon::after { content: " ✓"; color: var(--ok); opacity: 1; }
.hp-bh-more    { font-size: .68rem; color: var(--text2); opacity: .55; margin-top: .2rem;
                 padding-left: 1rem; }
.hp-bh-art     { font-size: .73rem; padding: .15rem 0; border-top: 1px solid var(--border); line-height: 1.4; }
.hp-bh-art:first-of-type { border-top: none; }
.hp-bh-link    { color: var(--text); text-decoration: none; }
.hp-bh-link:hover { color: var(--accent); text-decoration: underline; }

@media (max-width: 600px) {
  #health-list { grid-template-columns: 1fr; }
  .hp-hist-stats { display: none; }
}

/* ── Vendor Panel ──────────────────────────────────────────────────────── */
.vendor-panel { background: var(--card-bg); border: 1px solid var(--border); border-radius: 8px; padding: 1rem; margin: .75rem 0; }
.vpanel-empty { color: var(--text-muted); padding: .5rem 0; font-size: .85rem; }
.vpanel-card { border-bottom: 1px solid var(--border); }
.vpanel-card:last-child { border-bottom: none; }
.vpanel-row { display: flex; align-items: center; gap: .5rem; padding: .55rem .25rem; cursor: pointer; border-radius: 4px; flex-wrap: wrap; }
.vpanel-row:hover { background: var(--hover-bg, rgba(255,255,255,.04)); }
.vpanel-row-open { background: var(--hover-bg, rgba(255,255,255,.04)); }
.vpanel-row-open .vpanel-chevron { transform: rotate(90deg); }
.vpanel-name { font-weight: 600; font-size: .9rem; min-width: 110px; }
.vpanel-badges { display: flex; gap: .3rem; flex-wrap: wrap; flex: 1; }
.vpanel-meta { display: flex; align-items: center; gap: .5rem; margin-left: auto; }
.vpanel-stat { font-size: .78rem; color: var(--text-muted); }
.vpanel-chevron { font-size: .7rem; color: var(--text-muted); transition: transform .2s; margin-left: .25rem; }
.vpanel-badge { font-size: .65rem; font-weight: 700; padding: .15rem .4rem; border-radius: 3px; white-space: nowrap; }
.vpanel-kev  { background: #7f1d1d; color: #fca5a5; }
.vpanel-epss { background: #1e3a5f; color: #93c5fd; }
.vpanel-wl   { background: #1a2a1a; color: #86efac; }
.vpanel-cve  { background: #1a1a2e; color: #c4b5fd; font-family: monospace; letter-spacing: .01em; }
.vpanel-crit-badge { font-size: .72rem; font-weight: 600; }
.vpanel-crit-high .vpanel-name { color: var(--crit-high, #f87171); }
.vpanel-crit-med  .vpanel-name { color: var(--crit-med,  #fbbf24); }
.vpanel-crit-low  .vpanel-name { color: var(--text-muted); }
.vpanel-detail { padding: .4rem .5rem .6rem 1.2rem; display: flex; flex-direction: column; gap: .3rem; }
.vpanel-article { display: flex; align-items: baseline; gap: .4rem; font-size: .8rem; flex-wrap: wrap; }
.vpanel-ac { font-size: .7rem; }
.vpanel-article-title { color: var(--text); text-decoration: none; flex: 1; min-width: 200px; }
.vpanel-article-title:hover { text-decoration: underline; color: var(--accent, #60a5fa); }
.vpanel-article-src { font-size: .65rem; color: var(--text-muted); white-space: nowrap; }
.vpanel-briefing { background: #1a1a3a; color: #a78bfa; }
.vpanel-search-bar  { padding:.5rem .25rem .25rem; }
.vpanel-search-input {
  width: 100%; box-sizing: border-box;
  background: var(--surface2); color: var(--text);
  border: 1px solid var(--border); border-radius: var(--radius);
  padding: .4rem .65rem; font-size: .8rem; outline: none;
}
.vpanel-search-input:focus { border-color: var(--accent); }
.vpanel-search-input::placeholder { color: var(--text2); opacity: .6; }
.vpanel-sort-bar { display:flex; align-items:center; gap:.5rem; padding:.4rem .25rem .6rem; flex-wrap:wrap; }
.vpanel-sort-label { font-size:.75rem; color:var(--text-muted); }
.vpanel-sort-select { font-size:.75rem; background:var(--card-bg); color:var(--text); border:1px solid var(--border); border-radius:4px; padding:.2rem .4rem; cursor:pointer; }
.vpanel-sort-hint { font-size:.7rem; color:var(--text-muted); font-style:italic; }
.vpanel-kpi-bar { display:flex; gap:1rem; flex-wrap:wrap; padding:.1rem 0 .4rem; }
.vpanel-kpi { display:flex; flex-direction:column; align-items:center; min-width:72px; }
.vpanel-kpi-val { font-size:1.1rem; font-weight:700; color:var(--text); line-height:1.2; }
.vpanel-kpi-lbl { font-size:.62rem; color:var(--text-muted); text-align:center; white-space:nowrap; }
.vpanel-filter-bar { display:flex; gap:.4rem; flex-wrap:wrap; padding:.25rem 0 .5rem; }
.vpanel-filter-btn { font-size:.72rem; padding:.2rem .6rem; border-radius:12px; border:1px solid var(--border); background:transparent; color:var(--text-muted); cursor:pointer; white-space:nowrap; }
.vpanel-filter-btn:hover { border-color:var(--accent,#60a5fa); color:var(--text); }
.vpanel-filter-btn.active { background:var(--accent,#60a5fa); border-color:var(--accent,#60a5fa); color:#fff; font-weight:600; }
.vpanel-article-top { background:rgba(167,139,250,.07); border-radius:4px; padding:.1rem .3rem; }
.vpanel-in-briefing { font-size:.6rem; }
.vpanel-prod-block  { width:100%; margin-bottom:.3rem; padding:.35rem .5rem .2rem;
                  border:1px solid var(--border); border-radius:4px;
                  background:rgba(255,255,255,.02); }
.vpanel-prod-head   { font-size:.62rem; text-transform:uppercase; letter-spacing:.05em;
                  color:var(--text2); opacity:.65; margin-bottom:.3rem; }
.vpanel-prod-row    { display:flex; align-items:center; gap:.4rem; flex-wrap:wrap;
                  padding:.18rem 0; font-size:.72rem; }
.vpanel-prod-row + .vpanel-prod-row { border-top:1px solid var(--border); }
.vpanel-prod-name   { min-width:7rem; color:var(--text); font-weight:500; }
.vpanel-prod-stat   { color:var(--text2); font-size:.67rem; white-space:nowrap; }

/* ── CVE Panel ────────────────────────────────────────────────────────────── */

/* Barre de contrôles (recherche + filtres) */
.cp-controls      { padding:.5rem 1rem .25rem; }
.cp-search-bar    { margin-bottom:.4rem; }
.cp-search-input  { width:100%; max-width:28rem; background:var(--card);
                    border:1px solid var(--border); border-radius:5px;
                    color:var(--text); padding:.3rem .6rem; font-size:.8rem;
                    outline:none; transition:border-color .15s; }
.cp-search-input:focus { border-color:var(--accent); }

/* Barre de filtres */
.cp-filter-bar    { display:flex; gap:.4rem; padding:0 0 .5rem; flex-wrap:wrap; }
.cp-filter-btn    { background:var(--card); border:1px solid var(--border); color:var(--text2);
                    border-radius:4px; padding:.25rem .65rem; font-size:.75rem; cursor:pointer;
                    transition:border-color .15s, color .15s; }
.cp-filter-btn:hover { border-color:var(--accent); color:var(--text); }
.cp-filter-btn.active { border-color:var(--accent); color:var(--accent); font-weight:600; }

/* ── Filtre de période (date) dans le panneau CVE ──────────────────────────── */
.cp-date-bar  { display:flex; align-items:center; gap:.35rem; padding:0 0 .5rem; flex-wrap:wrap; }
.cp-date-lbl  { font-size:.7rem; color:var(--text2); margin-right:.1rem; white-space:nowrap; }
.cp-date-btn  { background:transparent; border:1px solid var(--border); color:var(--text2);
                border-radius:4px; padding:.2rem .55rem; font-size:.72rem; cursor:pointer;
                transition:border-color .15s, color .15s; }
.cp-date-btn:hover  { border-color:var(--accent); color:var(--text); }
.cp-date-btn.active { border-color:#a371f7; color:#a371f7; font-weight:600;
                      background:rgba(163,113,247,.07); }

/* Table principale */
.cp-table         { width:100%; border-collapse:collapse; font-size:.78rem; }
.cp-thead th      { text-align:left; padding:.4rem .6rem; color:var(--text2);
                    font-size:.68rem; font-weight:600; text-transform:uppercase;
                    letter-spacing:.04em; border-bottom:1px solid var(--border); }
.cp-th-num        { text-align:right !important; }

/* Ligne CVE cliquable */
.cp-row           { cursor:pointer; border-bottom:1px solid var(--border);
                    transition:background .12s; }
.cp-row:hover     { background:rgba(88,166,255,.06); }
.cp-row.cp-row-open { background:rgba(88,166,255,.1); }
.cp-row td        { padding:.45rem .6rem; vertical-align:middle; }

/* Détail expandable */
.cp-detail-row td { padding:0; background:var(--bg); }
.cp-detail-inner  { padding:.6rem 1rem .8rem 2rem;
                    border-left:2px solid var(--accent);
                    border-bottom:1px solid var(--border); }
.cp-detail-head   { margin:0 0 .5rem; font-size:.75rem; color:var(--text2); }

/* Ligne article dans le détail */
.cp-art-row       { display:flex; align-items:center; gap:.5rem; flex-wrap:wrap;
                    padding:.25rem 0; border-top:1px solid var(--border); font-size:.74rem; }
.cp-art-row:first-of-type { border-top:none; }
.cp-art-date      { min-width:7rem; white-space:nowrap; font-family:monospace; }
.cp-art-cri       { font-size:.8rem; }
.cp-art-src       { min-width:9rem; white-space:nowrap; overflow:hidden;
                    text-overflow:ellipsis; max-width:12rem; }
.cp-art-badges    { display:flex; gap:.25rem; flex-shrink:0; }
.cp-art-title     { color:var(--link); text-decoration:none; font-size:.74rem;
                    flex:1; min-width:0; word-break:break-word; }
.cp-art-title:hover { text-decoration:underline; }

/* Badges signaux */
.cp-badge         { display:inline-block; font-size:.62rem; padding:.1rem .35rem;
                    border-radius:3px; font-weight:600; white-space:nowrap; }
.cp-kev           { background:#2d1515; color:#f85149; }
.cp-wl            { background:#0d2818; color:#3fb950; }
.cp-tr            { background:#1a1300; color:#f0883e; }
.cp-epss          { background:#1a1a2e; color:#c4b5fd; font-family:monospace; }

/* Typo utilitaires */
.cp-cve-id        { font-family:monospace; font-size:.77rem;
                    color:var(--accent); background:transparent; }
.cp-num           { text-align:right; font-family:monospace; font-size:.75rem; }
.cp-dim           { color:var(--text2); }

/* CVE table — Search in Trend per-row action */
.cp-th-trend      { text-align:center !important; width:5.5rem; }
.cp-td-trend      { text-align:center; white-space:nowrap; }
.cp-trend-btn     { background:none; border:1px solid rgba(88,166,255,.25); color:#58a6ff;
                    border-radius:4px; padding:.1rem .4rem; font-size:.7rem; cursor:pointer;
                    line-height:1.4; transition:background .15s; }
.cp-trend-btn:hover     { background:rgba(88,166,255,.12); }
.cp-trend-btn:disabled  { color:#8b949e; border-color:rgba(139,148,158,.18); cursor:default; }
.cp-trend-found   { font-size:.7rem; font-weight:600; }
.cp-trend-empty   { font-size:.7rem; color:#8b949e; }
.cp-trend-unknown { font-style:italic; }
.cp-vendors-cell  { max-width:18rem; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

/* CVE detail — inline Search in Trend block */
.cp-detail-trend        { display:flex; align-items:center; gap:.5rem; padding:.35rem 0 .2rem; }
.cp-detail-trend-btn    { font-size:.75rem; padding:.18rem .55rem; border-radius:4px; border:1px solid var(--border,#30363d); background:transparent; color:var(--text,#e6edf3); cursor:pointer; }
.cp-detail-trend-btn:hover { background:var(--hover-bg,rgba(255,255,255,.04)); }
.cp-detail-trend-result { font-size:.8rem; }

/* État vide */
.cp-empty         { padding:1.5rem 1rem; color:var(--text2); font-size:.82rem; }

/* Fallback vendor — articles sans CVE ID */
.cp-vendor-fallback {
  margin: .75rem 0 1rem;
  border: 1px solid rgba(240,136,62,.35);
  border-radius: 6px;
  background: rgba(240,136,62,.04);
  overflow: hidden;
}
.cp-vendor-fallback-hdr {
  padding: .6rem .9rem;
  font-size: .78rem;
  color: #f0883e;
  border-bottom: 1px solid rgba(240,136,62,.2);
}
.cp-vendor-fallback-articles { padding: .25rem .4rem; }
.cp-vendor-fallback-note {
  padding: .5rem .9rem;
  font-size: .72rem;
  color: var(--text2);
  border-top: 1px solid rgba(240,136,62,.15);
  background: rgba(240,136,62,.03);
}
.cp-vendor-fallback-note code {
  background: rgba(255,255,255,.08);
  padding: .1rem .3rem;
  border-radius: 3px;
  font-size: .72rem;
}

/* Lien CVE depuis Top CVEs (stats.js) */
.cp-cve-link      { cursor:pointer; color:var(--accent); font-family:monospace;
                    font-size:.8rem; text-decoration:underline dotted; }
.cp-cve-link:hover{ text-decoration:underline; }
.cp-nvd-link      { color:var(--text2); font-size:.7rem; margin-left:.25rem;
                    text-decoration:none; opacity:.6; }

/* ══════════════════════════════════════════════════════════════════════════
   INCIDENT PANEL  (.ip-*)
   ══════════════════════════════════════════════════════════════════════════ */

/* Barre de filtres + recherche */
.ip-toolbar        { display:flex; align-items:center; gap:.5rem; flex-wrap:wrap;
                     padding:.55rem 1rem; border-bottom:1px solid var(--border); }
.ip-filter-btn     { background:var(--surface2); border:1px solid var(--border);
                     color:var(--text2); border-radius:4px; padding:.2rem .55rem;
                     font-size:.72rem; cursor:pointer; transition:all .12s; white-space:nowrap; }
.ip-filter-btn:hover  { color:var(--text); border-color:var(--accent); }
.ip-filter-btn.active { background:rgba(88,166,255,.15); color:var(--accent);
                         border-color:var(--accent); }
.ip-search         { margin-left:auto; background:var(--surface2);
                     border:1px solid var(--border); border-radius:4px;
                     color:var(--text); padding:.25rem .55rem; font-size:.75rem;
                     font-family:var(--font); min-width:14rem; }
.ip-search:focus   { outline:none; border-color:var(--accent); }

/* Table incidents */
.ip-table          { width:100%; border-collapse:collapse; font-size:.78rem; }
.ip-thead th       { text-align:left; padding:.4rem .6rem; color:var(--text2);
                     font-size:.68rem; font-weight:600; text-transform:uppercase;
                     letter-spacing:.04em; border-bottom:1px solid var(--border); }
.ip-th-num         { text-align:right !important; }

/* Ligne incident cliquable */
.ip-row            { cursor:pointer; border-bottom:1px solid var(--border);
                     transition:background .12s; }
.ip-row:hover      { background:rgba(88,166,255,.06); }
.ip-row.ip-row-open { background:rgba(88,166,255,.1); }
.ip-row td         { padding:.45rem .6rem; vertical-align:middle; }

/* Titre incident */
.ip-title          { font-size:.8rem; color:var(--text); word-break:break-word; }
.ip-cves           { font-family:monospace; font-size:.7rem; color:var(--text2);
                     margin-top:.15rem; }

/* Détail expandable — timeline */
.ip-detail-row td  { padding:0; background:var(--bg); }
.ip-detail-inner   { padding:.6rem 1rem .8rem 2rem;
                     border-left:2px solid var(--accent);
                     border-bottom:1px solid var(--border); }
.ip-detail-head    { margin:0 0 .5rem; font-size:.75rem; color:var(--text2); }

/* Ligne article dans la timeline */
.ip-tl-row         { display:flex; align-items:center; gap:.5rem; flex-wrap:wrap;
                     padding:.25rem 0; border-top:1px solid var(--border); font-size:.74rem; }
.ip-tl-row:first-of-type { border-top:none; }
.ip-tl-date        { min-width:7rem; white-space:nowrap; font-family:monospace; }
.ip-tl-cri         { font-size:.8rem; }
.ip-tl-src         { min-width:9rem; white-space:nowrap; overflow:hidden;
                     text-overflow:ellipsis; max-width:12rem; color:var(--text2); }
.ip-tl-badges      { display:flex; gap:.25rem; flex-shrink:0; }
.ip-tl-title       { color:var(--accent); text-decoration:none; font-size:.74rem;
                     flex:1; min-width:0; word-break:break-word; }
.ip-tl-title:hover { text-decoration:underline; }

/* Badges signaux (réutilise cp-badge mais préfixés ip-) */
.ip-badge          { display:inline-block; font-size:.62rem; padding:.1rem .35rem;
                     border-radius:3px; font-weight:600; white-space:nowrap; }
.ip-kev            { background:#2d1515; color:#f85149; }
.ip-wl             { background:#0d2818; color:#3fb950; }
.ip-epss           { background:#1a1a2e; color:#c4b5fd; font-family:monospace; }

/* Colonne numérique */
.ip-num            { text-align:right; font-family:monospace; font-size:.75rem; }
.ip-dim            { color:var(--text2); }
.ip-vendors-cell   { max-width:18rem; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
                     color:var(--text2); font-size:.73rem; }

/* État vide */
.ip-empty          { padding:1.5rem 1rem; color:var(--text2); font-size:.82rem; }
.cp-nvd-link:hover{ opacity:1; color:var(--accent); }

/* ─────────────────────────────────────────────────────────────────────────── */
/* Saved Filters modal (.sf-*)                                                 */
/* ─────────────────────────────────────────────────────────────────────────── */
.sf-save-row        { display:flex; gap:.5rem; padding:.75rem 1.25rem;
                      border-bottom:1px solid var(--border); align-items:center; }
.sf-save-input      { flex:1; background:var(--card); border:1px solid var(--border);
                      border-radius:6px; padding:.4rem .7rem; font-size:.85rem;
                      color:var(--text); min-width:0; }
.sf-save-input:focus      { outline:none; border-color:var(--accent); }
.sf-save-input.sf-input-error { border-color:#f85149; }

.sf-preset-list     { padding:.25rem 0; max-height:400px; overflow-y:auto; }
.sf-empty           { text-align:center; color:var(--text2); font-size:.82rem;
                      padding:2rem 1rem; }
.sf-preset-row      { display:flex; align-items:center; gap:.65rem;
                      padding:.55rem 1.25rem; border-bottom:1px solid var(--border);
                      flex-wrap:wrap; }
.sf-preset-row:last-child { border-bottom:none; }

.sf-view-badge      { font-size:.67rem; padding:.15rem .45rem; border-radius:4px;
                      background:rgba(88,166,255,.15); color:var(--accent);
                      white-space:nowrap; flex-shrink:0; }
.sf-preset-info     { display:flex; flex-direction:column; gap:.1rem; flex:1; min-width:0; }
.sf-preset-name     { font-size:.84rem; font-weight:600; color:var(--text);
                      white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sf-preset-meta     { font-size:.71rem; color:var(--text2);
                      white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sf-preset-actions  { display:flex; gap:.35rem; flex-shrink:0; }
.sf-apply-btn       { font-size:.75rem; padding:.2rem .6rem; }
.sf-delete-btn      { font-size:.75rem; padding:.2rem .45rem; opacity:.5; }
.sf-delete-btn:hover { opacity:1; color:#f85149; border-color:#f85149; }
.sf-update-btn      { font-size:.75rem; padding:.2rem .45rem; opacity:.55; }
.sf-update-btn:hover { opacity:1; color:var(--accent); border-color:var(--accent); }

/* ── Sprint 17 : Profile-scoped presets ─────────────────────────────────── */
/* Scope badge */
.sf-scope            { display:inline-flex; align-items:center; justify-content:center;
                       font-size:.8rem; width:1.4rem; flex-shrink:0;
                       opacity:.85; }
.sf-scope-global     { opacity:.55; }
.sf-scope-profile    { opacity:1; }

/* Group labels */
.sf-group-label      { font-size:.67rem; font-weight:600; text-transform:uppercase;
                       letter-spacing:.06em; color:var(--text2); padding:.6rem 1.25rem .25rem;
                       border-top:1px solid var(--border); margin-top:.15rem; }
.sf-group-label:first-child { border-top:none; margin-top:0; }

/* Presets from other profiles — dimmed */
.sf-row-other        { opacity:.6; }
.sf-row-other:hover  { opacity:1; }

/* Profile hint below save input */
.sf-profile-hint     { display:flex; align-items:center; gap:.4rem; padding:.3rem 0 .1rem;
                       font-size:.74rem; color:var(--text2); }
.sf-profile-hint-text strong { color:var(--text); }

/* ── Bouton statut inline dans les cartes ────────────────────────────────── */
.card-status-btn {
  font-size: .68rem; font-weight: 600;
  padding: .15rem .5rem; border-radius: 4px;
  border: 1px solid rgba(255,255,255,.12);
  cursor: pointer; white-space: nowrap;
  transition: opacity .15s, transform .1s;
  line-height: 1.4; letter-spacing: .02em;
}
.card-status-btn:hover { opacity: .8; transform: scale(1.04); }
.card-status-new {
  color: #8b949e !important;
  background: rgba(139,148,158,.1) !important;
  border-color: rgba(139,148,158,.25) !important;
  opacity: 1;
}
.card-status-new:hover { opacity: .8; }

/* ── États analyste — entity-status.js ──────────────────────────────────── */
.es-badge-slot  { display:inline; }
.es-badge       { display:inline-flex; align-items:center; gap:.2rem;
                  font-size:.6rem; font-weight:600; padding:.1rem .4rem;
                  border-radius:3px; white-space:nowrap; vertical-align:middle;
                  margin-right:.25rem; }

.es-block       { margin:.5rem 0 .7rem; padding:.45rem .65rem;
                  border:1px solid var(--border); border-radius:6px;
                  background:rgba(255,255,255,.025); }
.es-label       { display:block; font-size:.62rem; color:var(--text2);
                  text-transform:uppercase; letter-spacing:.05em; margin-bottom:.35rem; }
.es-row         { display:flex; gap:.5rem; align-items:center; flex-wrap:wrap; }
.es-select      { font-size:.72rem; background:var(--card); color:var(--text);
                  border:1px solid var(--border); border-radius:4px;
                  padding:.2rem .45rem; cursor:pointer; flex-shrink:0; }
.es-note-input  { flex:1; min-width:10rem; font-size:.72rem;
                  background:var(--card); color:var(--text);
                  border:1px solid var(--border); border-radius:4px;
                  padding:.2rem .5rem; }
.es-select:focus,
.es-note-input:focus,
.es-owner-input:focus { outline:none; border-color:var(--accent); }
.es-owner-input { flex:1; min-width:10rem; font-size:.72rem;
                  background:var(--card); color:var(--text);
                  border:1px solid var(--border); border-radius:4px;
                  padding:.2rem .5rem; }
.es-owner-row   { margin-top:.3rem; }
.es-block-header{ display:flex; align-items:center; justify-content:space-between;
                  margin-bottom:.35rem; }
.es-block-header .es-label { margin-bottom:0; }
.es-updated     { font-size:.6rem; color:var(--text2); opacity:.7; }

/* Barres de filtre statut (incidents + cves) */
.ip-status-bar,
.cp-status-bar  { display:flex; gap:.3rem; flex-wrap:wrap;
                  padding:.35rem 0 0; margin-top:.3rem;
                  border-top:1px solid var(--border); }
.ip-status-btn,
.cp-status-btn  { background:transparent; border:1px solid var(--border);
                  border-radius:4px; padding:.18rem .5rem;
                  font-size:.67rem; cursor:pointer; color:var(--text2);
                  transition:background .12s, color .12s; white-space:nowrap; }
.ip-status-btn:hover,
.cp-status-btn:hover { color:var(--text); }
.ip-status-btn.active,
.cp-status-btn.active { background:rgba(88,166,255,.15);
                        color:var(--accent); border-color:var(--accent);
                        font-weight:600; }

/* ── Panneau Visibilité — visibility-panel.js ──────────────────────────── */
.vb-header      { display:flex; align-items:center; gap:1rem; flex-wrap:wrap; margin-bottom:.75rem; }
.vb-title-h3    { font-size:1rem; font-weight:700; margin:0; }

.vb-section     { margin-bottom:1.5rem; }
.vb-section-title { font-size:.82rem; font-weight:700; margin:0 0 .2rem; letter-spacing:.01em; }
.vb-section-sub   { font-size:.68rem; color:var(--text2); margin:0 0 .6rem; }

.vb-two-col  { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; }
.vb-col      { min-width:0; }
@media (max-width:720px) { .vb-two-col { grid-template-columns:1fr; } }

/* KPI Cards */
.vb-kpi-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(118px,1fr)); gap:.55rem; margin-bottom:.25rem; }
.vb-kpi-card { background:var(--surface); border:1px solid var(--border); border-radius:8px;
               padding:.85rem .65rem; text-align:center;
               display:flex; flex-direction:column; align-items:center; gap:.22rem; }
.vb-kpi-ok   { border-top:3px solid var(--ok); }
.vb-kpi-warn { border-top:3px solid var(--warn); }
.vb-kpi-err  { border-top:3px solid var(--err); }
.vb-kpi-neutral { border-top:3px solid var(--border); }
.vb-kpi-icon  { font-size:1.05rem; line-height:1; }
.vb-kpi-value { font-size:1.55rem; font-weight:700; line-height:1.1; letter-spacing:-.02em; }
.vb-kpi-label { font-size:.6rem; color:var(--text2); text-transform:uppercase; letter-spacing:.05em; }

/* Enrichment bars */
.vb-enr-list  { display:flex; flex-direction:column; gap:.38rem; }
.vb-enr-row   { display:flex; align-items:center; gap:.45rem; }
.vb-enr-icon  { font-size:.8rem; flex-shrink:0; width:1.1rem; text-align:center; }
.vb-enr-label { font-size:.7rem; flex:0 0 125px; color:var(--text2); white-space:nowrap;
                overflow:hidden; text-overflow:ellipsis; }
.vb-enr-bar-wrap { flex:1; height:5px; background:var(--border); border-radius:3px; overflow:hidden; min-width:30px; }
.vb-enr-bar-fill { height:100%; border-radius:3px; min-width:2px; }
.vb-enr-pct   { font-size:.68rem; font-weight:600; width:2.4rem; text-align:right; flex-shrink:0; }

/* Feed table */
.vb-feed-scroll   { overflow-x:auto; }
.vb-feed-table    { width:100%; border-collapse:collapse; font-size:.71rem; }
.vb-thead th      { color:var(--text2); font-size:.63rem; text-transform:uppercase;
                    letter-spacing:.04em; padding:.22rem .45rem;
                    border-bottom:1px solid var(--border); text-align:left; white-space:nowrap; }
.vb-feed-row      { border-bottom:1px solid var(--border); transition:background .1s; }
.vb-feed-row:hover { background:rgba(255,255,255,.028); }
.vb-feed-row td   { padding:.32rem .45rem; vertical-align:middle; }
.vb-feed-name     { display:flex; align-items:center; gap:.3rem; font-weight:600; white-space:nowrap; }
.vb-feed-meta     { color:var(--text2); font-size:.65rem; white-space:nowrap; }
.vb-feed-err      { color:var(--err); font-size:.65rem; }
.vb-errmsg        { max-width:180px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

/* Top tables (vendors + incidents) */
.vb-top-table { width:100%; border-collapse:collapse; font-size:.71rem; }
.vb-top-row   { border-bottom:1px solid var(--border); transition:background .1s; }
.vb-top-row:hover { background:rgba(255,255,255,.028); }
.vb-top-row td { padding:.3rem .45rem; vertical-align:middle; }
.vb-inc-title  { max-width:200px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.vb-num        { text-align:right; color:var(--text2); white-space:nowrap; }
.vb-dim        { color:var(--text2); font-size:.68rem; }
.vb-empty      { color:var(--text2); font-style:italic; font-size:.76rem; padding:.6rem 0; }

/* Badges inline Visibilité */
.vb-badge   { display:inline-flex; align-items:center; font-size:.6rem; font-weight:600;
              padding:.1rem .35rem; border-radius:3px; white-space:nowrap; }
.vb-ok      { background:rgba(63,185,80,.14);   color:var(--ok); }
.vb-warn    { background:rgba(240,136,62,.14);  color:var(--warn); }
.vb-err     { background:rgba(248,81,73,.14);   color:var(--err); }
.vb-muted   { background:var(--surface2); color:var(--text2); }
.vb-neutral { background:var(--surface2); color:var(--text); }

/* ══════════════════════════════════════════════════════════════════════════
   IOC UTILS  (.ioc-*)  — ioc-utils.js V1
   ══════════════════════════════════════════════════════════════════════════ */

/* Bloc principal */
.ioc-block            { margin:.65rem 0 .5rem; border:1px solid var(--border);
                        border-left:3px solid #79c0ff; border-radius:6px;
                        background:rgba(121,192,255,.03); overflow:hidden; }

/* En-tête du bloc */
.ioc-block-head       { display:flex; align-items:center; gap:.5rem; flex-wrap:wrap;
                        padding:.38rem .65rem;
                        border-bottom:1px solid var(--border);
                        background:rgba(121,192,255,.07); }
.ioc-block-title      { font-size:.72rem; font-weight:700; color:#79c0ff;
                        white-space:nowrap; }
.ioc-block-count      { font-size:.67rem; color:var(--text2);
                        margin-right:auto; white-space:nowrap; }
.ioc-block-actions    { display:flex; gap:.3rem; flex-shrink:0; flex-wrap:wrap; }

/* Section par type (IPs, Domaines, URLs, Hashes) */
.ioc-section          { padding:.32rem .65rem; border-bottom:1px solid var(--border); }
.ioc-section:last-child { border-bottom:none; }

.ioc-section-head     { display:flex; align-items:center; gap:.35rem; margin-bottom:.28rem; }
.ioc-type-icon        { font-size:.75rem; flex-shrink:0; }
.ioc-type-label       { font-size:.68rem; font-weight:600; color:var(--text); }
.ioc-type-count       { font-size:.64rem; color:var(--text2); margin-right:auto; }

/* Liste des valeurs IOC */
.ioc-list             { display:flex; flex-wrap:wrap; gap:.28rem .45rem; }
.ioc-item             { display:inline-flex; align-items:center; gap:.18rem; }
.ioc-val              { font-family:monospace; font-size:.67rem; color:var(--text);
                        background:var(--surface2); border:1px solid var(--border);
                        border-radius:3px; padding:.07rem .28rem;
                        max-width:32rem; overflow:hidden;
                        text-overflow:ellipsis; white-space:nowrap; }

/* Boutons IOC (cohérents avec le thème existant) */
.ioc-copy-one,
.ioc-copy-group,
.ioc-copy-all,
.ioc-export-json,
.ioc-export-txt       { background:transparent; border:1px solid var(--border);
                        border-radius:3px; color:var(--text2); cursor:pointer;
                        font-family:var(--font); font-size:.62rem;
                        padding:.07rem .3rem; white-space:nowrap;
                        transition:color .12s, border-color .12s; }
.ioc-copy-one:hover,
.ioc-copy-group:hover,
.ioc-copy-all:hover   { color:var(--accent); border-color:var(--accent); }
.ioc-export-json:hover,
.ioc-export-txt:hover { color:var(--ok); border-color:var(--ok); }

/* Badge IOC dans la colonne Signaux de l'incident panel */
.ip-ioc               { background:rgba(121,192,255,.12); color:#79c0ff; }

/* Message "aucun IOC" dans le détail */
.ip-ioc-empty         { margin:.5rem 0 .4rem; font-size:.74rem; color:var(--text2);
                        font-style:italic; padding:.3rem 0; }

/* ── Priorité incident — ligne dans la cellule titre ─────────────────────── */
.ip-prio-line         { font-size:.68rem; padding:.1rem .4rem .1rem .5rem;
                        border-radius:3px; margin-bottom:.18rem;
                        border-left:2px solid currentColor; display:flex;
                        align-items:center; gap:.3rem; flex-wrap:wrap; }
.ip-prio-score        { font-family:monospace; font-size:.65rem; opacity:.8; }
.ip-prio-reason       { opacity:.85; font-style:italic; }

/* ── Priorité dans le détail expandé ─────────────────────────────────────── */
.ip-prio-header       { display:flex; align-items:center; gap:.6rem; flex-wrap:wrap;
                        font-size:.74rem; padding:.28rem .5rem;
                        border-radius:4px; margin-bottom:.3rem;
                        border-left:3px solid currentColor; }
.ip-prio-badge        { font-size:.8rem; font-weight:700; }
.ip-prio-pts          { font-family:monospace; font-size:.7rem; }
.ip-prio-reasons      { font-size:.7rem; font-style:italic; opacity:.85;
                        border-left:1px solid rgba(255,255,255,.15);
                        padding-left:.5rem; }

/* Résumé lisible de l'incident */
.ip-summary           { margin:.1rem 0 .4rem; font-size:.74rem; color:var(--text2);
                        line-height:1.4; }

/* ── Compact reasoning block (incident detail) ──────────────────────────── */
.ip-reasoning         { border:1px solid var(--border); border-radius:6px;
                        overflow:hidden; margin:.35rem 0 .65rem; }
.ip-rsn-row           { display:flex; align-items:flex-start; gap:.55rem;
                        padding:.35rem .65rem;
                        border-top:1px solid var(--border); }
.ip-rsn-row:first-child { border-top:none; }
.ip-rsn-lbl           { font-size:.6rem; font-weight:700; color:var(--text2);
                        letter-spacing:.05em; text-transform:uppercase;
                        white-space:nowrap; min-width:6.5rem; flex-shrink:0;
                        padding-top:.17rem; }
.ip-rsn-why           { display:flex; flex-direction:column; gap:.1rem; flex:1; }
.ip-rsn-why-item      { font-size:.75rem; color:var(--text); line-height:1.35; }
.ip-rsn-why-item::before { content:"·"; margin-right:.3rem; color:#a371f7; }
.ip-rsn-tags          { display:flex; flex-wrap:wrap; gap:.25rem;
                        align-items:center; flex:1; }
.ip-rsn-score         { background:rgba(88,166,255,.1); color:var(--accent); }
.ip-rsn-src           { font-size:.65rem; color:var(--text2); font-family:monospace; }
.ip-rsn-focus         { font-size:.75rem; font-weight:500; color:var(--text);
                        line-height:1.35; flex:1; }

/* Barre de tri incidents */
.ip-sort-bar          { display:flex; align-items:center; gap:.3rem; flex-wrap:wrap;
                        padding:.3rem 1rem; border-top:1px solid var(--border); }
.ip-sort-label        { font-size:.7rem; }
.ip-sort-btn          { background:var(--surface2); border:1px solid var(--border);
                        color:var(--text2); border-radius:4px; padding:.2rem .55rem;
                        font-size:.72rem; cursor:pointer; transition:all .12s; }
.ip-sort-btn:hover    { color:var(--text); border-color:var(--accent); }
.ip-sort-btn.active   { background:rgba(88,166,255,.15); color:var(--accent);
                        border-color:var(--accent); }

/* ═══════════════════════════════════════════════════════════════════════════
   PRIORITÉ EXPLICABLE — computePriority() — scorer.js V2
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Ligne de priorité dans les cartes de la vue principale ───────────────── */
.card-priority-line {
  font-size: .71rem;
  font-weight: 500;
  padding: 3px 8px 3px 10px;
  border-radius: 4px;
  margin-bottom: 5px;
  border-left: 3px solid transparent;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 3px;
  line-height: 1.35;
}
.card-priority-line strong { font-weight: 700; }
/* ── Sprint Surface the Reasoning — raisons visibles directement ─────────── */
/* Séparateur · entre le niveau et chaque raison */
.card-why-sep    { opacity: .4; margin: 0 2px; flex-shrink: 0; }
/* 2e/3e raison — légèrement atténuée pour hiérarchiser visuellement */
.card-why-dim    { opacity: .78; }
/* 2e raison dans la ligne priorité incident */
.ip-prio-reason-dim { opacity: .75; }

.prio-critical-now {
  color: #f85149;
  border-left-color: #f85149;
  background: rgba(248,81,73,.08);
}
.prio-investigate {
  color: #f0883e;
  border-left-color: #f0883e;
  background: rgba(240,136,62,.08);
}
.prio-watch {
  color: #79c0ff;
  border-left-color: #79c0ff;
  background: rgba(121,192,255,.07);
}

/* ── Signal chips — explainability visuelle sur les cartes ──────────────── */
.card-signal-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  padding: 4px 10px 2px;
}

.sig-chip {
  display: inline-flex;
  align-items: center;
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .03em;
  padding: .15rem .45rem;
  border-radius: 10px;
  white-space: nowrap;
  border: 1px solid transparent;
  cursor: default;
  line-height: 1.3;
  transition: opacity .12s;
}
.sig-chip:hover { opacity: .8; }

/* Niveau de priorité */
.sig-chip-critical-now { color:#f85149; background:rgba(248,81,73,.15); border-color:rgba(248,81,73,.35); }
.sig-chip-investigate  { color:#f0883e; background:rgba(240,136,62,.13); border-color:rgba(240,136,62,.32); }
.sig-chip-watch        { color:#79c0ff; background:rgba(121,192,255,.11); border-color:rgba(121,192,255,.28); }

/* KEV */
.sig-chip-kev          { color:#ff6b35; background:rgba(255,107,53,.14); border-color:rgba(255,107,53,.4); }

/* EPSS */
.sig-chip-epss-high    { color:#f85149; background:rgba(248,81,73,.13); border-color:rgba(248,81,73,.3); }
.sig-chip-epss-med     { color:#d29922; background:rgba(210,153,34,.13); border-color:rgba(210,153,34,.3); }
.sig-chip-epss-low     { color:#8b949e; background:rgba(139,148,158,.1); border-color:rgba(139,148,158,.2); }

/* 0-Day */
.sig-chip-zeroday      { color:#ff4040; background:rgba(255,64,64,.14); border-color:rgba(255,64,64,.35); }

/* Watchlist */
.sig-chip-watchlist    { color:#58a6ff; background:rgba(88,166,255,.12); border-color:rgba(88,166,255,.3); }

/* ATT&CK */
.sig-chip-attack       { color:#bc8cff; background:rgba(188,140,255,.11); border-color:rgba(188,140,255,.28); }

/* Sources */
.sig-chip-sources      { color:#3fb950; background:rgba(63,185,80,.11); border-color:rgba(63,185,80,.28); }
.sig-chip-sources-dim  { color:#8b949e; background:rgba(139,148,158,.08); border-color:rgba(139,148,158,.18); }

/* IOC */
.sig-chip-ioc          { color:#e3b341; background:rgba(227,179,65,.11); border-color:rgba(227,179,65,.28); }

/* ── Score breakdown tooltip sur le chip de niveau ──────────────────────── */
.sig-chip-level.has-score-tip {
  position: relative;
  cursor: default;
}

/* Popup — always rendered (visibility:hidden) so getBoundingClientRect() works for
   JS viewport-aware positioning; revealed at hover via opacity/visibility transition */
.score-tip-popup {
  display: flex;
  flex-direction: column;
  gap: 3px;
  visibility: hidden;
  opacity: 0;
  /* Instant hide, fast reveal — avoids flicker on quick mouse passes */
  transition: opacity .12s ease, visibility 0s .12s;
  position: absolute;
  top: calc(100% + 7px);
  left: 0;
  z-index: 1300;  /* above .qa-ticket-modal (1200) */
  min-width: 170px;
  max-width: 220px;
  background: #1c2128;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 8px;
  padding: 8px 10px;
  box-shadow: 0 6px 20px rgba(0,0,0,.55);
  pointer-events: none;
}

/* Petite flèche — default: points up (tooltip is below chip) */
.score-tip-popup::before {
  content: '';
  position: absolute;
  top: -5px; left: 12px;
  width: 8px; height: 8px;
  background: #1c2128;
  border-left: 1px solid rgba(255,255,255,.14);
  border-top:  1px solid rgba(255,255,255,.14);
  transform: rotate(45deg);
}

.sig-chip-level.has-score-tip:hover .score-tip-popup {
  visibility: visible;
  opacity: 1;
  transition: opacity .12s ease, visibility 0s 0s;
}

/* JS-applied modifier: tooltip opens above the chip */
.score-tip-popup.tip-above::before {
  top: auto;
  bottom: -5px;
  transform: rotate(225deg); /* flipped: now points down */
}

/* JS-applied modifier: tooltip is right-aligned to chip edge */
.score-tip-popup.tip-right::before {
  left: auto;
  right: 12px;
}

/* Ligne d'en-tête */
.stp-head {
  font-size: .67rem;
  font-weight: 700;
  color: #e6edf3;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding-bottom: 4px;
  border-bottom: 1px solid rgba(255,255,255,.09);
  margin-bottom: 2px;
}

/* Lignes contributeurs */
.stp-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  font-size: .68rem;
  line-height: 1.45;
}
.stp-lbl { color: #8b949e; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.stp-pts { color: #e6edf3; font-weight: 700; font-variant-numeric: tabular-nums; flex-shrink: 0; }

/* Lignes bonus — légèrement distinctes */
.stp-bonus .stp-lbl { color: #6e7681; font-style: italic; }
.stp-bonus .stp-pts { color: #d29922; }

/* ── Bloc "Pourquoi cette priorité ?" dans le modal article ──────────────── */
.art-priority-block {
  padding: 12px 14px;
  border-radius: 6px;
  background: var(--surface);
  border: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.art-priority-level-badge {
  font-size: .82rem;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 4px;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  align-self: flex-start;
  border: 1px solid transparent;
}
.prio-critical-now.art-priority-level-badge { background:#2d1515; color:#f85149; border-color:#f85149; }
.prio-investigate.art-priority-level-badge  { background:#2d1a00; color:#f0883e; border-color:#f0883e; }
.prio-watch.art-priority-level-badge        { background:#0d1b2e; color:#79c0ff; border-color:#79c0ff; }
.prio-low.art-priority-level-badge          { background:#21262d; color:#8b949e; border-color:#30363d; }

/* Liste des raisons */
.art-priority-reasons {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.art-priority-reasons li {
  font-size: .78rem;
  color: var(--text);   /* text2 → text : les raisons sont du contenu primaire */
  display: flex;
  align-items: flex-start;
  gap: 6px;
}
.art-priority-reasons li::before {
  content: '→';
  color: var(--accent);
  flex-shrink: 0;
}
.art-priority-no-reason {
  font-size: .77rem;
  color: var(--text2);
  font-style: italic;
  margin: 0;
}

/* Tableau des signaux bruts */
.art-priority-signals {
  width: 100%;
  border-collapse: collapse;
  font-size: .73rem;
}
.art-priority-signals tr + tr td { border-top: 1px solid var(--border); }
.art-psig-key {
  color: var(--text2);
  padding: 3px 10px 3px 0;
  white-space: nowrap;
  font-weight: 600;
  width: 30%;
}
.art-psig-val {
  color: var(--text);
  padding: 3px 0;
}

/* ═══════════════════════════════════════════════════════════════════════════
   WATCHLIST V2 — profil d'exposition structuré
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Formulaire d'ajout ────────────────────────────────────────────────────── */
.watchlist-add-form    { display:flex; flex-direction:column; gap:.5rem; margin-top:.75rem; }
.watchlist-add-selects { display:flex; gap:.5rem; }
.wl-select {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 4px;
  color: var(--text);
  font-family: var(--font);
  font-size: .78rem;
  padding: 5px 8px;
  cursor: pointer;
  flex: 1;
}
.wl-select:focus { outline: none; border-color: var(--accent); }
.watchlist-add-row { display:flex; gap:.5rem; }
.watchlist-add-row .settings-input { flex:1; }

/* ── Liste des items ───────────────────────────────────────────────────────── */
.wl-empty { color:var(--text2); font-size:.8rem; display:block; padding:.5rem 0; }

.wl-group          { margin-bottom:.6rem; }
.wl-group-label    { font-size:.68rem; font-weight:700; text-transform:uppercase;
                     letter-spacing:.04em; margin-bottom:.25rem; padding:.1rem .4rem;
                     border-radius:3px; display:inline-block; }

/* Couleurs des types */
.wl-type-vendor     { color:#79c0ff; background:rgba(121,192,255,.12); }
.wl-type-product    { color:#a5d6a7; background:rgba(165,214,167,.12); }
.wl-type-technology { color:#ffd54f; background:rgba(255,213,79,.10); }
.wl-type-keyword    { color:#ce93d8; background:rgba(206,147,216,.12); }

/* Item individuel */
.wl-item {
  display: flex;
  align-items: center;
  gap: .45rem;
  padding: .28rem .4rem;
  border-radius: 4px;
  font-size: .8rem;
  transition: background .1s;
}
.wl-item:hover            { background: var(--surface); }
.wl-item-disabled         { opacity: .45; }
.wl-item-quiet            { opacity: .6; }
.wl-no-match {
  font-size: 0.7rem;
  color: var(--text3, #6e7681);
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 3px;
  padding: 0.05rem 0.35rem;
  flex-shrink: 0;
  cursor: default;
}
.wl-prio-dot              { font-size: .7rem; flex-shrink:0; }
.wl-item-label            { flex:1; color:var(--text); font-weight:500;
                             overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.wl-item-type             { font-size:.65rem; font-weight:600; padding:.1rem .35rem;
                             border-radius:3px; flex-shrink:0; }

/* Boutons toggle / remove */
.wl-toggle-btn,
.wl-remove-btn {
  background: transparent;
  border: 1px solid transparent;
  border-radius: 3px;
  color: var(--text2);
  cursor: pointer;
  font-size: .7rem;
  padding: .1rem .3rem;
  transition: color .12s, border-color .12s;
  flex-shrink: 0;
}
.wl-toggle-btn:hover { color: var(--accent); border-color: var(--accent); }
.wl-remove-btn:hover  { color: var(--err);    border-color: var(--err);    }

/* ═══════════════════════════════════════════════════════════════════════════
   RECOMMANDATIONS ACTIONNABLES — recommender.js
   ═══════════════════════════════════════════════════════════════════════════ */

.reco-block {
  margin: .75rem 1.5rem 0;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}

/* Dans le panel incidents, le bloc est directement dans .ip-detail-inner */
.ip-detail-inner .reco-block {
  margin: .75rem 0 0;
}

.reco-header {
  display: flex;
  align-items: baseline;
  gap: .6rem;
  flex-wrap: wrap;
  background: rgba(88,166,255,.07);
  border-bottom: 1px solid var(--border);
  padding: .5rem 1rem;
}

.reco-header-label {
  font-size: .8rem;
  font-weight: 600;
  color: var(--accent);
}

.reco-header-hint {
  font-size: .7rem;
  color: var(--text3);
}

.reco-cats {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
}

.reco-cat {
  padding: .7rem .9rem;
  border-right: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

/* Supprime la bordure superflue sur la dernière colonne et dernière ligne */
.reco-cat:nth-child(5n)  { border-right: none; }
.reco-cat:last-child      { border-bottom: none; }

.reco-cat-title {
  display: flex;
  align-items: center;
  gap: .3rem;
  font-size: .76rem;
  font-weight: 600;
  color: var(--text1);
  margin-bottom: .4rem;
}

.reco-cat-icon { font-size: .88rem; }

.reco-list {
  margin: 0;
  padding: 0 0 0 1rem;
  list-style: disc;
}

.reco-item {
  font-size: .74rem;
  color: var(--text2);
  line-height: 1.5;
  margin-bottom: .25rem;
}
.reco-item:last-child { margin-bottom: 0; }

/* ── Export / Import configuration (config-export.js) ──────────────────── */

.cex-overlay {
  position: fixed; inset: 0; z-index: 1100;
  background: rgba(0,0,0,.65);
  display: flex; align-items: center; justify-content: center;
}
.cex-box {
  background: var(--card); border: 1px solid var(--border);
  border-radius: 12px; padding: 0;
  width: min(560px, 96vw);
  box-shadow: 0 20px 60px rgba(0,0,0,.6);
  display: flex; flex-direction: column;
  max-height: 92vh; overflow: hidden;
}
.cex-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1rem 1.25rem .75rem;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.cex-title { margin: 0; font-size: .95rem; font-weight: 700; color: var(--text); }
.cex-close {
  background: transparent; border: none; color: var(--text2);
  font-size: .9rem; cursor: pointer; padding: .2rem .4rem;
  border-radius: 4px; transition: color .15s;
}
.cex-close:hover { color: var(--err); }

.cex-body { padding: 1.1rem 1.25rem; overflow-y: auto; }

.cex-section { margin-bottom: .25rem; }
.cex-section-title {
  font-size: .8rem; font-weight: 700; color: var(--accent);
  text-transform: uppercase; letter-spacing: .05em;
  margin-bottom: .55rem;
}
.cex-desc {
  font-size: .78rem; color: var(--text2); line-height: 1.55;
  margin-bottom: .75rem;
}
.cex-desc strong { color: var(--text); }

/* Chips compteurs */
.cex-chips {
  display: flex; flex-wrap: wrap; gap: .35rem; margin-bottom: .85rem;
}
.cex-chip {
  font-size: .68rem; padding: .18rem .55rem;
  border-radius: 10px; border: 1px solid var(--border);
  background: var(--surface2); color: var(--text2); white-space: nowrap;
}

/* Bouton export */
.cex-export-btn { font-size: .8rem; }

/* Séparateur */
.cex-sep {
  height: 1px; background: var(--border); margin: 1rem 0;
}

/* Zone file input */
.cex-file-label {
  display: inline-flex; align-items: center; gap: .4rem;
  font-size: .78rem; color: var(--accent);
  cursor: pointer; padding: .3rem .7rem;
  border: 1px dashed var(--accent); border-radius: 6px;
  transition: background .15s;
}
.cex-file-label:hover { background: rgba(88,166,255,.08); }

/* Zone import */
#cex-import-zone { margin-top: .75rem; }

/* Preview fichier importé */
.cex-preview { display: block; }
.cex-preview-meta {
  font-size: .74rem; color: var(--text2); margin-bottom: .55rem;
}
.cex-preview-meta strong { color: var(--text); }

/* Boutons de mode (Fusionner / Remplacer) */
.cex-mode-row {
  display: flex; gap: .6rem; margin-top: .8rem; flex-wrap: wrap;
}
.cex-mode-btn {
  flex: 1; min-width: 160px;
  display: flex; align-items: flex-start; gap: .55rem;
  padding: .6rem .85rem; text-align: left;
  background: var(--surface2); border: 1px solid var(--border);
  color: var(--text); border-radius: 8px; cursor: pointer;
  font-family: var(--font); transition: border-color .15s, background .15s;
}
.cex-mode-btn:hover { border-color: var(--accent); background: rgba(88,166,255,.07); }
.cex-mode-btn-danger:hover { border-color: var(--err); background: rgba(248,81,73,.07); }
.cex-mode-icon { font-size: 1rem; flex-shrink: 0; margin-top: .1rem; }
.cex-mode-info { display: flex; flex-direction: column; gap: .15rem; }
.cex-mode-label { font-size: .8rem; font-weight: 700; }
.cex-mode-hint  { font-size: .68rem; color: var(--text2); line-height: 1.4; }

/* Erreur */
.cex-error {
  font-size: .78rem; color: var(--err);
  background: rgba(248,81,73,.08); border: 1px solid rgba(248,81,73,.3);
  border-radius: 6px; padding: .55rem .75rem; margin-top: .5rem;
}

/* Succès */
.cex-success {
  display: flex; align-items: flex-start; gap: .65rem;
  font-size: .78rem; color: var(--ok);
  background: rgba(63,185,80,.08); border: 1px solid rgba(63,185,80,.3);
  border-radius: 6px; padding: .65rem .85rem; margin-top: .5rem;
  line-height: 1.6;
}
.cex-success-icon { font-size: 1.1rem; flex-shrink: 0; }
.cex-success strong { color: var(--ok); }
.cex-success small  { color: var(--text2); }
.cex-reload-msg { color: var(--text2); font-style: italic; }

/* ── Export security hardening ────────────────────────────────────────────── */
.cex-security-notice {
  font-size: .72rem;
  color: var(--warn);
  background: rgba(210,153,34,.08);
  border: 1px solid rgba(210,153,34,.22);
  border-radius: 6px;
  padding: .45rem .65rem;
  margin: .55rem 0 .25rem;
  line-height: 1.5;
}
.cex-security-notice strong { color: var(--warn); }
.cex-security-notice em { font-style: normal; font-weight: 600; }

.cex-chip-warn { background: rgba(210,153,34,.12); color: var(--warn); }

.cex-export-row { display: flex; gap: .5rem; margin-top: .6rem; flex-wrap: wrap; align-items: center; }

.cex-btn-safe {
  font-size: .78rem;
  background: rgba(63,185,80,.1);
  color: #3fb950;
  border: 1px solid rgba(63,185,80,.3);
  padding: .38rem .75rem;
  border-radius: 6px;
  cursor: pointer;
  font-weight: 600;
}
.cex-btn-safe:hover { background: rgba(63,185,80,.2); border-color: #3fb950; }

.cex-btn-full {
  font-size: .72rem;
  color: var(--text2);
  border: 1px solid var(--border);
  padding: .35rem .65rem;
  border-radius: 6px;
  cursor: pointer;
  background: transparent;
}
.cex-btn-full:hover { border-color: var(--warn); color: var(--warn); }

.cex-badge-safe {
  display: inline-block;
  font-size: .68rem;
  color: #3fb950;
  background: rgba(63,185,80,.1);
  border: 1px solid rgba(63,185,80,.25);
  border-radius: 4px;
  padding: .05rem .35rem;
  vertical-align: middle;
}

@media (max-width: 640px) {
  .cex-mode-row { flex-direction: column; }
  .cex-mode-btn { min-width: 0; }
  .cex-export-row { flex-direction: column; }
  .cex-btn-safe, .cex-btn-full { width: 100%; text-align: center; }
}

/* ── TV1 Watchlist Sync — Sprint TV1 v1 ─────────────────────────────────── */

/* Preview box in Settings → Integrations */
.tv1-preview-box {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: .75rem 1rem;
}
.tv1-preview-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: .55rem; flex-wrap: wrap; gap: .3rem;
}
.tv1-source-badge {
  font-size: .68rem; font-weight: 700; border-radius: 4px;
  padding: .1rem .45rem; text-transform: uppercase; letter-spacing: .05em;
}
.tv1-demo-badge  { color: #f59e0b; background: rgba(245,158,11,.12); border: 1px solid rgba(245,158,11,.3); }
.tv1-live-badge  { color: #34d399; background: rgba(52,211,153,.1);  border: 1px solid rgba(52,211,153,.25); }
.tv1-preview-count { font-size: .75rem; color: var(--text2); }
.tv1-preview-note  { margin: .2rem 0 .5rem; font-size: .75rem; }
.tv1-auth-warning  { margin: .2rem 0 .5rem; font-size: .75rem; color: #f59e0b; font-weight: 500; }

.tv1-preview-list {
  display: flex; flex-wrap: wrap; gap: .35rem;
  margin-bottom: .7rem; max-height: 160px; overflow-y: auto;
}
.tv1-preview-item {
  display: inline-flex; align-items: center; gap: .3rem;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 5px; padding: .18rem .5rem; font-size: .77rem;
}
.tv1-preview-item.tv1-preview-item-exists {
  opacity: .5;
}
.tv1-preview-type  { color: var(--text2); font-size: .72rem; }
.tv1-preview-label { color: var(--text); font-weight: 500; }
.tv1-preview-exists-badge {
  font-size: .65rem; color: var(--text2);
  background: var(--surface2); border-radius: 3px; padding: 0 .3rem;
  font-style: italic;
}
.tv1-preview-actions {
  display: flex; gap: .5rem; flex-wrap: wrap;
}

/* TV1 badge on watchlist items */
.wl-tv1-badge {
  font-size: .62rem; font-weight: 700;
  color: #60a5fa; background: rgba(96,165,250,.12);
  border: 1px solid rgba(96,165,250,.25);
  border-radius: 3px; padding: 0 .3rem;
  letter-spacing: .04em; flex-shrink: 0;
}

/* Stale date — filtre TV1 obsolètes : label complet rouge discret */
.wl-stale-since {
  font-size: .62rem;
  color: #f87171;
  background: rgba(248,113,113,.08);
  border: 1px solid rgba(248,113,113,.2);
  border-radius: 3px; padding: 0 .35rem;
  white-space: nowrap; flex-shrink: 0;
}
/* Stale age — autres filtres : âge relatif très discret, tooltip pour la date */
.wl-stale-age {
  font-size: .62rem;
  color: var(--text2);
  opacity: .6;
  white-space: nowrap; flex-shrink: 0;
}

/* TV1 sync button in watchlist modal footer */
.btn-tv1-wl {
  color: #60a5fa;
  border-color: rgba(96,165,250,.3);
  font-size: .78rem;
}
.btn-tv1-wl:hover {
  background: rgba(96,165,250,.1);
  border-color: rgba(96,165,250,.6);
  color: #93c5fd;
}

/* ── AI Brief — Sprint IA v1 ─────────────────────────────────────────────── */

/* Bouton "🔵 Search in Trend" dans les quick-actions dropdowns */
.qa-actions-item-trend-search { color: #58a6ff; }
.qa-actions-item-trend-search:hover { background: rgba(88,166,255,.1); color: #79c0ff; }

/* ── Trend Search result block (art-trend-search-result) ────────────────────── */
.art-trend-search-result {
  margin: .5rem 1.2rem .25rem;
  border: 1px solid rgba(88,166,255,.2);
  border-radius: 8px;
  background: rgba(13,27,42,.6);
  font-size: .82rem;
  overflow: hidden;
}

.ts-header {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: .45rem .75rem;
  border-bottom: 1px solid rgba(88,166,255,.15);
  background: rgba(88,166,255,.06);
}
.ts-title    { font-weight: 600; color: #58a6ff; }
.ts-subtitle { color: #8b949e; font-size: .78rem; }

.ts-rows { padding: .25rem 0; }

.ts-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .5rem;
  padding: .3rem .75rem;
  border-bottom: 1px solid rgba(255,255,255,.04);
}
.ts-row:last-child { border-bottom: none; }

.ts-q {
  font-family: monospace;
  font-size: .8rem;
  color: #e6edf3;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ts-badge {
  font-size: .78rem;
  white-space: nowrap;
  flex-shrink: 0;
}
.ts-badge-found   { font-weight: 600; }
.ts-badge-notfound{ color: #8b949e; }
.ts-badge-unknown { color: #8b949e; font-style: italic; }
.ts-badge-loading { color: #58a6ff; animation: ts-spin .8s linear infinite; display: inline-block; }

/* VP connection badge removed — per-CVE signal unsupported by TV1 API (2026-04) */

@keyframes ts-spin { to { transform: rotate(360deg); } }

/* Bouton "✦ AI Brief" dans les quick-actions dropdowns */
.qa-actions-item-ai {
  color: #a371f7;
  font-weight: 600;
}
.qa-actions-item-ai:hover { background: rgba(163,113,247,.1); color: #c9a6ff; }

/* ── Bouton primaire ✦ AI Brief — incident panel (Sprint 24) ─────────────── */
.qa-btn-ai {
  color: #a371f7;
  border-color: rgba(163,113,247,.3);
  font-weight: 600;
}
.qa-btn-ai:hover {
  background: rgba(163,113,247,.12);
  border-color: rgba(163,113,247,.6);
  color: #c9a6ff;
}

/* Overlay (full-screen modal backdrop) */
.ai-brief-overlay {
  position: fixed; inset: 0; z-index: 1150;  /* above .cex-overlay (1100) */
  background: rgba(0,0,0,.65);
  display: flex; align-items: center; justify-content: center;
  padding: 1rem;
}

/* Boîte modale */
.ai-brief-box {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  width: 100%; max-width: 620px;
  max-height: 90vh;
  display: flex; flex-direction: column;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(0,0,0,.5);
}

/* Header */
.ai-brief-modal-hd {
  display: flex; align-items: center; gap: .5rem;
  padding: .75rem 1rem;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.ai-brief-modal-logo {
  font-size: .95rem; color: #a371f7; flex-shrink: 0;
}
.ai-brief-modal-hd-text {
  flex: 1; display: flex; flex-direction: column; gap: .12rem;
  overflow: hidden; min-width: 0;
}
.ai-brief-modal-title {
  font-size: .8rem; font-weight: 600;
  color: var(--text); overflow: hidden;
  white-space: nowrap; text-overflow: ellipsis;
}
.ai-brief-context-badge {
  font-size: .68rem; color: #a371f7; font-weight: 500;
  letter-spacing: .01em;
}
.ai-brief-modal-close {
  background: none; border: none; cursor: pointer;
  color: var(--text2); font-size: .9rem; padding: .2rem .4rem;
  border-radius: 4px; flex-shrink: 0;
}
.ai-brief-modal-close:hover { color: var(--err); }

/* Body scrollable */
.ai-brief-modal-body {
  overflow-y: auto; padding: 1rem;
  flex: 1; min-height: 0;
}

/* Loading */
.ai-brief-loading {
  display: flex; align-items: center; gap: .65rem;
  color: var(--text2); font-size: .82rem;
  padding: 1.5rem 0;
}
.ai-brief-spinner {
  display: inline-block;
  width: 16px; height: 16px; flex-shrink: 0;
  border: 2px solid var(--border);
  border-top-color: #a371f7;
  border-radius: 50%;
  animation: ai-spin .7s linear infinite;
}
@keyframes ai-spin { to { transform: rotate(360deg); } }

/* Panel de résultats */
.ai-brief-panel { display: flex; flex-direction: column; gap: .9rem; }

/* Section individuelle */
.ai-brief-sec {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 7px;
  padding: .7rem .85rem .55rem;
  position: relative;
}
.ai-brief-sec-title {
  font-size: .7rem; font-weight: 700;
  color: var(--text2); letter-spacing: .04em;
  text-transform: uppercase; margin-bottom: .4rem;
}
.ai-brief-text {
  font-size: .82rem; line-height: 1.6;
  color: var(--text); margin: 0 0 .45rem;
  overflow-wrap: break-word; word-break: break-word;
}
.ai-brief-nextstep-sec { border-color: rgba(163,113,247,.3); }
.ai-brief-nextstep-sec .ai-brief-sec-title { color: #a371f7; }
.ai-brief-nextstep-text { font-weight: 500; }

/* Boutons copy */
.ai-brief-copy-btn {
  font-size: .68rem; color: var(--text2);
  background: none; border: 1px solid var(--border);
  border-radius: 4px; padding: .15rem .5rem;
  cursor: pointer;
}
.ai-brief-copy-btn:hover { border-color: var(--accent); color: var(--accent); }

/* Footer */
.ai-brief-footer {
  display: flex; align-items: center; justify-content: space-between;
  gap: .5rem; flex-wrap: wrap;
  padding-top: .2rem;
}
.ai-brief-disclaimer {
  font-size: .65rem; color: var(--text2);
  font-style: italic; flex: 1;
}
.ai-brief-copy-all-btn {
  font-size: .7rem; font-weight: 600;
  color: #a371f7; border-color: rgba(163,113,247,.35);
}
.ai-brief-copy-all-btn:hover {
  background: rgba(163,113,247,.1); border-color: #a371f7;
}

/* Erreurs */
.ai-brief-error {
  font-size: .8rem; color: var(--warn);
  background: rgba(210,153,34,.08);
  border: 1px solid rgba(210,153,34,.22);
  border-radius: 6px; padding: .7rem .9rem;
  line-height: 1.5;
}
.ai-brief-error strong { color: var(--warn); }
.ai-brief-err-hint { color: var(--text2); }

/* ── Sprint IA v3 — Tab bar ─────────────────────────────────────────────── */
.ai-brief-tabs {
  display: flex; gap: .3rem;
  border-bottom: 1px solid var(--border);
  padding-bottom: .55rem;
  flex-wrap: nowrap; overflow-x: auto;
}
.ai-brief-tab {
  font-size: .72rem; font-weight: 600;
  background: none; border: 1px solid var(--border);
  border-radius: 5px; padding: .25rem .65rem;
  color: var(--text2); cursor: pointer;
  white-space: nowrap;
  transition: color .15s, border-color .15s, background .15s;
}
.ai-brief-tab:hover { color: var(--text); border-color: var(--accent); }
.ai-brief-tab-active {
  background: rgba(163,113,247,.12);
  border-color: #a371f7; color: #a371f7;
}
.ai-brief-tab-empty { opacity: .45; }
.ai-brief-tab-empty.ai-brief-tab-active { opacity: 1; }

/* Tab panels */
.ai-brief-tab-panel { display: flex; flex-direction: column; gap: .9rem; }
.ai-brief-tab-panel-hidden { display: none !important; }

/* Per-tab footer (copy button row inside tab) */
.ai-brief-tab-footer {
  display: flex; justify-content: flex-end;
  padding-top: .1rem;
}

/* Section hint (e.g. "Slack / Teams") */
.ai-brief-sec-hint {
  font-size: .65rem; font-weight: 400;
  color: var(--text2); margin-left: .4rem;
  text-transform: none; letter-spacing: 0;
}

/* ── Sprint IA v3 — Line-by-line outputs (Escalate / Share) ─────────────── */
.ai-brief-lines {
  display: flex; flex-direction: column; gap: .3rem;
  margin-bottom: .45rem;
}
.ai-brief-line {
  font-size: .82rem; line-height: 1.6;
  color: var(--text); margin: 0;
  overflow-wrap: break-word; word-break: break-word;
}
.ai-brief-share-lines .ai-brief-line {
  font-weight: 500;
}

/* ── Sprint IA v3 — Ticket block ────────────────────────────────────────── */
.ai-ticket-block {
  display: flex; flex-direction: column;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 7px;
  overflow: hidden;
}
.ai-ticket-row {
  display: flex; align-items: baseline;
  gap: .6rem;
  padding: .42rem .85rem;
  border-bottom: 1px solid var(--border);
}
.ai-ticket-row:last-child { border-bottom: none; }
.ai-ticket-row-full { display: block; }
.ai-ticket-key {
  font-size: .66rem; font-weight: 700;
  color: var(--text2); text-transform: uppercase;
  letter-spacing: .04em; min-width: 5.5rem; flex-shrink: 0;
}
.ai-ticket-val {
  font-size: .82rem; color: var(--text); line-height: 1.55;
}

@media (max-width: 640px) {
  .ai-brief-box { max-height: 95vh; border-radius: 8px; }
  .ai-brief-footer { flex-direction: column; align-items: flex-start; }
  .ai-brief-tabs { gap: .2rem; }
  .ai-brief-tab { font-size: .68rem; padding: .2rem .5rem; }
  .ai-ticket-key { min-width: 4rem; }
}

/* ── Watchlist Polish — filter bar & TV1 obsoletes (Sprint TV1 v3) ─────────── */

/* Filter bar container */
.wl-filter-bar {
  width: 100%; display: flex; gap: .35rem; flex-wrap: wrap;
  padding: .5rem 0 .4rem; border-bottom: 1px solid var(--border);
  margin-bottom: .4rem;
}

/* Individual filter button */
.wl-filter-btn {
  display: inline-flex; align-items: center; gap: .3rem;
  padding: .22rem .6rem;
  font-size: .72rem; font-weight: 500;
  color: var(--text2);
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 5px;
  cursor: pointer;
  transition: background .15s, color .15s, border-color .15s;
}
.wl-filter-btn:hover {
  background: var(--surface2);
  color: var(--text);
  border-color: var(--border2, var(--border));
}
.wl-filter-btn.wl-filter-active {
  background: rgba(96,165,250,.12);
  color: #60a5fa;
  border-color: rgba(96,165,250,.35);
  font-weight: 600;
}

/* Count badge inside filter button */
.wl-filter-count {
  display: inline-block;
  background: var(--surface2);
  color: var(--text2);
  border-radius: 10px;
  padding: 0 .4rem;
  font-size: .67rem; font-weight: 600;
  min-width: 1.2rem; text-align: center;
}
.wl-filter-btn.wl-filter-active .wl-filter-count {
  background: rgba(96,165,250,.2);
  color: #93c5fd;
}

/* Demo mode info banner */
.wl-demo-note {
  width: 100%;
  background: rgba(251,191,36,.07);
  border: 1px solid rgba(251,191,36,.25);
  border-radius: 6px;
  padding: .5rem .75rem;
  font-size: .75rem; color: #fbbf24;
  line-height: 1.5;
  margin-bottom: .35rem;
}
.wl-demo-note code {
  background: rgba(251,191,36,.12);
  border-radius: 3px; padding: 0 .3rem;
  font-size: .72rem;
}

/* Reactivate-all row (shown on tv1_stale filter) */
.wl-reactivate-row {
  width: 100%;
  display: flex; align-items: center; gap: .5rem;
  padding: .35rem .5rem;
  background: rgba(239,68,68,.06);
  border: 1px solid rgba(239,68,68,.18);
  border-radius: 6px;
  margin-bottom: .35rem;
}

/* "▶ Réactiver tous" button */
.wl-reactivate-btn {
  padding: .25rem .7rem;
  font-size: .74rem; font-weight: 600;
  color: #4ade80;
  background: rgba(74,222,128,.08);
  border: 1px solid rgba(74,222,128,.3);
  border-radius: 5px;
  cursor: pointer;
  white-space: nowrap;
  transition: background .15s, border-color .15s;
}
.wl-reactivate-btn:hover {
  background: rgba(74,222,128,.16);
  border-color: rgba(74,222,128,.55);
}

/* ── (suite styles existants) ────────────────────────────────────────────── */

@media (max-width: 640px) {
  .reco-block    { margin: .5rem 0 0; }
  .reco-cats     { grid-template-columns: 1fr; }
  .reco-cat      { border-right: none; border-bottom: 1px solid var(--border); }
  .reco-cat:last-child { border-bottom: none; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   Exec / CISO View modal
   ═══════════════════════════════════════════════════════════════════════════ */

/* Analytics dropdown divider + Exec item highlight */
.nav-menu-divider {
  height: 1px; background: var(--border); margin: .3rem 0;
}
.nav-menu-item-exec { color: #79c0ff; font-weight: 600; }
.nav-menu-item-exec:hover { background: rgba(88,166,255,.1); }

/* ── Overlay ─────────────────────────────────────────────────────────────── */
.exec-modal-overlay {
  position: fixed; inset: 0; z-index: 2000;
  /* Stronger recession: higher opacity + blur + desaturation of background content */
  background: rgba(0,0,0,.92);
  backdrop-filter: blur(8px) saturate(40%);
  -webkit-backdrop-filter: blur(8px) saturate(40%);
  display: flex; align-items: flex-start; justify-content: center;
  padding: 2rem 1rem; overflow-y: auto;
}

.exec-modal-box {
  /* Fix: --surface1 was undefined (transparent); use --surface (#161b22) for solid base */
  background: var(--surface);
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 12px;
  /* Layered shadow: deep ambient + tight contact shadow for "lifted" feel */
  box-shadow:
    0 0 0 1px rgba(255,255,255,.04),
    0 24px 64px rgba(0,0,0,.85),
    0 8px 20px  rgba(0,0,0,.5);
  width: 100%; max-width: 860px;
  display: flex; flex-direction: column;
}

/* ── Header ──────────────────────────────────────────────────────────────── */
.exec-modal-header {
  display: flex; align-items: center; gap: .6rem;
  padding: .9rem 1.25rem .75rem;
  border-bottom: 1px solid var(--border);
}
.exec-modal-logo  { font-size: 1.25rem; }
.exec-modal-title { font-size: .95rem; font-weight: 700; color: var(--text); margin: 0; flex-shrink: 0; }
.exec-modal-sub   { font-size: .72rem; color: var(--text3); flex: 1; }
.exec-modal-close {
  background: none; border: none; color: var(--text2);
  font-size: 1rem; cursor: pointer; padding: .2rem .5rem;
  border-radius: 4px; flex-shrink: 0;
}
.exec-modal-close:hover { background: var(--surface2); }

/* ── Body ────────────────────────────────────────────────────────────────── */
.exec-view-body {
  padding: 1.25rem; display: flex; flex-direction: column; gap: 1.1rem;
}

/* ── Posture banner ──────────────────────────────────────────────────────── */
.ev-posture {
  display: flex; align-items: center; gap: 1rem;
  padding: .85rem 1.1rem; border-radius: 8px; border-left: 4px solid;
}
.ev-posture-critical { background: rgba(248,81,73,.1);  border-color: #f85149; }
.ev-posture-high     { background: rgba(240,136,62,.1); border-color: #f0883e; }
.ev-posture-elevated { background: rgba(210,153,34,.1); border-color: #d29922; }
.ev-posture-nominal  { background: rgba(63,185,80,.08); border-color: #3fb950; }

.ev-posture-icon   { font-size: 1.6rem; line-height: 1; flex-shrink: 0; }
.ev-posture-text   { flex: 1; display: flex; flex-direction: column; gap: .15rem; }
.ev-posture-level  { font-size: .8rem; font-weight: 800; letter-spacing: .08em; color: var(--text); }
.ev-posture-desc   { font-size: .78rem; color: var(--text2); }
.ev-posture-period { font-size: .65rem; color: var(--text3); flex-shrink: 0; text-align: right; }

/* ── KPI tiles ───────────────────────────────────────────────────────────── */
.ev-kpis {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: .65rem;
}
.ev-kpi {
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: 8px; padding: .75rem .9rem;
  text-align: center; display: flex; flex-direction: column; gap: .2rem;
  transition: border-color .15s;
}
.ev-kpi-active { border-color: rgba(255,255,255,.18); }
.ev-kpi-value  { font-size: 1.75rem; font-weight: 800; line-height: 1; }
.ev-kpi-label  { font-size: .66rem; color: var(--text2); font-weight: 600; }

.ev-kpi-critical.ev-kpi-active .ev-kpi-value { color: #f85149; }
.ev-kpi-kev.ev-kpi-active      .ev-kpi-value { color: #ff6b35; }
.ev-kpi-wl.ev-kpi-active       .ev-kpi-value { color: #58a6ff; }
.ev-kpi-inv.ev-kpi-active      .ev-kpi-value { color: #f0883e; }

/* ── Section titles ──────────────────────────────────────────────────────── */
.ev-section-title {
  font-size: .7rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; color: var(--text2); margin: 0 0 .6rem;
}

/* ── Executive summary ───────────────────────────────────────────────────── */
.ev-summary { display: flex; flex-direction: column; gap: .35rem; }
.ev-summary-line {
  font-size: .83rem; color: var(--text); line-height: 1.5; margin: 0;
  padding-left: 1rem; position: relative;
}
.ev-summary-line::before {
  content: '→'; position: absolute; left: 0; color: var(--text3);
}

/* ── Two-column layout ───────────────────────────────────────────────────── */
.ev-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; }
.ev-col  { display: flex; flex-direction: column; }

/* ── Incident cards ──────────────────────────────────────────────────────── */
.ev-incident-card {
  background: var(--surface2); border: 1px solid var(--border);
  border-left: 3px solid var(--border);
  border-radius: 6px; padding: .6rem .75rem;
  margin-bottom: .45rem; display: flex; flex-direction: column; gap: .3rem;
  cursor: pointer; transition: all .15s;
}
.ev-incident-card:hover {
  border-color: rgba(255,255,255,.16);
  background: rgba(255,255,255,.03);
  transform: translateX(2px);
}
.ev-incident-card:focus {
  outline: 2px solid rgba(88,166,255,.5);
  outline-offset: -1px;
}
.ev-inc-critical_now { border-left-color: #f85149; }
.ev-inc-investigate  { border-left-color: #f0883e; }
.ev-inc-watch        { border-left-color: #79c0ff; }
.ev-incident-card:hover .ev-inc-title { text-decoration: underline; text-decoration-color: rgba(255,255,255,.3); }

.ev-inc-header { display: flex; align-items: flex-start; gap: .4rem; }
.ev-inc-icon   { font-size: .9rem; flex-shrink: 0; margin-top: .05rem; }
.ev-inc-title  { font-size: .76rem; font-weight: 600; color: var(--text); line-height: 1.35; }
.ev-inc-chips  { display: flex; flex-wrap: wrap; gap: .25rem; }
.ev-inc-meta   { font-size: .65rem; color: var(--text3); }

/* ── Vendor list ─────────────────────────────────────────────────────────── */
.ev-vendor-list { display: flex; flex-direction: column; gap: .1rem; }
.ev-vendor-row  {
  display: flex; align-items: center; gap: .5rem;
  padding: .3rem 0; border-bottom: 1px solid rgba(255,255,255,.04);
}
.ev-vendor-rank     { font-size: .65rem; color: var(--text3); width: 1.6rem; flex-shrink: 0; }
.ev-vendor-bar-wrap { flex: 1; display: flex; flex-direction: column; gap: .15rem; overflow: hidden; }
.ev-vendor-name     { font-size: .76rem; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ev-vendor-bar      { height: 3px; background: rgba(88,166,255,.4); border-radius: 2px; transition: width .3s; }
.ev-vendor-count    {
  font-size: .68rem; color: var(--text2); font-weight: 700;
  background: var(--surface2); border: 1px solid var(--border);
  padding: .05rem .35rem; border-radius: 8px; flex-shrink: 0;
}

/* ── CVE list ────────────────────────────────────────────────────────────── */
.ev-cve-list { display: flex; flex-direction: column; gap: .2rem; }
.ev-cve-row  {
  display: flex; align-items: center; gap: .4rem;
  padding: .2rem 0; border-bottom: 1px solid rgba(255,255,255,.04);
}
.ev-cve-id   { font-size: .72rem; font-family: var(--font-mono, monospace); color: var(--text); }
.ev-cve-epss { font-size: .65rem; color: var(--text3); }
.ev-cve-count{ font-size: .63rem; color: var(--text3); margin-left: auto; }

/* ── Chips (shared) ──────────────────────────────────────────────────────── */
.ev-chip {
  font-size: .62rem; font-weight: 700; padding: .1rem .35rem;
  border-radius: 8px; white-space: nowrap; line-height: 1.3;
}
.ev-chip-kev  { color:#ff6b35; background:rgba(255,107,53,.14); border:1px solid rgba(255,107,53,.3); }
.ev-chip-wl   { color:#58a6ff; background:rgba(88,166,255,.12);  border:1px solid rgba(88,166,255,.25); }
.ev-chip-epss { color:#d29922; background:rgba(210,153,34,.12);  border:1px solid rgba(210,153,34,.25); }

/* ── Empty / no-data ─────────────────────────────────────────────────────── */
.ev-no-data {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: .75rem; padding: 3rem 1rem; text-align: center; color: var(--text2);
  font-size: .85rem; line-height: 1.5;
}
.ev-empty { font-size: .78rem; color: var(--text3); font-style: italic; margin: 0; }

/* ── IOC Export Modal ─────────────────────────────────────────────────────── */
.iocexp-modal-box {
  max-width: 600px;
  width: 95vw;
  padding: 0;
  display: flex;
  flex-direction: column;
}

.iocexp-header {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.9rem 1.2rem;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.iocexp-header-icon { font-size: 1.2rem; line-height: 1; }
.iocexp-title { font-size: 1.05rem; font-weight: 700; color: var(--text); margin: 0; flex: 1; }

/* Summary tiles */
.iocexp-summary {
  display: flex;
  gap: 0.5rem;
  padding: 1rem 1.2rem 0.5rem;
  flex-wrap: wrap;
}
.iocexp-tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 0.5rem 0.9rem;
  min-width: 72px;
  gap: 0.15rem;
}
.iocexp-tile-total {
  border-color: var(--accent);
  background: rgba(88,166,255,.08);
}
.iocexp-tile-val {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--text);
  line-height: 1;
}
.iocexp-tile-total .iocexp-tile-val { color: var(--accent); }
.iocexp-tile-lbl {
  font-size: 0.65rem;
  color: var(--text2);
  white-space: nowrap;
}

.iocexp-sub {
  font-size: 0.72rem;
  color: var(--text3);
  margin: 0.1rem 1.2rem 0.6rem;
  font-style: italic;
}

/* Controls section */
.iocexp-controls {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  padding: 0.6rem 1.2rem 0.8rem;
  border-top: 1px solid var(--border);
}
.iocexp-ctrl-row {
  display: flex;
  align-items: flex-start;
  gap: 0.8rem;
}
.iocexp-ctrl-label {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--text2);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  min-width: 54px;
  padding-top: 0.2rem;
  flex-shrink: 0;
}

/* Scope pills (same pattern as Exec View / Morning Brief) */
.iocexp-scope-pills { display: flex; gap: 0.2rem; flex-wrap: wrap; }
.iocexp-scope-pill {
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 4px;
  color: var(--text2);
  cursor: pointer;
  font-size: 0.68rem;
  font-weight: 500;
  padding: 0.18rem 0.45rem;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.iocexp-scope-pill:hover { background: var(--surface2); border-color: var(--accent); color: var(--text); }
.iocexp-scope-pill.iocexp-scope-active {
  background: rgba(88,166,255,.15);
  border-color: var(--accent);
  color: var(--accent);
  font-weight: 600;
}

/* Type checkboxes */
.iocexp-type-filters { display: flex; gap: 0.8rem; flex-wrap: wrap; }
.iocexp-type-item {
  display: flex;
  align-items: center;
  gap: 0.3rem;
  font-size: 0.8rem;
  color: var(--text);
  cursor: pointer;
}
.iocexp-type-item input[type="checkbox"] { accent-color: var(--accent); cursor: pointer; }

/* Format radio group */
.iocexp-fmt-group { display: flex; flex-direction: column; gap: 0.35rem; }
.iocexp-fmt-item {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.8rem;
  color: var(--text);
  cursor: pointer;
}
.iocexp-fmt-item input[type="radio"] { accent-color: var(--accent); cursor: pointer; }
.iocexp-fmt-hint { font-size: 0.68rem; color: var(--text3); }

/* Footer */
.iocexp-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  padding: 0.75rem 1.2rem;
  border-top: 1px solid var(--border);
  flex-shrink: 0;
  flex-wrap: wrap;
}
.iocexp-footer-hint { font-size: 0.68rem; color: var(--text3); font-style: italic; flex: 1; }
.iocexp-footer-btns { display: flex; gap: 0.5rem; flex-shrink: 0; }

/* ── Morning Brief Modal ──────────────────────────────────────────────────── */
.mb-modal-box {
  max-width: 660px;
  width: 95vw;
  max-height: 88vh;
  display: flex;
  flex-direction: column;
  padding: 0;
}

.mb-header {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.9rem 1.2rem;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

.mb-header-icon { font-size: 1.2rem; line-height: 1; }

.mb-title {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--text);
  margin: 0;
}

/* Scope pills — same visual language as Exec View */
.mb-scope-pills {
  display: flex;
  gap: 0.2rem;
  margin-left: auto;
  margin-right: 0.5rem;
}

.mb-scope-pill {
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 4px;
  color: var(--text2);
  cursor: pointer;
  font-size: 0.68rem;
  font-weight: 500;
  padding: 0.18rem 0.45rem;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.mb-scope-pill:hover {
  background: var(--surface2);
  border-color: var(--accent);
  color: var(--text);
}
.mb-scope-pill.mb-scope-active {
  background: rgba(88,166,255,.15);
  border-color: var(--accent);
  color: var(--accent);
  font-weight: 600;
}

.mb-body {
  flex: 1;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  padding: 0.8rem 1.2rem;
  min-height: 0;
}

.mb-textarea {
  flex: 1;
  width: 100%;
  min-height: 380px;
  max-height: calc(88vh - 140px);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text);
  font-family: 'Courier New', Courier, monospace;
  font-size: 0.78rem;
  line-height: 1.6;
  padding: 0.9rem 1rem;
  resize: vertical;
  white-space: pre;
  overflow-wrap: normal;
  overflow-x: auto;
  tab-size: 4;
}
.mb-textarea:focus { outline: none; border-color: var(--accent); }

.mb-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.75rem 1.2rem;
  border-top: 1px solid var(--border);
  flex-shrink: 0;
}

.mb-hint {
  font-size: 0.71rem;
  color: var(--text3);
  font-style: italic;
}

/* ── Exec View — Actionability Section ───────────────────────────────────── */
.ev-act-meta {
  font-size: 0.75rem;
  color: var(--text3, #6e7681);
  margin: 0.15rem 0 0.6rem 0;
  font-style: italic;
}

.ev-act-list {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.ev-act-row {
  display: grid;
  grid-template-columns: 1.6rem 1fr auto auto;
  align-items: center;
  gap: 0 0.75rem;
  padding: 0.55rem 0.75rem;
  border-radius: 6px;
  border: 1px solid transparent;
  background: var(--surface-alt, rgba(255,255,255,0.03));
  transition: background 0.15s ease;
}

.ev-act-row-active {
  border-color: var(--border);
}

.ev-act-row-active.ev-act-kev  { border-left: 3px solid #f85149; }
.ev-act-row-active.ev-act-ioc  { border-left: 3px solid #58a6ff; }
.ev-act-row-active.ev-act-cve  { border-left: 3px solid #3fb950; }
.ev-act-row-active.ev-act-zero { border-left: 3px solid #f0883e; }

.ev-act-icon {
  font-size: 1rem;
  text-align: center;
  line-height: 1;
}

.ev-act-label {
  font-size: 0.88rem;
  color: var(--text2);
  font-weight: 500;
}

.ev-act-count {
  font-size: 1.05rem;
  font-weight: 700;
  min-width: 2.2rem;
  text-align: right;
}

.ev-act-c-kev  { color: #f85149; }
.ev-act-c-ioc  { color: #58a6ff; }
.ev-act-c-cve  { color: #3fb950; }
.ev-act-c-zero { color: #f0883e; }
.ev-act-c-none { color: var(--text3, #6e7681); }

.ev-act-hint {
  font-size: 0.72rem;
  color: var(--text3, #6e7681);
  text-align: right;
  white-space: nowrap;
}

/* ── Keyboard Shortcuts Modal ────────────────────────────────────────────── */
.ks-modal-box {
  max-width: 380px;
}

.ks-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--border);
}

.ks-header h2 {
  font-size: 1rem;
  font-weight: 700;
  margin: 0;
  color: var(--text);
}

.ks-body {
  padding: 1rem 1.25rem 1.25rem;
}

.ks-table {
  width: 100%;
  border-collapse: collapse;
}

.ks-table tr {
  border-bottom: 1px solid var(--border);
}

.ks-table tr:last-child {
  border-bottom: none;
}

.ks-table td {
  padding: 0.6rem 0.5rem;
  vertical-align: middle;
}

.ks-table td:first-child {
  width: 3.5rem;
  text-align: center;
}

.ks-table td:last-child {
  font-size: 0.88rem;
  color: var(--text2);
}

.ks-table kbd {
  display: inline-block;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-bottom-width: 2px;
  border-radius: 4px;
  padding: 0.15rem 0.5rem;
  font-family: var(--font-mono, monospace);
  font-size: 0.8rem;
  color: var(--text);
  white-space: nowrap;
}

.ks-divider-row td {
  padding: 0 !important;
  height: 1px;
  background: var(--border);
}

/* ── Scope pills (24h / 7d / 30d / All) ─────────────────────────────────── */
.ev-scope-pills {
  display: flex;
  gap: 0.25rem;
  align-items: center;
  margin-left: auto;
  margin-right: 0.5rem;
  flex-shrink: 0;
}

.ev-scope-pill {
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 4px;
  color: var(--text2);
  cursor: pointer;
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  padding: 0.2rem 0.5rem;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.ev-scope-pill:hover {
  background: var(--surface2);
  border-color: var(--accent);
  color: var(--text);
}
.ev-scope-pill.ev-scope-active {
  background: rgba(88,166,255,.15);
  border-color: var(--accent);
  color: var(--accent);
  font-weight: 600;
}

/* Hide scope pills in print output */
#ev-print-clone .ev-scope-pills { display: none !important; }

/* ── Print button (screen only) ──────────────────────────────────────────── */
.ev-btn-print {
  font-size: 1rem;
  opacity: 0.6;
  transition: opacity 0.2s ease;
}
.ev-btn-print:hover { opacity: 1; }

.exec-modal-print-date {
  font-size: 0.72rem;
  color: var(--text3);
  margin-left: auto;
  margin-right: 0.25rem;
  display: none; /* visible only in print output */
}

/* ── Print / PDF ─────────────────────────────────────────────────────────── */
@media print {
  /* Hide everything — the clone (#ev-print-clone) is the only exception */
  body.ev-printing > *:not(#ev-print-clone) { display: none !important; }

  /* Clone sits naturally in document flow — no position:fixed to fight */
  #ev-print-clone {
    display: block !important;
    max-width: 100% !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    print-color-adjust: exact;
    -webkit-print-color-adjust: exact;
  }

  /* Reveal print date, hide interactive controls */
  #ev-print-clone .exec-modal-print-date { display: inline !important; }
  #ev-print-clone .exec-modal-close,
  #ev-print-clone .ev-btn-print { display: none !important; }

  /* Page-break guards */
  .ev-kpis,
  .ev-act-list,
  .ev-cols          { break-inside: avoid; page-break-inside: avoid; }
  .ev-incident-card { break-inside: avoid; page-break-inside: avoid; }
  .ev-section       { break-inside: avoid; page-break-inside: avoid; }
}

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 640px) {
  .ev-kpis { grid-template-columns: repeat(2, 1fr); }
  .ev-cols  { grid-template-columns: 1fr; }
  .exec-modal-sub { display: none; }
  .ev-act-hint { display: none; }
}

/* ── CVE Timeline / Age Tracker ─────────────────────────────────────────── */

/* Age badge on article cards (inside nvd-row) */
.nvd-age {
  display: inline-block;
  font-size: .67rem;
  font-weight: 600;
  padding: .1rem .45rem;
  border-radius: 4px;
  margin-left: .35rem;
  vertical-align: middle;
  letter-spacing: .01em;
}
.nvd-age-fresh { background: #0d2818; color: #3fb950; border: 1px solid #238636; }
.nvd-age-med   { background: #271e08; color: #d29922; border: 1px solid #9e6a03; }
.nvd-age-old   { background: #2d1515; color: #f85149; border: 1px solid #6e2020; }

/* Age badge in CVE panel table (under CVE ID) */
.cp-cve-age {
  display: inline-block;
  font-size: .62rem;
  font-weight: 700;
  padding: .05rem .35rem;
  border-radius: 3px;
  margin-left: .3rem;
  vertical-align: middle;
  letter-spacing: .02em;
}
.cp-age-fresh { background: #0d2818; color: #3fb950; }
.cp-age-med   { background: #271e08; color: #d29922; }
.cp-age-old   { background: #2d1515; color: #f85149; }

/* Timeline row in CVE detail */
.cp-timeline {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .4rem .2rem;
  margin: .5rem 0 .75rem 0;
  padding: .55rem .75rem;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border, #30363d);
  border-radius: 6px;
  font-size: .72rem;
}

.cp-tl-node {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
}

.cp-tl-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}
.cp-tl-disclose .cp-tl-dot { background: #58a6ff; }
.cp-tl-feed     .cp-tl-dot { background: #8b949e; }
.cp-tl-patch    .cp-tl-dot { background: #3fb950; }

.cp-tl-meta {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
}
.cp-tl-label {
  font-weight: 600;
  color: var(--text, #e6edf3);
  font-size: .68rem;
  white-space: nowrap;
}
.cp-tl-date {
  color: #8b949e;
  font-size: .66rem;
  white-space: nowrap;
}
.cp-tl-age {
  color: #58a6ff;
  font-size: .63rem;
  font-weight: 600;
}

.cp-tl-arrow {
  color: #484f58;
  font-size: .8rem;
  margin: 0 .1rem;
  align-self: center;
}

/* Exposure window pill */
.cp-tl-exposure {
  margin-left: auto;
  padding: .15rem .5rem;
  border-radius: 10px;
  font-size: .67rem;
  font-weight: 700;
  white-space: nowrap;
  letter-spacing: .01em;
}
.cp-exposure-high { background: #2d1515; color: #f85149; border: 1px solid #6e2020; }
.cp-exposure-med  { background: #271e08; color: #d29922; border: 1px solid #9e6a03; }
.cp-exposure-low  { background: #0d2818; color: #3fb950; border: 1px solid #238636; }

/* VP timeline node, "No VP yet" note, Exec View VP row — all removed (2026-04) */
