/* ═══════════════════════════════════════════
   InfraX QMS — style.css
   ═══════════════════════════════════════════ */

/* ─── Design tokens ─────────────────────────────────────────────── */
:root {
  --pink:       #d54084;
  --pink-dark:  #a8275f;
  --pink-deep:  #7a1040;
  --pink-light: #f3b2d0;
  --pink-pale:  #fdf0f6;
  --blue:       #4286f4;
  --navy:       #001a72;
  --white:      #ffffff;
  --gray-50:    #fdf5f8;
  --gray-100:   #f7eaf1;
  --gray-200:   #e8cdd9;
  --gray-400:   #b8809a;
  --gray-600:   #7a4060;
  --gray-800:   #3d1028;
  --success:    #22c55e;
  --warning:    #f59e0b;
  --danger:     #ef4444;
  --radius:     12px;
  --radius-sm:  8px;
  --shadow:     0 4px 24px rgba(213,64,132,.10);
  --shadow-md:  0 8px 40px rgba(213,64,132,.16);
  --sidebar-w:  600px;
  --transition: .22s cubic-bezier(.4,0,.2,1);
  --font:       'DM Sans', sans-serif;
  --mono:       'DM Mono', monospace;
}

/* ─── Reset ──────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; overflow: hidden; }
body { font-family: var(--font); background: var(--gray-50); color: var(--gray-800); font-size: 14px; line-height: 1.5; }
button { font-family: var(--font); cursor: pointer; border: none; background: none; }
input, textarea, select { font-family: var(--font); }
a { color: inherit; text-decoration: none; }

::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--gray-200); border-radius: 99px; }
::-webkit-scrollbar-thumb:hover { background: var(--pink-light); }

/* ─── Hidden utility ─────────────────────────────────────────────── */
.hidden { display: none !important; }

/* ─── Spinner ────────────────────────────────────────────────────── */
.spinner {
  width: 44px; height: 44px;
  border: 3px solid var(--pink-light);
  border-top-color: var(--pink);
  border-radius: 50%;
  animation: spin .7s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ════════════════════════════════════════════════
   DASHBOARD INDEX — Light, airy, card grid
   ════════════════════════════════════════════════ */
#dashboard-view {
  position: fixed; inset: 0;
  background: var(--gray-50);
  z-index: 50;
  display: flex; flex-direction: column;
  overflow: hidden;
}
#dashboard-view.hidden { display: none; }

/* ─── Topbar ─────────────────────────────────── */
.dash-topbar {
  height: 56px; flex-shrink: 0;
  background: var(--white);
  border-bottom: 1.5px solid var(--gray-100);
  display: flex; align-items: center;
  padding: 0 32px; gap: 16px;
  box-shadow: 0 1px 8px rgba(213,64,132,.06);
}
.dash-topbar-brand { display: flex; align-items: center; gap: 10px; }
.dash-brand-mark {
  width: 30px; height: 30px; border-radius: 8px;
  background: linear-gradient(135deg, var(--pink), var(--pink-dark));
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 10px rgba(213,64,132,.35);
}
.dash-brand-name { font-size: 15px; font-weight: 700; color: var(--gray-800); letter-spacing: -.3px; }
.dash-brand-badge {
  font-size: 10px; font-weight: 700; letter-spacing: .7px;
  color: var(--pink); background: var(--pink-pale);
  border: 1px solid var(--pink-light);
  border-radius: 4px; padding: 2px 7px; text-transform: uppercase;
}
.dash-topbar-center {
  flex: 1; text-align: center;
  font-size: 12px; color: var(--gray-400);
  font-weight: 500; letter-spacing: .3px;
}
.dash-topbar-right { display: flex; align-items: center; gap: 10px; }
.dash-user-chip {
  display: flex; align-items: center; gap: 6px;
  font-size: 12px; color: var(--gray-600);
  background: var(--gray-50); border: 1.5px solid var(--gray-200);
  border-radius: 99px; padding: 4px 12px;
}
.dash-user-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--success); }
.dash-btn-logout {
  font-size: 12px; color: var(--gray-400);
  border: 1.5px solid var(--gray-200); background: none;
  cursor: pointer; padding: 5px 12px;
  border-radius: var(--radius-sm); font-family: var(--font);
  transition: all var(--transition);
}
.dash-btn-logout:hover { color: var(--pink); border-color: var(--pink-light); background: var(--pink-pale); }

/* ─── Hero ───────────────────────────────────── */
.dash-hero {
  padding: 40px 32px 0;
  text-align: center; flex-shrink: 0;
}
.dash-hero-title {
  font-size: 26px; font-weight: 700; letter-spacing: -.5px;
  color: var(--gray-800); margin-bottom: 6px;
}
.dash-hero-sub { font-size: 14px; color: var(--gray-400); }

/* ─── Grid 4×2 ───────────────────────────────── */
.dash-grid {
  flex: 1;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: repeat(2, 1fr);
  gap: 20px;
  padding: 28px 32px 32px;
  overflow: hidden;
}

/* ─── Card base ──────────────────────────────── */
.dash-card {
  background: var(--white);
  border-radius: 16px;
  border: 1.5px solid var(--gray-100);
  padding: 24px 22px 20px;
  display: flex; flex-direction: column; gap: 0;
  box-shadow: 0 2px 12px rgba(0,0,0,.04), 0 0 0 0 rgba(213,64,132,0);
  transition: all .25s cubic-bezier(.4,0,.2,1);
  position: relative; overflow: hidden;
}

/* ─── Live (clickable) cards ─────────────────── */
.dash-card--live {
  cursor: pointer;
}
.dash-card--live:hover {
  border-color: var(--pink-light);
  box-shadow: 0 8px 32px rgba(213,64,132,.12), 0 2px 8px rgba(213,64,132,.06);
  transform: translateY(-3px);
}
.dash-card--live::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  border-radius: 16px 16px 0 0;
  background: linear-gradient(90deg, var(--pink), var(--pink-dark));
  opacity: 0; transition: opacity .25s;
}
.dash-card--live:hover::before { opacity: 1; }

/* ─── Soon cards ─────────────────────────────── */
.dash-card--soon {
  cursor: default;
  background: var(--gray-50);
  border-color: var(--gray-100);
  box-shadow: none;
}

/* ─── Stat card ──────────────────────────────── */
.dash-card--stat {
  cursor: default;
  background: linear-gradient(135deg, var(--pink-deep) 0%, var(--pink-dark) 100%);
  border-color: transparent;
  box-shadow: 0 8px 32px rgba(213,64,132,.25);
  justify-content: space-between;
}

/* ─── Card header (num + badge) ──────────────── */
.dash-card-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 16px;
}
.dash-card-num {
  font-size: 11px; font-weight: 700; letter-spacing: 1.2px;
  color: var(--gray-400); text-transform: uppercase;
}
.dash-card--stat .dash-card-num { color: rgba(255,255,255,.5); }
.dash-card-modules-count {
  font-size: 10px; font-weight: 600; color: var(--pink);
  background: var(--pink-pale); border: 1px solid var(--pink-light);
  border-radius: 99px; padding: 2px 9px;
}
.dash-card-soon-pill {
  font-size: 10px; font-weight: 600; color: var(--gray-400);
  background: var(--gray-100); border: 1px solid var(--gray-200);
  border-radius: 99px; padding: 2px 9px;
}

/* ─── Icon ───────────────────────────────────── */
.dash-card-icon {
  width: 46px; height: 46px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 14px; flex-shrink: 0;
  transition: transform .25s;
}
.dash-card--live:hover .dash-card-icon { transform: scale(1.08); }
.dash-card-icon--blue   { background: #dbeafe; color: #1d4ed8; }
.dash-card-icon--teal   { background: #ccfbf1; color: #0f766e; }
.dash-card-icon--orange { background: #ffedd5; color: #c2410c; }
.dash-card-icon--purple { background: #ede9fe; color: #6d28d9; }
.dash-card-icon--gray   { background: var(--gray-100); color: var(--gray-600); }
.dash-card-icon--green  { background: #dcfce7; color: #15803d; }
.dash-card-icon--pink   { background: var(--pink-pale); color: var(--pink-dark); }
.dash-card--soon .dash-card-icon { opacity: .5; }

/* ─── Card body ──────────────────────────────── */
.dash-card-body { flex: 1; }
.dash-card-title {
  font-size: 14px; font-weight: 600; color: var(--gray-800);
  letter-spacing: -.2px; line-height: 1.35; margin-bottom: 5px;
}
.dash-card--soon .dash-card-title { color: var(--gray-400); }
.dash-card-desc {
  font-size: 11.5px; color: var(--gray-400); line-height: 1.55;
}
.dash-card--soon .dash-card-desc { color: var(--gray-200); }

/* ─── Card footer ────────────────────────────── */
.dash-card-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 14px; margin-top: 14px;
  border-top: 1.5px solid var(--gray-100);
  font-size: 12px; font-weight: 600; color: var(--pink);
}
.dash-card-footer--soon {
  border-top-color: var(--gray-100);
  color: var(--gray-200);
}
.dash-card-cta { transition: color .2s; }
.dash-card--live:hover .dash-card-cta { color: var(--pink-dark); }
.dash-card-arrow {
  color: var(--pink-light);
  transition: transform .22s cubic-bezier(.4,0,.2,1), color .2s;
}
.dash-card--live:hover .dash-card-arrow { transform: translateX(3px); color: var(--pink); }

/* ─── Stat card internals ────────────────────── */
.dash-stat-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 16px; flex: 1;
}
.dash-stat-item { display: flex; flex-direction: column; gap: 3px; }
.dash-stat-item--wide { grid-column: span 2; }
.dash-stat-value {
  font-size: 32px; font-weight: 800; letter-spacing: -1.5px;
  color: var(--white); line-height: 1;
}
.dash-stat-value--sm { font-size: 22px; letter-spacing: -.8px; }
.dash-stat-label {
  font-size: 10px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .6px; color: rgba(255,255,255,.5);
}
.dash-stat-brand {
  font-size: 11px; color: rgba(255,255,255,.35);
  font-weight: 500; letter-spacing: .3px; margin-top: 8px;
}

/* ─── Card entrance animation ────────────────── */
.dash-card { animation: cardIn .45s cubic-bezier(.4,0,.2,1) both; }
.dash-grid .dash-card:nth-child(1) { animation-delay: 0ms; }
.dash-grid .dash-card:nth-child(2) { animation-delay: 45ms; }
.dash-grid .dash-card:nth-child(3) { animation-delay: 90ms; }
.dash-grid .dash-card:nth-child(4) { animation-delay: 135ms; }
.dash-grid .dash-card:nth-child(5) { animation-delay: 180ms; }
.dash-grid .dash-card:nth-child(6) { animation-delay: 225ms; }
.dash-grid .dash-card:nth-child(7) { animation-delay: 270ms; }
.dash-grid .dash-card:nth-child(8) { animation-delay: 315ms; }
@keyframes cardIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ════════════════════════════════════════════════
   PROCESS DASHBOARD (layer intermédiaire)
   ════════════════════════════════════════════════ */
#process-dash {
  position: fixed; inset: 0;
  background: var(--gray-50);
  z-index: 60;
  display: flex; flex-direction: column;
  overflow-y: auto;
}
#process-dash.hidden { display: none; }

/* ─── Process topbar ─────────────────────────── */
.proc-topbar {
  height: 56px; flex-shrink: 0;
  background: #e72c85 !important;
  border-bottom: none;
  display: flex; align-items: center;
  padding: 0 32px; gap: 20px;
  box-shadow: 0 2px 12px rgba(231,44,133,.28);
  position: sticky; top: 0; z-index: 10;
}
.proc-back-btn {
  display: flex; align-items: center; gap: 7px;
  font-size: 13px; font-weight: 600; color: #fff;
  padding: 6px 12px; border-radius: var(--radius-sm);
  background: rgba(255,255,255,.16); border: 1.5px solid rgba(255,255,255,.28);
  cursor: pointer; transition: all var(--transition); flex-shrink: 0;
}
.proc-back-btn:hover { color: #fff; border-color: rgba(255,255,255,.45); background: rgba(255,255,255,.26); }
.proc-topbar-brand { display: flex; align-items: center; gap: 10px; flex: 1; justify-content: center; }
.proc-topbar-right { display: flex; align-items: center; gap: 10px; flex-shrink: 0; min-width: 120px; justify-content: flex-end; }
.proc-topbar, .proc-topbar * { color: #fff; }

/* ─── Process hero ───────────────────────────── */
.proc-hero {
  display: flex; align-items: flex-start; gap: 20px;
  padding: 40px 52px 32px;
  flex-wrap: wrap;
}
.proc-hero-num {
  font-size: 64px; font-weight: 800; letter-spacing: -3px;
  color: var(--gray-100); line-height: 1; flex-shrink: 0;
  font-variant-numeric: tabular-nums;
  user-select: none;
  padding-top: 4px;
  transition: color .3s, background .3s;
  width: 90px; height: 72px; display: flex; align-items: center; justify-content: center;
  border-radius: 14px;
}
.proc-hero-text { padding-top: 4px; flex: 1; min-width: 200px; }
.proc-hero-title {
  font-size: 28px; font-weight: 700; letter-spacing: -.6px;
  color: var(--gray-800); margin-bottom: 6px;
}
.proc-hero-desc { font-size: 14px; color: var(--gray-400); line-height: 1.6; }

/* ─── Module cards in process dash ──────────── */
.proc-modules-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 20px;
  padding: 0 52px 52px;
}
.proc-module-card {
  background: var(--white);
  border: 1.5px solid var(--gray-100);
  border-radius: 16px;
  padding: 28px 24px 22px;
  cursor: pointer;
  display: flex; flex-direction: column; gap: 12px;
  box-shadow: 0 2px 12px rgba(0,0,0,.04);
  transition: all .25s cubic-bezier(.4,0,.2,1);
  position: relative; overflow: hidden;
}
.proc-module-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  border-radius: 16px 16px 0 0;
  background: linear-gradient(90deg, var(--pink), var(--pink-dark));
  opacity: 0; transition: opacity .25s;
}
.proc-module-card:hover {
  border-color: var(--pink-light);
  box-shadow: 0 10px 36px rgba(213,64,132,.13);
  transform: translateY(-4px);
}
.proc-module-card:hover::before { opacity: 1; }

.proc-module-icon {
  width: 48px; height: 48px; border-radius: 12px;
  background: var(--pink-pale); color: var(--pink);
  display: flex; align-items: center; justify-content: center;
  transition: transform .25s; flex-shrink: 0;
}
.proc-module-card:hover .proc-module-icon { transform: scale(1.1); }
.proc-module-title {
  font-size: 16px; font-weight: 700; color: var(--gray-800); letter-spacing: -.3px;
}
.proc-module-desc {
  font-size: 13px; color: var(--gray-400); line-height: 1.6; flex: 1;
}
.proc-module-cta {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 12px; margin-top: 2px;
  border-top: 1.5px solid var(--gray-100);
  font-size: 12px; font-weight: 600; color: var(--pink);
}
.proc-module-cta svg { transition: transform .22s; }
.proc-module-card:hover .proc-module-cta svg { transform: translateX(3px); }

/* ─── Process dash entrance ──────────────────── */
#process-dash { animation: procIn .3s cubic-bezier(.4,0,.2,1); }
@keyframes procIn {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ════════════════════════════════════════════════
   APP LAYOUT (Requirements + topbar)
   ════════════════════════════════════════════════ */
/* ══════════════════════════════════════════════
   REQ APP — layout flex-column avec header partagé
   ══════════════════════════════════════════════ */
#req-app {
  display: flex; flex-direction: column;
  height: 100vh; overflow: hidden;
  position: fixed; inset: 0; z-index: 50;
}
#req-app.hidden { display: none; }

/* Header pleine largeur */
#req-module-header {
  height: 52px; flex-shrink: 0;
  background: #e72c85 !important;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 20px;
  box-shadow: 0 2px 12px rgba(0,0,0,.18);
}
.req-header-left  { display: flex; align-items: center; gap: 8px; }
.req-header-right { display: flex; align-items: center; gap: 10px; }
.req-header-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 12px; border-radius: 6px;
  font-size: 12px; font-weight: 700; color: white;
  cursor: pointer; font-family: var(--font); border: none;
  transition: background .15s;
}
.req-header-back { background: rgba(255,255,255,.22); }
.req-header-home { background: rgba(255,255,255,.12); }
.req-header-back:hover { background: rgba(255,255,255,.36); }
.req-header-home:hover { background: rgba(255,255,255,.22); }
.req-header-sep {
  width: 1px; height: 20px;
  background: rgba(255,255,255,.25); margin: 0 4px;
}
.req-header-title {
  font-size: 13px; font-weight: 700; color: rgba(255,255,255,.9);
  letter-spacing: .01em;
}

/* Corps horizontal */
#req-body {
  display: flex; flex: 1; overflow: hidden;
}

/* ─── Sidebar ────────────────────────────────── */
#sidebar {
  width: var(--sidebar-w); min-width: var(--sidebar-w);
  background: var(--white);
  border-right: 1.5px solid var(--gray-200);
  display: flex; flex-direction: column; overflow: hidden;
  transition: width var(--transition);
  position: relative; z-index: 10;
}
.sidebar-header { padding: 16px 18px 12px; border-bottom: 1.5px solid var(--gray-100); flex-shrink: 0; }
.logo-row { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.logo-img { height: 32px; width: auto; object-fit: contain; }
.logo-fallback {
  width: 32px; height: 32px;
  background: linear-gradient(135deg, var(--pink), var(--pink-dark));
  border-radius: 8px; display: flex; align-items: center; justify-content: center;
  color: white; font-weight: 700; font-size: 16px; letter-spacing: -.5px;
}
.logo-title { display: flex; flex-direction: column; gap: 1px; }
.logo-title strong { font-size: 14px; font-weight: 700; color: var(--pink-dark); letter-spacing: -.3px; }
.logo-title span { font-size: 10px; color: var(--gray-400); font-weight: 400; text-transform: uppercase; letter-spacing: .8px; }

.search-wrap { position: relative; }
.search-wrap input {
  width: 100%; padding: 8px 12px 8px 34px;
  border: 1.5px solid var(--gray-200); border-radius: var(--radius-sm);
  font-size: 13px; background: var(--gray-50); color: var(--gray-800);
  transition: border-color var(--transition), box-shadow var(--transition); outline: none;
}
.search-wrap input:focus {
  border-color: var(--pink); box-shadow: 0 0 0 3px rgba(213,64,132,.12); background: var(--white);
}
.search-icon { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); color: var(--gray-400); pointer-events: none; }

.filters { display: flex; gap: 6px; margin-top: 8px; flex-wrap: wrap; }
.filter-chip {
  padding: 3px 10px; border-radius: 99px; font-size: 11px; font-weight: 500;
  border: 1.5px solid var(--gray-200); color: var(--gray-600); cursor: pointer;
  transition: all var(--transition); white-space: nowrap;
}
.filter-chip:hover { border-color: var(--pink-light); color: var(--pink); }
.filter-chip.active { background: var(--pink); border-color: var(--pink); color: white; }
.proc-filters-wrap { padding: 6px 18px 4px; border-top: 1px solid var(--gray-100); background: var(--gray-50); display: none; }
.proc-filters-wrap.visible { display: block; }
.proc-filters-label { font-size: 9.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .6px; color: var(--gray-400); margin-bottom: 5px; }
.proc-filters { display: flex; flex-wrap: wrap; gap: 4px; }

.tree-test-count { font-size: 9px; font-weight: 700; padding: 1px 5px; border-radius: 99px; background: #dcfce7; color: #166534; margin-left: 4px; flex-shrink: 0; }
.tree-no-test { font-size: 9px; font-weight: 700; padding: 1px 6px; border-radius: 99px; background: #fee2e2; color: #991b1b; margin-left: 4px; flex-shrink: 0; letter-spacing: .2px; }

.sidebar-content { flex: 1; overflow-y: auto; padding: 8px 0; }
.tree-section { margin-bottom: 2px; }
.tree-section-label { padding: 8px 18px 4px; font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 1px; color: var(--gray-400); }

.tree-node { position: relative; }
.tree-node-row {
  display: flex; align-items: center; gap: 0;
  padding: 0 8px 0 0; border-radius: var(--radius-sm);
  margin: 0 6px 1px; cursor: pointer;
  transition: background var(--transition); min-height: 32px;
}
.tree-node-row:hover { background: var(--pink-pale); }
.tree-node-row.selected { background: var(--pink-pale); }
.tree-node-row.selected .tree-node-id,
.tree-node-row.selected .tree-node-title { color: var(--pink-dark); }
.tree-toggle {
  width: 24px; min-width: 24px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  color: var(--gray-400); transition: transform var(--transition), color var(--transition); flex-shrink: 0;
}
.tree-toggle.open { transform: rotate(90deg); color: var(--pink); }
.tree-toggle.leaf { color: transparent; pointer-events: none; }
.tree-type-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; margin-right: 7px; }
.tree-type-dot.source   { background: var(--pink-dark); }
.tree-type-dot.sys      { background: var(--blue); }
.tree-type-dot.sw       { background: #7c3aed; }
.tree-type-dot.test     { background: var(--success); }
.tree-type-dot.risk     { background: var(--danger); }
.tree-type-dot.orphan   { background: var(--gray-400); }
.tree-node-text { flex: 1; overflow: hidden; padding: 4px 0; }
.tree-node-id { font-size: 11px; color: var(--gray-400); font-family: var(--mono); display: block; white-space: nowrap; }
.tree-node-title { font-size: 13px; color: var(--gray-800); font-weight: 400; display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tree-children { border-left: 1.5px solid var(--gray-100); margin-left: 18px; padding-left: 20px; }

/* ─── Main + Topbar ──────────────────────────── */
#main { flex: 1; display: flex; flex-direction: column; overflow: hidden; background: var(--gray-50); }
#topbar {
  height: 56px; min-height: 56px;
  background: var(--white); border-bottom: 1.5px solid var(--gray-200);
  display: flex; align-items: center; gap: 12px; padding: 0 24px; flex-shrink: 0;
}
.topbar-breadcrumb {
  display: flex; align-items: center; gap: 6px; flex: 1;
  font-size: 13px; color: var(--gray-400); overflow: hidden;
}
.topbar-breadcrumb span { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.topbar-breadcrumb .sep { color: var(--gray-200); }
.topbar-breadcrumb .current { color: var(--gray-800); font-weight: 500; }
.topbar-actions { display: flex; gap: 8px; align-items: center; }

#content { flex: 1; overflow-y: auto; padding: 24px; }

/* ─── Buttons ────────────────────────────────── */
.btn { padding: 7px 16px; border-radius: var(--radius-sm); font-size: 13px; font-weight: 500; cursor: pointer; transition: all var(--transition); display: inline-flex; align-items: center; gap: 6px; border: none; }
.btn-primary { background: var(--pink); color: white; }
.btn-primary:hover { background: var(--pink-dark); }
.btn-secondary { background: var(--gray-100); color: var(--gray-800); border: 1.5px solid var(--gray-200); }
.btn-secondary:hover { border-color: var(--pink-light); color: var(--pink); background: var(--pink-pale); }
.btn-ghost { color: var(--gray-600); }
.btn-ghost:hover { color: var(--pink); background: var(--pink-pale); border-radius: var(--radius-sm); }
.btn-sm { padding: 4px 10px; font-size: 12px; }
.btn-home {
  background: rgba(255,255,255,.15);
  color: var(--white); border: none;
  border-radius: 6px; padding: 5px 12px;
  font-size: 12px; font-weight: 600; cursor: pointer;
  display: flex; align-items: center; gap: 5px;
  transition: background var(--transition);
}
.btn-home:hover { background: rgba(255,255,255,.25); }
.btn-export { background: linear-gradient(135deg, var(--pink-dark), var(--navy)); color: white; border: none; }
.btn-export:hover { opacity: .88; }
.btn-export.loading { opacity: .6; pointer-events: none; }
.btn-export-matrix { background: linear-gradient(135deg, var(--navy), #1a3a8f); color: white; border: none; }
.btn-export-matrix:hover { opacity: .88; }
.btn-export-matrix.loading { opacity: .6; pointer-events: none; }
.btn-capa-topbar {
  background: linear-gradient(135deg, var(--pink-dark), var(--navy));
  color: var(--white); font-weight: 600; border-radius: var(--radius-sm);
  padding: 6px 14px; font-size: 12.5px; display: flex; align-items: center; gap: 6px;
  transition: opacity var(--transition); border: none; cursor: pointer;
}
.btn-capa-topbar:hover { opacity: .88; }

/* ─── Empty / Welcome state ──────────────────── */
.empty-state {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; height: 100%; gap: 12px;
  color: var(--gray-400); text-align: center;
}
.empty-state-icon { width: 64px; height: 64px; background: var(--gray-100); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 28px; margin-bottom: 4px; }
.empty-state h2 { font-size: 18px; color: var(--gray-600); font-weight: 600; }
.empty-state p { font-size: 13px; max-width: 320px; }

/* ─── Loading overlay ────────────────────────── */
#loading-overlay {
  position: fixed; inset: 0; background: rgba(253,240,246,.85);
  backdrop-filter: blur(4px);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  z-index: 9999; gap: 16px; transition: opacity .3s;
}
#loading-overlay.hidden { opacity: 0; pointer-events: none; }
.loading-text { color: var(--pink-dark); font-weight: 500; font-size: 15px; }
.loading-sub  { color: var(--gray-400); font-size: 13px; }

/* ─── Login overlay ──────────────────────────── */
#login-overlay { position: fixed; inset: 0; background: var(--gray-50); z-index: 9998; display: flex; align-items: center; justify-content: center; }
#login-overlay.hidden { display: none; }
.login-card { background: var(--white); border: 1.5px solid var(--gray-200); border-radius: var(--radius); padding: 38px 36px 40px; width: 400px; box-shadow: var(--shadow-md); display: flex; flex-direction: column; gap: 20px; }
.login-logo { display: flex; align-items: center; justify-content: center; min-height: 72px; margin-bottom: 2px; }
.login-logo-img { display: block; width: min(280px, 100%); height: auto; max-height: 72px; object-fit: contain; }
.login-heading { display: flex; flex-direction: column; gap: 4px; text-align: center; }
.login-title { font-size: 15px; font-weight: 600; color: var(--gray-800); }
.login-subtitle { font-size: 13px; color: var(--gray-400); }
.login-field { display: flex; flex-direction: column; gap: 6px; }
.login-field label { font-size: 12px; font-weight: 600; color: var(--gray-600); }
.login-field input { border: 1.5px solid var(--gray-200); border-radius: var(--radius-sm); padding: 9px 12px; font-size: 13px; outline: none; transition: border var(--transition); background: var(--white); }
.login-field input:focus { border-color: var(--pink); }
.login-field input.input-error { border-color: var(--danger); }
.login-hint { font-size: 11px; color: var(--gray-400); }
.login-error { font-size: 12px; color: var(--danger); min-height: 16px; font-weight: 500; }
.login-btn { background: var(--pink); color: #fff; border-radius: var(--radius-sm); padding: 10px; font-size: 13px; font-weight: 600; cursor: pointer; border: none; display: flex; align-items: center; justify-content: center; gap: 8px; transition: background var(--transition); }
.login-btn:hover:not(:disabled) { background: var(--pink-dark); }
.login-btn:disabled { opacity: .6; cursor: default; }

/* ─── User chip ──────────────────────────────── */
.user-chip { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--gray-600); border: 1.5px solid var(--gray-200); border-radius: 99px; padding: 4px 12px; background: var(--white); }
.user-chip-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--success); flex-shrink: 0; }
.btn-logout { font-size: 12px; color: var(--gray-400); border: 1.5px solid var(--gray-200); background: none; cursor: pointer; padding: 5px 10px; border-radius: var(--radius-sm); font-family: var(--font); transition: all var(--transition); }
.btn-logout:hover { color: var(--danger); border-color: var(--danger); background: #fff0f3; }

/* ─── Issue card ─────────────────────────────── */
.issue-header { background: var(--white); border-radius: var(--radius); border: 1.5px solid var(--gray-200); padding: 24px 28px 20px; margin-bottom: 16px; box-shadow: var(--shadow); }
.issue-type-row { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }
.issue-type-badge { display: inline-flex; align-items: center; gap: 6px; padding: 4px 12px; border-radius: 99px; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .6px; }
.badge-source  { background: #fde8ef; color: var(--pink-dark); }
.badge-sys     { background: #dbeafe; color: #1d4ed8; }
.badge-sw      { background: #ede9fe; color: #5b21b6; }
.badge-test    { background: #dcfce7; color: #166534; }
.badge-risk    { background: #fee2e2; color: #991b1b; }
.badge-orphan  { background: var(--gray-100); color: var(--gray-600); }
.issue-key { font-family: var(--mono); font-size: 12px; color: var(--gray-400); margin-left: auto; padding: 3px 8px; background: var(--gray-100); border-radius: 6px; }
.issue-title { font-size: 20px; font-weight: 700; color: var(--gray-800); letter-spacing: -.3px; line-height: 1.3; margin-bottom: 12px; }
.issue-title-input { font-size: 20px; font-weight: 700; color: var(--gray-800); letter-spacing: -.3px; width: 100%; border: 1.5px solid var(--pink-light); border-radius: var(--radius-sm); padding: 6px 10px; outline: none; margin-bottom: 12px; }
.issue-title-input:focus { border-color: var(--pink); box-shadow: 0 0 0 3px rgba(213,64,132,.1); }
.issue-meta { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; padding-top: 12px; border-top: 1px solid var(--gray-100); }
.issue-meta-item { display: flex; align-items: center; gap: 5px; font-size: 12px; color: var(--gray-400); }
.issue-meta-item strong { color: var(--gray-600); font-weight: 500; }

/* ─── Status badge ───────────────────────────── */
.status-badge { display: inline-flex; align-items: center; gap: 5px; padding: 3px 10px; border-radius: 99px; font-size: 11px; font-weight: 600; }
.status-badge::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.status-blue    { background: #dbeafe; color: #1d4ed8; }
.status-green   { background: #dcfce7; color: #166534; }
.status-yellow  { background: #fef9c3; color: #854d0e; }
.status-red     { background: #fee2e2; color: #991b1b; }
.status-gray    { background: var(--gray-100); color: var(--gray-600); }

/* ─── Tabs ───────────────────────────────────── */
.tabs { display: flex; gap: 0; border-bottom: 2px solid var(--gray-200); margin-bottom: 16px; overflow-x: auto; }
.tab { padding: 10px 18px; font-size: 13px; font-weight: 500; color: var(--gray-400); cursor: pointer; white-space: nowrap; border-bottom: 2px solid transparent; margin-bottom: -2px; transition: color var(--transition), border-color var(--transition); display: flex; align-items: center; gap: 6px; }
.tab:hover { color: var(--pink); }
.tab.active { color: var(--pink); border-bottom-color: var(--pink); }
.tab-count { background: var(--pink-pale); color: var(--pink); font-size: 10px; padding: 1px 6px; border-radius: 99px; font-weight: 600; }
.tab-panel { display: none; }
.tab-panel.active { display: block; }

/* ─── Fields grid ────────────────────────────── */
.fields-card { background: var(--white); border-radius: var(--radius); border: 1.5px solid var(--gray-200); padding: 20px 24px; margin-bottom: 12px; box-shadow: var(--shadow); }
.fields-card-title { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .8px; color: var(--gray-400); margin-bottom: 16px; display: flex; align-items: center; gap: 8px; }
.fields-card-title::after { content: ''; flex: 1; height: 1px; background: var(--gray-100); }
.fields-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 16px; }
.field-item { display: flex; flex-direction: column; gap: 4px; }
.field-item.full { grid-column: 1 / -1; }
.field-label { font-size: 11px; font-weight: 600; color: var(--gray-400); text-transform: uppercase; letter-spacing: .5px; }
.field-value { font-size: 13px; color: var(--gray-800); padding: 6px 0; min-height: 28px; }
.field-value.empty { color: var(--gray-400); font-style: italic; font-size: 12px; }
.field-value.mono { font-family: var(--mono); font-size: 12px; }
.field-value.multiline { white-space: pre-wrap; line-height: 1.6; }
.field-input, .field-textarea, .field-select { border: 1.5px solid var(--gray-200); border-radius: var(--radius-sm); padding: 7px 10px; font-size: 13px; color: var(--gray-800); background: var(--white); width: 100%; outline: none; transition: border-color var(--transition), box-shadow var(--transition); font-family: var(--font); }
.field-input:focus, .field-textarea:focus, .field-select:focus { border-color: var(--pink); box-shadow: 0 0 0 3px rgba(213,64,132,.1); }
.field-textarea { resize: vertical; min-height: 80px; line-height: 1.5; }
.field-input.mono { font-family: var(--mono); font-size: 12px; }

/* ─── Links section ──────────────────────────── */
.links-section { margin-bottom: 12px; }
.link-item { display: flex; align-items: flex-start; gap: 10px; padding: 10px 14px; border-radius: var(--radius-sm); border: 1.5px solid var(--gray-200); margin-bottom: 6px; background: var(--white); cursor: pointer; transition: border-color var(--transition), background var(--transition); }
.link-item:hover { border-color: var(--pink-light); background: var(--pink-pale); }
.link-dot { width: 8px; height: 8px; border-radius: 50%; margin-top: 5px; flex-shrink: 0; }
.link-info { flex: 1; overflow: hidden; }
.link-rel { font-size: 10px; color: var(--gray-400); text-transform: uppercase; letter-spacing: .5px; margin-bottom: 2px; }
.link-key { font-family: var(--mono); font-size: 11px; color: var(--gray-400); }
.link-summary { font-size: 13px; color: var(--gray-800); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ─── Comments ───────────────────────────────── */
.comment-item { padding: 14px 16px; background: var(--white); border-radius: var(--radius-sm); border: 1.5px solid var(--gray-200); margin-bottom: 8px; }
.comment-header { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.comment-avatar { width: 28px; height: 28px; border-radius: 50%; background: linear-gradient(135deg, var(--pink), var(--pink-dark)); display: flex; align-items: center; justify-content: center; font-size: 12px; color: white; font-weight: 600; flex-shrink: 0; }
.comment-author { font-weight: 600; font-size: 13px; color: var(--gray-800); }
.comment-date   { font-size: 11px; color: var(--gray-400); margin-left: auto; }
.comment-body   { font-size: 13px; color: var(--gray-600); white-space: pre-wrap; line-height: 1.6; }
.comment-form { margin-top: 12px; }
.comment-form textarea { width: 100%; border: 1.5px solid var(--gray-200); border-radius: var(--radius-sm); padding: 10px 12px; font-size: 13px; font-family: var(--font); resize: vertical; min-height: 80px; outline: none; transition: border-color var(--transition), box-shadow var(--transition); }
.comment-form textarea:focus { border-color: var(--pink); box-shadow: 0 0 0 3px rgba(213,64,132,.1); }
.comment-form-actions { display: flex; justify-content: flex-end; margin-top: 8px; }

/* ─── Toast ──────────────────────────────────── */
#toast-container { position: fixed; bottom: 24px; right: 24px; display: flex; flex-direction: column; gap: 8px; z-index: 9999; pointer-events: none; }
.toast { padding: 12px 18px; border-radius: var(--radius-sm); font-size: 13px; font-weight: 500; box-shadow: var(--shadow-md); pointer-events: all; display: flex; align-items: center; gap: 8px; animation: toastIn .3s cubic-bezier(.4,0,.2,1) forwards; max-width: 340px; }
.toast.success { background: #dcfce7; color: #166534; border: 1.5px solid #86efac; }
.toast.error   { background: #fee2e2; color: #991b1b; border: 1.5px solid #fca5a5; }
.toast.info    { background: var(--pink-pale); color: var(--pink-dark); border: 1.5px solid var(--pink-light); }
.toast.fade-out { animation: toastOut .3s forwards; }
@keyframes toastIn  { from { opacity:0; transform: translateY(12px); } to { opacity:1; transform: none; } }
@keyframes toastOut { to   { opacity:0; transform: translateY(12px); } }

/* ─── Risk card ──────────────────────────────── */
.risk-card { display: flex; gap: 12px; padding: 12px 16px; background: #fff8f8; border: 1.5px solid #fecaca; border-radius: var(--radius-sm); margin-bottom: 8px; cursor: pointer; transition: border-color var(--transition), background var(--transition); }
.risk-card:hover { border-color: var(--danger); background: #fee2e2; }
.risk-id-col { flex-shrink: 0; }
.risk-id { font-family: var(--mono); font-size: 11px; color: #991b1b; font-weight: 500; }
.risk-pills { display: flex; gap: 6px; margin-top: 4px; flex-wrap: wrap; }
.risk-pill { font-size: 10px; padding: 1px 7px; border-radius: 99px; font-weight: 600; letter-spacing: .3px; }
.risk-g { background: #fee2e2; color: #991b1b; }
.risk-p { background: #fef9c3; color: #854d0e; }
.risk-info { flex: 1; overflow: hidden; }
.risk-summary { font-size: 13px; color: var(--gray-800); }

/* ─── Stats bar ──────────────────────────────── */
.stats-bar { display: flex; gap: 12px; margin-bottom: 20px; flex-wrap: wrap; }
.stat-card { flex: 1; min-width: 120px; background: var(--white); border: 1.5px solid var(--gray-200); border-radius: var(--radius); padding: 14px 18px; display: flex; flex-direction: column; gap: 4px; box-shadow: var(--shadow); cursor: pointer; transition: all var(--transition); }
.stat-card:hover { border-color: var(--pink-light); box-shadow: var(--shadow-md); }
.stat-number { font-size: 28px; font-weight: 700; letter-spacing: -1px; }
.stat-label  { font-size: 11px; color: var(--gray-400); text-transform: uppercase; letter-spacing: .6px; }
.stat-source { color: var(--pink-dark); }
.stat-sys    { color: var(--blue); }
.stat-sw     { color: #7c3aed; }
.stat-test   { color: var(--success); }
.stat-risk   { color: var(--danger); }

/* ─── Edit bar ───────────────────────────────── */
.edit-bar { background: var(--pink-pale); border: 1.5px solid var(--pink-light); border-radius: var(--radius-sm); padding: 10px 16px; display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.edit-bar p { font-size: 13px; color: var(--pink-dark); font-weight: 500; flex: 1; }

/* ─── Risk structured fields ─────────────────── */
.risk-fields { display: flex; flex-direction: column; gap: 0; }
.risk-field-row { display: grid; grid-template-columns: 220px 1fr; border-bottom: 1px solid var(--gray-100); min-height: 42px; }
.risk-field-row:last-child { border-bottom: none; }
.risk-field-label { padding: 10px 14px 10px 0; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; color: var(--gray-400); display: flex; align-items: flex-start; padding-top: 12px; border-right: 1.5px solid var(--gray-100); min-width: 0; }
.risk-field-value { padding: 10px 0 10px 14px; font-size: 13px; color: var(--gray-800); line-height: 1.6; }
.risk-field-value.empty { color: var(--gray-400); font-style: italic; font-size: 12px; }
.seq-steps { display: flex; flex-direction: column; gap: 0; margin: 2px 0; }
.seq-step { display: flex; align-items: flex-start; gap: 8px; padding: 5px 0; }
.seq-step:not(:last-child) { border-bottom: 1px dashed var(--gray-100); padding-bottom: 8px; margin-bottom: 4px; }
.seq-step-num { width: 22px; height: 22px; border-radius: 50%; background: var(--danger); color: white; font-size: 10px; font-weight: 700; flex-shrink: 0; display: flex; align-items: center; justify-content: center; margin-top: 1px; }
.seq-step-text { font-size: 13px; color: var(--gray-800); line-height: 1.5; }

/* ─── Severity pills ─────────────────────────── */
.severity-pill { display: inline-flex; align-items: center; gap: 6px; padding: 4px 12px; border-radius: 99px; font-size: 12px; font-weight: 600; }
.sev-catastrophique { background: #fecaca; color: #7f1d1d; }
.sev-critique       { background: #fee2e2; color: #991b1b; }
.sev-serieux        { background: #fef3c7; color: #78350f; }
.sev-mineur         { background: #fef9c3; color: #854d0e; }
.sev-negligeable    { background: #dcfce7; color: #14532d; }
.sev-frequent       { background: #fecaca; color: #7f1d1d; }
.sev-probable       { background: #fed7aa; color: #7c2d12; }
.sev-occasionnel    { background: #fef3c7; color: #78350f; }
.sev-eloigne        { background: #e0f2fe; color: #075985; }
.sev-improbable     { background: #dcfce7; color: #14532d; }

/* ─── Indicators table ───────────────────────── */
.indicators-table { width: 100%; border-collapse: collapse; font-size: 13px; margin-top: 4px; }
.indicators-table th { text-align: left; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .6px; color: var(--gray-400); padding: 6px 10px; background: var(--gray-50); border-bottom: 2px solid var(--gray-200); }
.indicators-table td { padding: 8px 10px; border-bottom: 1px solid var(--gray-100); color: var(--gray-800); vertical-align: top; line-height: 1.5; }
.indicators-table tr:last-child td { border-bottom: none; }
.indicators-table tr:hover td { background: var(--pink-pale); }
.indicators-table td.mono { font-family: var(--mono); font-size: 12px; color: var(--pink-dark); }
.indicators-table td.target { font-weight: 600; color: var(--pink-dark); }
.indicators-empty { font-size: 12px; color: var(--gray-400); font-style: italic; padding: 6px 0; }
.indicator-edit-row { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr auto; gap: 8px; align-items: start; margin-bottom: 8px; padding: 10px; background: var(--gray-50); border: 1.5px solid var(--gray-200); border-radius: var(--radius-sm); }
.indicator-edit-row:hover { border-color: var(--pink-light); }
.indicator-edit-label { font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: .5px; color: var(--gray-400); margin-bottom: 3px; }
.btn-add-row { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; border-radius: var(--radius-sm); font-size: 12px; font-weight: 500; color: var(--pink); border: 1.5px dashed var(--pink-light); background: var(--pink-pale); cursor: pointer; transition: all var(--transition); margin-top: 8px; }
.btn-add-row:hover { background: var(--pink); color: white; border-style: solid; }
.btn-del-row { padding: 4px 6px; border-radius: 6px; font-size: 14px; line-height: 1; color: var(--danger); background: #fee2e2; border: none; cursor: pointer; transition: background var(--transition); margin-top: 18px; }
.btn-del-row:hover { background: var(--danger); color: white; }

/* ─── Procedure + Resultat tables ───────────────*/
.procedure-table { width: 100%; border-collapse: collapse; font-size: 13px; margin-top: 4px; }
.procedure-table th { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; color: var(--gray-400); padding: 6px 10px; text-align: left; border-bottom: 1.5px solid var(--gray-200); background: var(--gray-50); }
.procedure-table td { padding: 8px 10px; vertical-align: top; border-bottom: 1px solid var(--gray-100); color: var(--gray-800); line-height: 1.45; }
.procedure-table tbody tr:last-child td { border-bottom: none; }
.procedure-table tbody tr:hover td { background: var(--gray-50); }
.procedure-table td:first-child { font-weight: 600; width: 40%; }
.resultat-table { width: 100%; border-collapse: collapse; font-size: 13px; margin-top: 4px; }
.resultat-table th { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; color: var(--gray-400); padding: 6px 10px; text-align: left; border-bottom: 1.5px solid var(--gray-200); background: var(--gray-50); }
.resultat-table td { padding: 8px 10px; vertical-align: middle; border-bottom: 1px solid var(--gray-100); color: var(--gray-800); }
.resultat-table tbody tr:last-child td { border-bottom: none; }
.resultat-table tbody tr:hover td { background: var(--gray-50); }
.resultat-table td:first-child { font-weight: 600; }
.resultat-table td:nth-child(2) { font-weight: 700; color: var(--pink-dark); text-align: center; width: 130px; }
.resultat-table td:nth-child(3) { color: var(--gray-400); font-family: var(--mono); font-size: 12px; text-align: center; width: 70px; }

/* ─── Config banner ──────────────────────────── */
.config-banner { background: #fef3c7; border: 1.5px solid #fcd34d; border-radius: var(--radius); padding: 16px 20px; margin-bottom: 20px; display: flex; align-items: center; gap: 12px; }
.config-banner p { font-size: 13px; color: #78350f; }

/* ─── Search results ─────────────────────────── */
.search-result-item { padding: 8px 12px; margin: 2px 6px; border-radius: var(--radius-sm); cursor: pointer; transition: background var(--transition); display: flex; align-items: center; gap: 8px; }
.search-result-item:hover { background: var(--pink-pale); }
.search-result-key { font-family: var(--mono); font-size: 10px; color: var(--gray-400); white-space: nowrap; }
.search-result-title { font-size: 12.5px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ─── Create test button ─────────────────────── */
.btn-create-test { display: inline-flex; align-items: center; gap: 7px; background: var(--success); color: #fff; border-radius: var(--radius-sm); padding: 8px 16px; font-size: 13px; font-weight: 600; cursor: pointer; transition: background var(--transition), transform var(--transition), box-shadow var(--transition); border: none; box-shadow: 0 2px 8px rgba(34,197,94,.25); }
.btn-create-test:hover { background: #16a34a; transform: translateY(-1px); box-shadow: 0 4px 14px rgba(34,197,94,.35); }
.create-test-wrap { display: flex; justify-content: flex-end; padding: 4px 0 8px; }

/* ════════════════════════════════════════════════
   TEST MODAL
   ════════════════════════════════════════════════ */
.modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.50); display: flex; align-items: center; justify-content: center; z-index: 1000; backdrop-filter: blur(3px); animation: tmFadeIn .18s ease; }
.modal-overlay.hidden { display: none; }
@keyframes tmFadeIn { from { opacity:0 } to { opacity:1 } }
.modal-container { background: var(--white); border-radius: var(--radius); box-shadow: 0 24px 80px rgba(0,0,0,.22); width: min(820px, 96vw); max-height: 94vh; height: 94vh; display: flex; flex-direction: column; overflow: hidden; animation: tmSlideUp .22s cubic-bezier(.4,0,.2,1); }
@keyframes tmSlideUp { from { transform: translateY(18px); opacity:0 } to { transform: translateY(0); opacity:1 } }
.modal-header { padding: 16px 22px 14px; border-bottom: 1.5px solid var(--gray-100); display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.modal-header-titles { flex:1; min-width:0; }
.modal-header-titles h2 { font-size: 15px; font-weight: 700; color: var(--gray-800); letter-spacing: -.2px; }
.modal-header-sub { font-size: 11px; color: var(--gray-400); margin-top: 1px; }
.modal-close-btn { width: 30px; height: 30px; display: flex; align-items: center; justify-content: center; border-radius: 8px; color: var(--gray-400); flex-shrink: 0; transition: background var(--transition), color var(--transition); }
.modal-close-btn:hover { background: var(--gray-100); color: var(--gray-800); }
.modal-steps { display: flex; align-items: center; gap: 0; padding: 12px 22px; border-bottom: 1.5px solid var(--gray-100); background: var(--gray-50); flex-shrink: 0; }
.modal-step { display: flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 600; color: var(--gray-400); transition: color var(--transition); }
.modal-step.active  { color: var(--pink); }
.modal-step.done    { color: var(--success); }
.modal-step-num { width: 22px; height: 22px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 700; flex-shrink: 0; background: var(--gray-200); color: var(--gray-400); transition: background var(--transition), color var(--transition); }
.modal-step.active .modal-step-num { background: var(--pink); color: #fff; }
.modal-step.done   .modal-step-num { background: var(--success); color: #fff; }
.modal-step-sep { flex: 1; height: 2px; background: var(--gray-200); margin: 0 10px; border-radius: 99px; transition: background var(--transition); }
.modal-step-sep.done { background: var(--success); }
.modal-body { flex: 1; min-height: 0; overflow-y: auto; padding: 20px 22px; display: flex; flex-direction: column; gap: 16px; }
.modal-section { border: 1.5px solid var(--gray-200); border-radius: var(--radius-sm); overflow: hidden; flex-shrink: 0; }
.modal-section-title { padding: 8px 14px; background: var(--gray-50); font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .7px; color: var(--gray-600); border-bottom: 1.5px solid var(--gray-200); display: flex; align-items: center; gap: 7px; }
.modal-section-body { padding: 14px; }
.modal-id-row { display:flex; align-items:center; gap:14px; }
.modal-id-badge { display: inline-flex; align-items: center; background: var(--gray-100); border-radius: 8px; padding: 7px 16px; font-family: var(--mono); font-size: 16px; font-weight: 700; color: var(--gray-800); letter-spacing: .5px; }
.modal-id-note { font-size: 12px; color: var(--gray-400); }
.tm-table-controls { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.tm-table-count { font-size: 12px; color: var(--gray-400); }
.tm-table-wrap { max-height: 220px; overflow-y: auto; border: 1.5px solid var(--gray-100); border-radius: var(--radius-sm); }
.modal-indicators-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.modal-indicators-table thead th { position: sticky; top: 0; background: var(--white); z-index: 1; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; color: var(--gray-400); padding: 8px 10px; text-align: left; border-bottom: 1.5px solid var(--gray-100); }
.modal-indicators-table thead th:first-child { width: 36px; }
.modal-indicators-table td { padding: 9px 10px; vertical-align: middle; color: var(--gray-800); }
.modal-indicators-table tbody tr { cursor: pointer; transition: background var(--transition); }
.modal-indicators-table tbody tr:hover  { background: var(--gray-50); }
.modal-indicators-table tbody tr.ind-selected { background: var(--pink-pale); }
.modal-indicators-table tbody tr:not(:last-child) td { border-bottom: 1px solid var(--gray-100); }
.modal-indicators-table input[type=checkbox] { accent-color: var(--pink); cursor: pointer; width: 14px; height: 14px; }
.modal-sys-note { font-size: 11px; color: var(--gray-400); margin-bottom: 10px; display: flex; align-items: center; gap: 5px; }
.modal-sys-note .sys-key { font-family: var(--mono); font-weight: 600; color: var(--gray-600); background: var(--gray-100); padding: 1px 6px; border-radius: 4px; }
.modal-risk-list { display: flex; flex-direction: column; gap: 7px; }
.modal-risk-item { display: flex; align-items: flex-start; gap: 10px; padding: 10px 12px; border-radius: var(--radius-sm); border: 1.5px solid var(--gray-200); cursor: pointer; transition: border-color var(--transition), background var(--transition); }
.modal-risk-item:hover { border-color: var(--pink-light); background: var(--pink-pale); }
.modal-risk-item.risk-selected { border-color: var(--pink); background: var(--pink-pale); }
.modal-risk-item input[type=checkbox] { margin-top: 2px; accent-color: var(--pink); cursor: pointer; width: 14px; height: 14px; flex-shrink: 0; }
.modal-risk-info { flex: 1; min-width: 0; }
.modal-risk-id { font-size: 10px; font-weight: 700; color: var(--pink); font-family: var(--mono); margin-bottom: 2px; }
.modal-risk-summary { font-size: 13px; color: var(--gray-800); line-height: 1.4; }
.modal-risk-severity { font-size: 10px; font-weight: 600; padding: 2px 7px; border-radius: 99px; flex-shrink: 0; align-self: center; }
.modal-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.modal-form-field { display: flex; flex-direction: column; gap: 5px; }
.modal-form-field.full { grid-column: 1/-1; }
.modal-form-label { font-size: 10.5px; font-weight: 700; color: var(--gray-600); text-transform: uppercase; letter-spacing: .4px; display: flex; align-items: center; gap: 4px; }
.modal-form-label .req { color: var(--danger); }
.modal-input, .modal-select, .modal-textarea { border: 1.5px solid var(--gray-200); border-radius: var(--radius-sm); padding: 7px 10px; font-size: 13px; color: var(--gray-800); background: var(--white); width: 100%; font-family: var(--font); transition: border-color var(--transition), box-shadow var(--transition); }
.modal-input:focus, .modal-select:focus, .modal-textarea:focus { outline: none; border-color: var(--pink); box-shadow: 0 0 0 3px rgba(213,64,132,.10); }
.modal-input.error { border-color: var(--danger); }
.modal-textarea { resize: vertical; min-height: 76px; line-height: 1.55; }
.modal-textarea.auto-filled { background: var(--pink-pale); border-color: var(--pink-light); }
.modal-footer { padding: 14px 22px; border-top: 1.5px solid var(--gray-100); display: flex; align-items: center; justify-content: space-between; gap: 10px; flex-shrink: 0; }
.modal-footer-left  { display: flex; align-items: center; gap: 8px; }
.modal-footer-right { display: flex; align-items: center; gap: 8px; }
.modal-footer-info  { font-size: 12px; color: var(--gray-400); }
.modal-loading { display: flex; align-items: center; justify-content: center; gap: 10px; padding: 60px 0; color: var(--gray-400); font-size: 13px; }
.modal-empty { text-align: center; color: var(--gray-400); font-size: 13px; padding: 10px 0; font-style: italic; }
.tm-form-stack { display: flex; flex-direction: column; gap: 16px; flex-shrink: 0; }
.tm-field-block { display: flex; flex-direction: column; gap: 6px; }
.tm-field-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .6px; color: var(--gray-600); display: flex; align-items: center; gap: 4px; }
.tm-field-label .req { color: var(--danger); }
.tm-field-label .auto-badge { font-size: 9px; font-weight: 600; padding: 1px 6px; border-radius: 99px; background: var(--pink-pale); color: var(--pink); letter-spacing: 0; text-transform: none; }
.tm-select-row   { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; }
.tm-select-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.tm-dataset-wrap { border: 1.5px solid var(--gray-200); border-radius: var(--radius-sm); overflow: hidden; }
.tm-dataset-search { display: flex; align-items: center; gap: 8px; padding: 8px 10px; border-bottom: 1.5px solid var(--gray-100); background: var(--gray-50); }
.tm-dataset-search svg { flex-shrink: 0; color: var(--gray-400); }
.tm-dataset-search input { flex: 1; border: none; background: transparent; outline: none; font-family: var(--font); font-size: 13px; color: var(--gray-800); }
.tm-dataset-search input::placeholder { color: var(--gray-400); }
.tm-dataset-list { max-height: 190px; overflow-y: auto; }
.tm-dataset-item { display: flex; align-items: flex-start; gap: 10px; padding: 9px 12px; cursor: pointer; border-bottom: 1px solid var(--gray-100); transition: background var(--transition); }
.tm-dataset-item:last-child { border-bottom: none; }
.tm-dataset-item:hover { background: var(--gray-50); }
.tm-dataset-item.ds-selected { background: var(--pink-pale); }
.tm-dataset-item input[type=checkbox] { margin-top: 2px; accent-color: var(--pink); cursor: pointer; width: 14px; height: 14px; flex-shrink: 0; }
.tm-dataset-id   { font-size: 10px; font-weight: 700; color: var(--pink); font-family: var(--mono); margin-bottom: 1px; }
.tm-dataset-name { font-size: 13px; color: var(--gray-800); line-height: 1.4; }
.tm-dataset-none { text-align:center; color:var(--gray-400); font-size:13px; padding:18px; font-style:italic; }

/* ════════════════════════════════════════════════
   CAPA PANEL
   ════════════════════════════════════════════════ */
.btn-capa-topbar { background: linear-gradient(135deg, var(--pink-dark), var(--navy)); color: var(--white); font-weight: 600; border-radius: var(--radius-sm); padding: 6px 14px; font-size: 12.5px; display: flex; align-items: center; gap: 6px; transition: opacity var(--transition); border: none; cursor: pointer; }
.btn-capa-topbar:hover { opacity: .88; }

#capa-panel { position: fixed; inset: 0; background: var(--gray-50); z-index: 200; display: flex; flex-direction: column; overflow: hidden; }
#capa-panel.hidden { display: none; }

.capa-topbar { display: flex; align-items: center; gap: 12px; padding: 0 24px; height: 56px; background: #a8275f; flex-shrink: 0; box-shadow: 0 2px 12px rgba(0,0,0,.18); }
.capa-topbar-title { color: var(--white); font-size: 15px; font-weight: 700; letter-spacing: .02em; flex: 1; display: flex; align-items: center; gap: 8px; }
.capa-topbar-title svg { opacity: .85; }
.capa-topbar-actions { display: flex; gap: 8px; align-items: center; }
.btn-capa-export { background: rgba(255,255,255,.18); color: var(--white); border: 1.5px solid rgba(255,255,255,.35); border-radius: var(--radius-sm); padding: 5px 12px; font-size: 12px; font-weight: 600; cursor: pointer; display: flex; align-items: center; gap: 5px; transition: background var(--transition); }
.btn-capa-export:hover { background: rgba(255,255,255,.28); }
.btn-capa-export.loading { opacity: .5; pointer-events: none; }
.btn-capa-close { background: rgba(255,255,255,.15); color: var(--white); border: none; border-radius: 6px; width: 34px; height: 34px; font-size: 18px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background var(--transition); }
.btn-capa-close:hover { background: rgba(255,255,255,.30); }
.btn-capa-home { background: rgba(255,255,255,.12); color: rgba(255,255,255,.85); border: 1.5px solid rgba(255,255,255,.2); border-radius: var(--radius-sm); padding: 5px 12px; font-size: 12px; font-weight: 600; cursor: pointer; display: flex; align-items: center; gap: 5px; transition: background var(--transition); }
.btn-capa-home:hover { background: rgba(255,255,255,.22); }

.capa-tabs { display: flex; gap: 0; background: var(--white); border-bottom: 2px solid var(--gray-200); flex-shrink: 0; padding: 0 24px; }
.capa-tab { padding: 12px 20px; font-size: 13px; font-weight: 600; color: var(--gray-600); border-bottom: 2.5px solid transparent; margin-bottom: -2px; cursor: pointer; transition: color var(--transition), border-color var(--transition); display: flex; align-items: center; gap: 7px; background: none; border-top: none; border-left: none; border-right: none; }
.capa-tab:hover { color: var(--pink); }
.capa-tab.active { color: var(--pink); border-bottom-color: var(--pink); }
.capa-tab-badge { background: var(--pink-light); color: var(--pink-dark); border-radius: 20px; padding: 1px 7px; font-size: 11px; font-weight: 700; }
.capa-tab.active .capa-tab-badge { background: var(--pink); color: var(--white); }

/* ── CAPA Content area (scroll fix) ── */
.capa-content { flex: 1; min-height: 0; overflow: hidden; display: flex; flex-direction: column; }
.capa-tab-panel { display: none; flex-direction: column; }
.capa-tab-panel.active { display: flex; flex-direction: column; gap: 12px; padding: 16px 24px; overflow-y: auto; min-height: 0; flex: 1; }

.capa-toolbar { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; flex-shrink: 0; }
.capa-toolbar-spacer { flex: 1; }
.capa-search { border: 1.5px solid var(--gray-200); border-radius: var(--radius-sm); padding: 7px 12px; font-size: 13px; width: 220px; outline: none; transition: border-color var(--transition); }
.capa-search:focus { border-color: var(--pink); }
.capa-filter-chip { padding: 5px 12px; border-radius: 20px; border: 1.5px solid var(--gray-200); background: var(--white); font-size: 12px; font-weight: 600; color: var(--gray-600); cursor: pointer; transition: all var(--transition); }
.capa-filter-chip:hover { border-color: var(--pink-light); color: var(--pink); }
.capa-filter-chip.active { background: var(--pink); color: var(--white); border-color: var(--pink); }

.btn-capa-primary { background: var(--pink); color: var(--white); border-radius: var(--radius-sm); padding: 7px 16px; font-size: 13px; font-weight: 600; cursor: pointer; border: none; display: flex; align-items: center; gap: 6px; transition: opacity var(--transition); }
.btn-capa-primary:hover { opacity: .88; }
.btn-capa-secondary { background: var(--white); color: var(--gray-800); border: 1.5px solid var(--gray-200); border-radius: var(--radius-sm); padding: 7px 16px; font-size: 13px; font-weight: 500; cursor: pointer; display: flex; align-items: center; gap: 6px; transition: all var(--transition); }
.btn-capa-secondary:hover { border-color: var(--pink-light); color: var(--pink); }
.btn-capa-icon { background: none; border: none; padding: 4px; cursor: pointer; color: var(--gray-400); border-radius: 6px; transition: color var(--transition), background var(--transition); display: flex; align-items: center; }
.btn-capa-icon:hover { color: var(--pink); background: var(--pink-pale); }

/* ── CAPA Table (compact rows + scroll) ── */
.capa-card { background: var(--white); border-radius: var(--radius); border: 1.5px solid var(--gray-200); overflow: hidden; box-shadow: var(--shadow); flex-shrink: 0; }
.capa-table-wrap { overflow-x: auto; overflow-y: auto; max-height: calc(100vh - 300px); }
.capa-table { width: 100%; border-collapse: collapse; font-size: 12.5px; }
.capa-table thead tr { background: var(--gray-100); }
.capa-table th { padding: 7px 12px; text-align: left; font-weight: 700; color: var(--gray-800); font-size: 11px; text-transform: uppercase; letter-spacing: .05em; white-space: nowrap; border-bottom: 2px solid var(--gray-200); }
.capa-table td { padding: 5px 12px; color: var(--gray-800); vertical-align: middle; border-bottom: 1px solid var(--gray-100); line-height: 1.35; }
.capa-table tbody tr { transition: background var(--transition); cursor: pointer; }
.capa-table tbody tr:hover td { background: var(--pink-pale); }
.capa-table tbody tr:last-child td { border-bottom: none; }

/* ── Badges ── */
.badge-status { display: inline-flex; align-items: center; padding: 3px 9px; border-radius: 20px; font-size: 11px; font-weight: 700; white-space: nowrap; }
.badge-status.st-todo    { background:#f1f5f9; color:#475569; }
.badge-status.st-doing   { background:#dbeafe; color:#1d4ed8; }
.badge-status.st-review  { background:#fef3c7; color:#b45309; }
.badge-status.st-upload  { background:#ede9fe; color:#6d28d9; }
.badge-status.st-done    { background:#dcfce7; color:#166534; }
.badge-status.st-cancel  { background:#f1f5f9; color:#94a3b8; }
.badge-prio { display: inline-block; width: 8px; height: 8px; border-radius: 50%; margin-right: 5px; }
.badge-prio.prio-highest,.badge-prio.prio-high { background:#ef4444; }
.badge-prio.prio-medium { background:#f59e0b; }
.badge-prio.prio-low,.badge-prio.prio-lowest { background:#22c55e; }
.badge-capa { display: inline-flex; align-items: center; padding: 2px 8px; border-radius: 12px; font-size: 11px; font-weight: 700; }
.badge-capa.required { background: var(--pink); color: var(--white); }
.badge-capa.not-required { background: var(--gray-100); color: var(--gray-600); }
.badge-type { display: inline-flex; align-items: center; padding: 2px 8px; border-radius: 12px; font-size: 11px; font-weight: 600; background: var(--blue); color: var(--white); }
.badge-type.preventive { background: #0ea5e9; }
.badge-type.improvement { background: #8b5cf6; }
.badge-type.corrective  { background: var(--pink); }

/* ── NC Upload ── */
.nc-upload-zone { border: 2.5px dashed var(--gray-200); border-radius: var(--radius); padding: 40px 32px; text-align: center; cursor: pointer; transition: all var(--transition); background: var(--white); flex-shrink: 0; }
.nc-upload-zone:hover, .nc-upload-zone.drag-over { border-color: var(--pink); background: var(--pink-pale); }
.nc-upload-icon { color: var(--gray-400); margin-bottom: 12px; }
.nc-upload-title { font-size: 15px; font-weight: 600; color: var(--gray-800); margin-bottom: 4px; }
.nc-upload-sub { font-size: 12.5px; color: var(--gray-400); }

/* ── NC Preview ── */
.nc-preview { background: var(--white); border-radius: var(--radius); border: 1.5px solid var(--gray-200); overflow: hidden; box-shadow: var(--shadow); }
.nc-preview-header { background: linear-gradient(135deg, var(--pink-dark), var(--navy)); padding: 16px 20px; display: flex; align-items: center; gap: 12px; }
.nc-preview-id { color: var(--white); font-size: 18px; font-weight: 800; letter-spacing: -.01em; }
.nc-preview-source { color: rgba(255,255,255,.75); font-size: 12px; font-weight: 500; }
.nc-preview-capa-badge { margin-left: auto; padding: 4px 12px; border-radius: 20px; font-size: 12px; font-weight: 700; background: rgba(255,255,255,.2); color: var(--white); border: 1.5px solid rgba(255,255,255,.35); }
.nc-preview-capa-badge.required { background: rgba(255,200,50,.25); border-color: rgba(255,200,50,.5); color: #fffbe6; }
.nc-preview-body { padding: 16px 20px; display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.nc-preview-field { display: flex; flex-direction: column; gap: 3px; }
.nc-preview-field.full { grid-column: 1/-1; }
.nc-preview-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--gray-400); }
.nc-preview-value { font-size: 13px; color: var(--gray-800); line-height: 1.5; }
.nc-preview-value.long { max-height: 80px; overflow-y: auto; font-size: 12px; background: var(--gray-50); padding: 8px; border-radius: 6px; }
.nc-preview-actions { padding: 12px 20px; border-top: 1.5px solid var(--gray-100); display: flex; gap: 10px; justify-content: flex-end; }

/* ── CAPA Plan Form ── */
.capa-plan-card { background: var(--white); border-radius: var(--radius); border: 1.5px solid var(--gray-200); overflow: hidden; box-shadow: var(--shadow); }
.capa-plan-header { background: var(--gray-100); padding: 14px 20px; display: flex; align-items: center; justify-content: space-between; border-bottom: 1.5px solid var(--gray-200); }
.capa-plan-title { font-size: 14px; font-weight: 700; color: var(--gray-800); }
.action-rows { padding: 0 20px 16px; }
.action-row { display: grid; grid-template-columns: 1fr 160px 100px 130px 130px 36px; gap: 8px; padding: 10px 0; border-bottom: 1px solid var(--gray-100); align-items: start; }
.action-row:last-child { border-bottom: none; }
.action-row-num { grid-column: 1/-1; font-size: 11px; font-weight: 700; color: var(--pink-dark); text-transform: uppercase; letter-spacing: .06em; margin-bottom: -4px; }
.form-group { display: flex; flex-direction: column; gap: 3px; }
.form-label { font-size: 11px; font-weight: 600; color: var(--gray-600); }
.form-input, .form-select { border: 1.5px solid var(--gray-200); border-radius: 6px; padding: 7px 10px; font-size: 13px; font-family: var(--font); color: var(--gray-800); background: var(--white); outline: none; transition: border-color var(--transition); width: 100%; }
.form-input:focus, .form-select:focus { border-color: var(--pink); }
.form-textarea { resize: vertical; min-height: 64px; }
.btn-remove-row { align-self: flex-end; margin-bottom: 2px; background: none; border: 1.5px solid var(--gray-200); color: var(--gray-400); border-radius: 6px; width: 34px; height: 34px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all var(--transition); }
.btn-remove-row:hover { border-color: var(--danger); color: var(--danger); background: #fee2e2; }

/* ── NC Detail Split ── */
.capa-split { display: flex; gap: 20px; flex: 1; overflow: hidden; min-height: 0; }
.capa-list-col { width: 420px; min-width: 420px; overflow-y: auto; display: flex; flex-direction: column; gap: 8px; }
.capa-detail-col { flex: 1; overflow-y: auto; display: flex; flex-direction: column; gap: 16px; }
.nc-list-item { background: var(--white); border: 1.5px solid var(--gray-200); border-radius: var(--radius-sm); padding: 12px 14px; cursor: pointer; transition: all var(--transition); flex-shrink: 0; }
.nc-list-item:hover { border-color: var(--pink-light); box-shadow: var(--shadow); }
.nc-list-item.selected { border-color: var(--pink); background: var(--pink-pale); }
.nc-list-item-key { font-size: 12px; font-weight: 700; color: var(--pink-dark); margin-bottom: 4px; display: flex; align-items: center; gap: 8px; }
.nc-list-item-title { font-size: 12.5px; color: var(--gray-800); line-height: 1.4; margin-bottom: 6px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.nc-list-item-meta { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }

/* ── Detail Sections ── */
.detail-section { background: var(--white); border: 1.5px solid var(--gray-200); border-radius: var(--radius); overflow: hidden; flex-shrink: 0; }
.detail-section-header { padding: 12px 16px; background: var(--gray-100); border-bottom: 1.5px solid var(--gray-200); display: flex; align-items: center; justify-content: space-between; font-size: 13px; font-weight: 700; color: var(--gray-800); gap: 8px; }
.detail-section-body { padding: 14px 16px; }
.detail-row { display: flex; justify-content: space-between; padding: 7px 0; border-bottom: 1px solid var(--gray-100); font-size: 13px; gap: 12px; }
.detail-row:last-child { border-bottom: none; }
.detail-key { color: var(--gray-600); font-weight: 500; flex-shrink: 0; }
.detail-val { color: var(--gray-800); font-weight: 500; text-align: right; }
.review-date-box { background: linear-gradient(135deg, #fef3c7, #fde68a); border: 1.5px solid #f59e0b; border-radius: var(--radius-sm); padding: 14px 16px; display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.review-date-icon { font-size: 24px; }
.review-date-label { font-size: 11px; font-weight: 700; text-transform: uppercase; color: #78350f; letter-spacing: .06em; }
.review-date-value { font-size: 18px; font-weight: 800; color: #b45309; }

/* ── Effectiveness Form ── */
.eff-form { display: flex; flex-direction: column; gap: 12px; }
.eff-choice-row { display: flex; gap: 10px; }
.eff-choice { flex: 1; border: 2px solid var(--gray-200); border-radius: var(--radius-sm); padding: 12px 16px; cursor: pointer; text-align: center; transition: all var(--transition); font-weight: 600; font-size: 13px; }
.eff-choice:hover { border-color: var(--pink-light); }
.eff-choice.selected.eff-yes { border-color: var(--success); background: #dcfce7; color: #166534; }
.eff-choice.selected.eff-no  { border-color: var(--danger); background: #fee2e2; color: #991b1b; }
.eff-choice .eff-icon { font-size: 20px; display: block; margin-bottom: 4px; }

/* ── Empty state ── */
.capa-empty { text-align: center; padding: 48px 32px; color: var(--gray-400); }
.capa-empty-icon { font-size: 44px; margin-bottom: 10px; }
.capa-empty-title { font-size: 15px; font-weight: 600; color: var(--gray-600); margin-bottom: 6px; }
.capa-empty-sub { font-size: 13px; }

/* ── Spinner inline ── */
.capa-spinner { width: 20px; height: 20px; border: 2.5px solid var(--gray-200); border-top-color: var(--pink); border-radius: 50%; animation: spin .7s linear infinite; display: inline-block; }

/* ── Sub-tabs amélioration continue ── */
.ia-sub-tabs { display: flex; gap: 6px; flex-wrap: wrap; padding-bottom: 10px; border-bottom: 1.5px solid var(--gray-200); flex-shrink: 0; }
.ia-sub-tab { padding: 5px 13px; border-radius: 20px; border: 1.5px solid var(--gray-200); background: var(--white); font-size: 12px; font-weight: 600; color: var(--gray-600); cursor: pointer; transition: all var(--transition); display: inline-flex; align-items: center; gap: 5px; white-space: nowrap; }
.ia-sub-tab:hover { border-color: var(--pink-light); color: var(--pink); }
.ia-sub-tab.active { background: var(--pink); color: var(--white); border-color: var(--pink); }
.ia-sub-tab-count { background: rgba(0,0,0,.12); color: inherit; border-radius: 10px; padding: 1px 6px; font-size: 10px; font-weight: 700; }
.ia-sub-tab.active .ia-sub-tab-count { background: rgba(255,255,255,.25); }

/* ══════════════════════════════════════════════════════════════
   CAPA MODULE v3 — Sidebar shell + Dashboard KPIs
══════════════════════════════════════════════════════════════ */

/* ── Panel & app shell ───────────────────────────────────── */
#capa-main { height: 100%; display: flex; flex-direction: column; }
.capa-app  { display: flex; height: 100%; overflow: hidden; }

/* ── Sidebar ─────────────────────────────────────────────── */
.capa-sidebar {
  width: 220px; flex-shrink: 0;
  background: var(--white);
  border-right: 1.5px solid var(--gray-100);
  display: flex; flex-direction: column; overflow-y: auto;
}
.capa-sidebar-header {
  display: flex; align-items: center; gap: 10px;
  padding: 16px 14px; border-bottom: 1.5px solid var(--gray-100);
}
.capa-logo-icon   { font-size: 20px; }
.capa-sidebar-title { font-weight: 800; color: var(--gray-800); font-size: 13px; letter-spacing: .04em; text-transform: uppercase; }

/* ── Sidebar nav ─────────────────────────────────────────── */
.capa-nav { padding: 8px 0; flex: 1; }
.capa-nav-item {
  display: flex; align-items: center; gap: 9px;
  width: calc(100% - 12px); margin: 1px 6px; padding: 9px 12px;
  background: none; border: none; color: var(--gray-600);
  cursor: pointer; font-size: 12.5px; text-align: left;
  border-radius: 6px; transition: background .12s, color .12s;
  position: relative;
}
.capa-nav-item:hover  { background: var(--pink-pale); color: var(--pink-dark); }
.capa-nav-item.active { background: var(--pink-pale); color: var(--pink-dark); font-weight: 700; }
.capa-nav-badge {
  margin-left: auto; background: var(--pink); color: white;
  border-radius: 10px; padding: 1px 6px; font-size: 10px; font-weight: 800;
}

/* ── Sidebar export & footer ─────────────────────────────── */
.capa-sidebar-actions { padding: 8px 10px; border-top: 1.5px solid var(--gray-100); display: flex; flex-direction: column; gap: 6px; }
.capa-sidebar-export-btn {
  width: 100%; padding: 7px 10px; border-radius: 6px;
  background: var(--gray-50); border: 1.5px solid var(--gray-200);
  color: var(--gray-600); font-size: 12px; cursor: pointer; text-align: left;
  transition: background .12s, color .12s;
}
.capa-sidebar-export-btn:hover { background: var(--pink-pale); color: var(--pink-dark); border-color: var(--pink-light); }
.capa-sidebar-export-btn.loading { opacity: .5; cursor: wait; }
.capa-sidebar-footer { padding: 10px; border-top: 1.5px solid var(--gray-100); }
.capa-home-btn {
  width: 100%; padding: 8px 10px; border-radius: 6px;
  background: var(--gray-50); border: 1.5px solid var(--gray-200);
  color: var(--gray-600); font-size: 12px; cursor: pointer; text-align: left;
  transition: background .12s, color .12s;
}
.capa-home-btn:hover { background: var(--pink-pale); color: var(--pink-dark); }

/* ── Content area ────────────────────────────────────────── */
.capa-content-area {
  flex: 1; overflow-y: auto; display: flex; flex-direction: column;
  background: var(--gray-50, #f8fafc);
}
.capa-loading-inner { display: flex; align-items: center; justify-content: center; flex: 1; min-height: 200px; }

/* ── Pages ───────────────────────────────────────────────── */
.capa-page { padding: 20px 24px; display: flex; flex-direction: column; gap: 16px; flex: 1; }
.capa-page-dashboard { max-width: 1400px; }
.capa-page-title { margin: 0 0 4px; font-size: 20px; font-weight: 800; color: var(--gray-900, #0f172a); }
.capa-section-title { font-size: 15px; font-weight: 700; color: var(--gray-800); margin: 0 0 12px; display: flex; align-items: center; gap: 8px; }
.capa-flow-hint { font-size: 12px; font-weight: 400; color: var(--gray-400); }

/* ── Stat cards grid ─────────────────────────────────────── */
.capa-stats-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(155px,1fr)); gap: 12px; }
.capa-stat-card {
  background: var(--white, #fff); border: 1.5px solid var(--gray-200, #e2e8f0);
  border-radius: 12px; padding: 16px; text-align: center; box-shadow: 0 1px 4px rgba(0,0,0,.05);
}
.capa-stat-card.warn { border-color: rgba(239,68,68,.3); background: #fff5f5; }
.capa-stat-icon  { font-size: 22px; margin-bottom: 6px; }
.capa-stat-value { font-size: 28px; font-weight: 800; color: var(--gray-900, #0f172a); line-height: 1; }
.capa-stat-label { font-size: 11.5px; color: var(--gray-400); margin-top: 4px; }

/* ── KPI cards ───────────────────────────────────────────── */
.capa-kpi-row { display: flex; gap: 16px; flex-wrap: wrap; }
.capa-kpi-card {
  background: var(--white, #fff); border: 1.5px solid var(--gray-200, #e2e8f0);
  border-radius: 14px; padding: 18px; box-shadow: 0 1px 4px rgba(0,0,0,.05);
  flex: 1; min-width: 260px;
}
.capa-kpi-card-wide { flex: 2; min-width: 360px; }
.capa-kpi-full { width: 100%; box-sizing: border-box; }
.capa-kpi-title { font-size: 13.5px; font-weight: 700; color: var(--gray-800); margin-bottom: 3px; }
.capa-kpi-sub   { font-size: 11.5px; color: var(--gray-400); margin-bottom: 12px; }

/* KPI 1 details table */
.kpi1-detail-row { display: flex; align-items: center; gap: 8px; padding: 3px 0; border-bottom: 1px solid var(--gray-100); font-size: 11px; }
.kpi1-detail-row:last-child { border-bottom: none; }
.kpi1-detail-key  { flex: 1; font-weight: 700; }
.kpi1-detail-days { color: var(--gray-400); margin-left: 4px; font-variant-numeric: tabular-nums; }
.kpi1-detail-status { padding: 1px 7px; border-radius: 10px; font-weight: 700; font-size: 10px; }
.kpi1-detail-status.ok { background: #dcfce7; color: #166534; }
.kpi1-detail-status.ko { background: #fee2e2; color: #991b1b; }

/* ── Dashboard lower (proc card + flowchart) ─────────────── */
.capa-dashboard-lower {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 20px;
  align-items: start;
}

/* ── Procedure section & card ────────────────────────────── */
.capa-proc-section {
  background: var(--white); border: 1.5px solid var(--gray-200);
  border-radius: 14px; padding: 16px;
  box-shadow: 0 1px 4px rgba(0,0,0,.05);
}
.capa-proc-card {
  background: var(--pink-pale); border: 1.5px solid var(--pink-light);
  border-radius: 10px; padding: 14px; cursor: pointer;
  transition: background .15s, border-color .15s, transform .1s;
  display: flex; flex-direction: column; gap: 8px;
}
.capa-proc-card:hover {
  background: var(--pink-light); border-color: var(--pink);
  transform: translateY(-1px);
}
.capa-proc-card-icon  { font-size: 26px; }
.capa-proc-card-body  { display: flex; flex-direction: column; gap: 3px; }
.capa-proc-card-title { font-size: 13px; font-weight: 700; color: var(--gray-800); line-height: 1.4; }
.capa-proc-card-ref   { font-size: 11px; color: var(--pink-dark); font-weight: 600; }
.capa-proc-card-hint  { font-size: 11px; color: var(--gray-400); margin-top: 2px; }
.capa-proc-edit-row {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 10px; padding-top: 10px;
  border-top: 1px solid var(--gray-200);
}
.capa-proc-hint { font-size: 11px; color: var(--gray-400); }
.capa-proc-empty {
  display: flex; flex-direction: column; align-items: flex-start;
  gap: 10px; padding: 14px;
  background: var(--gray-50); border: 1.5px dashed var(--gray-200);
  border-radius: 8px; font-size: 13px; color: var(--gray-400);
}

/* ── Flowchart section (narrower) ────────────────────────── */
.capa-flow-section {
  background: var(--white); border: 1.5px solid var(--gray-200);
  border-radius: 14px; padding: 18px; min-width: 0;
}
.capa-flow-container {
  overflow: auto; border-radius: 8px;
  border: 1px solid var(--pink-light); background: var(--pink-pale);
  max-height: 860px; max-width: 100%;
  scrollbar-width: thin; scrollbar-color: var(--pink-light) transparent;
}
.capa-flow-container::-webkit-scrollbar { width:6px; height:6px; }
.capa-flow-container::-webkit-scrollbar-thumb { background: var(--pink-light); border-radius:3px; }

@media (max-width: 900px) {
  .capa-dashboard-lower { grid-template-columns: 1fr; }
}

/* ── Error ───────────────────────────────────────────────── */
.capa-error { color: var(--danger, #ef4444); background: #fee2e2; border: 1px solid #fca5a5; border-radius: 10px; padding: 20px 24px; font-size: 13px; margin: 24px; }

/* ── Icon button ─────────────────────────────────────────── */
.btn-capa-icon { background: none; border: 1px solid var(--gray-200); border-radius: 5px; padding: 4px 7px; cursor: pointer; font-size: 12px; color: var(--gray-400); transition: all var(--transition); }
.btn-capa-icon:hover { border-color: var(--pink-light); color: var(--pink); }

/* ── Flowchart toolbar ───────────────────────────────────── */
.capa-flow-toolbar { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; flex-wrap: wrap; }
.capa-flow-procedure-link { display: inline-flex; align-items: center; gap: 6px; padding: 6px 14px; border-radius: 20px; background: var(--pink-pale); border: 1.5px solid var(--pink-light); color: var(--pink-dark); font-size: 12px; font-weight: 600; text-decoration: none; transition: all var(--transition); }
.capa-flow-procedure-link:hover { background: var(--pink-light); color: var(--pink-dark); }
.btn-flow-edit { display: inline-flex; align-items: center; gap: 6px; padding: 6px 14px; border-radius: 20px; background: var(--white); border: 1.5px solid var(--gray-200); color: var(--gray-600); font-size: 12px; font-weight: 600; cursor: pointer; transition: all var(--transition); }
.btn-flow-edit:hover { border-color: var(--pink-light); color: var(--pink); }
.btn-flow-edit.active { background: var(--pink); border-color: var(--pink); color: #fff; }
.btn-flow-reset { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; border-radius: 20px; background: var(--white); border: 1.5px solid var(--gray-200); color: var(--gray-400); font-size: 11px; font-weight: 600; cursor: pointer; transition: all var(--transition); margin-left: auto; }
.btn-flow-reset:hover { border-color: var(--danger); color: var(--danger); }

/* ── Settings page ───────────────────────────────────────── */
.capa-settings-card { background: var(--white); border: 1.5px solid var(--gray-200); border-radius: 14px; overflow: hidden; box-shadow: 0 1px 4px rgba(0,0,0,.05); }
.capa-settings-card-header { padding: 14px 20px; background: var(--gray-100); border-bottom: 1.5px solid var(--gray-200); font-size: 13.5px; font-weight: 700; color: var(--gray-800); display: flex; align-items: center; gap: 8px; }
.capa-settings-card-body { padding: 20px; display: flex; flex-direction: column; gap: 16px; }
.capa-settings-field { display: flex; flex-direction: column; gap: 5px; }
.capa-settings-field label { font-size: 12px; font-weight: 700; color: var(--gray-600); text-transform: uppercase; letter-spacing: .05em; }
.capa-settings-field input, .capa-settings-field textarea { border: 1.5px solid var(--gray-200); border-radius: 8px; padding: 8px 12px; font-size: 13px; color: var(--gray-800); outline: none; transition: border-color var(--transition); font-family: var(--font); }
.capa-settings-field input:focus, .capa-settings-field textarea:focus { border-color: var(--pink); }
.capa-settings-field .hint { font-size: 11px; color: var(--gray-400); margin-top: 2px; }
.capa-settings-save-row { display: flex; justify-content: flex-end; gap: 10px; padding-top: 4px; }

/* ── Procedure modal ─────────────────────────────────────── */
.capa-proc-modal-wrap {
  position: fixed; inset: 0; background: rgba(0,0,0,.55);
  display: flex; align-items: center; justify-content: center; z-index: 9999;
}
.capa-proc-modal-card {
  background: var(--white); border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0,0,0,.25); width: 480px; max-width: 96vw; overflow: hidden;
}
.capa-proc-modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 20px; background: linear-gradient(135deg, var(--pink-deep,#7a1040), var(--pink-dark,#a8275f));
}
.capa-proc-modal-title { display: flex; align-items: center; gap: 12px; color: #fff; }
.capa-proc-modal-name  { font-size: 15px; font-weight: 700; }
.capa-proc-modal-sub   { font-size: 12px; opacity: .8; margin-top: 2px; }
.capa-proc-modal-close {
  background: rgba(255,255,255,.15); border: none; color: #fff;
  width: 28px; height: 28px; border-radius: 50%; cursor: pointer; font-size: 14px;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s;
}
.capa-proc-modal-close:hover { background: rgba(255,255,255,.3); }
.capa-proc-launch-body {
  padding: 24px 20px; display: flex; flex-direction: column; gap: 16px; align-items: center;
}
.capa-proc-launch-icon { font-size: 44px; }
.capa-proc-launch-actions { display: flex; flex-direction: column; gap: 10px; width: 100%; }
.capa-proc-launch-btn {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 16px; border-radius: 10px; border: 1.5px solid;
  cursor: pointer; text-align: left; width: 100%; transition: all .15s;
}
.capa-proc-launch-btn-primary {
  background: var(--pink-pale); border-color: var(--pink-light); color: var(--gray-800);
}
.capa-proc-launch-btn-primary:hover { background: var(--pink-light); border-color: var(--pink); }
.capa-proc-launch-btn-secondary {
  background: var(--gray-50); border-color: var(--gray-200); color: var(--gray-600);
}
.capa-proc-launch-btn-secondary:hover { background: var(--gray-100); border-color: var(--gray-400); }
.capa-proc-btn-icon   { font-size: 22px; flex-shrink: 0; }
.capa-proc-btn-text   { display: flex; flex-direction: column; gap: 2px; }
.capa-proc-btn-text strong { font-size: 13.5px; font-weight: 700; }
.capa-proc-btn-text small  { font-size: 11px; opacity: .65; font-weight: 400; }
.capa-proc-launch-note {
  font-size: 11.5px; color: var(--gray-400); text-align: center;
  background: var(--gray-50); border-radius: 8px; padding: 10px 14px; line-height: 1.5;
}

/* ── Period picker in sidebar ────────────────────────────── */
.capa-period-section {
  padding: 10px 10px 14px;
  border-top: 1px solid rgba(0,0,0,.15);
  display: flex; flex-direction: column; gap: 7px;
}
.capa-period-label {
  font-size: 10px; font-weight: 800; text-transform: uppercase;
  letter-spacing: .07em; color: rgba(255,255,255,.55); margin-bottom: 2px;
}
.capa-period-row { display: flex; align-items: center; gap: 6px; }
.capa-period-sublabel {
  font-size: 11px; color: rgba(255,255,255,.65); width: 20px; flex-shrink: 0;
}
.capa-period-input {
  flex: 1; padding: 5px 7px; border-radius: 6px;
  border: 1px solid rgba(255,255,255,.2); background: rgba(0,0,0,.2);
  color: #fff; font-size: 11px; font-family: var(--font);
  outline: none; cursor: pointer; color-scheme: dark; min-width: 0;
}
.capa-period-input:focus { border-color: rgba(255,255,255,.5); background: rgba(0,0,0,.3); }
.capa-period-apply {
  margin-top: 4px; padding: 7px 10px; border-radius: 6px;
  background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.25);
  color: #fff; font-size: 12px; font-weight: 700; cursor: pointer;
  transition: background .12s; width: 100%;
}
.capa-period-apply:hover { background: rgba(255,255,255,.28); }
.capa-period-apply:active { background: rgba(255,255,255,.35); }

/* ── Period badge on dashboard title ─────────────────────── */
.capa-period-badge {
  display: inline-block; margin-left: 10px;
  font-size: 12px; font-weight: 600; padding: 3px 10px;
  background: var(--pink-pale); border: 1.5px solid var(--pink-light);
  color: var(--pink-dark); border-radius: 20px; vertical-align: middle;
  letter-spacing: 0;
}

@media (max-width: 780px) {
  .capa-sidebar { width: 52px; }
  .capa-sidebar-title, .capa-nav-item span, .capa-sidebar-export-btn span,
  .capa-home-btn span, .capa-sidebar-actions .capa-sidebar-export-btn { font-size: 0; }
  .capa-nav-item { padding: 10px; justify-content: center; }
  .capa-sidebar-footer, .capa-sidebar-actions { padding: 6px; }
  .capa-home-btn { text-align: center; }
  .capa-period-section { display: none; }
}

/* ── Modal add action ── */
#modal-add-action.hidden { display: none; }

/* ─── Responsive ─────────────────────────────── */
@media (max-width: 900px) {
  .capa-split { flex-direction: column; }
  .capa-list-col { width: 100%; min-width: 0; max-height: 300px; }
  .action-row { grid-template-columns: 1fr 1fr; }
  #sidebar { position: absolute; top: 0; left: 0; height: 100%; z-index: 100; transform: translateX(-100%); }
  #sidebar.open { transform: none; box-shadow: var(--shadow-md); }
}

/* ════════════════════════════════════════════════
   DASHBOARD - Navigation par cartes
   ════════════════════════════════════════════════ */
#dashboard-view {
  position: fixed; inset: 0;
  background: var(--gray-50);
  z-index: 50;
  display: flex; flex-direction: column;
  overflow-y: auto;
}
#dashboard-view.hidden { display: none; }

.dash-topbar {
  height: 60px; flex-shrink: 0;
  background: #a8275f;
  display: flex; align-items: center; gap: 14px;
  padding: 0 40px;
  box-shadow: 0 2px 16px rgba(0,0,0,.18);
}
.dash-logo { display: flex; align-items: center; gap: 10px; }
.dash-logo-icon {
  width: 34px; height: 34px; border-radius: 8px;
  background: rgba(255,255,255,.2);
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 15px; color: var(--white);
}
.dash-logo-text { color: var(--white); font-size: 15px; font-weight: 700; letter-spacing: -.2px; }
.dash-logo-badge { font-size: 10px; font-weight: 700; letter-spacing: .5px; background: rgba(255,255,255,.2); color: var(--white); border-radius: 4px; padding: 2px 7px; }
.dash-topbar-spacer { flex: 1; }
.dash-user-chip { display: flex; align-items: center; gap: 6px; font-size: 12px; color: rgba(255,255,255,.85); background: rgba(255,255,255,.15); border-radius: 99px; padding: 4px 12px; }
.dash-user-dot { width: 7px; height: 7px; border-radius: 50%; background: #4ade80; }
.dash-btn-logout { font-size: 12px; color: rgba(255,255,255,.7); border: 1.5px solid rgba(255,255,255,.3); background: none; cursor: pointer; padding: 5px 10px; border-radius: var(--radius-sm); font-family: var(--font); transition: all var(--transition); }
.dash-btn-logout:hover { color: var(--white); border-color: rgba(255,255,255,.6); background: rgba(255,255,255,.1); }

.dash-body { flex: 1; padding: 64px 40px 80px; display: flex; flex-direction: column; align-items: center; gap: 48px; }
.dash-hero { text-align: center; }
.dash-hero-title { font-size: 36px; font-weight: 800; letter-spacing: -.8px; color: var(--pink-dark); margin-bottom: 10px; }
.dash-hero-sub { font-size: 16px; color: var(--gray-400); line-height: 1.6; }

.dash-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; max-width: 1060px; width: 100%; }
.dash-card { background: var(--white); border-radius: 18px; border: 1.5px solid var(--gray-200); padding: 28px; display: flex; flex-direction: column; gap: 14px; box-shadow: 0 4px 24px rgba(0,0,0,.05); transition: all .25s cubic-bezier(.4,0,.2,1); cursor: pointer; position: relative; overflow: hidden; }
.dash-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; border-radius: 18px 18px 0 0; opacity: 0; transition: opacity .25s; }
.dash-card.req::before  { background: linear-gradient(90deg, var(--blue), #60a5fa); }
.dash-card.capa::before { background: linear-gradient(90deg, var(--pink), var(--pink-dark)); }
.dash-card.hr::before   { background: linear-gradient(90deg, #22c55e, #4ade80); }
.dash-card:hover:not(.coming-soon) { transform: translateY(-6px); box-shadow: 0 16px 48px rgba(213,64,132,.14); border-color: var(--pink-light); }
.dash-card:hover:not(.coming-soon)::before { opacity: 1; }
.dash-card.coming-soon { cursor: not-allowed; opacity: .6; }
.dash-card-icon { width: 54px; height: 54px; border-radius: 14px; display: flex; align-items: center; justify-content: center; font-size: 26px; flex-shrink: 0; }
.dash-card.req  .dash-card-icon { background: linear-gradient(135deg, #dbeafe, #bfdbfe); }
.dash-card.capa .dash-card-icon { background: linear-gradient(135deg, #fde8ef, #fcc5db); }
.dash-card.hr   .dash-card-icon { background: linear-gradient(135deg, #dcfce7, #bbf7d0); }
.dash-card-title { font-size: 19px; font-weight: 700; color: var(--gray-800); letter-spacing: -.3px; }
.dash-card-desc { font-size: 13px; color: var(--gray-400); line-height: 1.65; flex: 1; }
.dash-card-stats { display: flex; gap: 20px; flex-wrap: wrap; min-height: 52px; }
.dash-stat { display: flex; flex-direction: column; gap: 1px; }
.dash-stat-value { font-size: 22px; font-weight: 800; color: var(--gray-800); letter-spacing: -1px; }
.dash-stat-label { font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: .6px; color: var(--gray-400); }
.dash-card-footer { display: flex; align-items: center; justify-content: space-between; padding-top: 12px; border-top: 1.5px solid var(--gray-100); font-size: 13px; font-weight: 600; color: var(--pink); }
.dash-card.coming-soon .dash-card-footer { color: var(--gray-400); }
.dash-coming-badge { display: inline-flex; align-items: center; padding: 3px 10px; border-radius: 20px; font-size: 11px; font-weight: 700; background: var(--gray-100); color: var(--gray-600); }

@media (max-width: 900px) { .dash-cards { grid-template-columns: 1fr; } .dash-hero-title { font-size: 26px; } .dash-body { padding: 40px 24px 60px; } }

/* Le bouton Accueil dans le topbar des exigences */
.btn-home-topbar { background: rgba(213,64,132,.1); color: var(--pink-dark); border: 1.5px solid var(--pink-light); border-radius: var(--radius-sm); padding: 5px 12px; font-size: 12px; font-weight: 600; cursor: pointer; display: flex; align-items: center; gap: 5px; transition: all var(--transition); }
.btn-home-topbar:hover { background: var(--pink); color: var(--white); border-color: var(--pink); }
/* Bouton Accueil dans le topbar CAPA */
.btn-capa-home { background: rgba(255,255,255,.12); color: rgba(255,255,255,.85); border: 1.5px solid rgba(255,255,255,.2); border-radius: var(--radius-sm); padding: 5px 12px; font-size: 12px; font-weight: 600; cursor: pointer; display: flex; align-items: center; gap: 5px; transition: background var(--transition); }
.btn-capa-home:hover { background: rgba(255,255,255,.22); color: var(--white); }

/* ════════════════════════════════════════════════
   CAPA SCROLL FIX + LIGNES COMPACTES
   ════════════════════════════════════════════════ */
/* Override des styles existants pour corriger le scroll */
.capa-content {
  flex: 1 !important;
  min-height: 0 !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
}
.capa-tab-panel { display: none; }
.capa-tab-panel.active {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  padding: 16px 24px !important;
  overflow-y: auto !important;
  min-height: 0 !important;
  flex: 1 !important;
}
.capa-table-wrap {
  overflow-x: auto !important;
  overflow-y: auto !important;
  max-height: calc(100vh - 300px) !important;
}
.capa-table th { padding: 7px 12px !important; font-size: 11px !important; }
.capa-table td { padding: 5px 12px !important; font-size: 12.5px !important; line-height: 1.35 !important; }

/* ─── Sous-onglets processus (Amélioration Continue) ── */
.ia-sub-tabs { display: flex; gap: 6px; flex-wrap: wrap; padding-bottom: 10px; border-bottom: 1.5px solid var(--gray-200); flex-shrink: 0; }
.ia-sub-tab { padding: 5px 13px; border-radius: 20px; border: 1.5px solid var(--gray-200); background: var(--white); font-size: 12px; font-weight: 600; color: var(--gray-600); cursor: pointer; transition: all var(--transition); display: inline-flex; align-items: center; gap: 5px; white-space: nowrap; }
.ia-sub-tab:hover { border-color: var(--pink-light); color: var(--pink); }
.ia-sub-tab.active { background: var(--pink); color: var(--white); border-color: var(--pink); }
.ia-sub-tab-count { background: rgba(0,0,0,.12); color: inherit; border-radius: 10px; padding: 1px 6px; font-size: 10px; font-weight: 700; }
.ia-sub-tab.active .ia-sub-tab-count { background: rgba(255,255,255,.25); }
/* ════════════════════════════════════════════════
   CONFIG CARD (8th slot)
   ════════════════════════════════════════════════ */
.dash-card-config { cursor: pointer; }
.dash-card-config:hover {
  border-color: #d1d5db;
  box-shadow: 0 8px 32px rgba(0,0,0,.09), 0 2px 8px rgba(0,0,0,.05);
  transform: translateY(-3px);
}
.dash-card-config::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  border-radius: 16px 16px 0 0;
  background: linear-gradient(90deg, #6b7280, #374151);
  opacity: 0; transition: opacity .25s;
}
.dash-card-config:hover::before { opacity: 1; }
.dash-card-config .dash-card-footer { color: #6b7280 !important; border-top-color: #f3f4f6 !important; }
.dash-card-config:hover .dash-card-cta { color: #374151; }
.dash-card-config:hover .dash-card-icon { transform: scale(1.08) rotate(15deg); }
.dash-card-config .dash-card-icon { transition: transform .3s cubic-bezier(.4,0,.2,1); }

/* ════════════════════════════════════════════════
   PROCESS DASH — FP area + module proc badge
   ════════════════════════════════════════════════ */
.proc-fp-area {
  margin-top: 12px;
  min-width: 260px;
}
.proc-fp-loading {
  display: flex; align-items: center; gap: 8px;
  font-size: 12px; color: var(--gray-400);
}
.proc-fp-spinner {
  display: inline-block; width: 14px; height: 14px;
  border: 2px solid var(--gray-200); border-top-color: var(--gray-400);
  border-radius: 50%; animation: spin .7s linear infinite;
}
.proc-fp-card {
  display: flex; align-items: center; gap: 10px;
  background: white; border: 1.5px solid var(--gray-100);
  border-radius: 10px; padding: 10px 14px;
  cursor: pointer; transition: all .2s;
}
.proc-fp-card:hover { border-color: var(--pink-light); background: var(--pink-pale); }
.proc-fp-card-icon { font-size: 20px; flex-shrink: 0; }
.proc-fp-card-body { flex: 1; min-width: 0; }
.proc-fp-card-label { font-size: 10px; font-weight: 700; color: var(--gray-400); text-transform: uppercase; letter-spacing: .6px; }
.proc-fp-card-title { font-size: 12.5px; font-weight: 600; color: var(--gray-800); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 1px; }
.proc-fp-card-meta { display: flex; align-items: center; gap: 8px; margin-top: 3px; }
.proc-fp-status { font-size: 11px; color: var(--gray-400); }
.proc-fp-version { font-size: 11px; color: var(--gray-400); font-family: var(--mono); }
.proc-fp-open { font-size: 11px; font-weight: 600; color: var(--pink); white-space: nowrap; flex-shrink: 0; }
.proc-fp-none { font-size: 12px; color: var(--gray-400); font-style: italic; padding: 8px 0; }

/* Module card procedure badge */
.proc-module-content { flex: 1; }
.proc-module-proc-badge {
  display: inline-block; margin-top: 6px;
  font-size: 10px; font-weight: 700; letter-spacing: .6px;
  color: var(--pink); background: var(--pink-pale);
  border: 1px solid var(--pink-light);
  border-radius: 4px; padding: 2px 8px;
  font-family: var(--mono);
}

/* ════════════════════════════════════════════════
   CONFIG PANEL
   ════════════════════════════════════════════════ */
#config-panel {
  position: fixed; inset: 0;
  background: var(--gray-50);
  z-index: 65;
  display: flex; flex-direction: column;
  overflow: hidden;
}
#config-panel.hidden { display: none !important; }

.cfg-topbar {
  height: 56px; flex-shrink: 0;
  background: var(--white);
  border-bottom: 1.5px solid var(--gray-100);
  display: flex; align-items: center;
  padding: 0 28px; gap: 14px;
  box-shadow: 0 1px 8px rgba(0,0,0,.04);
}
.cfg-back-btn {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 600; color: var(--gray-600);
  cursor: pointer; padding: 6px 12px; border-radius: var(--radius-sm);
  transition: all .18s; background: none; border: none; font-family: var(--font);
}
.cfg-back-btn:hover { background: var(--gray-100); color: var(--gray-800); }
.cfg-topbar-sep { color: var(--gray-200); font-size: 16px; }
.cfg-topbar-title { font-size: 14px; font-weight: 700; color: var(--gray-800); letter-spacing: -.2px; }
.cfg-topbar-badge {
  font-size: 10px; font-weight: 700; letter-spacing: .7px;
  color: var(--gray-400); background: var(--gray-100);
  border: 1px solid var(--gray-200);
  border-radius: 4px; padding: 2px 7px; text-transform: uppercase;
}

.cfg-main {
  flex: 1; overflow-y: auto; padding: 32px;
}
.cfg-scroll-inner {
  max-width: 780px; margin: 0 auto;
  display: flex; flex-direction: column; gap: 28px;
}

/* Sections */
.cfg-section {
  background: var(--white);
  border-radius: 16px;
  border: 1.5px solid var(--gray-100);
  padding: 28px;
  display: flex; flex-direction: column; gap: 20px;
  box-shadow: 0 2px 12px rgba(0,0,0,.04);
}
.cfg-section-header {
  display: flex; align-items: flex-start; gap: 14px;
  padding-bottom: 16px;
  border-bottom: 1.5px solid var(--gray-100);
}
.cfg-section-icon {
  width: 42px; height: 42px; border-radius: 10px;
  background: var(--gray-50); border: 1.5px solid var(--gray-100);
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; flex-shrink: 0;
}
.cfg-section-title { font-size: 15px; font-weight: 700; color: var(--gray-800); letter-spacing: -.2px; }
.cfg-section-sub { font-size: 12px; color: var(--gray-400); margin-top: 3px; }

/* Fields */
.cfg-field { display: flex; flex-direction: column; gap: 6px; }
.cfg-label { font-size: 13px; font-weight: 600; color: var(--gray-800); }
.cfg-required { color: var(--danger); margin-left: 3px; }
.cfg-hint { font-size: 12px; color: var(--gray-400); line-height: 1.55; }
.cfg-input {
  width: 100%; padding: 9px 12px; border-radius: var(--radius-sm);
  border: 1.5px solid var(--gray-200); background: var(--white);
  font-size: 13px; color: var(--gray-800); font-family: var(--font);
  transition: border-color .18s;
  outline: none;
}
.cfg-input:focus { border-color: var(--pink); box-shadow: 0 0 0 3px var(--pink-pale); }
.cfg-input-mono { font-family: var(--mono) !important; font-size: 12px !important; }

/* Language selector */
.cfg-lang-row { display: flex; gap: 12px; }
.cfg-lang-opt {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 18px; border-radius: 10px;
  border: 1.5px solid var(--gray-200); background: var(--white);
  cursor: pointer; font-size: 13px; font-weight: 500; color: var(--gray-600);
  transition: all .18s; user-select: none;
}
.cfg-lang-opt input[type="radio"] { display: none; }
.cfg-lang-opt:hover { border-color: var(--pink-light); color: var(--pink); }
.cfg-lang-opt--active {
  border-color: var(--pink); background: var(--pink-pale);
  color: var(--pink-dark); font-weight: 700;
}
.cfg-lang-flag { font-size: 18px; }

/* Buttons */
.cfg-btn-primary {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 9px 20px; border-radius: var(--radius-sm);
  background: var(--pink); color: var(--white);
  font-size: 13px; font-weight: 600; font-family: var(--font);
  cursor: pointer; border: none; transition: all .18s;
  align-self: flex-start;
}
.cfg-btn-primary:hover { background: var(--pink-dark); transform: translateY(-1px); }

/* Colors grid */
.cfg-colors-grid { display: flex; flex-direction: column; gap: 14px; }
.cfg-color-row {
  display: flex; align-items: center; gap: 16px;
  padding: 14px 16px; border-radius: 10px;
  background: var(--gray-50); border: 1.5px solid var(--gray-100);
}
.cfg-color-preview {
  width: 52px; height: 52px; border-radius: 12px;
  border: 2px solid transparent; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  transition: all .2s;
}
.cfg-color-preview-label { font-size: 13px; font-weight: 800; }
.cfg-color-info { flex: 1; min-width: 0; }
.cfg-color-name { font-size: 12.5px; font-weight: 600; color: var(--gray-800); margin-bottom: 8px; }
.cfg-color-inputs { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.cfg-color-input-group { display: flex; flex-direction: column; gap: 4px; }
.cfg-color-sublabel { font-size: 10px; font-weight: 700; color: var(--gray-400); text-transform: uppercase; letter-spacing: .5px; }
.cfg-color-swatch-wrap { display: flex; align-items: center; gap: 6px; }
.cfg-color-swatch {
  width: 24px; height: 24px; border-radius: 6px;
  border: 1px solid var(--gray-200); flex-shrink: 0; cursor: pointer;
  transition: transform .15s;
}
.cfg-color-native {
  width: 0; height: 0; opacity: 0; position: absolute; pointer-events: none;
}
.cfg-color-swatch:hover { transform: scale(1.1); }
/* Make swatch trigger picker */
.cfg-color-swatch-wrap:has(.cfg-color-native) .cfg-color-swatch {
  cursor: pointer;
}
.cfg-color-hex {
  width: 80px; padding: 4px 8px; border-radius: 6px;
  border: 1.5px solid var(--gray-200); font-family: var(--mono);
  font-size: 12px; color: var(--gray-800); outline: none;
  transition: border-color .15s;
}
.cfg-color-hex:focus { border-color: var(--pink); }
.cfg-btn-reset {
  width: 28px; height: 28px; border-radius: 6px;
  border: 1.5px solid var(--gray-200); background: var(--white);
  color: var(--gray-600); font-size: 14px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font); transition: all .15s;
}
.cfg-btn-reset:hover { border-color: var(--pink-light); color: var(--pink); background: var(--pink-pale); }

/* ─── Color picker swatch — overlay native input ──────────────────── */
.cfg-color-swatch-wrap {
  position: relative;
}
.cfg-color-native {
  position: absolute; inset: 0;
  width: 100% !important; height: 100% !important;
  opacity: 0; cursor: pointer;
  border: none; padding: 0; margin: 0;
}

/* ════════════════════════════════════════════════
   NAVIGATION HARMONISÉE — boutons ← Processus / 🏠 Accueil
   Partagés par : REQ topbar, HR header, CAPA sidebar, DMS topbar
   ════════════════════════════════════════════════ */

/* REQ module — bouton ← Pn dans le topbar */
.btn-back-process {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 12px; border-radius: var(--radius-sm);
  background: var(--pink-pale); border: 1.5px solid var(--pink-light);
  color: var(--pink-dark); font-size: 12px; font-weight: 700;
  cursor: pointer; font-family: var(--font);
  transition: all var(--transition);
}
.btn-back-process:hover {
  background: var(--pink); color: var(--white);
  border-color: var(--pink);
}

/* HR overlay header — boutons de navigation */
#hr-overlay-header {
  display: flex; align-items: center; justify-content: space-between;
}
.hr-nav-back-btn, .hr-nav-home-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 13px; border-radius: var(--radius-sm);
  font-size: 12px; font-weight: 700; cursor: pointer;
  font-family: var(--font); border: none;
  transition: all .18s;
}
.hr-nav-back-btn {
  background: rgba(255,255,255,.18); color: white;
  border: 1.5px solid rgba(255,255,255,.35);
}
.hr-nav-back-btn:hover { background: rgba(255,255,255,.32); }
.hr-nav-home-btn {
  background: transparent; color: rgba(255,255,255,.75);
  border: 1.5px solid rgba(255,255,255,.2);
}
.hr-nav-home-btn:hover { background: rgba(255,255,255,.15); color: white; }

/* CAPA sidebar — bouton ← Pn */
.capa-back-proc-btn {
  width: 100%; padding: 8px 12px;
  background: rgba(255,255,255,.08); color: rgba(255,255,255,.75);
  border: 1px solid rgba(255,255,255,.15); border-radius: 8px;
  font-size: 12px; font-weight: 700; cursor: pointer;
  font-family: var(--font); text-align: left;
  display: flex; align-items: center; gap: 6px;
  transition: all .18s; margin-bottom: 6px;
}
.capa-back-proc-btn:hover { background: rgba(255,255,255,.16); color: white; }

/* ════════════════════════════════════════════════
   REQ (PR-1B) — sidebar nav header
   ════════════════════════════════════════════════ */
.sidebar-nav-header {
  display: flex; align-items: center; gap: 6px;
  padding: 10px 12px; flex-shrink: 0;
  border-bottom: 1px solid rgba(0,0,0,.08);
  background: linear-gradient(135deg, var(--pink-deep), var(--pink-dark));
}
.sidebar-nav-back, .sidebar-nav-home {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 11px; border-radius: 6px;
  font-size: 11.5px; font-weight: 700;
  cursor: pointer; font-family: var(--font); border: none;
  color: white; transition: background .15s;
}
.sidebar-nav-back  { background: rgba(255,255,255,.22); }
.sidebar-nav-home  { background: rgba(255,255,255,.12); }
.sidebar-nav-back:hover  { background: rgba(255,255,255,.35); }
.sidebar-nav-home:hover  { background: rgba(255,255,255,.22); }

/* ════════════════════════════════════════════════
   CAPA — nouvelle structure shell/topbar/body
   ════════════════════════════════════════════════ */
.capa-shell {
  display: flex; flex-direction: column; height: 100%; overflow: hidden;
}
/* Topbar */
.capa-module-topbar {
  height: 52px; flex-shrink: 0;
  background: #e72c85 !important;
  display: flex; align-items: center; gap: 12px;
  padding: 0 18px;
  box-shadow: 0 2px 12px rgba(0,0,0,.18);
}
.capa-module-topbar-left  { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
.capa-module-topbar-title {
  flex: 1; text-align: center;
  color: white; font-size: 13px; font-weight: 700; letter-spacing: .02em;
  opacity: .9;
}
.capa-module-topbar-right { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.capa-topbar-nav-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 11px; border-radius: 6px;
  font-size: 11.5px; font-weight: 700; color: white;
  cursor: pointer; font-family: var(--font); border: none;
  transition: background .15s;
}
.capa-topbar-back-btn { background: rgba(255,255,255,.22); }
.capa-topbar-home-btn { background: rgba(255,255,255,.12); }
.capa-topbar-back-btn:hover { background: rgba(255,255,255,.35); }
.capa-topbar-home-btn:hover { background: rgba(255,255,255,.22); }
.capa-topbar-action-btn {
  padding: 5px 12px; border-radius: 6px;
  background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.2);
  color: rgba(255,255,255,.88); font-size: 11.5px; cursor: pointer;
  font-family: var(--font); transition: background .15s;
}
.capa-topbar-action-btn:hover { background: rgba(255,255,255,.22); color: white; }
.capa-topbar-action-btn.loading { opacity: .5; cursor: wait; }

/* Body */
.capa-body { display: flex; flex: 1; overflow: hidden; }

/* Harmonize sidebar — fond blanc comme les autres modules */
.capa-sidebar {
  width: 210px; flex-shrink: 0;
  background: var(--white);
  border-right: 1.5px solid var(--gray-100);
  display: flex; flex-direction: column; overflow-y: auto;
}
.capa-nav { padding: 8px 0; flex: 1; }
.capa-nav-item {
  color: var(--gray-600);
}
.capa-nav-item:hover  { background: var(--pink-pale); color: var(--pink-dark); }
.capa-nav-item.active { background: var(--pink-pale); color: var(--pink-dark); font-weight: 700; }
.capa-nav-badge { background: var(--pink); color: white; }

/* Period section in sidebar */
.capa-period-section {
  padding: 12px 10px; border-top: 1.5px solid var(--gray-100);
}
.capa-period-label { color: var(--gray-400); }
.capa-period-sublabel { color: var(--gray-400); }
.capa-period-input { background: var(--gray-50); border-color: var(--gray-200); color: var(--gray-800); }
.capa-period-apply { background: var(--gray-100); border-color: var(--gray-200); color: var(--gray-700); }
.capa-period-apply:hover { background: var(--pink-pale); border-color: var(--pink-light); color: var(--pink-dark); }

/* ════════════════════════════════════════════════
   HR header — button text always white
   ════════════════════════════════════════════════ */
.hr-nav-back-btn, .hr-nav-home-btn {
  color: white !important;
}

/* === INFRA HEADER FINAL OVERRIDES === */
:root { --pink: #e72c85; }

.dash-topbar {
  height: 64px !important;
  flex-shrink: 0 !important;
  background: #e72c85 !important;
  border-bottom: none !important;
  display: flex !important;
  align-items: center !important;
  padding: 0 32px !important;
  gap: 16px !important;
  box-shadow: 0 4px 20px rgba(231,44,133,.25) !important;
}
.dash-topbar-brand {
  display: flex !important;
  align-items: center !important;
  height: 100% !important;
  min-width: 180px !important;
  gap: 0 !important;
  flex-shrink: 0 !important;
}
.dash-logo-img {
  display: block !important;
  height: 56px !important;
  max-height: calc(100% - 8px) !important;
  width: auto !important;
  object-fit: contain !important;
}
.dash-brand-mark,
.dash-brand-name,
.dash-brand-badge,
.dash-logo,
.dash-logo-icon,
.dash-logo-text,
.dash-logo-badge {
  display: none !important;
}
.dash-topbar-center {
  flex: 1 !important;
  text-align: center !important;
  color: #ffffff !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  letter-spacing: .2px !important;
}
.dash-topbar-right {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 10px !important;
  min-width: 180px !important;
}
.dash-user-chip {
  color: rgba(255,255,255,.92) !important;
  background: rgba(255,255,255,.15) !important;
  border: 1px solid rgba(255,255,255,.24) !important;
}
.dash-btn-logout {
  color: rgba(255,255,255,.9) !important;
  border-color: rgba(255,255,255,.35) !important;
  background: rgba(255,255,255,.08) !important;
}
.dash-btn-logout:hover {
  color: #fff !important;
  border-color: rgba(255,255,255,.55) !important;
  background: rgba(255,255,255,.16) !important;
}
.proc-topbar {
  background: #e72c85 !important;
  border-bottom: none !important;
  box-shadow: 0 4px 20px rgba(231,44,133,.25) !important;
}
.proc-topbar-brand {
  display: flex !important;
  align-items: center !important;
  height: 100% !important;
  min-width: 160px !important;
}
.proc-logo-img {
  height: 46px !important;
  max-height: calc(100% - 10px) !important;
}
/* ════════════════════════════════════════════════
   REQUIREMENTS MODULE PR-1B — dashboard + generic features
   ════════════════════════════════════════════════ */
.req-module-tabs {
  display:flex; align-items:center; gap:5px; flex-wrap:wrap;
  max-width:min(820px, 52vw); overflow:hidden;
}
.req-module-tab {
  display:inline-flex; align-items:center; gap:5px;
  padding:5px 10px; border-radius:7px;
  color:rgba(255,255,255,.78); background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  font-size:11.5px; font-weight:700; font-family:var(--font);
  cursor:pointer; transition:background .15s,color .15s,border-color .15s;
  white-space:nowrap;
}
.req-module-tab:hover { color:#fff; background:rgba(255,255,255,.18); border-color:rgba(255,255,255,.28); }
.req-module-tab.active { color:#fff; background:rgba(255,255,255,.26); border-color:rgba(255,255,255,.42); }
.req-generic-content {
  flex:1; min-width:0; overflow-y:auto; background:var(--gray-50);
  padding:26px 32px 48px;
}
.req-generic-content.hidden { display:none !important; }
.req-generic-page { max-width:1380px; margin:0 auto; display:flex; flex-direction:column; gap:18px; }
.req-generic-header {
  display:flex; justify-content:space-between; align-items:flex-start; gap:18px; flex-wrap:wrap;
  background:var(--white); border:1.5px solid var(--gray-100); border-radius:16px;
  padding:22px 24px; box-shadow:0 2px 12px rgba(0,0,0,.04);
}
.req-generic-header h2 { font-size:22px; font-weight:800; color:var(--gray-800); margin:0 0 5px; letter-spacing:-.4px; }
.req-generic-header p { font-size:13px; color:var(--gray-400); line-height:1.6; max-width:760px; }
.req-eyebrow { font-size:10px; font-weight:800; letter-spacing:.9px; text-transform:uppercase; color:var(--pink); margin-bottom:4px; }
.req-dashboard-actions { display:flex; align-items:center; gap:9px; flex-wrap:wrap; }
.req-primary-action, .req-secondary-action {
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  padding:8px 14px; border-radius:9px; font-size:12px; font-weight:800;
  font-family:var(--font); cursor:pointer; transition:all .16s;
}
.req-primary-action { background:var(--pink); color:#fff; border:1.5px solid var(--pink); }
.req-primary-action:hover { background:var(--pink-dark); border-color:var(--pink-dark); transform:translateY(-1px); }
.req-secondary-action { background:var(--white); color:var(--pink-dark); border:1.5px solid var(--pink-light); }
.req-secondary-action:hover { background:var(--pink-pale); }
.req-dash-grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:14px; }
.req-dash-card {
  text-align:left; background:var(--white); border:1.5px solid var(--gray-100); border-radius:16px;
  padding:18px; box-shadow:0 2px 12px rgba(0,0,0,.04); cursor:pointer;
  display:flex; flex-direction:column; gap:6px; transition:all .18s; min-height:138px;
}
.req-dash-card:hover { border-color:var(--pink-light); box-shadow:0 8px 30px rgba(213,64,132,.12); transform:translateY(-2px); }
.req-dash-card-icon { width:42px; height:42px; border-radius:12px; background:var(--pink-pale); display:flex; align-items:center; justify-content:center; font-size:22px; margin-bottom:4px; }
.req-dash-card-value { font-size:25px; font-weight:900; color:var(--gray-800); line-height:1; }
.req-dash-card-label { font-size:12px; font-weight:800; color:var(--gray-700,var(--gray-600)); text-transform:uppercase; letter-spacing:.45px; }
.req-dash-card-hint { font-size:11.5px; color:var(--gray-400); line-height:1.45; }
.req-dashboard-lower { display:grid; grid-template-columns:minmax(260px, 420px) 1fr; gap:18px; align-items:start; }
.req-dashboard-panel, .req-form-section {
  background:var(--white); border:1.5px solid var(--gray-100); border-radius:16px;
  padding:18px; box-shadow:0 2px 12px rgba(0,0,0,.04);
}
.req-panel-title { font-size:14px; font-weight:800; color:var(--gray-800); margin-bottom:12px; }
.req-quick-list { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:10px; }
.req-quick-list button {
  text-align:left; padding:12px 14px; border-radius:10px; border:1.5px solid var(--gray-200);
  background:var(--gray-50); color:var(--gray-700,var(--gray-600)); font-size:12.5px; font-weight:700;
  transition:all .15s;
}
.req-quick-list button:hover { border-color:var(--pink-light); background:var(--pink-pale); color:var(--pink-dark); }
.req-doc-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:14px; }
.req-doc-card {
  background:var(--white); border:1.5px solid var(--gray-100); border-radius:14px; padding:14px;
  display:flex; flex-direction:column; gap:8px; box-shadow:0 1px 8px rgba(0,0,0,.035);
}
.req-doc-card-head { display:flex; align-items:center; justify-content:space-between; gap:8px; }
.req-doc-ref { font-family:var(--mono); font-size:11px; font-weight:800; color:var(--pink-dark); }
.req-doc-ver { font-family:var(--mono); font-size:10.5px; color:var(--gray-400); background:var(--gray-50); border-radius:99px; padding:2px 7px; }
.req-doc-title { font-size:13px; font-weight:700; color:var(--gray-800); line-height:1.35; }
.req-doc-kind { font-size:11px; color:var(--gray-400); }
.req-doc-actions { margin-top:auto; padding-top:8px; border-top:1px solid var(--gray-100); display:flex; justify-content:flex-end; }
.req-doc-link { color:var(--pink); font-size:12px; font-weight:800; }
.req-doc-link:hover { color:var(--pink-dark); }
.req-muted { color:var(--gray-400); font-size:12px; }
.req-empty {
  padding:24px; color:var(--gray-400); background:var(--gray-50); border:1.5px dashed var(--gray-200);
  border-radius:12px; font-size:13px; text-align:center;
}
.req-loading { min-height:220px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; color:var(--gray-400); font-size:13px; }
.req-flowchart-container { background:var(--pink-pale); border:1.5px solid var(--pink-light); border-radius:14px; padding:10px; overflow:auto; max-height:calc(100vh - 220px); }
.req-record-head { margin:14px 0 10px; font-size:12px; color:var(--gray-400); }
.req-record-list { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:10px; margin-bottom:12px; }
.req-create-record {
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  padding:8px 13px; border-radius:9px; background:var(--pink); color:#fff;
  font-size:12px; font-weight:800; transition:all .15s;
}
.req-create-record:hover { background:var(--pink-dark); transform:translateY(-1px); }
@media (max-width:1100px) {
  .req-module-tabs { max-width:100%; order:2; flex-basis:100%; padding-top:4px; }
  #req-module-header { height:auto; min-height:52px; padding-top:8px; padding-bottom:8px; align-items:flex-start; }
  .req-dash-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .req-dashboard-lower { grid-template-columns:1fr; }
}
@media (max-width:700px) {
  .req-generic-content { padding:18px; }
  .req-dash-grid, .req-quick-list { grid-template-columns:1fr; }
}


/* ════════════════════════════════════════════════
   PR-1B Requirements Module — generic-module sidebar shell
   Added to make Analyse des exigences behave like a module, not only Jira.
   ════════════════════════════════════════════════ */
#req-body {
  display: flex;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

.req-module-sidebar {
  width: 230px;
  flex-shrink: 0;
  background: var(--white);
  border-right: 1.5px solid var(--gray-100);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  z-index: 12;
}

.req-module-sidebar.hidden { display: none !important; }

.req-module-sidebar-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 14px;
  border-bottom: 1.5px solid var(--gray-100);
}

.req-module-sidebar-icon {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  background: var(--pink-pale);
  border: 1.5px solid var(--pink-light);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 17px;
  flex-shrink: 0;
}

.req-module-sidebar-title {
  font-size: 13px;
  font-weight: 800;
  color: var(--gray-800);
  letter-spacing: .04em;
}

.req-module-sidebar-sub {
  font-size: 11px;
  color: var(--gray-400);
  margin-top: 1px;
}

.req-module-nav {
  padding: 8px 6px;
  display: flex;
  flex-direction: column;
  gap: 1px;
  flex: 1;
}

.req-module-nav-item {
  display: flex;
  align-items: center;
  gap: 9px;
  width: 100%;
  padding: 9px 10px;
  background: transparent;
  border: none;
  color: var(--gray-600);
  cursor: pointer;
  font-size: 12.5px;
  text-align: left;
  border-radius: 7px;
  transition: background .12s, color .12s;
  font-family: var(--font);
}

.req-module-nav-item:hover {
  background: var(--pink-pale);
  color: var(--pink-dark);
}

.req-module-nav-item.active {
  background: var(--pink-pale);
  color: var(--pink-dark);
  font-weight: 800;
}

.req-module-sidebar-foot {
  border-top: 1.5px solid var(--gray-100);
  padding: 10px;
}

.req-module-foot-btn {
  width: 100%;
  padding: 8px 10px;
  border-radius: 7px;
  background: var(--gray-50);
  border: 1.5px solid var(--gray-200);
  color: var(--gray-600);
  font-size: 12px;
  font-weight: 700;
  text-align: left;
  font-family: var(--font);
  transition: all .15s;
}

.req-module-foot-btn:hover {
  background: var(--pink-pale);
  border-color: var(--pink-light);
  color: var(--pink-dark);
}

/* The legacy Jira tree sidebar now lives next to the PR-1B module sidebar. */
#req-body > #sidebar {
  position: relative;
  height: auto;
  transform: none;
  z-index: 10;
}

.req-generic-content {
  flex: 1;
  min-width: 0;
  overflow-y: auto;
  background: var(--gray-50);
  padding: 28px 32px 48px;
}

.req-generic-content.hidden { display: none !important; }

.req-generic-page {
  max-width: 1380px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.req-generic-header {
  background: var(--white);
  border: 1.5px solid var(--gray-100);
  border-radius: 16px;
  padding: 22px 24px;
  box-shadow: 0 2px 12px rgba(0,0,0,.04);
}

.req-generic-header h2 {
  font-size: 22px;
  font-weight: 800;
  color: var(--gray-800);
  margin: 0 0 5px;
  letter-spacing: -.4px;
}

.req-generic-header p {
  font-size: 13px;
  color: var(--gray-400);
  line-height: 1.6;
  max-width: 780px;
}

.req-dashboard-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 14px;
}

.req-dashboard-card {
  text-align: left;
  background: var(--white);
  border: 1.5px solid var(--gray-100);
  border-radius: 15px;
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 7px;
  box-shadow: 0 2px 12px rgba(0,0,0,.04);
  transition: all .18s;
  font-family: var(--font);
}

.req-dashboard-card:hover {
  transform: translateY(-2px);
  border-color: var(--pink-light);
  box-shadow: 0 8px 28px rgba(213,64,132,.12);
}

.req-dashboard-icon {
  width: 42px;
  height: 42px;
  border-radius: 11px;
  background: var(--pink-pale);
  border: 1px solid var(--pink-light);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 19px;
  margin-bottom: 5px;
}

.req-dashboard-card strong {
  font-size: 15px;
  color: var(--gray-800);
}

.req-dashboard-card span {
  font-size: 12px;
  color: var(--gray-400);
  line-height: 1.45;
}

.req-dashboard-lower {
  display: grid;
  grid-template-columns: minmax(300px, 430px) 1fr;
  gap: 18px;
  align-items: start;
}

.req-dashboard-section {
  background: var(--white);
  border: 1.5px solid var(--gray-100);
  border-radius: 16px;
  padding: 18px;
  box-shadow: 0 2px 12px rgba(0,0,0,.04);
}

.req-dashboard-section h3 {
  font-size: 14px;
  font-weight: 800;
  color: var(--gray-800);
  margin-bottom: 12px;
}

.req-jira-stats {
  display: grid;
  grid-template-columns: repeat(5, minmax(80px, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.req-jira-stats div {
  background: var(--gray-50);
  border: 1px solid var(--gray-100);
  border-radius: 10px;
  padding: 12px 8px;
  text-align: center;
}

.req-jira-stats strong {
  display: block;
  font-size: 22px;
  font-weight: 900;
  color: var(--pink-dark);
  line-height: 1;
}

.req-jira-stats span {
  display: block;
  font-size: 10px;
  color: var(--gray-400);
  margin-top: 5px;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.req-doc-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 14px;
}

.req-doc-card {
  background: var(--white);
  border: 1.5px solid var(--gray-100);
  border-radius: 14px;
  padding: 15px;
  box-shadow: 0 1px 8px rgba(0,0,0,.035);
}

.req-doc-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 8px;
}

.req-doc-ref {
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 800;
  color: var(--pink-dark);
  background: var(--pink-pale);
  border: 1px solid var(--pink-light);
  border-radius: 5px;
  padding: 2px 7px;
}

.req-doc-ver {
  font-family: var(--mono);
  font-size: 10.5px;
  color: var(--gray-400);
}

.req-doc-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--gray-800);
  line-height: 1.45;
  min-height: 38px;
}

.req-doc-kind {
  margin-top: 8px;
  font-size: 11px;
  color: var(--gray-400);
}

.req-doc-actions {
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--gray-100);
  display: flex;
  justify-content: flex-end;
}

.req-doc-link,
.req-create-record {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  background: var(--pink);
  color: var(--white);
  border-radius: 8px;
  padding: 7px 12px;
  font-size: 12px;
  font-weight: 800;
  border: none;
  font-family: var(--font);
  cursor: pointer;
  transition: background .15s;
}

.req-doc-link:hover,
.req-create-record:hover {
  background: var(--pink-dark);
}

.req-form-section {
  background: var(--white);
  border: 1.5px solid var(--gray-100);
  border-radius: 16px;
  padding: 16px;
  box-shadow: 0 2px 12px rgba(0,0,0,.04);
}

.req-record-head {
  margin: 12px 0 8px;
  font-size: 12px;
  color: var(--gray-400);
}

.req-record-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 10px;
  margin-bottom: 12px;
}

.req-flowchart-container {
  min-height: 620px;
  max-height: calc(100vh - 190px);
  overflow: auto;
  border-radius: 12px;
  border: 1.5px solid var(--pink-light);
  background: var(--pink-pale);
}

.req-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  min-height: 220px;
  color: var(--gray-400);
  font-size: 13px;
}

.req-empty {
  background: var(--white);
  border: 1.5px dashed var(--gray-200);
  border-radius: 12px;
  padding: 18px;
  color: var(--gray-400);
  font-size: 13px;
}

.req-muted {
  color: var(--gray-400);
  font-size: 12px;
}

@media (max-width: 980px) {
  .req-module-sidebar { width: 56px; }
  .req-module-sidebar-title,
  .req-module-sidebar-sub,
  .req-module-nav-item span,
  .req-module-sidebar-foot { display: none; }
  .req-module-nav-item { justify-content: center; font-size: 16px; }
  .req-dashboard-lower { grid-template-columns: 1fr; }
  .req-jira-stats { grid-template-columns: repeat(2, 1fr); }
  .req-generic-content { padding: 18px; }
}
/* PR-1B module parity fixes — sidebar form entries and editable FlowchartEngine toolbar */
.req-module-nav-section {
  padding: 12px 10px 5px;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--gray-400);
}
.req-module-empty-mini {
  margin: 4px 10px 10px;
  padding: 8px 9px;
  border: 1px dashed var(--gray-200);
  border-radius: 8px;
  background: var(--gray-50);
  color: var(--gray-400);
  font-size: 11px;
  line-height: 1.35;
}
.req-module-nav-icon { width: 18px; text-align: center; flex-shrink: 0; }
.req-module-nav-label { display: flex; flex-direction: column; min-width: 0; line-height: 1.2; }
.req-module-nav-label strong { font-size: 12px; color: inherit; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.req-module-nav-label small { margin-top: 2px; font-size: 10.5px; color: var(--gray-400); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.req-module-nav-item.active .req-module-nav-label small { color: var(--pink-dark); opacity: .75; }
.req-section-title-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.req-section-actions { margin-left: auto; display: inline-flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.req-mini-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  border: 1.5px solid var(--gray-200);
  background: var(--white);
  color: var(--gray-600);
  border-radius: 8px;
  padding: 6px 10px;
  font-size: 11px;
  font-weight: 800;
  font-family: var(--font);
  cursor: pointer;
  transition: all .15s;
}
.req-mini-btn:hover { border-color: var(--pink-light); color: var(--pink-dark); background: var(--pink-pale); }
.req-mini-btn.active,
.req-mini-btn.primary { border-color: var(--pink); background: var(--pink); color: var(--white); }
.req-form-master { max-width: 520px; margin-bottom: 14px; }
@media (max-width: 980px) {
  .req-module-nav-label,
  .req-module-nav-section,
  .req-module-empty-mini { display: none; }
  .req-section-actions { width: 100%; margin-left: 0; }
}

/* PR-1B — restauration de la vue EN avec preview type module générique */
.req-fr-split-view {
  height: calc(100vh - 96px);
  min-height: 640px;
  max-width: none;
}
.req-fr-split-view .gpm-fr-split-body {
  min-height: 0;
}
.req-en-detail-inner {
  min-height: 0;
}
#req-en-detail-col .gpm-en-detail-preview,
#req-en-detail-col .gpm-en-embed {
  min-height: 0;
}