/* ═══════════════════════════════════════════════════
   NORMASHIELD ADMIN DASHBOARD
   Design: Forensic Record v3.0
   ════════════════════════════════════════════════════ */
:root {
  --bg-dark:    #0c0c09;
  --bg-sidebar: #0f0f0c;
  --bg-card:    #1a1b16;
  --bg-input:   #131310;
  --border:     rgba(230,220,170,0.07);
  --border-hi:  rgba(230,220,170,0.13);

  --text:   #e8e4d9;
  --muted:  #6a6655;
  --muted2: #8a8670;

  --blue:   #4a7fa3;
  --indigo: #4a7fa3;
  --green:  #3d7a56;
  --amber:  #c4901f;
  --red:    #9e3025;

  --gold:        #c4901f;
  --gold-hi:     #e0a830;
  --gold-pale:   rgba(196,144,31,0.10);
  --steel:       #4a7fa3;
  --steel-hi:    #6b9fc4;

  --blue-glow:   rgba(74,127,163,0.15);
  --indigo-glow: rgba(74,127,163,0.15);

  --r-lg: 6px;
  --r-md: 4px;
  --r-sm: 3px;

  --font: 'Inter', -apple-system, sans-serif;
  --mono: 'JetBrains Mono', monospace;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: var(--font);
  background: var(--bg-dark);
  color: var(--text);
  min-height: 100vh;
  font-size: 0.9rem;
  overflow-x: hidden;
}

h1, h2, h3 { color: var(--text); font-weight: 700; line-height: 1.2; }
a { color: var(--gold-hi); text-decoration: none; }

/* ════════ VIEW CONTAINERS ════════ */
.view-container { display: none; width: 100%; min-height: 100vh; }
.view-container.active { display: flex; }
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ════════ LOGIN ════════ */
#loginView {
  justify-content: center;
  align-items: center;
  position: relative;
  overflow: hidden;
}
.bg-glow { display: none; }
.glow-1 { display: none; }
.glow-2 { display: none; }

.login-box {
  position: relative; z-index: 1;
  background: var(--bg-card);
  border: 1px solid var(--border-hi);
  border-top: 2px solid var(--gold);
  border-radius: var(--r-lg);
  padding: 2.5rem;
  width: 100%; max-width: 400px;
  animation: fadeUp 0.4s ease forwards;
}
.login-logo { display: flex; align-items: center; gap: 10px; margin-bottom: 1.75rem; justify-content: center; }
.login-logo svg { width: 32px; height: 32px; }
.logo-text { font-size: 1.25rem; font-weight: 700; color: var(--text); }
.logo-accent { color: var(--gold-hi); }
.login-box h2 { text-align: center; margin-bottom: 0.35rem; font-size: 1.35rem; }
.login-subtitle { text-align: center; color: var(--muted2); font-size: 0.85rem; margin-bottom: 1.75rem; }
.error-text { color: #d0695f; font-size: 0.81rem; margin: -6px 0 10px; text-align: center; }

/* ════════ INPUTS ════════ */
.input-group { margin-bottom: 1.25rem; }
.input-group label { display: block; font-size: 0.82rem; color: var(--muted2); font-weight: 500; margin-bottom: 6px; }
.input-group input,
.input-group select {
  width: 100%; padding: 11px 14px;
  background: var(--bg-input);
  border: 1px solid var(--border-hi);
  border-radius: var(--r-md);
  color: #fff; font-size: 0.93rem; font-family: var(--font);
  transition: border-color 0.2s, box-shadow 0.2s;
}
.input-group textarea {
  width: 100%; padding: 11px 14px;
  background: var(--bg-input);
  border: 1px solid var(--border-hi);
  border-radius: var(--r-md);
  color: #fff; font-size: 0.93rem; font-family: var(--font);
  resize: vertical; min-height: 64px;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.input-group textarea:focus {
  outline: none;
  border-color: var(--blue);
  box-shadow: 0 0 0 3px var(--blue-glow);
}
.input-group textarea::placeholder { color: var(--muted); }

.input-group input:focus,
.input-group select:focus {
  outline: none;
  border-color: var(--gold);
}
.input-group input:focus,
.input-group textarea:focus,
.input-group select:focus { box-shadow: none; }
.input-group select option { background: var(--bg-dark); }

/* ════════ BUTTONS ════════ */
button { cursor: pointer; font-family: var(--font); border: none; transition: all 0.18s ease; }

.btn-primary {
  display: inline-flex; align-items: center;
  background: var(--gold);
  color: #0c0c09; padding: 9px 20px;
  border-radius: var(--r-md);
  font-weight: 700; font-size: 0.88rem;
}
.btn-primary:hover { background: var(--gold-hi); }
.btn-primary:active { transform: scale(0.99); }
.btn-block { width: 100%; justify-content: center; }

.btn-secondary {
  display: inline-flex; align-items: center; gap: 5px;
  background: var(--bg-card);
  border: 1px solid var(--border-hi);
  color: var(--muted2); padding: 7px 14px;
  border-radius: var(--r-md); font-size: 0.83rem;
}
.btn-secondary:hover { background: var(--bg-input); color: var(--text); border-color: var(--gold); }

.btn-text {
  background: transparent; color: var(--muted2);
  font-weight: 500;
  display: flex; align-items: center; gap: 7px;
}
.btn-text:hover { color: var(--text); }
.btn-text svg { width: 17px; height: 17px; }

.btn-danger {
  background: rgba(158,48,37,0.1); color: #d0695f;
  padding: 4px 11px; border-radius: var(--r-sm); font-size: 0.8rem; font-weight: 600;
  border: 1px solid rgba(158,48,37,0.25);
}
.btn-danger:hover { background: rgba(158,48,37,0.2); color: #e07068; }

.btn-approve {
  background: rgba(61,122,86,0.1); color: #7ac49a;
  padding: 4px 11px; border-radius: var(--r-sm); font-size: 0.8rem; font-weight: 600;
  border: 1px solid rgba(61,122,86,0.25);
}
.btn-approve:hover { background: rgba(61,122,86,0.2); }

.btn-reject {
  background: rgba(158,48,37,0.1); color: #d0695f;
  padding: 4px 11px; border-radius: var(--r-sm); font-size: 0.8rem; font-weight: 600;
  border: 1px solid rgba(158,48,37,0.25);
}
.btn-reject:hover { background: rgba(158,48,37,0.2); color: #e07068; }

/* ════════ LAYOUT ════════ */
#dashboardView { align-items: stretch; }

.sidebar {
  width: 256px; flex-shrink: 0;
  background: var(--bg-sidebar);
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
  position: sticky; top: 0; height: 100vh;
}
.sidebar-header {
  padding: 1.75rem 1.5rem;
  display: flex; align-items: center; gap: 10px;
  border-bottom: 1px solid var(--border);
}
.sidebar-header svg { width: 28px; height: 28px; }
.sidebar-logo-link { line-height: 0; display: flex; align-items: center; flex-shrink: 0; }
.sidebar-title {
  font-weight: 700; font-size: 1.05rem;
  color: var(--gold-hi);
}

.sidebar-nav {
  padding: 1.25rem 0.75rem;
  flex: 1; display: flex; flex-direction: column; gap: 4px;
  overflow-y: auto;
}
.nav-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; color: var(--muted2);
  border-radius: var(--r-md); font-weight: 500;
  transition: background 0.15s, color 0.15s;
  position: relative;
}
.nav-item svg { width: 18px; height: 18px; flex-shrink: 0; }
.nav-item span { flex: 1; }
.nav-item:hover { background: rgba(196,144,31,0.06); color: var(--text); }
.nav-item.active { background: rgba(196,144,31,0.08); color: var(--gold-hi); }
.nav-item-acquisitions { color: var(--steel-hi) !important; }
.nav-item-acquisitions:hover { background: rgba(74,127,163,0.08) !important; color: var(--steel-hi) !important; }
.nav-item.active::before {
  content: '';
  position: absolute; left: 0; top: 50%; transform: translateY(-50%);
  width: 2px; height: 16px; background: var(--gold); border-radius: 0 2px 2px 0;
}

.nav-badge {
  min-width: 18px; height: 18px;
  background: var(--gold); color: #0c0c09;
  border-radius: 3px; font-size: 0.68rem; font-weight: 700;
  display: inline-flex; align-items: center; justify-content: center; padding: 0 4px;
}

/* sidebar-footer removed - content moved to topbar */
.user-info { display: flex; flex-direction: column; gap: 4px; }
#currentUser { font-weight: 600; color: var(--text); font-size: 0.9rem; }

/* ════════ TOPBAR ════════ */
.topbar {
  display: flex; align-items: center; justify-content: flex-end;
  gap: 1rem;
  padding: 0.65rem 2rem;
  border-bottom: 1px solid var(--border);
  background: var(--bg-dark);
  position: sticky; top: 0; z-index: 10;
}

.topbar-user {
  display: flex; align-items: center; gap: 8px;
  margin-right: auto;
  color: var(--muted2); font-size: 0.88rem;
}

.topbar-user #currentUser { font-weight: 600; color: var(--text); }

.main-content {
  flex: 1; overflow-y: auto;
  background: var(--bg-dark);
  min-height: 100vh;
  display: flex; flex-direction: column;
}

.panel { padding: 2rem 2.25rem; }

/* ════════ PANELS ════════ */
.panel { display: none; animation: fadeUp 0.28s ease forwards; }
.panel.active { display: block; }
.panel-header { margin-bottom: 1.75rem; }
.panel-header h1 { font-size: 1.5rem; margin-bottom: 0.25rem; }
.panel-header p { color: var(--muted2); font-size: 0.87rem; }
.flex-between { display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; }

/* ════════ KPI CARDS ════════ */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1.1rem; margin-bottom: 1.75rem;
}
.kpi-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-left: 3px solid var(--gold);
  border-radius: var(--r-lg); padding: 1.25rem;
  display: flex; align-items: center; gap: 0.9rem;
  transition: border-color 0.18s;
}
.kpi-card:hover { border-color: var(--border-hi); border-left-color: var(--gold-hi); }

.kpi-icon {
  width: 42px; height: 42px; border-radius: var(--r-md); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.kpi-icon svg { width: 20px; height: 20px; }
.kpi-icon.blue   { background: rgba(74,127,163,0.12);  color: var(--steel-hi); }
.kpi-icon.purple { background: rgba(122,111,163,0.12); color: #9b90c4; }
.kpi-icon.green  { background: rgba(61,122,86,0.12);   color: #7ac49a; }
.kpi-icon.amber  { background: var(--gold-pale);        color: var(--gold-hi); }

.kpi-label { font-size: 0.72rem; color: var(--muted2); font-weight: 600; margin-bottom: 3px; text-transform: uppercase; letter-spacing: 0.07em; }
.kpi-value { font-size: 1.75rem; font-weight: 700; color: var(--text); line-height: 1; }
.kpi-sub   { font-size: 0.75rem; color: var(--muted2); margin-top: 3px; }
.kpi-sub-warn { color: var(--gold-hi); }

/* ════════ QUICK ACTIONS ════════ */
.quick-actions { margin-bottom: 1.75rem; }
.qa-label { font-size: 0.7rem; color: var(--muted2); text-transform: uppercase; letter-spacing: 0.09em; font-weight: 700; margin-bottom: 0.75rem; }
.qa-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 0.9rem; }

.qa-btn {
  display: flex; align-items: center; gap: 0.85rem;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: 1rem 1.1rem;
  text-align: left; color: var(--text);
  transition: border-color 0.18s, background 0.18s;
  cursor: pointer;
}
.qa-btn:hover { background: #22231d; border-color: var(--border-hi); }

.qa-btn-users:hover        { border-color: rgba(61,122,86,0.4);  }
.qa-btn-requests:hover     { border-color: rgba(196,144,31,0.4); }
.qa-btn-logs:hover         { border-color: rgba(122,111,163,0.4); }
.qa-btn-acquisitions       { text-decoration: none; color: var(--text); background: var(--bg-card); border-radius: var(--r-md); font-family: var(--font); }
.qa-btn-acquisitions:hover { border-color: rgba(74,127,163,0.4); }

.qa-icon {
  width: 38px; height: 38px; border-radius: var(--r-sm); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.qa-icon svg { width: 18px; height: 18px; }
.qa-btn-users        .qa-icon { background: rgba(61,122,86,0.12);   color: #7ac49a; }
.qa-btn-requests     .qa-icon { background: var(--gold-pale);        color: var(--gold-hi); }
.qa-btn-logs         .qa-icon { background: rgba(122,111,163,0.12); color: #9b90c4; }
.qa-btn-acquisitions .qa-icon { background: rgba(74,127,163,0.12);  color: var(--steel-hi); }

.qa-text { flex: 1; }
.qa-text strong { display: block; font-size: 0.88rem; color: var(--text); font-weight: 600; margin-bottom: 2px; }
.qa-text span   { font-size: 0.78rem; color: var(--muted2); }
.qa-arrow { width: 16px; height: 16px; color: var(--muted); flex-shrink: 0; }

/* ════════ CHARTS ════════ */
.charts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.25rem;
}
.chart-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: 1.5rem;
}
.chart-card h3 { font-size: 0.95rem; margin-bottom: 1rem; color: var(--muted2); font-weight: 600; }
.chart-container { height: 260px; }

/* ════════ FILTER BAR ════════ */
.filter-bar {
  display: flex; gap: 8px; margin-bottom: 1.25rem; flex-wrap: wrap;
}
.filter-btn {
  padding: 6px 16px; border-radius: 20px;
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--border);
  color: var(--muted2); font-size: 0.83rem; font-weight: 500;
  transition: all 0.15s;
}
.filter-btn:hover { border-color: var(--border-hi); color: #fff; }
.filter-btn.active { background: var(--indigo); border-color: var(--indigo); color: #fff; }

.log-filter-bar {
  margin-bottom: 1rem;
  display: flex;
  gap: 0.85rem;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}
.log-search {
  width: 100%; max-width: 380px;
  padding: 9px 14px;
  background: var(--bg-input); border: 1px solid var(--border-hi);
  border-radius: var(--r-md); color: #fff; font-size: 0.88rem; font-family: var(--font);
}
.log-search:focus { outline: none; border-color: var(--blue); box-shadow: 0 0 0 3px var(--blue-glow); }
.log-search::placeholder { color: var(--muted); }
.acq-toolbar-actions {
  display: flex;
  gap: 0.65rem;
  align-items: center;
  flex-wrap: wrap;
}
.acq-selection-summary {
  font-size: 0.78rem;
  color: #cbd5e1;
  padding: 0.4rem 0.75rem;
  border-radius: 999px;
  border: 1px solid rgba(59,130,246,0.18);
  background: rgba(59,130,246,0.1);
  white-space: nowrap;
}

.local-storage-notice {
  margin-bottom: 1rem;
  padding: 0.95rem 1.1rem;
  border-radius: var(--r-md);
  border: 1px solid rgba(245,158,11,0.24);
  background: rgba(245,158,11,0.08);
  color: var(--text);
  line-height: 1.6;
  font-size: 0.9rem;
}

.local-storage-notice strong {
  color: #fbbf24;
}

/* ════════ TABLE ════════ */
.table-container {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-lg); overflow-x: auto;
}
.data-table {
  width: 100%; border-collapse: collapse; text-align: left;
}
.data-table th, .data-table td {
  padding: 0.85rem 1.25rem;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.data-table th {
  color: var(--muted); font-weight: 600; font-size: 0.76rem;
  text-transform: uppercase; letter-spacing: 0.5px;
  background: rgba(0,0,0,0.15);
}
.data-table tr:last-child td { border-bottom: none; }
.data-table tbody tr:hover td { background: rgba(255,255,255,0.02); }
.acq-row-selected td {
  background: rgba(59,130,246,0.08);
}
.acq-row-selected:hover td {
  background: rgba(59,130,246,0.12);
}
.acq-select-head,
.acq-select-cell {
  width: 44px;
  text-align: center;
  padding-left: 0.9rem !important;
  padding-right: 0.9rem !important;
}
.acq-checkbox {
  width: 16px;
  height: 16px;
  accent-color: var(--blue);
  cursor: pointer;
}

.td-mono    { font-family: var(--mono); font-size: 0.82rem; color: var(--muted2); }
.td-link    { color: var(--blue); font-size: 0.85rem; }
.td-link:hover { text-decoration: underline; }
.td-details { font-family: var(--mono); font-size: 0.79rem; color: var(--muted); max-width: 300px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.td-muted   { color: var(--muted); }
.td-empty   { text-align: center; padding: 2.5rem !important; color: var(--muted2); }

/* ── Checkbox selezione log ── */
.log-cb-cell { width: 36px; padding: 0 8px !important; text-align: center; }
.log-cb-cell input[type="checkbox"],
thead input[type="checkbox"] {
  width: 15px; height: 15px; cursor: pointer;
  accent-color: var(--primary);
}
.btn-danger-sm {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px; border-radius: 7px; border: 1px solid rgba(239,68,68,0.35);
  background: rgba(239,68,68,0.1); color: #f87171;
  font-size: 0.78rem; font-weight: 600; cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  white-space: nowrap;
}
.btn-danger-sm:hover { background: rgba(239,68,68,0.2); border-color: rgba(239,68,68,0.55); }

/* ── Righe espandibili log/acquisizioni ── */
.log-expandable-row { cursor: pointer; transition: background 0.15s; }
.log-expandable-row:hover { background: rgba(255,255,255,0.02) !important; }
.log-expandable-row.log-row-open { background: rgba(99,102,241,0.07) !important; }

.log-expand-cell {
  text-align: center;
  padding: 0 6px !important;
  width: 28px;
  color: var(--muted);
}
.log-expand-chevron {
  width: 15px; height: 15px;
  transition: transform 0.2s ease;
  display: inline-block; vertical-align: middle;
  opacity: 0.45;
}
.log-expandable-row:hover .log-expand-chevron { opacity: 1; }
.log-expandable-row.log-row-open .log-expand-chevron { transform: rotate(180deg); opacity: 1; }

.log-detail-row { display: none; }
.log-detail-row.log-detail-open { display: table-row; }

.log-detail-cell {
  padding: 0 !important;
  background: rgba(10, 12, 20, 0.55) !important;
  border-top: none !important;
}
.log-detail-inner {
  padding: 14px 22px 18px;
  border-top: 1px solid var(--border);
  animation: logDetailExpand 0.18s ease;
}
@keyframes logDetailExpand {
  from { opacity: 0; transform: translateY(-5px); }
  to   { opacity: 1; transform: translateY(0); }
}

.log-detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 10px 20px;
}
.log-detail-field { display: flex; flex-direction: column; gap: 3px; }
.log-detail-label {
  font-size: 0.68rem; font-weight: 700;
  color: var(--muted); text-transform: uppercase; letter-spacing: 0.06em;
}
.log-detail-value {
  font-size: 0.82rem; color: #cbd5e1;
  font-family: var(--mono); word-break: break-all; line-height: 1.4;
}
.log-detail-value.muted { color: var(--muted2); }
.log-detail-full { grid-column: 1 / -1; }
.log-detail-section-title {
  font-size: 0.7rem; font-weight: 700; color: var(--indigo);
  text-transform: uppercase; letter-spacing: 0.08em;
  margin-bottom: 6px;
  grid-column: 1 / -1;
}

.req-actions { display: flex; gap: 6px; align-items: center; }
.btn-approve[href] { text-decoration: none; display: inline-flex; align-items: center; }

.acq-label {
  max-width: 220px; overflow: hidden;
  text-overflow: ellipsis; white-space: nowrap;
}

/* ════════ BADGES ════════ */
.badge {
  display: inline-flex; align-items: center;
  padding: 3px 9px; border-radius: 10px;
  font-size: 0.74rem; font-weight: 600;
  background: rgba(99,102,241,0.18); color: #c4b5fd;
  width: fit-content;
}
.badge-self {
  display: inline-flex; align-items: center;
  padding: 2px 7px; border-radius: 8px;
  font-size: 0.7rem; font-weight: 600;
  background: rgba(16,185,129,0.15); color: #34d399; margin-left: 6px;
}
.badge-role-admin { background: rgba(239,68,68,0.15);   color: #fca5a5; }
.badge-role-op    { background: rgba(99,102,241,0.15);  color: #c4b5fd; }

.badge-action {
  display: inline-flex; align-items: center;
  padding: 3px 9px; border-radius: 10px;
  font-size: 0.75rem; font-weight: 600; white-space: nowrap;
}
.badge-green { background: rgba(16,185,129,0.15); color: #34d399; }
.badge-red   { background: rgba(239,68,68,0.15);  color: #fca5a5; }
.badge-blue  { background: rgba(59,130,246,0.15); color: #93c5fd; }
.badge-amber  { background: rgba(245,158,11,0.15);  color: #fcd34d; }
.badge-violet { background: rgba(139,92,246,0.15);  color: #c4b5fd; }
.badge-pink   { background: rgba(236,72,153,0.15);  color: #f9a8d4; }
.badge-teal   { background: rgba(20,184,166,0.15);  color: #5eead4; }
.badge-indigo { background: rgba(99,102,241,0.15);  color: #a5b4fc; }
.badge-orange { background: rgba(234,88,12,0.15);   color: #fdba74; }
.badge-muted  { background: rgba(255,255,255,0.07); color: var(--muted2); }

.badge-status {
  display: inline-flex; align-items: center;
  padding: 4px 10px; border-radius: 10px;
  font-size: 0.77rem; font-weight: 600;
}

/* ════════ FORM CARD ════════ */
.form-card {
  background: var(--bg-card); border: 1px solid var(--blue);
  border-radius: var(--r-lg); padding: 1.5rem; margin-bottom: 1.75rem;
  box-shadow: 0 0 24px rgba(59,130,246,0.08);
}
.form-card.hidden { display: none; }
.form-card h3 { margin-bottom: 1.25rem; }
.form-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 1rem; }
.form-actions { display: flex; justify-content: flex-end; gap: 1rem; margin-top: 1rem; }

/* ════════ EDIT BUTTON ════════ */
.btn-edit {
  background: rgba(59,130,246,0.12); color: var(--blue);
  padding: 5px 12px; border-radius: var(--r-sm); font-size: 0.82rem; font-weight: 600;
}
.btn-edit:hover { background: var(--blue); color: #fff; }

/* ════════ TOKEN BADGE ════════ */
.token-badge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 36px; padding: 3px 10px; border-radius: 20px;
  font-size: 0.82rem; font-weight: 700; font-family: var(--mono);
}
.token-ok    { background: rgba(16,185,129,0.15); color: #34d399; }
.token-empty { background: rgba(239,68,68,0.13);  color: #fca5a5; }

/* ════════ USER STATUS BADGES ════════ */
.badge-active, .badge-disabled {
  display: inline-block; padding: 2px 9px; border-radius: 20px; font-size: 0.78rem; font-weight: 600;
}
.badge-active   { background: rgba(16,185,129,0.15); color: #34d399; }
.badge-disabled { background: rgba(239,68,68,0.13);  color: #fca5a5; }
.user-row-disabled td { opacity: 0.55; }
.user-row-disabled td:last-child { opacity: 1; }

/* Bottone toggle abilita/disabilita - amber (enable usa btn-approve già esistente) */
.btn-warn {
  padding: 5px 12px; border-radius: var(--r-sm); font-size: 0.82rem; font-weight: 600;
  background: rgba(245,158,11,0.12); color: #f59e0b; border: 1px solid rgba(245,158,11,0.25);
}
.btn-warn:hover { background: #f59e0b; color: #fff; border-color: #f59e0b; }

/* ── Training column cell ─────────────────────────────────────────────────── */
.training-toggle-cell { display: flex; align-items: center; gap: 6px; flex-wrap: nowrap; }
.badge-training {
  display: inline-block; padding: 2px 9px; border-radius: 20px; font-size: 0.78rem; font-weight: 600; white-space: nowrap;
}
.badge-training.on  { background: rgba(16,185,129,0.12); color: #34d399; }
.badge-training.off { background: rgba(239,68,68,0.10);  color: #fca5a5; }
.btn-training-toggle {
  padding: 4px 10px; border-radius: var(--r-sm); font-size: 0.78rem; font-weight: 600; white-space: nowrap;
  background: transparent; border: 1px solid rgba(255,255,255,0.15); color: var(--text-muted); cursor: pointer;
}
.btn-training-toggle.btn-warn    { background: rgba(245,158,11,0.10); color: #f59e0b; border-color: rgba(245,158,11,0.25); }
.btn-training-toggle.btn-warn:hover { background: #f59e0b; color: #fff; }
.btn-training-toggle.btn-approve { background: rgba(16,185,129,0.10); color: #34d399; border-color: rgba(16,185,129,0.25); }
.btn-training-toggle.btn-approve:hover { background: #10b981; color: #fff; }

/* ════════ MODAL OVERLAY ════════ */
.modal-overlay {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(0,0,0,0.65);
  backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  padding: 1.5rem;
}

.modal-box {
  background: #1a1d2e;
  border: 1px solid var(--border-hi);
  border-radius: var(--r-lg);
  padding: 2rem;
  width: 100%; max-width: 560px;
  box-shadow: 0 24px 64px rgba(0,0,0,0.5);
  animation: fadeUp 0.22s ease forwards;
}

.modal-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 1.75rem;
}
.modal-header h3 { font-size: 1.15rem; color: #fff; }

.btn-close-modal {
  background: rgba(255,255,255,0.06); border: 1px solid var(--border);
  border-radius: var(--r-sm); width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  color: var(--muted2);
}
.btn-close-modal:hover { background: rgba(255,255,255,0.12); color: #fff; }
.btn-close-modal svg { width: 16px; height: 16px; }

/* ════════ TOKEN SECTION ════════ */
.token-section {
  background: rgba(99,102,241,0.06);
  border: 1px solid rgba(99,102,241,0.2);
  border-radius: var(--r-md);
  padding: 1rem 1.25rem;
  margin: 1.25rem 0 0;
}
.token-section-header {
  display: flex; align-items: center; gap: 8px;
  color: var(--muted2); font-size: 0.88rem; font-weight: 500;
}
.token-section-header svg { width: 16px; height: 16px; color: #a5b4fc; flex-shrink: 0; }
.token-current-badge {
  background: rgba(99,102,241,0.25); color: #c4b5fd;
  padding: 2px 10px; border-radius: 12px;
  font-size: 0.85rem; font-weight: 700; font-family: var(--mono);
  margin-left: 4px;
}

/* ════════ MODAL PARTS ════════ */
.modal-body { padding: 0 0 1.25rem; }
.modal-footer {
  display: flex; justify-content: flex-end; gap: 8px;
  padding-top: 1.25rem;
  border-top: 1px solid var(--border);
}
.modal-close {
  background: rgba(255,255,255,0.06); border: 1px solid var(--border);
  border-radius: var(--r-sm); width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  color: var(--muted2); cursor: pointer; flex-shrink: 0;
}
.modal-close:hover { background: rgba(255,255,255,0.12); color: #fff; }
.modal-close svg { width: 16px; height: 16px; }

/* ════════ FORM ELEMENTS ════════ */
.form-group { margin-bottom: 1.1rem; }
.form-label {
  display: block; font-size: 0.85rem; font-weight: 500;
  color: var(--muted2); margin-bottom: 0.4rem;
}
.form-control {
  width: 100%; background: var(--bg-input);
  border: 1px solid var(--border); border-radius: var(--r-sm);
  color: var(--text); font-size: 0.9rem; padding: 0.5rem 0.75rem;
  outline: none; transition: border-color 0.15s;
  font-family: inherit;
}
.form-control:focus { border-color: var(--gold); }
.form-hint  { font-size: 0.78rem; color: var(--muted); margin-top: 0.3rem; }
.form-error {
  font-size: 0.82rem; color: #fca5a5;
  background: rgba(239,68,68,0.08); border: 1px solid rgba(239,68,68,0.25);
  border-radius: var(--r-sm); padding: 0.45rem 0.75rem; margin-top: 0.5rem;
}

/* ════════ SMALL BUTTONS ════════ */
.btn-xs {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 0.78rem; font-weight: 500; padding: 4px 10px;
  border-radius: var(--r-sm); border: 1px solid transparent;
  cursor: pointer; transition: background 0.15s, color 0.15s;
  white-space: nowrap;
}
.btn-xs.btn-danger {
  background: rgba(239,68,68,0.1); border-color: rgba(239,68,68,0.3); color: #fca5a5;
}
.btn-xs.btn-danger:hover { background: rgba(239,68,68,0.2); }
.btn-xs.btn-secondary {
  background: rgba(255,255,255,0.06); border-color: var(--border); color: var(--muted2);
}
.btn-xs.btn-secondary:hover { background: rgba(255,255,255,0.1); color: var(--text); }

/* ════════ TABLE ERROR STATE ════════ */
.td-error { color: #fca5a5 !important; }

/* ════════ UTILITIES ════════ */
.hidden { display: none !important; }

/* ════════ RESPONSIVE ════════ */
@media (max-width: 900px) {
  .sidebar { width: 64px; }
  .sidebar-title,
  .nav-item span { display: none; }
  .nav-item { justify-content: center; padding: 12px; }
  .nav-item.active::before { display: none; }
  .topbar { padding: 0.75rem 1rem; gap: 0.75rem; }
  .topbar .btn-text span,
  .topbar-user #currentRole { display: none; }
  .panel { padding: 1.5rem 1rem; }
  .panel-header.flex-between { flex-direction: column; align-items: flex-start; }
  .modal-box { padding: 1.5rem; }
  .sec-overview-grid { grid-template-columns: 1fr; }
  .sec-score-card { flex-direction: row; gap: 24px; align-items: center; justify-content: flex-start; padding: 20px; }
}
@media (max-width: 600px) {
  .sidebar { width: 52px; }
  .nav-item { padding: 10px 8px; }
  .nav-badge { display: none; }
  .topbar-user { display: none; }
  .kpi-grid { grid-template-columns: 1fr 1fr; }
  .qa-grid  { grid-template-columns: 1fr; }
  .charts-grid { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .log-filter-bar { align-items: stretch; }
  .log-search { max-width: none; }
  .acq-toolbar-actions { justify-content: flex-end; }
  .data-table th, .data-table td { padding: 0.6rem 0.75rem; font-size: 0.8rem; }
  .td-details { max-width: 160px; }
  .acq-label { max-width: 130px; }
  .panel { padding: 1rem 0.75rem; }
  .panel-header h1 { font-size: 1.35rem; }
  .sec-overview-grid { grid-template-columns: 1fr; }
}

/* ════════ SECURITY ASSESSMENT PANEL ════════ */

.nav-badge-red {
  background: var(--red);
  color: #fff;
}

.sec-running-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.82rem;
  color: var(--amber);
  background: rgba(245, 158, 11, 0.12);
  border: 1px solid rgba(245, 158, 11, 0.25);
  border-radius: var(--r-sm);
  padding: 5px 10px;
}

.sec-spinner {
  width: 12px; height: 12px;
  border: 2px solid rgba(245, 158, 11, 0.3);
  border-top-color: var(--amber);
  border-radius: 50%;
  animation: secSpin 0.8s linear infinite;
  flex-shrink: 0;
}
@keyframes secSpin { to { transform: rotate(360deg); } }

.sec-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  padding: 60px 20px;
  color: var(--muted2);
  text-align: center;
  line-height: 1.6;
}

/* ── Overview grid ── */
.sec-overview-grid {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 20px;
  margin-bottom: 24px;
}

/* ── Score card ── */
.sec-score-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 24px 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

.sec-gauge-wrap {
  position: relative;
  width: 140px;
  height: 140px;
}

.sec-gauge {
  width: 100%;
  height: 100%;
  transform: rotate(-90deg);
}

.sec-gauge-bg {
  fill: none;
  stroke: rgba(255,255,255,0.06);
  stroke-width: 10;
}

.sec-gauge-fill {
  fill: none;
  stroke-width: 10;
  stroke-linecap: round;
  transition: stroke-dashoffset 0.8s cubic-bezier(.4,0,.2,1), stroke 0.4s ease;
}
.sec-gauge-fill.gauge-green { stroke: var(--green); filter: drop-shadow(0 0 6px rgba(16,185,129,0.5)); }
.sec-gauge-fill.gauge-amber { stroke: var(--amber); filter: drop-shadow(0 0 6px rgba(245,158,11,0.5)); }
.sec-gauge-fill.gauge-red   { stroke: var(--red);   filter: drop-shadow(0 0 6px rgba(239,68,68,0.5)); }

.sec-gauge-center {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
}

.sec-score-num {
  font-size: 2rem;
  font-weight: 700;
  color: #fff;
  line-height: 1;
}

.sec-score-label {
  font-size: 0.75rem;
  color: var(--muted2);
}

.sec-grade-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
}

.sec-grade {
  font-size: 1.6rem;
  font-weight: 700;
  min-width: 48px;
  text-align: center;
  padding: 4px 12px;
  border-radius: var(--r-sm);
  background: rgba(255,255,255,0.06);
}
.sec-grade-sm {
  font-size: 0.95rem;
  padding: 2px 8px;
  border-radius: 4px;
}
.sec-grade.grade-green, .sec-grade-sm.grade-green { color: var(--green); background: rgba(16,185,129,0.12); }
.sec-grade.grade-blue,  .sec-grade-sm.grade-blue  { color: var(--blue);  background: rgba(59,130,246,0.12); }
.sec-grade.grade-amber, .sec-grade-sm.grade-amber { color: var(--amber); background: rgba(245,158,11,0.12); }
.sec-grade.grade-red,   .sec-grade-sm.grade-red   { color: var(--red);   background: rgba(239,68,68,0.12); }

.sec-grade-label {
  font-size: 0.82rem;
  color: var(--muted2);
}

/* ── Summary card ── */
.sec-summary-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.sec-counts {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}

.sec-count-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  min-width: 64px;
  padding: 10px 16px;
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.04);
}
.sec-count-item.sec-count-pass { border: 1px solid rgba(16,185,129,0.2); }
.sec-count-item.sec-count-warn { border: 1px solid rgba(245,158,11,0.2); }
.sec-count-item.sec-count-fail { border: 1px solid rgba(239,68,68,0.2); }

.sec-count-num {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1;
}
.sec-count-pass .sec-count-num { color: var(--green); }
.sec-count-warn .sec-count-num { color: var(--amber); }
.sec-count-fail .sec-count-num { color: var(--red); }

.sec-count-text {
  font-size: 0.75rem;
  color: var(--muted2);
}

.sec-summary-text {
  font-size: 0.9rem;
  color: var(--muted2);
  line-height: 1.5;
}

.sec-meta {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-top: 8px;
  border-top: 1px solid var(--border);
}

.sec-meta-row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.82rem;
  color: var(--muted2);
}
.sec-meta-row strong { color: var(--text); }
.sec-meta-row svg { color: var(--muted); flex-shrink: 0; }

/* ── Checks section ── */
.sec-checks-section {
  margin-bottom: 28px;
}

.sec-section-title {
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted2);
  margin-bottom: 12px;
}

.sec-check-group {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  margin-bottom: 12px;
}

.sec-check-group-title {
  padding: 8px 16px;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--muted2);
  background: rgba(255,255,255,0.03);
  border-bottom: 1px solid var(--border);
}

.sec-check-row {
  display: grid;
  grid-template-columns: 28px 1fr auto;
  gap: 12px;
  align-items: start;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
  transition: background 0.15s;
}
.sec-check-row:last-child { border-bottom: none; }
.sec-check-row:hover { background: rgba(255,255,255,0.02); }

.sec-check-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 1px;
}
.sec-check-icon svg { width: 13px; height: 13px; }

.sec-check-pass .sec-check-icon { background: rgba(16,185,129,0.15); color: var(--green); }
.sec-check-warn .sec-check-icon { background: rgba(245,158,11,0.15); color: var(--amber); }
.sec-check-fail .sec-check-icon { background: rgba(239,68,68,0.15);   color: var(--red);   }

.sec-check-body {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}

.sec-check-name {
  font-size: 0.88rem;
  font-weight: 500;
  color: var(--text);
}

.sec-check-msg {
  font-size: 0.82rem;
  color: var(--muted2);
}

.sec-check-rec {
  display: flex;
  align-items: flex-start;
  gap: 5px;
  font-size: 0.78rem;
  color: var(--amber);
  margin-top: 4px;
  line-height: 1.4;
}
.sec-check-rec svg { margin-top: 1px; color: var(--amber); }

.sec-check-severity {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 3px 8px;
  border-radius: 4px;
  white-space: nowrap;
  flex-shrink: 0;
  align-self: start;
}
.sec-sev-critical { color: #ff6b6b; background: rgba(239,68,68,0.12); border: 1px solid rgba(239,68,68,0.2); }
.sec-sev-high     { color: var(--amber); background: rgba(245,158,11,0.1); border: 1px solid rgba(245,158,11,0.2); }
.sec-sev-medium   { color: var(--blue); background: rgba(59,130,246,0.1); border: 1px solid rgba(59,130,246,0.2); }
.sec-sev-low      { color: var(--muted2); background: rgba(255,255,255,0.04); border: 1px solid var(--border); }

/* ── History expandable rows ── */
.sec-hist-table { border-collapse: collapse; }
.sec-hist-th-toggle { width: 32px; }

.sec-hist-row {
  cursor: pointer;
  transition: background 0.15s;
}
.sec-hist-row:hover,
.sec-hist-row-open { background: rgba(99,102,241,0.06) !important; }

.sec-hist-td-chevron {
  text-align: center;
  padding: 0 8px !important;
  color: var(--muted);
}
.sec-hist-chevron {
  width: 16px; height: 16px;
  transition: transform 0.2s ease;
  display: inline-block;
}
.sec-hist-chevron-open { transform: rotate(180deg); }

.sec-hist-badges { display: flex; gap: 4px; align-items: center; flex-wrap: wrap; }
.sec-hist-mini-badge {
  font-size: 0.72rem;
  font-weight: 600;
  padding: 2px 7px;
  border-radius: 4px;
  white-space: nowrap;
}
.sec-hist-fail { color: var(--red);   background: rgba(239,68,68,0.12);   border: 1px solid rgba(239,68,68,0.2); }
.sec-hist-warn { color: var(--amber); background: rgba(245,158,11,0.1);   border: 1px solid rgba(245,158,11,0.2); }
.sec-hist-pass { color: var(--green); background: rgba(16,185,129,0.1);   border: 1px solid rgba(16,185,129,0.2); }

/* Detail row - hidden by default */
.sec-hist-detail-row { display: none; }
.sec-hist-detail-row.sec-hist-detail-open { display: table-row; }

.sec-hist-detail-cell {
  padding: 0 !important;
  background: rgba(10,12,20,0.5);
  border-top: none !important;
}
.sec-hist-detail-inner {
  padding: 16px 20px 20px;
  border-top: 1px solid var(--border);
  animation: secHistExpand 0.2s ease;
}
@keyframes secHistExpand {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

.sec-hist-summary-text {
  font-size: 0.85rem;
  color: var(--muted2);
  margin-bottom: 14px;
  line-height: 1.5;
}
.sec-hist-no-checks {
  font-size: 0.85rem;
  color: var(--muted);
  padding: 8px 0;
}

.sec-hist-cats {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 12px;
}

.sec-hist-cat {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  overflow: hidden;
}

.sec-hist-cat-label {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--muted2);
  padding: 6px 12px;
  background: rgba(255,255,255,0.03);
  border-bottom: 1px solid var(--border);
}

.sec-hist-cat-items { display: flex; flex-direction: column; }

.sec-hist-check-item {
  display: grid;
  grid-template-columns: 22px 1fr auto;
  gap: 8px;
  align-items: start;
  padding: 8px 12px;
  border-bottom: 1px solid var(--border);
  font-size: 0.82rem;
}
.sec-hist-check-item:last-child { border-bottom: none; }

.sec-hist-ci-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 18px; height: 18px;
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 1px;
}
.sec-hist-ci-icon svg { width: 10px; height: 10px; }

.sec-hist-ci-fail .sec-hist-ci-icon { background: rgba(239,68,68,0.15);   color: var(--red); }
.sec-hist-ci-warn .sec-hist-ci-icon { background: rgba(245,158,11,0.15);  color: var(--amber); }
.sec-hist-ci-pass .sec-hist-ci-icon { background: rgba(16,185,129,0.15);  color: var(--green); }

.sec-hist-ci-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.sec-hist-ci-name { font-weight: 500; color: var(--text); }
.sec-hist-ci-msg  { color: var(--muted2); font-size: 0.78rem; }
.sec-hist-ci-rec  {
  color: var(--amber);
  font-size: 0.75rem;
  margin-top: 2px;
  line-height: 1.4;
}

/* severity badge reuse - already defined as .sec-check-severity .sec-sev-* */
.sec-hist-check-item .sec-check-severity { align-self: start; margin-top: 1px; }

/* ═══════════════════════════════════════════════
   OSINT TOOLS PANEL
   ═══════════════════════════════════════════════ */

/* Search card */
.osint-search-card {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 1.5rem;
  margin-bottom: 2rem;
}
.osint-search-header {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 1.25rem;
}
.osint-search-form {
  display: flex;
  gap: 12px;
  align-items: flex-end;
  flex-wrap: wrap;
}
.osint-scan-msg {
  margin-top: 0.85rem;
  font-size: 0.85rem;
  padding: 0.65rem 1rem;
  border-radius: 8px;
  border: 1px solid transparent;
}
.osint-scan-msg.msg-ok    { background: rgba(16,185,129,0.08); border-color: rgba(16,185,129,0.25); color: var(--green); }
.osint-scan-msg.msg-err   { background: rgba(239,68,68,0.08);  border-color: rgba(239,68,68,0.25);  color: var(--red);   }
.osint-scan-msg.msg-info  { background: rgba(14,165,233,0.08); border-color: rgba(14,165,233,0.25); color: var(--accent); }

/* Running scans banner */
.osint-running-wrap {
  background: rgba(245,158,11,0.08);
  border: 1px solid rgba(245,158,11,0.25);
  border-radius: 10px;
  padding: 0.85rem 1.25rem;
  margin-bottom: 1.5rem;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.875rem;
  color: var(--amber);
}
.osint-running-header { display:flex; align-items:center; gap:10px; }

/* History table */
.osint-history-wrap { margin-top: 0.5rem; }
.osint-hist-table .badge-running  { background: rgba(245,158,11,0.15); color: var(--amber); }
.osint-hist-table .badge-completed{ background: rgba(16,185,129,0.12); color: var(--green); }
.osint-hist-table .badge-error    { background: rgba(239,68,68,0.12);  color: var(--red); }

/* Result modal */
.osint-result-box {
  max-width: 900px;
  width: 96vw;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
}
.osint-tabs {
  display: flex;
  gap: 4px;
  border-bottom: 1px solid var(--border);
  margin: 1rem 0 0;
  padding: 0;
  flex-wrap: wrap;
}
.osint-tab {
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  padding: 0.55rem 1rem;
  font-size: 0.83rem;
  font-weight: 500;
  color: var(--muted2);
  cursor: pointer;
  white-space: nowrap;
  transition: color 0.15s, border-color 0.15s;
}
.osint-tab:hover  { color: var(--text); }
.osint-tab.active { color: var(--accent); border-bottom-color: var(--accent); }
.osint-tab-content {
  flex: 1;
  overflow-y: auto;
  padding: 1.25rem 0.25rem;
  min-height: 300px;
  max-height: calc(90vh - 200px);
}

/* Tab section blocks */
.osint-section {
  margin-bottom: 1.75rem;
}
.osint-section-title {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  margin-bottom: 0.85rem;
}
.osint-kv-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
@media (max-width: 600px) {
  .osint-kv-grid { grid-template-columns: 1fr; }
}
.osint-kv-item {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 0.85rem 1rem;
}
.osint-kv-label {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--muted);
  margin-bottom: 4px;
}
.osint-kv-value {
  font-size: 0.88rem;
  color: var(--text);
  word-break: break-all;
}

/* Subdomain list */
.osint-subdomain-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.osint-subdomain-tag {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 3px 10px;
  font-size: 0.8rem;
  font-family: 'JetBrains Mono', monospace;
  color: var(--muted2);
}
.osint-subdomain-tag.resolved { border-color: rgba(16,185,129,0.3); color: var(--green); }
.osint-subdomain-tag.unresolved { opacity: 0.55; }

/* CVE cards */
.osint-cve-card {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 1rem;
  margin-bottom: 0.75rem;
}
.osint-cve-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 0.5rem;
}
.osint-cve-id {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--accent);
}
.osint-cve-score {
  font-size: 0.78rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 5px;
}
.osint-cve-score.crit  { background: rgba(239,68,68,0.2);   color: #f87171; }
.osint-cve-score.high  { background: rgba(245,158,11,0.2);  color: var(--amber); }
.osint-cve-score.med   { background: rgba(14,165,233,0.15); color: var(--accent); }
.osint-cve-score.low   { background: rgba(16,185,129,0.12); color: var(--green); }
.osint-cve-desc { font-size: 0.83rem; color: var(--muted2); line-height: 1.5; }
.osint-cve-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.4rem 0.75rem;
  margin-bottom: 0.45rem;
  font-size: 0.74rem;
  color: var(--muted);
}
.osint-cve-version {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.7rem;
  background: rgba(14,165,233,0.12);
  color: var(--accent);
  border-radius: 4px;
  padding: 1px 6px;
  font-weight: 600;
}
.osint-cve-cwe {
  display: inline-block;
  font-size: 0.71rem;
  font-family: 'JetBrains Mono', monospace;
  background: rgba(139,92,246,0.15);
  color: #a78bfa;
  border-radius: 4px;
  padding: 1px 6px;
  margin: 0 2px 2px 0;
}
.osint-cve-vector-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: 0.3rem;
  margin-top: 0.5rem;
}
.osint-cve-vector-item {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 0.25rem 0.5rem;
}
.osint-cve-vector-item .v-label { font-size: 0.68rem; color: var(--muted); display: block; }
.osint-cve-vector-item .v-val   { font-size: 0.78rem; font-weight: 600; color: var(--text); }
.osint-cve-vector-item .v-val.HIGH,
.osint-cve-vector-item .v-val.CRITICAL { color: #f87171; }
.osint-cve-vector-item .v-val.MEDIUM   { color: var(--amber); }
.osint-cve-vector-item .v-val.LOW,
.osint-cve-vector-item .v-val.NONE     { color: var(--green); }
.osint-cve-refs {
  margin-top: 0.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.osint-cve-refs a {
  font-size: 0.73rem;
  color: var(--accent);
  text-decoration: none;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  display: block;
}
.osint-cve-refs a:hover { text-decoration: underline; }

/* Recon-ng table */
.osint-rn-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
}
.osint-rn-table th {
  text-align: left;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--muted);
  padding: 0.4rem 0.6rem;
  border-bottom: 1px solid var(--border);
}
.osint-rn-table td {
  padding: 0.45rem 0.6rem;
  border-bottom: 1px solid var(--border);
  color: var(--text);
  vertical-align: top;
  max-width: 280px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.osint-rn-table tr:last-child td { border-bottom: none; }
.osint-rn-table tr:hover td { background: var(--surface2); }

/* Leak cards */
.osint-leak-card {
  background: rgba(239,68,68,0.05);
  border: 1px solid rgba(239,68,68,0.2);
  border-radius: 10px;
  padding: 1rem;
  margin-bottom: 0.75rem;
}
.osint-leak-header { display:flex; align-items:center; gap:8px; margin-bottom:0.4rem; }
.osint-leak-sev { font-size:0.75rem; font-weight:700; padding:2px 8px; border-radius:5px; }
.osint-leak-sev.high { background:rgba(239,68,68,0.2); color:#f87171; }
.osint-leak-sev.med  { background:rgba(245,158,11,0.2); color:var(--amber); }
.osint-leak-sev.low  { background:rgba(16,185,129,0.12); color:var(--green); }
.osint-leak-desc { font-size:0.82rem; color:var(--muted2); }

/* Threat Intel */
.osint-threat-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.7rem 0;
  border-bottom: 1px solid var(--border);
  font-size: 0.85rem;
}
.osint-threat-row:last-child { border-bottom: none; }
.osint-threat-label { color: var(--muted); }
.osint-threat-value { font-weight: 500; color: var(--text); text-align: right; }

/* Summary stat cards */
.osint-stats-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 12px;
  margin-bottom: 1.5rem;
}
.osint-stat-card {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 1rem;
  text-align: center;
}
.osint-stat-num  { font-size: 2rem; font-weight: 700; color: var(--accent); line-height: 1.1; }
.osint-stat-label{ font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.07em; color: var(--muted); margin-top: 4px; }
.osint-stat-card.warn .osint-stat-num { color: var(--amber); }
.osint-stat-card.danger .osint-stat-num{ color: var(--red); }
.osint-stat-card.ok .osint-stat-num   { color: var(--green); }

/* Raw JSON */
.osint-raw-pre {
  background: #0d1117;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 1rem;
  font-size: 0.78rem;
  font-family: 'JetBrains Mono', monospace;
  color: #c9d1d9;
  overflow: auto;
  max-height: 55vh;
  white-space: pre;
  line-height: 1.5;
}

/* Config modal */
.osint-cfg-section-title {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--accent);
  border-bottom: 1px solid var(--border);
  padding-bottom: 0.35rem;
  margin: 1.1rem 0 0.7rem;
}
.osint-cfg-hint {
  display: block;
  font-size: 0.72rem;
  color: var(--muted);
  margin-top: 3px;
  line-height: 1.3;
}
.osint-cfg-status {
  font-size: 0.73rem;
  font-weight: 600;
  margin-left: 6px;
}
.osint-cfg-status.set   { color: var(--green); }
.osint-cfg-status.unset { color: var(--muted); }

/* Badge helpers already exist: badge-running / badge-completed - added via inline style or class */


/* ═══════════════════════════════════════════════════════════════
   PANEL DOCS - Documentazione & Offerta Commerciale
   ═══════════════════════════════════════════════════════════════ */

/* ── Print bar ──────────────────────────────────────────────── */
.docs-print-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 10px;
  margin-bottom: 1.5rem;
  font-size: 0.85rem;
  color: var(--muted);
  flex-wrap: wrap;
}

/* ── Tab navigation ─────────────────────────────────────────── */
.docs-tabs {
  display: flex;
  gap: 2px;
  border-bottom: 2px solid var(--border);
  margin-bottom: 1.75rem;
  overflow-x: auto;
}
.docs-tab {
  padding: 9px 20px;
  border: none;
  background: none;
  color: var(--muted);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  white-space: nowrap;
  transition: color 0.15s, border-color 0.15s;
}
.docs-tab:hover  { color: var(--text); }
.docs-tab.active { color: var(--accent); border-bottom-color: var(--accent); }

/* ── Tab content ────────────────────────────────────────────── */
.docs-tab-content { display: none; }
.docs-tab-content.active { display: block; }

/* ── Section ────────────────────────────────────────────────── */
.docs-section { margin-bottom: 2.25rem; }
.docs-section-title {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 0.85rem;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--border);
}

/* ── Intro card ─────────────────────────────────────────────── */
.docs-intro-card {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 1.25rem 1.5rem;
}
.docs-intro-badge {
  display: inline-block;
  padding: 3px 10px;
  background: rgba(var(--accent-rgb, 59,130,246), 0.12);
  color: var(--accent);
  border-radius: 20px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  margin-bottom: 0.65rem;
}
.docs-intro-card p {
  margin: 0 0 0.5rem;
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.65;
}
.docs-intro-card p:last-child { margin-bottom: 0; }
.docs-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 1rem;
}
.docs-meta-pill {
  padding: 3px 10px;
  background: var(--surface3, rgba(255,255,255,0.05));
  border: 1px solid var(--border);
  border-radius: 20px;
  font-size: 0.74rem;
  color: var(--muted);
}

/* ── Tech grid ──────────────────────────────────────────────── */
.docs-tech-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(175px, 1fr));
  gap: 10px;
}
.docs-tech-card {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 0.9rem 1rem;
  display: flex;
  align-items: flex-start;
  gap: 10px;
}
.docs-tech-card > div { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.docs-tech-card > div strong { font-size: 0.84rem; font-weight: 700; color: var(--text); }
.docs-tech-card > div span   { font-size: 0.75rem; color: var(--muted); line-height: 1.4; }

.docs-tech-icon {
  width: 34px; height: 34px;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  flex-shrink: 0;
}
.docs-tech-icon.blue   { background: rgba(59,130,246,0.15);  color: #60a5fa; }
.docs-tech-icon.green  { background: rgba(34,197,94,0.15);   color: #4ade80; }
.docs-tech-icon.purple { background: rgba(168,85,247,0.15);  color: #c084fc; }
.docs-tech-icon.orange { background: rgba(249,115,22,0.15);  color: #fb923c; }
.docs-tech-icon.amber  { background: rgba(245,158,11,0.15);  color: #fbbf24; }
.docs-tech-icon.red    { background: rgba(239,68,68,0.15);   color: #f87171; }
.docs-tech-icon.cyan   { background: rgba(6,182,212,0.15);   color: #22d3ee; }
.docs-tech-icon.yellow { background: rgba(234,179,8,0.15);   color: #facc15; }
.docs-tech-icon.pink   { background: rgba(236,72,153,0.15);  color: #f472b6; }
.docs-tech-icon.indigo { background: rgba(99,102,241,0.15);  color: #818cf8; }
.docs-tech-icon.teal   { background: rgba(20,184,166,0.15);  color: #2dd4bf; }
.docs-tech-icon.gray   { background: rgba(156,163,175,0.12); color: #9ca3af; }

/* ── Acquisition cards ──────────────────────────────────────── */
.docs-acq-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 10px;
}
.docs-acq-card {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent);
  border-radius: 10px;
  padding: 0.9rem 1rem;
  display: flex;
  gap: 12px;
  align-items: flex-start;
}
.docs-acq-num {
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--accent);
  opacity: 0.35;
  line-height: 1;
  flex-shrink: 0;
  min-width: 28px;
}
.docs-acq-body { flex: 1; min-width: 0; }
.docs-acq-body strong { display: block; font-size: 0.86rem; font-weight: 700; color: var(--text); margin-bottom: 4px; }
.docs-acq-body p      { margin: 0; font-size: 0.78rem; color: var(--muted); line-height: 1.5; }

/* ── Code block ─────────────────────────────────────────────── */
.docs-code-block {
  background: #0d1117;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 1rem 1.25rem;
  overflow: auto;
}
.docs-code-block pre {
  margin: 0;
  font-size: 0.78rem;
  font-family: 'JetBrains Mono', monospace;
  color: #c9d1d9;
  white-space: pre;
  line-height: 1.65;
}

/* ── Table ──────────────────────────────────────────────────── */
.docs-table-wrap { overflow-x: auto; }
.docs-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
}
.docs-table th {
  background: var(--surface2);
  color: var(--muted);
  font-weight: 600;
  text-align: left;
  padding: 8px 12px;
  border-bottom: 2px solid var(--border);
  white-space: nowrap;
}
.docs-table td {
  padding: 7px 12px;
  border-bottom: 1px solid var(--border);
  color: var(--text);
  vertical-align: top;
  line-height: 1.4;
}
.docs-table tr:last-child td { border-bottom: none; }
.docs-table td code {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.77rem;
  color: var(--accent);
  background: rgba(59,130,246,0.1);
  padding: 1px 5px;
  border-radius: 4px;
}

/* ── Infra grid ─────────────────────────────────────────────── */
.docs-infra-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 8px;
}
.docs-infra-item {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 0.7rem 1rem;
  display: flex;
  gap: 8px;
  align-items: baseline;
  font-size: 0.82rem;
}
.docs-infra-label {
  font-weight: 700;
  color: var(--text);
  flex-shrink: 0;
  min-width: 70px;
}
.docs-infra-item > span:last-child { color: var(--muted); font-size: 0.78rem; }

/* ── Pills ──────────────────────────────────────────────────── */
.docs-pills-wrap { display: flex; flex-wrap: wrap; gap: 6px; }
.docs-pill-item {
  padding: 3px 11px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 16px;
  font-size: 0.75rem;
  font-family: 'JetBrains Mono', monospace;
  color: var(--muted);
}

/* ── Security grid ──────────────────────────────────────────── */
.docs-security-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 12px;
}
.docs-sec-card {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 1rem 1.1rem;
  display: flex;
  gap: 12px;
  align-items: flex-start;
}
.docs-sec-card > div { flex: 1; min-width: 0; }
.docs-sec-card > div strong { display: block; font-size: 0.88rem; font-weight: 700; color: var(--text); margin-bottom: 4px; }
.docs-sec-card > div p { margin: 0; font-size: 0.78rem; color: var(--muted); line-height: 1.5; }
.docs-sec-card > div code {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.75rem;
  color: var(--accent);
  background: rgba(59,130,246,0.1);
  padding: 1px 4px;
  border-radius: 3px;
}
.docs-sec-icon {
  width: 36px; height: 36px;
  border-radius: 8px;
  font-size: 0.65rem;
  font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.docs-sec-icon.indigo { background: rgba(99,102,241,0.15);  color: #818cf8; }
.docs-sec-icon.blue   { background: rgba(59,130,246,0.15);  color: #60a5fa; }
.docs-sec-icon.purple { background: rgba(168,85,247,0.15);  color: #c084fc; }
.docs-sec-icon.teal   { background: rgba(20,184,166,0.15);  color: #2dd4bf; }
.docs-sec-icon.amber  { background: rgba(245,158,11,0.15);  color: #fbbf24; }
.docs-sec-icon.red    { background: rgba(239,68,68,0.15);   color: #f87171; }
.docs-sec-icon.green  { background: rgba(34,197,94,0.15);   color: #4ade80; }

/* ── Score badges ───────────────────────────────────────────── */
.docs-scoring-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 1rem;
}
.docs-score-badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 0.78rem;
  font-weight: 800;
  color: #fff;
}

/* ══════════════════════════════════════════════════════════════
   OFFER PRINT AREA
   ══════════════════════════════════════════════════════════════ */
#offerPrintArea {
  background: #fff;
  color: #111827;
  border-radius: 14px;
  padding: 2rem 2.25rem;
  border: 1px solid var(--border);
  font-family: Inter, 'Segoe UI', sans-serif;
}

/* Header */
.offer-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  margin-bottom: 2rem;
  padding-bottom: 1.5rem;
  border-bottom: 2px solid #e5e7eb;
  flex-wrap: wrap;
}
.offer-logo-area {
  display: flex;
  align-items: center;
  gap: 14px;
}
.offer-logo-svg { width: 48px; height: 48px; flex-shrink: 0; }
.offer-brand {
  font-size: 1.5rem;
  font-weight: 800;
  color: #111827;
  line-height: 1.1;
}
.offer-brand-sub {
  font-size: 0.78rem;
  color: #6b7280;
  margin-top: 2px;
}
.offer-header-right { text-align: right; }
.offer-doc-label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #1d4ed8;
  margin-bottom: 4px;
}
.offer-doc-meta { font-size: 0.8rem; color: #6b7280; }

/* Content blocks */
.offer-block { margin-bottom: 2rem; }
.offer-h2 {
  font-size: 1rem;
  font-weight: 700;
  color: #111827;
  margin: 0 0 0.6rem;
  padding-bottom: 5px;
  border-bottom: 1px solid #e5e7eb;
}
.offer-p {
  font-size: 0.875rem;
  color: #374151;
  line-height: 1.7;
  margin: 0 0 0.5rem;
}

/* Features grid */
.offer-features-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  gap: 10px;
}
.offer-feature {
  background: #f9fafb;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  padding: 0.85rem 1rem;
  display: flex;
  gap: 10px;
  align-items: flex-start;
}
.offer-feat-icon { font-size: 1.1rem; flex-shrink: 0; margin-top: 1px; }
.offer-feature strong { display: block; font-size: 0.84rem; color: #111827; margin-bottom: 2px; }
.offer-feature p { margin: 0; font-size: 0.76rem; color: #6b7280; line-height: 1.45; }

/* Plans grid */
.offer-plans-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(215px, 1fr));
  gap: 14px;
}
.offer-plan {
  background: #f9fafb;
  border: 2px solid #e5e7eb;
  border-radius: 12px;
  overflow: hidden;
  position: relative;
}
.offer-plan.featured { border-color: #1d4ed8; }
.offer-plan-badge {
  position: absolute;
  top: -1px;
  right: 12px;
  background: #1d4ed8;
  color: #fff;
  font-size: 0.68rem;
  font-weight: 700;
  padding: 2px 10px;
  border-radius: 0 0 8px 8px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.offer-plan-header {
  padding: 1rem 1.1rem 0.75rem;
  border-bottom: 1px solid #e5e7eb;
}
.offer-plan-header.starter      { background: #f3f4f6; }
.offer-plan-header.professional { background: #dbeafe; border-bottom-color: #bfdbfe; }
.offer-plan-header.enterprise   { background: #f5f3ff; border-bottom-color: #ddd6fe; }
.offer-plan-name   { font-size: 1rem; font-weight: 800; color: #111827; }
.offer-plan-target { font-size: 0.72rem; color: #6b7280; margin-top: 2px; line-height: 1.3; }

.offer-plan-body { padding: 1rem 1.1rem; }

.offer-price-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 0.85rem;
  flex-wrap: wrap;
}
.offer-price-block { flex: 1; min-width: 80px; }
.offer-price {
  font-size: 1.35rem;
  font-weight: 800;
  color: #1d4ed8;
  line-height: 1.1;
}
.offer-price span { font-size: 0.8rem; font-weight: 500; color: #6b7280; }
.offer-price.annual { color: #15803d; }
.offer-price-note { font-size: 0.7rem; color: #6b7280; margin-top: 2px; }
.offer-price-note.annual-note { color: #15803d; font-weight: 600; }
.offer-price-divider { font-size: 0.72rem; color: #9ca3af; flex-shrink: 0; }

.offer-tokens-box {
  border-radius: 10px;
  padding: 0.65rem 0.9rem;
  margin-bottom: 0.85rem;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.offer-tokens-box.starter-tokens      { background: #f3f4f6; border: 1px solid #e5e7eb; }
.offer-tokens-box.professional-tokens { background: #eff6ff; border: 1px solid #bfdbfe; }
.offer-tokens-box.enterprise-tokens   { background: #f5f3ff; border: 1px solid #ddd6fe; }
.offer-tokens-num {
  font-size: 1.6rem;
  font-weight: 800;
  color: #1d4ed8;
  line-height: 1;
}
.offer-tokens-box.enterprise-tokens .offer-tokens-num { color: #7c3aed; }
.offer-tokens-label  { font-size: 0.75rem; font-weight: 600; color: #374151; }
.offer-tokens-annual { font-size: 0.72rem; color: #6b7280; }

.offer-feat-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.offer-feat-list li {
  font-size: 0.78rem;
  color: #374151;
  padding: 3px 0;
  line-height: 1.4;
}
.offer-feat-list li:first-child(✔) { color: #15803d; }

/* Add-ons */
.offer-addons-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 10px;
}
.offer-addon {
  background: #f9fafb;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  padding: 0.85rem 1rem;
  text-align: center;
  position: relative;
}
.offer-addon.best { border-color: #1d4ed8; background: #eff6ff; }
.offer-addon-best-label {
  position: absolute;
  top: -1px;
  left: 50%;
  transform: translateX(-50%);
  background: #1d4ed8;
  color: #fff;
  font-size: 0.62rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 0 0 6px 6px;
  white-space: nowrap;
}
.offer-addon-qty   { font-size: 1rem; font-weight: 800; color: #111827; margin-bottom: 2px; }
.offer-addon-price { font-size: 1.3rem; font-weight: 800; color: #1d4ed8; line-height: 1.1; }
.offer-addon-unit  { font-size: 0.72rem; color: #6b7280; margin-top: 2px; }

/* Compare table */
.offer-compare-wrap { overflow-x: auto; }
.offer-compare {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.81rem;
}
.offer-compare th {
  background: #f3f4f6;
  color: #111827;
  font-weight: 700;
  padding: 9px 12px;
  text-align: center;
  border: 1px solid #e5e7eb;
}
.offer-compare th:first-child { text-align: left; }
.offer-compare th.starter-col { background: #f3f4f6; }
.offer-compare th.pro-col     { background: #dbeafe; color: #1d4ed8; }
.offer-compare th.ent-col     { background: #f5f3ff; color: #7c3aed; }
.offer-compare td {
  padding: 7px 12px;
  border: 1px solid #e5e7eb;
  text-align: center;
  color: #374151;
}
.offer-compare td:first-child { text-align: left; color: #111827; }
.offer-compare tr:nth-child(even) td { background: #f9fafb; }
.offer-compare .feature-divider td { border-top: 2px solid #d1d5db; }
.offer-compare .price-row td { background: #eff6ff !important; font-weight: 700; color: #1d4ed8; }
.offer-compare .price-row td:first-child { color: #111827; }

/* Guarantees */
.offer-guarantees-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  gap: 10px;
}
.offer-guarantee {
  background: #f9fafb;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  padding: 0.85rem 1rem;
}
.offer-guarantee-icon { font-size: 1.25rem; display: block; margin-bottom: 6px; }
.offer-guarantee strong { display: block; font-size: 0.84rem; color: #111827; margin-bottom: 3px; }
.offer-guarantee p { margin: 0; font-size: 0.75rem; color: #6b7280; line-height: 1.5; }

/* Footer */
.offer-footer {
  margin-top: 2rem;
  padding-top: 1.25rem;
  border-top: 1px solid #e5e7eb;
  text-align: center;
}
.offer-footer-logo {
  font-size: 1rem;
  font-weight: 800;
  color: #1d4ed8;
  margin-bottom: 6px;
}
.offer-footer-text p {
  margin: 0 0 4px;
  font-size: 0.78rem;
  color: #6b7280;
  line-height: 1.5;
}

/* ── Print styles ───────────────────────────────────────────── */
/* Stampa gestita via finestra dedicata in printOffer() - no @media print qui */

/* ── Training Admin Panel ────────────────────────────────────────────────────── */
.training-admin-tabs {
  display: flex; gap: .5rem; margin-bottom: 1.5rem;
  border-bottom: 1px solid rgba(255,255,255,0.08); padding-bottom: .75rem;
}
.training-admin-tab {
  padding: 7px 18px; border-radius: 8px 8px 0 0; font-size: .88rem; font-weight: 600;
  background: transparent; border: 1px solid rgba(255,255,255,0.1); border-bottom: none;
  color: var(--text-muted); cursor: pointer; transition: .15s;
}
.training-admin-tab.active, .training-admin-tab:hover { background: rgba(255,255,255,0.06); color: var(--text); }
.training-admin-tab.active { border-color: rgba(255,255,255,0.15); color: var(--primary); }
.training-admin-pane { }

/* Module answer-key sub-tabs */
.training-answer-modules {
  display: flex; gap: .5rem; margin-bottom: 1.5rem; flex-wrap: wrap;
}
.training-answer-tab {
  padding: 6px 16px; border-radius: 20px; font-size: .84rem; font-weight: 600;
  background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.1);
  color: var(--text-muted); cursor: pointer; transition: .15s;
}
.training-answer-tab.active { background: rgba(16,185,129,0.12); color: var(--primary); border-color: rgba(16,185,129,0.3); }
.training-answer-tab:hover  { background: rgba(255,255,255,0.07); }

/* Answer key questions */
.answer-key-q {
  background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.07);
  border-radius: 10px; padding: 1.1rem 1.25rem; margin-bottom: 1rem;
}
.answer-key-num  { margin: 0 0 .2rem; font-size: .75rem; color: var(--primary); font-weight: 700; text-transform: uppercase; letter-spacing: .05em; }
.answer-key-text { margin: 0 0 .9rem; font-size: .92rem; color: var(--text); font-weight: 500; }
.answer-key-opts { display: flex; flex-direction: column; gap: .4rem; }
.answer-key-opt {
  display: flex; align-items: center; gap: .75rem; padding: .5rem .75rem;
  border-radius: 7px; border: 1px solid rgba(255,255,255,0.06);
}
.answer-key-opt.correct { background: rgba(16,185,129,0.08); border-color: rgba(16,185,129,0.25); }
.answer-key-letter {
  flex-shrink: 0; width: 22px; height: 22px; border-radius: 50%;
  background: rgba(255,255,255,0.06); font-size: .72rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center; color: var(--text-muted);
}
.answer-key-letter.correct { background: var(--primary); color: #000; }
.answer-key-opt-text { flex: 1; font-size: .86rem; color: var(--text); }
.answer-key-check { margin-left: auto; font-size: .78rem; font-weight: 700; color: var(--primary); white-space: nowrap; }

/* Badges */
.badge-wrong {
  display: inline-block; padding: 2px 9px; border-radius: 20px; font-size: .78rem; font-weight: 600;
  background: rgba(239,68,68,0.12); color: #fca5a5;
}
