/* ============================================================
   Autoconsulta Lucki Motors — estética "banca limpia"
   Azul marino profundo + blanco, mucho aire, números grandes.
   Tipografía: Sora (títulos/cifras) + Hanken Grotesk (texto).
   El saldo de la bolsa se presenta como tarjeta bancaria.
   Móvil primero.
   ============================================================ */
:root {
  --marino: #0f2e4f;          /* azul marino profundo */
  --marino-2: #16406c;        /* marino claro (gradientes) */
  --acento: #2f7df6;          /* azul vivo */
  --acento-suave: #eaf2fe;
  --fondo: #f6f8fb;           /* blanco azulado */
  --carta: #ffffff;
  --texto: #1a2433;
  --gris: #64748b;
  --borde: #e4e9f1;
  --ok: #177245;       --ok-fondo: #e5f4ec;
  --alerta: #c02626;   --alerta-fondo: #fdebeb;
  --ambar: #a16007;    --ambar-fondo: #fdf3df;
  --azul: #1d5fd1;     --azul-fondo: #e7effd;
  --teal: #0d7d72;     --teal-fondo: #dcf2ef;
  --morado: #6d28a8;   --morado-fondo: #f2eafa;
  --sombra: 0 1px 2px rgba(15, 46, 79, .05), 0 10px 30px rgba(15, 46, 79, .06);
  --sombra-alta: 0 2px 4px rgba(15, 46, 79, .08), 0 16px 40px rgba(15, 46, 79, .14);
}

* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: "Hanken Grotesk", "Helvetica Neue", Arial, sans-serif;
  background: var(--fondo);
  color: var(--texto);
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
}

/* ===== cabecera ===== */
.barra {
  display: flex; justify-content: space-between; align-items: center;
  background: var(--marino); color: #fff; padding: 14px 20px;
}
.marca {
  font-family: "Sora", sans-serif; font-weight: 700;
  font-size: 17px; letter-spacing: -.2px;
}
.marca2 { color: #9cc3f9; font-weight: 500; }
.btn-salir {
  background: rgba(255, 255, 255, .1); color: #fff;
  border: none; border-radius: 99px; padding: 8px 18px;
  font-family: inherit; font-size: 13.5px; font-weight: 600;
  cursor: pointer; transition: background .15s;
}
.btn-salir:hover, .btn-salir:active { background: rgba(255, 255, 255, .22); }

/* línea de acento bajo la cabecera */
.franja {
  height: 3px;
  background: linear-gradient(90deg, var(--acento), #6ea8f8 55%, var(--marino));
}

/* ===== menú ===== */
.menu {
  display: flex; gap: 4px; overflow-x: auto; background: var(--carta);
  border-bottom: 1px solid var(--borde); padding: 8px 12px;
  -webkit-overflow-scrolling: touch; scrollbar-width: none;
  position: sticky; top: 0; z-index: 10;
}
.menu::-webkit-scrollbar { display: none; }
.menu a {
  padding: 8px 15px; white-space: nowrap; text-decoration: none;
  color: var(--gris); font-size: 14px; font-weight: 600;
  border-radius: 99px; transition: background .15s, color .15s;
}
.menu a:hover { color: var(--marino); background: var(--acento-suave); }
.menu a.activo { color: #fff; background: var(--marino); }

.contenido { max-width: 760px; margin: 0 auto; padding: 22px 18px 40px; }

/* ===== tipografía ===== */
h1 {
  font-family: "Sora", sans-serif; font-weight: 700;
  font-size: 22px; margin: 6px 0 4px; letter-spacing: -.4px;
  color: var(--marino);
}
h2 {
  font-family: "Sora", sans-serif; font-weight: 600;
  font-size: 14px; margin: 0 0 12px; color: var(--marino);
  letter-spacing: -.1px;
}
.sub { color: var(--gris); margin: 0 0 18px; font-size: 14px; }
.ayuda { color: var(--gris); font-size: 13px; line-height: 1.6; }
.error {
  background: var(--alerta-fondo); color: var(--alerta);
  border-radius: 10px; padding: 12px 15px; font-size: 14px; font-weight: 500;
}
.aviso {
  background: var(--ambar-fondo); color: var(--ambar);
  border-radius: 10px; padding: 12px 15px; font-size: 14px;
}

/* entrada escalonada al cargar */
@keyframes aparecer {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: none; }
}
.perfil, .tarjetas, .panel, .saldo-grande, .caja-login, .nav-mes, .leyenda, .anio-grid {
  animation: aparecer .4s cubic-bezier(.2, .7, .3, 1) backwards;
}
.tarjetas { animation-delay: .06s; }
.panel { animation-delay: .12s; }
.panel + .panel { animation-delay: .18s; }

/* ===== perfil (inicio) ===== */
.perfil {
  background: var(--carta); border-radius: 18px;
  padding: 20px; margin-bottom: 16px; box-shadow: var(--sombra);
}
.perfil-cabecera { display: flex; gap: 16px; align-items: center; }
.perfil-extra {
  list-style: none; margin: 16px 0 0; padding: 12px 0 0;
  border-top: 1px solid #eef2f7;
}
.perfil-extra li {
  display: flex; justify-content: space-between; gap: 12px;
  padding: 6px 0; font-size: 13.5px;
}
.perfil-extra li span { color: var(--gris); }
.perfil-extra li strong { text-align: right; word-break: break-word; }
.perfil-nota { margin: 8px 0 0; font-size: 12px; }
.avatar {
  width: 58px; height: 58px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg, var(--marino) 0%, var(--acento) 130%);
  color: #fff; font-family: "Sora", sans-serif; font-weight: 700;
  font-size: 20px; display: flex; align-items: center; justify-content: center;
}
.perfil-datos { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.perfil-datos strong {
  font-family: "Sora", sans-serif; font-size: 16px;
  line-height: 1.3; color: var(--marino);
}
.perfil-cargo { font-size: 13px; color: var(--gris); font-weight: 500; }
.perfil-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 7px; }
.chip-dato {
  background: var(--acento-suave); color: var(--azul);
  border-radius: 99px; padding: 3px 11px; font-size: 11.5px;
  font-weight: 600; white-space: nowrap;
}

/* ===== tarjetas resumen ===== */
.tarjetas {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin: 16px 0;
}
.tarjeta {
  background: var(--carta); border-radius: 16px; padding: 16px;
  text-decoration: none; color: inherit;
  display: flex; flex-direction: column; gap: 3px;
  box-shadow: var(--sombra);
  transition: transform .15s, box-shadow .15s;
}
a.tarjeta:hover { transform: translateY(-2px); box-shadow: var(--sombra-alta); }
a.tarjeta:active { transform: scale(.98); }
.dato {
  font-family: "Sora", sans-serif; font-weight: 700;
  font-size: 26px; letter-spacing: -.6px; color: var(--marino);
  font-variant-numeric: tabular-nums; line-height: 1.15;
}
.etiqueta { font-size: 12.5px; color: var(--gris); font-weight: 500; }

/* saldo como tarjeta bancaria */
.saldo-grande {
  position: relative; overflow: hidden;
  background: linear-gradient(130deg, var(--marino) 0%, var(--marino-2) 55%, #1d5288 100%);
  color: #fff; border-radius: 20px; padding: 30px 26px;
  text-align: center; margin: 16px 0;
  display: flex; flex-direction: column; gap: 5px;
  box-shadow: var(--sombra-alta);
}
.saldo-grande::before, .saldo-grande::after {
  content: ""; position: absolute; border-radius: 50%;
  background: rgba(255, 255, 255, .05);
}
.saldo-grande::before { width: 220px; height: 220px; top: -120px; right: -60px; }
.saldo-grande::after  { width: 150px; height: 150px; bottom: -80px; left: -40px;
  background: rgba(47, 125, 246, .15); }
.saldo-grande .dato { font-size: 46px; color: #fff; position: relative; }
.saldo-grande .etiqueta {
  color: #b9cfee; position: relative; font-size: 13px;
  letter-spacing: .4px;
}

/* ===== paneles y tablas ===== */
.panel {
  background: var(--carta); border-radius: 16px;
  padding: 18px; margin: 16px 0; overflow-x: auto;
  box-shadow: var(--sombra); display: block; border: none;
}
a.panel-link { text-decoration: none; color: inherit;
  transition: transform .15s, box-shadow .15s; }
a.panel-link:hover { transform: translateY(-2px); box-shadow: var(--sombra-alta); }
.tabla { width: 100%; border-collapse: collapse; font-size: 14px; }
.tabla th {
  text-align: left; color: var(--gris); font-size: 11.5px;
  font-weight: 600; text-transform: uppercase; letter-spacing: .6px;
  padding: 8px 6px; border-bottom: 1px solid var(--borde);
}
.tabla td {
  padding: 10px 6px; border-bottom: 1px solid #eef2f7;
  vertical-align: top; font-variant-numeric: tabular-nums;
}
.tabla tr:last-child td { border-bottom: none; }
.fila-alerta td { background: var(--alerta-fondo); }
.pasado td { color: #9aa6b5; }
.pos { color: var(--ok); font-weight: 700; }
.neg { color: var(--alerta); font-weight: 700; }

.lista-datos { list-style: none; margin: 0; padding: 0; }
.lista-datos li {
  display: flex; justify-content: space-between; gap: 12px; padding: 10px 0;
  border-bottom: 1px solid #eef2f7; font-size: 14px;
}
.lista-datos li span { color: var(--gris); }
.lista-datos li strong { text-align: right; font-variant-numeric: tabular-nums; }
.lista-datos li:last-child { border-bottom: none; }

/* ===== navegación mes/año y selector ===== */
.encabezado-vista {
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 8px;
}
.selector-vista {
  display: flex; gap: 2px; background: #e9eef5;
  border-radius: 99px; padding: 3px;
}
.chip {
  background: transparent; color: var(--gris);
  border-radius: 99px; padding: 6px 18px; font-size: 13px;
  font-weight: 600; text-decoration: none; transition: all .15s;
}
.chip.activo { background: var(--carta); color: var(--marino);
  box-shadow: 0 1px 3px rgba(15, 46, 79, .15); }

.nav-mes {
  display: flex; justify-content: space-between; align-items: center;
  margin: 16px 0; font-family: "Sora", sans-serif;
  font-weight: 600; font-size: 15px; color: var(--marino);
}
.btn-mes {
  background: var(--carta); border: 1px solid var(--borde);
  border-radius: 12px; padding: 6px 18px; text-decoration: none;
  color: var(--marino); font-size: 17px; box-shadow: var(--sombra);
  transition: all .15s;
}
.btn-mes:hover { border-color: var(--acento); color: var(--acento); }
.btn-mes.inactivo { color: #c3cdd9; box-shadow: none; }

/* ===== calendario mensual ===== */
.panel-cal { padding: 14px; }
.cal-grid {
  display: grid; grid-template-columns: repeat(7, 1fr); gap: 5px;
  margin-bottom: 5px;
}
.cal-cabecera span {
  text-align: center; font-size: 10.5px; color: var(--gris);
  font-weight: 600; text-transform: uppercase; letter-spacing: .4px;
  padding: 4px 0;
}
.cal-dia {
  position: relative; min-height: 48px; border-radius: 12px;
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; gap: 1px;
  text-decoration: none; color: var(--gris); font-size: 14px;
  background: var(--fondo); transition: transform .12s, box-shadow .12s;
}
.cal-dia:hover { transform: translateY(-1px); box-shadow: 0 3px 10px rgba(15,46,79,.12); }
.cal-dia:active { transform: scale(.93); }
.cal-dia .num { font-weight: 600; font-variant-numeric: tabular-nums; }
.cal-dia small { font-size: 9.5px; opacity: .9; }
.cal-dia.fuera { background: transparent; box-shadow: none; }
.cal-dia.ok       { background: var(--ok-fondo);     color: var(--ok); }
.cal-dia.tardanza { background: var(--ambar-fondo);  color: var(--ambar); }
.cal-dia.falta    { background: var(--alerta-fondo); color: var(--alerta); }
.cal-dia.permiso  { background: var(--azul-fondo);   color: var(--azul); }
.cal-dia.permiso_pend { background: var(--azul-fondo); color: var(--azul); opacity: .6; }
.cal-dia.vacaciones { background: var(--teal-fondo); color: var(--teal); }
.cal-dia.vacaciones_pend { background: var(--teal-fondo); color: var(--teal); opacity: .6; }
.cal-dia.feriado  { background: var(--morado-fondo); color: var(--morado); }
.cal-dia.futuro, .cal-dia.descanso, .cal-dia.libre { color: #b4bfcc; }
.cal-dia.es-hoy { outline: 2px solid var(--marino); outline-offset: -2px; font-weight: 700; }
.punto { position: absolute; top: 6px; right: 7px; width: 5px; height: 5px; border-radius: 50%; }
.punto-feriado { background: var(--morado); }
.punto-permiso { background: var(--azul); right: 15px; }
.punto-vacaciones { background: var(--teal); right: 15px; }

/* leyenda */
.leyenda {
  display: flex; flex-wrap: wrap; gap: 14px; margin: 12px 4px;
  font-size: 12px; color: var(--gris); font-weight: 500;
}
.leyenda span { display: flex; align-items: center; gap: 6px; }
.cua { width: 11px; height: 11px; border-radius: 4px; display: inline-block; }
.cua.ok       { background: var(--ok); }
.cua.tardanza { background: var(--ambar); }
.cua.falta    { background: var(--alerta); }
.cua.permiso  { background: var(--azul); }
.cua.vacaciones { background: var(--teal); }
.cua.feriado  { background: var(--morado); }

/* ===== calendario anual ===== */
.anio-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin: 16px 0; }
.mini-mes {
  background: var(--carta); border-radius: 14px; padding: 12px;
  text-decoration: none; color: inherit; box-shadow: var(--sombra);
  transition: transform .15s, box-shadow .15s;
}
.mini-mes:hover { transform: translateY(-2px); box-shadow: var(--sombra-alta); }
.mini-mes strong {
  font-family: "Sora", sans-serif; font-size: 12px; display: block;
  margin-bottom: 7px; color: var(--marino);
}
.mini-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 1px; }
.mini-cabecera span { font-size: 8px; color: #b4bfcc; text-align: center; }
.mini-dia {
  font-size: 9.5px; text-align: center; padding: 2.5px 0; border-radius: 5px;
  color: var(--gris); font-variant-numeric: tabular-nums;
}
.mini-dia.fuera { visibility: hidden; }
.mini-dia.feriado { background: var(--morado-fondo); color: var(--morado); font-weight: 700; }
.mini-dia.permiso { background: var(--azul-fondo); color: var(--azul); font-weight: 700; }
.mini-dia.vacaciones { background: var(--teal-fondo); color: var(--teal); font-weight: 700; }
.mini-dia.es-hoy { outline: 1.5px solid var(--marino); font-weight: 800; }

/* ===== detalle de día / bandas ===== */
.volver {
  display: inline-block; margin: 4px 0 6px; font-size: 13.5px;
  color: var(--acento); text-decoration: none; font-weight: 600;
}
.banda {
  border-radius: 12px; padding: 12px 15px; font-size: 14px;
  font-weight: 600; margin: 10px 0;
}
.banda-feriado { background: var(--morado-fondo); color: var(--morado); }
.banda-permiso { background: var(--azul-fondo); color: var(--azul); }
.banda-vacaciones { background: var(--teal-fondo); color: var(--teal); }
.banda-falta   { background: var(--alerta-fondo); color: var(--alerta); }

/* ===== estados de permisos ===== */
.estado {
  font-size: 12px; padding: 3px 10px; border-radius: 99px;
  white-space: nowrap; font-weight: 600;
}
.estado-validate { background: var(--ok-fondo); color: var(--ok); }
.estado-confirm, .estado-validate1 { background: var(--ambar-fondo); color: var(--ambar); }
.estado-refuse, .estado-cancel { background: var(--alerta-fondo); color: var(--alerta); }
.estado-draft { background: #eef2f7; color: var(--gris); }

/* ===== login ===== */
.caja-login {
  max-width: 390px; margin: 7vh auto 0; background: var(--carta);
  border-radius: 20px; padding: 30px; box-shadow: var(--sombra-alta);
}
.marca-login {
  font-family: "Sora", sans-serif; font-weight: 700;
  font-size: 21px; margin: 0; color: var(--marino);
}
.marca-login .marca2 { color: var(--acento); font-weight: 500; }
.caja-login h1 { font-size: 18px; }
.caja-login label {
  display: block; font-size: 13px; font-weight: 600;
  margin: 16px 0 6px; color: var(--texto);
}
.caja-login input {
  width: 100%; padding: 13px 14px; font-size: 16px; font-family: inherit;
  border: 1.5px solid var(--borde); border-radius: 12px;
  background: var(--fondo); transition: all .15s;
}
.caja-login input:focus {
  outline: none; border-color: var(--acento); background: #fff;
  box-shadow: 0 0 0 3px rgba(47, 125, 246, .15);
}
.btn-principal {
  display: block; width: 100%; margin-top: 22px; padding: 14px;
  background: var(--marino); color: #fff; border: none; border-radius: 12px;
  font-family: inherit; font-size: 15px; font-weight: 700;
  text-align: center; text-decoration: none; cursor: pointer;
  transition: background .15s, transform .1s;
}
.btn-principal:hover { background: var(--marino-2); }
.btn-principal:active { transform: scale(.98); }

.feriado-prox { font-size: 15px; font-weight: 600; margin: 0; color: var(--marino); }
.pie { text-align: center; color: #9aa6b5; font-size: 12px; padding: 22px 0 32px; }

.enlace-dia { color: var(--azul); text-decoration: none; font-weight: 600; }
.enlace-dia:hover { text-decoration: underline; }

@media (min-width: 600px) {
  .tarjetas { grid-template-columns: repeat(4, 1fr); }
  .tarjetas-3 { grid-template-columns: repeat(3, 1fr); }
  .anio-grid { grid-template-columns: repeat(3, 1fr); }
  .cal-dia { min-height: 58px; }
}

/* accesibilidad: respetar reducción de movimiento */
@media (prefers-reduced-motion: reduce) {
  .perfil, .tarjetas, .panel, .saldo-grande, .caja-login, .nav-mes,
  .leyenda, .anio-grid { animation: none; }
}
