/* ═══════════════════════════════════════════════════════════════════════
   Login & Landing — Tareas LP · Avanzar Soluciones
   Hereda variables base de estilos.css y extiende paleta con acentos neón.
   ═══════════════════════════════════════════════════════════════════════ */

:root {
  /* Acento cian extendido (mantenido como secundario corporativo) */
  --cian-br:       #22D3EE;

  /* Gradientes oficiales Avanzar */
  --grad-corp:     linear-gradient(135deg, #002855 0%, #D2232A 100%); /* firma azul→rojo */
  --grad-hero:     linear-gradient(135deg, #001A38 0%, #002855 45%, #D2232A 100%);
  --grad-acento:   linear-gradient(135deg, #002855 0%, #0891B2 100%);
  --grad-cian:     linear-gradient(135deg, #0891B2 0%, #22D3EE 100%);
  --grad-glass:    linear-gradient(135deg, rgba(255,255,255,.08) 0%, rgba(255,255,255,.02) 100%);

  /* Sombras con tinte corporativo */
  --s-glow-azul:   0 8px 32px rgba(0,40,85,.28), 0 0 0 1px rgba(255,255,255,.06) inset;
  --s-glow-rojo:   0 0 24px rgba(210,35,42,.35);
  --s-glow-cian:   0 0 24px rgba(8,145,178,.4);
}

* { box-sizing: border-box; }

/* ─── Base / Body ──────────────────────────────────────────────────────── */
body.login-body {
  margin: 0;
  font-family: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  color: var(--txt-1);
  background: var(--bg);
  min-height: 100vh;
  overflow-x: hidden;
}

/* Fondo decorativo con orbes */
.bg-orbes {
  position: fixed;
  inset: 0;
  z-index: -1;
  overflow: hidden;
  pointer-events: none;
}
.orbe {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: .42;
  animation: orbe-flota 18s ease-in-out infinite;
}
.orbe--1 { top: -120px;  left:  -80px; width: 480px; height: 480px;
           background: radial-gradient(circle, var(--azul) 0%, transparent 70%); }
.orbe--2 { top:  20%;    right: -120px; width: 520px; height: 520px;
           background: radial-gradient(circle, var(--rojo) 0%, transparent 70%);
           animation-delay: -6s; }
.orbe--3 { bottom: -160px; left: 30%;   width: 420px; height: 420px;
           background: radial-gradient(circle, var(--cian) 0%, transparent 70%);
           animation-delay: -12s; }

@keyframes orbe-flota {
  0%, 100% { transform: translate(0,0) scale(1); }
  33%      { transform: translate(40px, -30px) scale(1.05); }
  66%      { transform: translate(-30px, 40px) scale(.95); }
}

/* Grid decorativo de fondo */
.bg-grid {
  position: fixed;
  inset: 0;
  z-index: -1;
  background-image:
    linear-gradient(rgba(26,58,107,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(26,58,107,.04) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
}

/* ─── Navbar ───────────────────────────────────────────────────────────── */
.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(18px) saturate(180%);
  -webkit-backdrop-filter: blur(18px) saturate(180%);
  background: rgba(255,255,255,.72);
  border-bottom: 1px solid var(--borde);
  transition: background var(--mid);
}
[data-theme="dark"] .nav { background: rgba(20,29,48,.72); }

.nav__inner {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 28px;
}

.nav__brand {
  display: flex;
  align-items: center;
  text-decoration: none;
  color: var(--txt-1);
  transition: transform var(--fast);
}
.nav__brand:hover { transform: scale(1.03); }
.nav__logo {
  height: 52px;
  width: auto;
  filter: var(--logo-filter);
}

.nav__links {
  display: flex;
  align-items: center;
  gap: 6px;
}
.nav__link {
  position: relative;
  padding: 8px 14px;
  border-radius: var(--r-pill);
  color: var(--txt-2);
  font-size: .88rem;
  font-weight: 600;
  text-decoration: none;
  transition: color var(--fast), background var(--fast);
  cursor: pointer;
  background: none;
  border: none;
  font-family: inherit;
}
.nav__link:hover { color: var(--azul); background: var(--azul-lt); }

.nav__cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  border-radius: var(--r-pill);
  background: var(--grad-corp);
  color: #fff;
  font-weight: 700;
  font-size: .88rem;
  text-decoration: none;
  border: none;
  cursor: pointer;
  box-shadow: 0 4px 16px rgba(210,35,42,.3);
  transition: transform var(--fast), box-shadow var(--fast), filter var(--fast);
}
.nav__cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(210,35,42,.45), 0 2px 8px rgba(0,40,85,.3);
  filter: brightness(1.05);
}

/* ─── Hero ─────────────────────────────────────────────────────────────── */
.hero {
  position: relative;
  padding: 80px 28px 60px;
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 56px;
  align-items: center;
}

.hero__chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  border-radius: var(--r-pill);
  background: var(--rojo-lt);
  color: var(--rojo);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  margin-bottom: 20px;
  border: 1px solid rgba(210,35,42,.25);
}
.hero__chip-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--rojo);
  box-shadow: 0 0 8px var(--rojo);
  animation: pulse 1.8s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: .5; transform: scale(.8); }
}

.hero__titulo {
  font-size: clamp(2rem, 4.2vw, 3.2rem);
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -.02em;
  margin: 0 0 18px;
  color: var(--txt-1);
}
.hero__titulo-acento {
  background: var(--grad-corp);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

.hero__desc {
  font-size: 1.05rem;
  line-height: 1.6;
  color: var(--txt-2);
  margin: 0 0 24px;
  max-width: 540px;
}

.hero__frases {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 32px;
}
.hero__frase {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: .92rem;
  color: var(--txt-1);
  font-weight: 500;
}
.hero__frase-ico {
  flex-shrink: 0;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--grad-corp);
  display: grid; place-items: center;
  color: #fff;
}

.hero__stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  max-width: 420px;
}
.hero__stat {
  padding: 14px 16px;
  background: var(--surface);
  border: 1px solid var(--borde);
  border-radius: var(--r-md);
  transition: transform var(--mid), box-shadow var(--mid), border-color var(--mid);
}
.hero__stat:hover {
  transform: translateY(-3px);
  box-shadow: var(--s2);
  border-color: var(--azul-md);
}
.hero__stat-val {
  font-size: 1.45rem;
  font-weight: 800;
  background: var(--grad-acento);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.hero__stat-lbl {
  font-size: .72rem;
  color: var(--txt-3);
  text-transform: uppercase;
  letter-spacing: .04em;
  font-weight: 600;
}

/* ─── Mock dashboard del hero ──────────────────────────────────────────── */
.mock {
  position: relative;
  perspective: 1200px;
}
.mock__card {
  background: var(--surface);
  border: 1px solid var(--borde);
  border-radius: var(--r-xl);
  box-shadow: var(--s3);
  padding: 18px;
  transform: rotateY(-6deg) rotateX(4deg);
  transition: transform var(--mid);
}
.mock__card:hover { transform: rotateY(-3deg) rotateX(2deg); }

.mock__hd {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--borde);
}
.mock__titulo { font-size: .8rem; font-weight: 700; color: var(--txt-1); }
.mock__chips { display: flex; gap: 6px; }
.mock__chip {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--azul-md);
}
.mock__chip:nth-child(1) { background: #FCA5A5; }
.mock__chip:nth-child(2) { background: #FCD34D; }
.mock__chip:nth-child(3) { background: #6EE7B7; }

.mock__filas { display: flex; flex-direction: column; gap: 10px; }
.mock__fila {
  display: flex; align-items: center; gap: 12px;
  padding: 10px;
  border-radius: var(--r-md);
  background: var(--surface-2);
  transition: background var(--fast);
}
.mock__fila:hover { background: var(--azul-lt); }
.mock__avatar {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--grad-corp);
  flex-shrink: 0;
  display: grid; place-items: center;
  color: #fff;
  font-weight: 700;
  font-size: .72rem;
}
.mock__avatar--2 { background: var(--grad-acento); }
.mock__avatar--3 { background: linear-gradient(135deg, var(--rojo) 0%, var(--azul) 100%); }
.mock__info { flex: 1; }
.mock__nombre { font-size: .78rem; font-weight: 600; color: var(--txt-1); }
.mock__dato   { font-size: .68rem; color: var(--txt-3); }
.mock__estado {
  font-size: .65rem;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: var(--r-pill);
  letter-spacing: .04em;
  text-transform: uppercase;
}
.mock__estado--ok    { background: var(--ok-bg);   color: var(--ok); }
.mock__estado--warn  { background: var(--warn-bg); color: var(--warn); }
.mock__estado--neon  { background: var(--rojo-lt); color: var(--rojo); }

.mock__barra-wrap {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--borde);
}
.mock__barra-lbl { display: flex; justify-content: space-between; font-size: .68rem; color: var(--txt-3); margin-bottom: 6px; font-weight: 600; }
.mock__barra {
  width: 100%; height: 6px; border-radius: var(--r-pill);
  background: var(--surface-2);
  overflow: hidden;
}
.mock__barra-fill {
  height: 100%;
  width: 73%;
  background: var(--grad-corp);
  border-radius: var(--r-pill);
  animation: barra-grow 1.6s var(--ease) forwards;
}
@keyframes barra-grow {
  from { width: 0; }
  to   { width: 73%; }
}

/* Glow flotante detrás del mock */
.mock::before {
  content: '';
  position: absolute;
  inset: -40px;
  background: radial-gradient(ellipse at center, rgba(210,35,42,.22), transparent 70%);
  filter: blur(40px);
  z-index: -1;
}

/* ─── Sección Login (split) ────────────────────────────────────────────── */
.login-section {
  position: relative;
  padding: 60px 28px;
  background:
    linear-gradient(180deg, transparent 0%, rgba(26,58,107,.04) 50%, transparent 100%);
}

.login-grid {
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  align-items: stretch;
}

/* Tarjeta del form */
.login-card {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--borde);
  border-radius: var(--r-xl);
  box-shadow: var(--s3);
  padding: 40px 36px 32px;
  overflow: hidden;
  transition: transform var(--mid), box-shadow var(--mid);
}
.login-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--s3), var(--s-glow-rojo);
}
.login-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--grad-corp);
}

.login-card__hd {
  margin-bottom: 24px;
}
.login-card__chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px;
  border-radius: var(--r-pill);
  background: var(--cian-lt);
  color: var(--cian);
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-bottom: 14px;
}

.login-titulo {
  margin: 0 0 6px;
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--txt-1);
  letter-spacing: -.01em;
}
.login-sub {
  margin: 0;
  font-size: .9rem;
  color: var(--txt-2);
}

.login-alerta {
  display: flex; align-items: flex-start; gap: 10px;
  background: var(--dan-bg);
  color: var(--danger);
  border: 1px solid rgba(220,38,38,.25);
  border-radius: var(--r-md);
  padding: 10px 12px;
  font-size: .85rem;
  margin-bottom: 16px;
  animation: shake .35s var(--ease);
}
.login-alerta svg { flex-shrink: 0; margin-top: 1px; }
@keyframes shake {
  0%, 100% { transform: translateX(0); }
  20%, 60% { transform: translateX(-5px); }
  40%, 80% { transform: translateX(5px); }
}

.login-form { display: flex; flex-direction: column; }

.login-label {
  font-size: .78rem;
  font-weight: 700;
  color: var(--txt-2);
  margin-bottom: 6px;
  margin-top: 14px;
  letter-spacing: .03em;
  text-transform: uppercase;
}
.login-label:first-of-type { margin-top: 0; }

.login-input-wrap {
  position: relative;
}
.login-input-ico {
  position: absolute;
  left: 14px; top: 50%;
  transform: translateY(-50%);
  color: var(--txt-3);
  pointer-events: none;
  transition: color var(--fast);
}
.login-input {
  width: 100%;
  font: inherit;
  font-size: .94rem;
  color: var(--txt-1);
  background: var(--surface-2);
  border: 1.5px solid var(--borde-md);
  border-radius: var(--r-md);
  padding: 12px 14px 12px 44px;
  outline: none;
  transition: all var(--fast);
}
.login-input:hover { border-color: var(--azul-md); }
.login-input:focus {
  border-color: var(--azul);
  background: var(--surface);
  box-shadow: 0 0 0 4px rgba(26,58,107,.12);
}
.login-input:focus ~ .login-input-ico { color: var(--azul); }

.login-pass-toggle {
  position: absolute;
  right: 10px; top: 50%;
  transform: translateY(-50%);
  background: transparent;
  border: none;
  color: var(--txt-3);
  cursor: pointer;
  padding: 6px;
  border-radius: var(--r-sm);
  display: grid; place-items: center;
  transition: color var(--fast), background var(--fast);
}
.login-pass-toggle:hover { color: var(--azul); background: var(--azul-lt); }

.login-submit {
  margin-top: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--grad-corp);
  color: #fff;
  text-decoration: none;
  border: none;
  border-radius: var(--r-md);
  font: inherit;
  font-weight: 700;
  font-size: .95rem;
  padding: 14px 18px;
  cursor: pointer;
  box-shadow: 0 4px 16px rgba(210,35,42,.3);
  transition: transform var(--fast), box-shadow var(--fast), filter var(--fast);
}
.login-submit:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(210,35,42,.45), 0 2px 8px rgba(0,40,85,.3);
  filter: brightness(1.05);
}
.login-submit:active { transform: translateY(0); filter: brightness(.98); }

.login-pie {
  text-align: center;
  font-size: .76rem;
  color: var(--txt-3);
  margin: 18px 0 0;
}
.login-pie strong { color: var(--azul); }

/* ─── Lateral derecho: timeline post-login ─────────────────────────────── */
.login-side {
  position: relative;
  padding: 36px 32px;
  background: var(--grad-hero);
  border-radius: var(--r-xl);
  color: #fff;
  overflow: hidden;
  transition: transform var(--mid), box-shadow var(--mid);
}
.login-side:hover {
  transform: translateY(-4px);
  box-shadow: var(--s-glow-azul), 0 20px 40px rgba(109,40,217,.25);
}

.login-side::before {
  content: '';
  position: absolute;
  top: -40%; right: -20%;
  width: 320px; height: 320px;
  background: radial-gradient(circle, rgba(210,35,42,.32) 0%, transparent 70%);
  filter: blur(40px);
  pointer-events: none;
}

.login-side__chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 12px;
  border-radius: var(--r-pill);
  background: rgba(34,211,238,.16);
  color: var(--cian-br);
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  border: 1px solid rgba(34,211,238,.4);
  margin-bottom: 16px;
  position: relative;
}

.login-side__titulo {
  margin: 0 0 8px;
  font-size: 1.4rem;
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: -.01em;
  position: relative;
}
.login-side__sub {
  margin: 0 0 26px;
  font-size: .88rem;
  color: rgba(255,255,255,.78);
  line-height: 1.5;
  position: relative;
}

/* Timeline */
.timeline {
  position: relative;
  padding-left: 28px;
}
.timeline::before {
  content: '';
  position: absolute;
  left: 10px; top: 8px; bottom: 8px;
  width: 2px;
  background: linear-gradient(180deg, var(--cian-br) 0%, var(--rojo) 100%);
  opacity: .55;
}

.timeline__paso {
  position: relative;
  padding-bottom: 18px;
}
.timeline__paso:last-child { padding-bottom: 0; }

.timeline__num {
  position: absolute;
  left: -28px; top: 0;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--grad-corp);
  display: grid; place-items: center;
  font-size: .65rem;
  font-weight: 800;
  color: #fff;
  border: 2px solid rgba(15,35,71,.95);
  box-shadow: var(--s-glow-cian);
}

.timeline__titulo {
  font-size: .92rem;
  font-weight: 700;
  margin-bottom: 4px;
  display: flex; align-items: center; gap: 8px;
}
.timeline__titulo svg { color: var(--cian-br); }

.timeline__desc {
  font-size: .8rem;
  color: rgba(255,255,255,.7);
  line-height: 1.5;
}

/* ─── Sección de features ──────────────────────────────────────────────── */
.features {
  max-width: 1280px;
  margin: 0 auto;
  padding: 80px 28px;
}

.features__hd {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 48px;
}
.features__chip {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 14px;
  border-radius: var(--r-pill);
  background: var(--cian-lt);
  color: var(--cian);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  margin-bottom: 16px;
}
.features__titulo {
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  font-weight: 800;
  letter-spacing: -.02em;
  margin: 0 0 12px;
}
.features__sub {
  font-size: 1rem;
  color: var(--txt-2);
  line-height: 1.6;
  margin: 0;
}

.features__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 18px;
}

.feat-card {
  position: relative;
  padding: 24px;
  background: var(--surface);
  border: 1px solid var(--borde);
  border-radius: var(--r-lg);
  transition: transform var(--mid), box-shadow var(--mid), border-color var(--mid);
  overflow: hidden;
}
.feat-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 3px;
  background: var(--grad-corp);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--mid);
}
.feat-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--s2);
  border-color: var(--rojo);
}
.feat-card:hover::before { transform: scaleX(1); }

.feat-card__ico {
  width: 48px; height: 48px;
  border-radius: var(--r-md);
  background: var(--azul-lt);
  color: var(--azul);
  display: grid; place-items: center;
  margin-bottom: 16px;
  transition: all var(--mid);
}
.feat-card:hover .feat-card__ico {
  background: var(--grad-corp);
  color: #fff;
  transform: scale(1.08) rotate(-4deg);
}

.feat-card__titulo {
  font-size: 1rem;
  font-weight: 700;
  margin: 0 0 8px;
  color: var(--txt-1);
}
.feat-card__desc {
  font-size: .85rem;
  color: var(--txt-2);
  line-height: 1.5;
  margin: 0;
}

/* ─── Footer ───────────────────────────────────────────────────────────── */
.footer {
  border-top: 1px solid var(--borde);
  padding: 26px 28px;
  text-align: center;
  font-size: .82rem;
  color: var(--txt-3);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}
.footer__cliente { color: var(--txt-3); }
.footer__sep     { color: var(--borde-md); user-select: none; }
.footer__by      { color: var(--txt-2); font-weight: 500; }
.footer__brand {
  margin-left: 4px;
  font-weight: 800;
  text-decoration: none;
  background: var(--grad-corp);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  letter-spacing: -.01em;
  transition: filter var(--fast);
}
.footer__brand:hover { filter: brightness(1.15); }

@media (max-width: 560px) {
  .footer { gap: 6px; padding: 20px 16px; font-size: .76rem; }
  .footer__sep { display: none; }
  .footer__cliente, .footer__by { width: 100%; }
}

/* ─── Scroll reveal ────────────────────────────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .7s var(--ease), transform .7s var(--ease);
}
.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ─── Responsive ───────────────────────────────────────────────────────── */
@media (max-width: 960px) {
  .hero {
    grid-template-columns: 1fr;
    padding: 48px 20px 40px;
    gap: 40px;
  }
  .mock__card { transform: none; }
  .login-grid { grid-template-columns: 1fr; }
  .nav__inner { padding: 12px 18px; }
  .nav__logo { height: 44px; }
  .features { padding: 48px 20px; }
}

@media (max-width: 560px) {
  .hero__stats { grid-template-columns: 1fr 1fr; }
  .login-card  { padding: 28px 22px 24px; }
  .login-side  { padding: 28px 22px; }
  .nav__link   { padding: 6px 10px; font-size: .82rem; }
  .nav__cta    { padding: 8px 14px; font-size: .82rem; }
}

/* ─── Dashboard post-login (versión mínima) ────────────────────────────── */
.dash-tarjeta {
  margin: 22px 0;
  border: 1px solid var(--borde);
  border-radius: var(--r-lg);
  background: var(--surface-2);
  overflow: hidden;
}
.dash-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px;
  border-bottom: 1px solid var(--borde);
  font-size: .9rem;
}
.dash-row:last-child { border-bottom: none; }
.dash-row--col { flex-direction: column; align-items: flex-start; gap: 10px; }

.dash-label {
  color: var(--txt-2);
  font-weight: 700;
  font-size: .76rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.dash-valor { color: var(--txt-1); font-weight: 500; }

.dash-rol {
  display: inline-block;
  padding: 4px 12px;
  border-radius: var(--r-pill);
  font-size: .76rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  background: var(--azul-lt);
  color: var(--azul);
  border: 1px solid var(--azul-md);
}
.dash-rol--superadmin    { background: #FEECEE; color: var(--rojo);   border-color: #f3b9bf; }
.dash-rol--administrador { background: var(--azul-lt); color: var(--azul); border-color: var(--azul-md); }
.dash-rol--admingrupoA   { background: var(--cian-lt); color: var(--cian); border-color: #9bdce5; }
.dash-rol--admingrupoB   { background: var(--warn-bg); color: var(--warn); border-color: #fce3a8; }

.dash-permisos { display: flex; flex-wrap: wrap; gap: 6px; }
.dash-chip {
  background: var(--surface);
  border: 1px solid var(--borde-md);
  color: var(--txt-2);
  font-size: .74rem;
  font-weight: 500;
  padding: 3px 10px;
  border-radius: var(--r-pill);
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
}

.dash-acciones { display: flex; flex-direction: column; gap: 10px; }
.dash-logout {
  text-align: center;
  color: var(--txt-3);
  font-size: .85rem;
  text-decoration: none;
  padding: 8px;
}
.dash-logout:hover { color: var(--rojo); text-decoration: underline; }
