/* === auth.css === */

/* Clase utilitaria global — oculta cualquier elemento */
.hidden { display: none !important; }

/* ── LOGIN OVERLAY ── */
#login-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: var(--bg);
  display: flex; align-items: center; justify-content: center;
}
#login-overlay.hidden { display: none; }
.login-card {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--r2); padding: 40px 36px;
  width: 360px; max-width: 95vw;
  box-shadow: var(--shadow);
}
.login-logo {
  font-family: var(--font-head); font-size: 2rem; font-weight: 800;
  color: var(--amber); text-align: center; margin-bottom: 8px;
  letter-spacing: 1px;
  display: flex; align-items: center; justify-content: center; gap: 10px;
}
.login-logo-img { width: 40px; height: 40px; object-fit: contain; }
.login-subtitle { text-align: center; color: var(--text2); font-size: .88rem; margin-bottom: 28px; }
.login-error {
  background: var(--red-dim); border: 1px solid var(--red);
  color: var(--red); border-radius: var(--r); padding: 8px 12px;
  font-size: .85rem; margin-bottom: 14px; display: none;
}
.login-error.show { display: block; }

/* ── NAV USER INFO ── */
.nav-user {
  display: flex; align-items: center; gap: 8px;
  padding: 4px 10px; border-radius: var(--r);
  background: var(--bg3); border: 1px solid var(--border2);
  font-size: .82rem; cursor: default;
}
.nav-user-name { color: var(--text); font-weight: 600; }
.nav-user-role {
  font-size: .72rem; padding: 1px 6px; border-radius: 10px;
  font-weight: 700; text-transform: uppercase; letter-spacing: .4px;
}
.role-admin  { background: rgba(245,158,11,.2); color: var(--amber); }
.role-operator { background: var(--blue-dim); color: var(--blue); }
.role-viewer { background: var(--green-dim); color: var(--green); }

/* ── PERMISOS GRID ── */
.perm-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 10px; margin-top: 12px;
}
.perm-row {
  background: var(--bg3); border: 1px solid var(--border);
  border-radius: var(--r); padding: 10px 14px;
  display: flex; align-items: center; justify-content: space-between;
}
.perm-resource { font-weight: 600; font-size: .88rem; text-transform: capitalize; }
.perm-checks { display: flex; gap: 12px; }
.perm-check { display: flex; align-items: center; gap: 4px; font-size: .8rem; color: var(--text2); cursor: pointer; }
.perm-check input { accent-color: var(--amber); cursor: pointer; }

/* ── PERMISSION BADGE ── */
.perm-disabled { opacity: .4; pointer-events: none; }
