/* ============================================================================
   PULSAR — Estilo de las PANTALLAS DE ACCESO (portada + login)
   Paleta "azul noche / marino", corporativa y sobria (sin iconos).
   Se aplica solo aqui (no toca el tema del resto de la app).
   ============================================================================ */
.acceso {
  /* Paleta navy/marino local */
  --az-noche: #060c1a;
  --az-marino: #0c1f3d;
  --az-superficie: #0f2447;
  --az-superficie2: #13294f;
  --az-borde: #1e3a66;
  --az-borde2: #294a7d;
  --az-texto: #eaf1fb;
  --az-tenue: #9db2d4;
  --az-acento: #3f7fd1;       /* azul corporativo */
  --az-acento-claro: #5a9be6;

  min-height: 100vh;
  margin: 0;
  color: var(--az-texto);
  background: radial-gradient(120% 120% at 50% 0%, #0b1c38 0%, var(--az-noche) 70%);
  font-family: "Segoe UI", Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
}

/* Marca: sobria, en blanco-azulado con un realce sutil (sin verde) */
.acceso .marca {
  color: var(--az-texto);
  letter-spacing: 0.34rem;
  font-weight: 700;
}
.acceso .marca-acento { color: var(--az-acento-claro); }

/* --- Tarjeta central (login y bloques de la portada) --- */
.acc-card {
  width: min(92vw, 380px);
  margin: 0 auto;
  background: linear-gradient(180deg, var(--az-superficie) 0%, var(--az-marino) 100%);
  border: 1px solid var(--az-borde);
  border-radius: 16px;
  padding: 2rem 1.9rem;
  box-shadow: 0 18px 50px rgba(0, 0, 0, 0.45);
}
.acc-titulo { font-size: 2.4rem; margin: 0; text-align: center; }
.acc-sub { color: var(--az-tenue); margin: 0.3rem 0 1.4rem; text-align: center; font-size: 0.95rem; letter-spacing: 0.02rem; }

/* --- Formularios --- */
.acc-form { display: flex; flex-direction: column; gap: 0.85rem; text-align: left; }
.acc-form label { display: flex; flex-direction: column; gap: 0.3rem; font-size: 0.8rem; color: var(--az-tenue); letter-spacing: 0.02rem; }
.acceso input {
  padding: 0.7rem 0.8rem; border-radius: 10px; border: 1px solid var(--az-borde2);
  background: rgba(3, 9, 20, 0.55); color: var(--az-texto); font-size: 1rem; width: 100%;
}
.acceso input::placeholder { color: #5e7397; }
.acceso input:focus { outline: none; border-color: var(--az-acento-claro); box-shadow: 0 0 0 3px rgba(63, 127, 209, 0.25); }

/* Boton principal (azul corporativo, lleno) */
.acc-btn {
  margin-top: 0.5rem; padding: 0.8rem; border-radius: 11px; border: none;
  background: linear-gradient(180deg, var(--az-acento-claro), var(--az-acento));
  color: #fff; font-weight: 600; font-size: 1.02rem; letter-spacing: 0.02rem; cursor: pointer;
  transition: filter 0.15s;
}
.acc-btn:hover { filter: brightness(1.08); }
.acc-btn:disabled { opacity: 0.55; cursor: default; }

/* Boton secundario (contorno) */
.acc-btn-sec {
  padding: 0.75rem 1rem; border-radius: 11px; cursor: pointer; font-size: 0.98rem;
  background: transparent; color: var(--az-texto); border: 1px solid var(--az-borde2);
  width: 100%; transition: border-color 0.15s, background 0.15s;
}
.acc-btn-sec:hover { border-color: var(--az-acento-claro); background: rgba(63, 127, 209, 0.08); }

.acc-error { color: #ff8e8e; font-size: 0.85rem; min-height: 1em; text-align: center; }

/* Enlaces de navegacion (cambiar de modo, volver) */
.acc-link { background: none; border: none; color: var(--az-acento-claro); cursor: pointer; font-size: 0.88rem; padding: 0; }
.acc-link:hover { text-decoration: underline; }
.acc-pie { margin-top: 1.2rem; text-align: center; font-size: 0.85rem; color: var(--az-tenue); }
.acc-pie a { color: var(--az-tenue); }
.acc-sep { height: 1px; background: var(--az-borde); margin: 1.1rem 0; border: none; }

/* --- Portada --- */
.acc-portada { display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: 100vh; padding: 1.4rem; gap: 0.4rem; }
.acc-marca-grande { font-size: clamp(2.6rem, 9vw, 4.2rem); margin: 0; }
.acc-lema { color: var(--az-tenue); margin: 0.2rem 0 1.6rem; font-size: 1rem; letter-spacing: 0.03rem; }
.acc-grupo { margin-top: 1.1rem; }
.acc-grupo-tit { color: var(--az-tenue); font-weight: 600; font-size: 0.82rem; letter-spacing: 0.06rem; text-transform: uppercase; margin: 0 0 0.5rem; }
.acc-codigo { letter-spacing: 0.35rem; text-transform: uppercase; text-align: center; }
.acc-roles { display: flex; gap: 0.6rem; }
.acc-roles .acc-btn-sec { flex: 1 1 0; }
