/* ============================================================
   MISOKI DESIGN SYSTEM — Soft Modern Theme v2
   Cargado después de los estilos inline para sobreescribir
   componentes comunes con el nuevo look del dashboard.
   ============================================================ */

/* ── Tokens ── */
:root {
  --bg:            #F4F2F8;
  --bg-2:          #EDE9F4;
  --surface:       #FFFFFF;
  --surface-2:     #F9F7FD;
  --surface-hover: #F3F0FA;
  --border:        rgba(124,58,237,0.08);
  --border-hi:     rgba(124,58,237,0.16);

  --purple:        #7C3AED;
  --purple-mid:    #6D28D9;
  --purple-light:  #8B5CF6;
  --purple-dim:    rgba(124,58,237,0.10);
  --purple-glow:   rgba(124,58,237,0.22);
  --gold:          #D97706;
  --gold-dim:      rgba(217,119,6,0.10);

  --success:       #059669;
  --success-dim:   rgba(5,150,105,0.10);
  --success-text:  #065F46;
  --warning:       #D97706;
  --warning-dim:   rgba(217,119,6,0.10);
  --warning-text:  #92400E;
  --danger:        #DC2626;
  --danger-dim:    rgba(220,38,38,0.08);
  --danger-text:   #991B1B;

  --text-1:        #1E1B2E;
  --text-2:        #4B4569;
  --text-3:        #8B82A7;

  --radius:        14px;
  --radius-sm:     10px;
  --radius-xs:     7px;

  --shadow-card:   0 1px 4px rgba(124,58,237,0.06), 0 4px 16px rgba(124,58,237,0.05);
  --shadow-hover:  0 4px 12px rgba(124,58,237,0.12), 0 8px 24px rgba(124,58,237,0.08);
  --transition:    150ms cubic-bezier(0.4,0,0.2,1);
}

/* ── Base ── */
html { color-scheme: light; }

body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  background: var(--bg);
  color: var(--text-1);
  -webkit-font-smoothing: antialiased;
}

/* Dot texture overlay */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image: radial-gradient(circle, rgba(124,58,237,0.055) 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none;
  z-index: 0;
}
body::after { display: none; }

/* ── Container ── */
.container {
  position: relative;
  z-index: 1;
  max-width: 1480px;
  padding: 20px 20px 56px;
}

/* ══════════════════════════════════════
   HEADER — reemplaza el gradiente morado
   ══════════════════════════════════════ */
.header {
  background: var(--surface) !important;
  color: var(--text-1) !important;
  border: 1px solid var(--border-hi) !important;
  border-radius: var(--radius) !important;
  padding: 18px 24px !important;
  margin-bottom: 20px !important;
  box-shadow: var(--shadow-card) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
  flex-wrap: wrap !important;
  position: relative !important;
  overflow: visible !important;
  /* Elimina el patrón de líneas antiguo */
  background-image: none !important;
}

/* Línea degradada top — nueva firma visual */
.header::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important; left: 0 !important; right: 0 !important;
  height: 1px !important;
  background: linear-gradient(90deg, transparent, var(--purple), var(--gold), transparent) !important;
  opacity: 0.6 !important;
  pointer-events: none !important;
  background-image: linear-gradient(90deg, transparent, var(--purple), var(--gold), transparent) !important;
}

/* Elimina el patrón de fondo antiguo */
.header::after { display: none !important; }

.header h1, .header-brand h1 {
  font-family: 'Space Grotesk', 'Inter', sans-serif !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  color: var(--text-1) !important;
  letter-spacing: -0.3px !important;
  line-height: 1.2 !important;
}

.header p, .header-sub, .header-subtitle, .header h1 + p {
  font-size: 12.5px !important;
  color: var(--text-3) !important;
  margin-top: 3px !important;
}

.header-left {
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
}

.header-actions, .header-right {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
}

/* Role badge dentro del header */
.header .role-badge, .role-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 4px 12px !important;
  background: var(--purple-dim) !important;
  color: var(--purple-mid) !important;
  border: 1px solid rgba(124,58,237,0.2) !important;
  border-radius: 50px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
}

/* ══════════════════════════════════════
   BOTONES — header buttons
   ══════════════════════════════════════ */
.btn-back, .btn-app {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 8px 16px !important;
  background: var(--surface-2) !important;
  color: var(--text-2) !important;
  border: 1px solid var(--border-hi) !important;
  border-radius: 40px !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  font-family: 'Inter', sans-serif !important;
  text-decoration: none !important;
  cursor: pointer !important;
  transition: all var(--transition) !important;
  white-space: nowrap !important;
  box-shadow: none !important;
}
.btn-back:hover, .btn-app:hover {
  background: var(--purple-dim) !important;
  border-color: rgba(124,58,237,0.3) !important;
  color: var(--purple) !important;
  transform: none !important;
}

.btn-refresh {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 8px 14px !important;
  background: transparent !important;
  color: var(--text-3) !important;
  border: 1px solid var(--border-hi) !important;
  border-radius: 40px !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  font-family: 'Inter', sans-serif !important;
  cursor: pointer !important;
  transition: all var(--transition) !important;
  box-shadow: none !important;
}
.btn-refresh:hover {
  background: var(--surface-2) !important;
  color: var(--text-2) !important;
}

.btn-nuevo {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 8px 16px !important;
  background: linear-gradient(135deg, var(--purple), var(--purple-mid)) !important;
  color: white !important;
  border: none !important;
  border-radius: 40px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  font-family: 'Inter', sans-serif !important;
  cursor: pointer !important;
  transition: all var(--transition) !important;
  box-shadow: 0 2px 8px var(--purple-glow) !important;
  text-decoration: none !important;
}
.btn-nuevo:hover {
  box-shadow: 0 4px 16px var(--purple-glow) !important;
  transform: translateY(-1px) !important;
}

/* ══════════════════════════════════════
   BOTONES — sistema general
   ══════════════════════════════════════ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 9px 18px;
  border-radius: var(--radius-sm);
  font-size: 13px;
  font-weight: 600;
  font-family: 'Inter', sans-serif;
  border: 1px solid transparent;
  cursor: pointer;
  transition: all var(--transition);
  white-space: nowrap;
  text-decoration: none;
}
.btn:disabled { opacity: 0.5; cursor: not-allowed; transform: none !important; box-shadow: none !important; }

.btn-primary {
  background: linear-gradient(135deg, var(--purple), var(--purple-mid)) !important;
  color: white !important;
  border-color: transparent !important;
  box-shadow: 0 2px 8px var(--purple-glow);
}
.btn-primary:hover {
  box-shadow: 0 4px 16px var(--purple-glow) !important;
  transform: translateY(-1px);
  color: white !important;
}

.btn-secondary {
  background: var(--surface-2) !important;
  color: var(--text-2) !important;
  border-color: var(--border-hi) !important;
}
.btn-secondary:hover { background: var(--surface-hover) !important; color: var(--text-1) !important; }

.btn-success {
  background: linear-gradient(135deg, #059669, #047857) !important;
  color: white !important;
  border-color: transparent !important;
  box-shadow: 0 2px 8px rgba(5,150,105,0.25);
}
.btn-success:hover { box-shadow: 0 4px 16px rgba(5,150,105,0.35) !important; transform: translateY(-1px); }

.btn-danger {
  background: linear-gradient(135deg, #DC2626, #B91C1C) !important;
  color: white !important;
  border-color: transparent !important;
  box-shadow: 0 2px 8px rgba(220,38,38,0.25);
}
.btn-danger:hover { box-shadow: 0 4px 16px rgba(220,38,38,0.35) !important; transform: translateY(-1px); }

.btn-warning {
  background: linear-gradient(135deg, #D97706, #B45309) !important;
  color: white !important;
  border-color: transparent !important;
  box-shadow: 0 2px 8px rgba(217,119,6,0.25);
}
.btn-warning:hover { box-shadow: 0 4px 16px rgba(217,119,6,0.35) !important; transform: translateY(-1px); }

/* ══════════════════════════════════════
   TABS
   ══════════════════════════════════════ */
.tabs {
  display: flex !important;
  gap: 4px !important;
  background: var(--surface) !important;
  padding: 6px !important;
  border-radius: var(--radius) !important;
  border: 1px solid var(--border) !important;
  margin-bottom: 20px !important;
  box-shadow: var(--shadow-card) !important;
  overflow-x: auto !important;
  scrollbar-width: none !important;
  flex-wrap: wrap !important;
}
.tabs::-webkit-scrollbar { display: none; }

.tab, .tab-btn {
  flex-shrink: 0 !important;
  padding: 8px 16px !important;
  border-radius: var(--radius-sm) !important;
  border: none !important;
  background: transparent !important;
  color: var(--text-3) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  font-family: 'Inter', sans-serif !important;
  cursor: pointer !important;
  transition: all var(--transition) !important;
  white-space: nowrap !important;
  box-shadow: none !important;
}
.tab:hover, .tab-btn:hover {
  background: var(--surface-2) !important;
  color: var(--text-2) !important;
}
.tab.active, .tab-btn.active {
  background: linear-gradient(135deg, var(--purple), var(--purple-mid)) !important;
  color: white !important;
  box-shadow: 0 2px 8px var(--purple-glow) !important;
}

.tabs-wrap {
  position: sticky;
  top: 0;
  z-index: 10;
  background: var(--bg);
  padding: 8px 0;
}

/* ══════════════════════════════════════
   KPI CARDS
   ══════════════════════════════════════ */
.kpi-card {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-left: none !important;
  border-radius: var(--radius) !important;
  padding: 18px 20px !important;
  box-shadow: var(--shadow-card) !important;
  transition: all 200ms cubic-bezier(0.4,0,0.2,1) !important;
  position: relative !important;
  overflow: hidden !important;
}
.kpi-card::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important; left: 0 !important; right: 0 !important; bottom: auto !important;
  height: 2px !important;
  width: auto !important;
  border-radius: 2px 2px 0 0 !important;
  background: var(--gold) !important;
}
.kpi-card:hover {
  transform: translateY(-2px) !important;
  box-shadow: var(--shadow-hover) !important;
  border-color: var(--border-hi) !important;
}
.kpi-card.primary::before { background: linear-gradient(90deg, var(--purple-mid), var(--purple)) !important; }
.kpi-card.success::before { background: linear-gradient(90deg, #047857, var(--success)) !important; }
.kpi-card.warning::before { background: linear-gradient(90deg, #B45309, var(--warning)) !important; }
.kpi-card.danger::before  { background: linear-gradient(90deg, #B91C1C, var(--danger)) !important; }
.kpi-card.primary:hover { box-shadow: var(--shadow-hover), 0 0 20px var(--purple-dim) !important; }
.kpi-card.success:hover { box-shadow: var(--shadow-hover), 0 0 20px var(--success-dim) !important; }
.kpi-card.warning:hover { box-shadow: var(--shadow-hover), 0 0 20px var(--warning-dim) !important; }
.kpi-card.danger:hover  { box-shadow: var(--shadow-hover), 0 0 20px var(--danger-dim) !important; }

.kpi-label {
  font-size: 10.5px !important;
  font-weight: 600 !important;
  color: var(--text-3) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.7px !important;
  margin-bottom: 8px !important;
}
.kpi-value {
  font-family: 'Space Grotesk', 'Inter', sans-serif !important;
  font-size: 28px !important;
  font-weight: 700 !important;
  color: var(--text-1) !important;
  line-height: 1 !important;
  letter-spacing: -0.8px !important;
}
.kpi-card.primary .kpi-value { color: var(--purple) !important; }
.kpi-card.success .kpi-value { color: var(--success) !important; }
.kpi-card.warning .kpi-value { color: var(--warning) !important; }
.kpi-card.danger  .kpi-value { color: var(--danger) !important; }

/* Stat cards (mgm-inv, mgm-peti) */
.stat-card {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-left: none !important;
  border-radius: var(--radius) !important;
  padding: 18px 20px !important;
  box-shadow: var(--shadow-card) !important;
  transition: all var(--transition) !important;
  position: relative !important;
  overflow: hidden !important;
}
.stat-card::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important; left: 0 !important; right: 0 !important; bottom: auto !important;
  height: 2px !important;
  width: auto !important;
  border-radius: 2px 2px 0 0 !important;
  background: var(--gold) !important;
}
.stat-card:hover { transform: translateY(-2px) !important; box-shadow: var(--shadow-hover) !important; }
.stat-card.primary::before  { background: linear-gradient(90deg, var(--purple-mid), var(--purple)) !important; }
.stat-card.success::before  { background: linear-gradient(90deg, #047857, var(--success)) !important; }
.stat-card.warning::before  { background: linear-gradient(90deg, #B45309, var(--warning)) !important; }
.stat-card.danger::before, .stat-card.sin-stock::before { background: linear-gradient(90deg, #B91C1C, var(--danger)) !important; }
.stat-label { font-size: 10.5px !important; font-weight: 600 !important; color: var(--text-3) !important; text-transform: uppercase !important; letter-spacing: 0.7px !important; margin-bottom: 8px !important; }
.stat-value { font-family: 'Space Grotesk', 'Inter', sans-serif !important; font-size: 28px !important; font-weight: 700 !important; color: var(--text-1) !important; line-height: 1 !important; letter-spacing: -0.8px !important; }
.stat-card.primary .stat-value { color: var(--purple) !important; }
.stat-card.success .stat-value { color: var(--success) !important; }
.stat-card.warning .stat-value { color: var(--warning) !important; }
.stat-card.danger .stat-value, .stat-card.sin-stock .stat-value { color: var(--danger) !important; }

/* ══════════════════════════════════════
   CARDS GENERALES
   ══════════════════════════════════════ */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 24px;
  box-shadow: var(--shadow-card);
  margin-bottom: 16px;
}

/* ══════════════════════════════════════
   TABLAS
   ══════════════════════════════════════ */
.table-container {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  overflow-x: auto;
}

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

thead th {
  background: var(--surface-2) !important;
  color: var(--text-3) !important;
  padding: 11px 14px !important;
  text-align: left !important;
  font-size: 10.5px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.7px !important;
  border-bottom: 1px solid var(--border-hi) !important;
  white-space: nowrap !important;
}

tbody td {
  padding: 11px 14px !important;
  font-size: 13px !important;
  color: var(--text-2) !important;
  border-bottom: 1px solid var(--border) !important;
}
tbody tr:last-child td { border-bottom: none !important; }
tbody tr:hover td {
  background: var(--surface-2) !important;
  color: var(--text-1) !important;
}

.table-header, .records-table .table-header {
  background: var(--surface-2) !important;
  color: var(--text-3) !important;
  padding: 12px 16px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.8px !important;
  border-bottom: 1px solid var(--border) !important;
}

/* ══════════════════════════════════════
   FORMULARIOS
   ══════════════════════════════════════ */
input[type="text"],
input[type="email"],
input[type="number"],
input[type="date"],
input[type="search"],
input[type="password"],
input[type="tel"],
input[type="time"],
select,
textarea {
  width: 100%;
  padding: 10px 14px;
  border: 1px solid var(--border-hi) !important;
  border-radius: var(--radius-sm) !important;
  font-size: 14px;
  font-family: 'Inter', sans-serif;
  background: var(--surface-2) !important;
  color: var(--text-1) !important;
  transition: border-color var(--transition), box-shadow var(--transition);
}
input:focus, select:focus, textarea:focus {
  outline: none !important;
  border-color: var(--purple) !important;
  box-shadow: 0 0 0 3px var(--purple-dim) !important;
  background: var(--surface) !important;
}
input::placeholder, textarea::placeholder { color: var(--text-3); }

label {
  display: block;
  margin-bottom: 6px;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-2);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* ══════════════════════════════════════
   MODALES
   ══════════════════════════════════════ */
.modal {
  background: rgba(30,27,46,0.5) !important;
  backdrop-filter: blur(4px) !important;
  -webkit-backdrop-filter: blur(4px) !important;
}

.modal-content {
  background: var(--surface) !important;
  border: 1px solid var(--border-hi) !important;
  border-radius: var(--radius) !important;
  box-shadow: 0 20px 60px rgba(124,58,237,0.18) !important;
}

.modal-header {
  background: var(--surface) !important;
  border-bottom: 1px solid var(--border) !important;
  padding: 18px 24px !important;
}
.modal-header h2, .modal-header h3 {
  font-family: 'Space Grotesk', 'Inter', sans-serif !important;
  font-size: 17px !important;
  font-weight: 700 !important;
  color: var(--text-1) !important;
}

.modal-close {
  width: 32px !important; height: 32px !important;
  background: var(--surface-2) !important;
  border: 1px solid var(--border-hi) !important;
  border-radius: 8px !important;
  color: var(--text-3) !important;
  cursor: pointer !important;
  font-size: 18px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: all var(--transition) !important;
}
.modal-close:hover {
  background: var(--danger-dim) !important;
  color: var(--danger) !important;
  border-color: var(--danger) !important;
}

.modal-body { padding: 20px 24px !important; }

.modal-footer {
  background: var(--surface) !important;
  border-top: 1px solid var(--border) !important;
  padding: 16px 24px !important;
  display: flex !important;
  gap: 10px !important;
  justify-content: flex-end !important;
}

/* ══════════════════════════════════════
   FILTROS / CONTROLES
   ══════════════════════════════════════ */
.filters, .controls {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 16px;
  background: var(--surface);
  padding: 12px 16px;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-card);
}

/* ══════════════════════════════════════
   LOADING
   ══════════════════════════════════════ */
.loading {
  text-align: center;
  padding: 60px 20px;
  color: var(--text-3);
}
.loading-spinner {
  width: 36px !important; height: 36px !important;
  border: 2px solid var(--border-hi) !important;
  border-top-color: var(--purple) !important;
  border-radius: 50% !important;
  animation: spin 0.7s linear infinite !important;
  margin: 0 auto 14px !important;
  box-shadow: 0 0 10px var(--purple-glow) !important;
}
.loading p { font-size: 13px; color: var(--text-3); }

/* ══════════════════════════════════════
   BADGES
   ══════════════════════════════════════ */
.badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 50px;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.3px;
}

/* ══════════════════════════════════════
   ICON BUTTONS
   ══════════════════════════════════════ */
.icon-btn {
  width: 32px; height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-xs);
  border: 1px solid var(--border-hi);
  background: var(--surface-2);
  color: var(--text-2);
  cursor: pointer;
  font-size: 14px;
  transition: all var(--transition);
}
.icon-btn:hover { background: var(--surface-hover); color: var(--text-1); }

/* ══════════════════════════════════════
   SECTION TITLE (estilo dash)
   ══════════════════════════════════════ */
.section-title {
  font-size: 11px !important;
  font-weight: 600 !important;
  color: var(--text-3) !important;
  text-transform: uppercase !important;
  letter-spacing: 1.2px !important;
  margin-bottom: 12px !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}
.section-title::before {
  content: '' !important;
  width: 6px !important; height: 6px !important;
  border-radius: 50% !important;
  background: var(--purple) !important;
  box-shadow: 0 0 6px var(--purple-glow) !important;
  flex-shrink: 0 !important;
  display: block !important;
}
.section-title::after {
  content: '' !important;
  flex: 1 !important;
  height: 1px !important;
  background: var(--border) !important;
}

/* ══════════════════════════════════════
   SCROLLBAR
   ══════════════════════════════════════ */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--surface-2); }
::-webkit-scrollbar-thumb { background: var(--border-hi); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: rgba(124,58,237,0.3); }

/* ══════════════════════════════════════
   ANIMACIONES
   ══════════════════════════════════════ */
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
}

/* ══════════════════════════════════════
   RESPONSIVE MOBILE
   ══════════════════════════════════════ */
@media (max-width: 700px) {
  .header {
    padding: 14px 16px !important;
    gap: 12px !important;
  }
  .header h1 { font-size: 17px !important; }
  .kpi-value, .stat-value { font-size: 22px !important; }
}

/* ── Quick Nav Dropdown ── */
.quick-nav { position: relative; z-index: 1000; }
.quick-nav-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  background: var(--surface);
  border: 1px solid var(--border-hi);
  border-radius: 50px;
  font-size: 13px;
  font-weight: 600;
  color: var(--purple, #7C3AED);
  cursor: pointer;
  font-family: 'Inter', sans-serif;
  transition: all 0.15s;
  white-space: nowrap;
}
.quick-nav-btn:hover { background: var(--purple-dim, rgba(124,58,237,0.10)); border-color: var(--purple, #7C3AED); }
.quick-nav-btn .chevron { transition: transform 0.2s; }
.quick-nav.open .chevron { transform: rotate(180deg); }
.quick-nav-menu {
  display: none;
  position: fixed;
  background: var(--surface, #fff);
  border: 1px solid var(--border-hi, rgba(124,58,237,0.15));
  border-radius: 14px;
  box-shadow: 0 8px 32px rgba(124,58,237,0.18), 0 2px 8px rgba(0,0,0,0.10);
  padding: 8px;
  min-width: 210px;
  z-index: 99999;
}
.quick-nav.open .quick-nav-menu { display: block; animation: fadeUp 0.15s ease both; }
.qnav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  border-radius: 9px;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-2, #4B4569);
  text-decoration: none;
  transition: background 0.12s, color 0.12s;
}
.qnav-item:hover, .qnav-item.active { background: var(--purple-dim, rgba(124,58,237,0.08)); color: var(--purple, #7C3AED); }
.qnav-item svg { flex-shrink: 0; opacity: 0.65; }
.qnav-item:hover svg, .qnav-item.active svg { opacity: 1; }
.qnav-dash { font-weight: 700 !important; }
.qnav-divider { height: 1px; background: var(--border, rgba(124,58,237,0.08)); margin: 5px 4px; }
