/*
  Estilos del panel ERP (tema oscuro).
  Colores:
  - Fondo: #0f172a
  - Panels: #1e293b
  - Acento: #06b6d4
*/

:root {
  --erp-bg: #040404;
  --erp-panel: #01284f;
  --erp-accent: #00b5fa;
  --erp-accent2: #0055b2;
  --erp-text: #e4e2e3;
  --erp-text2: #646567;
  --erp-success: #22c55e;
  --erp-danger: #ef4444;
  --erp-warning: #f59e0b;
  --erp-border: rgba(0, 181, 250, 0.22);
}

body.erp {
  background: var(--erp-bg);
  color: var(--erp-text);
}

.btn-erp-cyan {
  background: rgba(0, 181, 250, 0.18);
  border-color: rgba(0, 181, 250, 0.40);
  color: var(--erp-text);
  font-weight: 800;
}

.btn-erp-cyan:hover {
  filter: brightness(1.08);
  color: var(--erp-text);
}

.erp-login-subtitle {
  color: var(--erp-text2);
}

.erp-login-error {
  background: rgba(239, 68, 68, 0.12);
  border: 1px solid rgba(239, 68, 68, 0.35);
  color: #fecaca;
}

.erp-input {
  background: rgba(1, 40, 79, 0.45);
  border: 1px solid rgba(100, 101, 103, 0.35);
  color: var(--erp-text);
}

.erp-input:focus {
  background: rgba(1, 40, 79, 0.60);
  border-color: rgba(0, 127, 182, 0.85);
  box-shadow: 0 0 0 0.2rem rgba(0, 181, 250, 0.14);
  color: var(--erp-text);
}

.erp-check .form-check-input {
  background-color: rgba(1, 40, 79, 0.45);
  border-color: rgba(100, 101, 103, 0.45);
}

.erp-check .form-check-input:checked {
  background-color: rgba(0, 181, 250, 0.95);
  border-color: rgba(0, 181, 250, 0.95);
}

.erp-avatar {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background: rgba(0, 181, 250, 0.18);
  border: 1px solid rgba(0, 181, 250, 0.40);
  color: var(--erp-text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  letter-spacing: 0.04em;
}

.erp-sidebar {
  position: fixed;
  inset: 0 auto 0 0;
  width: 240px;
  background: var(--erp-bg);
  border-right: 1px solid rgba(100, 101, 103, 0.35);
  z-index: 1030;
  overflow-y: auto;
}

.erp-sidebar .brand {
  height: 64px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 16px;
  border-bottom: 1px solid rgba(100, 101, 103, 0.35);
}

.erp-sidebar .brand .logo {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  background: rgba(1, 40, 79, 0.85);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--erp-accent);
}

.erp-sidebar .brand .name {
  font-weight: 800;
  letter-spacing: 0.3px;
}

.erp-sidebar .nav-section {
  padding: 14px 12px 6px;
  color: var(--erp-text2);
  font-size: 0.75rem;
  letter-spacing: 0.12em;
}

.erp-sidebar .nav a {
  color: var(--erp-text);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 10px;
  margin: 4px 8px;
}

.erp-sidebar .nav a .bi {
  color: var(--erp-text2);
}

.erp-sidebar .nav a:hover {
  background: rgba(30, 41, 59, 0.8);
}

.erp-sidebar .nav a.active {
  background: rgba(6, 182, 212, 0.12);
  border: 1px solid var(--erp-border);
}

.erp-sidebar .nav a.active .bi {
  color: var(--erp-accent);
}

.erp-sidebar .badge-soon {
  background: rgba(148, 163, 184, 0.15);
  color: var(--erp-text2);
  border: 1px solid rgba(148, 163, 184, 0.2);
}

.erp-main {
  margin-left: 240px;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.erp-navbar {
  position: sticky;
  top: 0;
  z-index: 1020;
  background: var(--erp-panel);
  border-bottom: 1px solid rgba(148, 163, 184, 0.15);
}

.erp-navbar .page-title {
  font-weight: 700;
}

.erp-card {
  background: var(--erp-panel);
  border: 1px solid var(--erp-border);
  border-radius: 14px;
}

.erp-metric {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.erp-metric .label {
  color: var(--erp-text2);
  font-size: 0.85rem;
}

.erp-metric .value {
  font-size: 1.4rem;
  font-weight: 800;
}

.erp-metric .trend {
  color: var(--erp-accent);
  font-size: 0.85rem;
}

.erp-table {
  color: var(--erp-text);
}

.erp-table thead th {
  color: var(--erp-text2);
  border-bottom-color: rgba(148, 163, 184, 0.18);
}

.erp-table tbody td {
  border-top-color: rgba(148, 163, 184, 0.12);
}

.badge-estado {
  font-weight: 700;
}

.badge-aceptado {
  background: rgba(34, 197, 94, 0.15);
  border: 1px solid rgba(34, 197, 94, 0.3);
  color: var(--erp-success);
}

.badge-pendiente {
  background: rgba(245, 158, 11, 0.15);
  border: 1px solid rgba(245, 158, 11, 0.3);
  color: var(--erp-warning);
}

.badge-rechazado {
  background: rgba(239, 68, 68, 0.15);
  border: 1px solid rgba(239, 68, 68, 0.3);
  color: var(--erp-danger);
}

.erp-actions .btn {
  border-radius: 12px;
  padding: 12px 14px;
  font-weight: 700;
}

.erp-actions .btn-primary {
  background: rgba(59, 130, 246, 0.18);
  border-color: rgba(59, 130, 246, 0.35);
  color: #dbeafe;
}

.erp-actions .btn-accent {
  background: rgba(6, 182, 212, 0.18);
  border-color: rgba(6, 182, 212, 0.35);
  color: #cffafe;
}

.erp-actions .btn-success {
  background: rgba(34, 197, 94, 0.18);
  border-color: rgba(34, 197, 94, 0.35);
  color: #dcfce7;
}

.erp-actions .btn:hover {
  filter: brightness(1.08);
}

.erp-footer {
  color: var(--erp-text2);
  padding: 16px 0;
}

@media (max-width: 992px) {
  .erp-sidebar {
    transform: translateX(-100%);
    transition: transform 180ms ease-in-out;
  }
  .erp-sidebar.open {
    transform: translateX(0);
  }
  .erp-main {
    margin-left: 0;
  }
}
