/* ============================================================
   Multas — Hooft & Freigo Abogados. SaaS claro, acento grafito
   sobrio, paleta slate, tarjetas con bordes finos. Mobile-first.
   ============================================================ */
:root {
  /* Fondos */
  --fondo: #F8FAFC;          /* slate-50 */
  --fondo-tarjeta: #FFFFFF;
  --fondo-hover: #F1F5F9;    /* slate-100 */
  --fondo-input: #FFFFFF;

  /* Texto */
  --texto: #0F172A;          /* slate-900 */
  --texto-sec: #475569;      /* slate-600 */
  --texto-tenue: #94A3B8;    /* slate-400 */

  /* Acento Hooft & Freigo: grafito sobrio */
  --acento: #374151;
  --acento-hover: #1F2937;
  --acento-suave: #F3F4F6;

  /* Estados */
  --exito: #10B981;  --exito-suave: #D1FAE5;  --exito-texto: #065F46;
  --alerta: #EF4444; --alerta-suave: #FEE2E2; --alerta-texto: #991B1B;
  --warn: #F59E0B;   --warn-suave: #FEF3C7;   --warn-texto: #92400E;

  /* Bordes */
  --borde: #E2E8F0;          /* slate-200 */
  --borde-fuerte: #CBD5E1;   /* slate-300 */

  /* Radios */
  --r-sm: 6px; --r-md: 10px; --r-lg: 14px;

  --mono: "Cascadia Mono", "Consolas", ui-monospace, monospace;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: "Segoe UI", system-ui, -apple-system, sans-serif;
  background: var(--fondo);
  color: var(--texto);
  font-size: 15px;
  line-height: 1.5;
}

/* ─── Barra superior ─── */
.topbar {
  background: var(--fondo-tarjeta);
  border-bottom: 1px solid var(--borde);
  padding: 0.7rem 1.25rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem 1.5rem;
  align-items: center;
  justify-content: space-between;
  position: sticky;
  top: 0;
  z-index: 50;
}
.marca { display: flex; align-items: baseline; gap: 0.5rem; text-decoration: none; }
.marca-logo {
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--acento);
}
.marca-estudio { font-weight: 600; color: var(--texto); font-size: 0.95rem; }
.topbar nav { display: flex; gap: 1.1rem; align-items: center; flex-wrap: wrap; }
.topbar nav a {
  color: var(--texto-sec); text-decoration: none; font-size: 0.9rem;
  padding: 0.2rem 0; border-bottom: 2px solid transparent; transition: color .12s, border-color .12s;
}
.topbar nav a:hover { color: var(--texto); border-bottom-color: var(--acento); }
.topbar nav a.activo { color: var(--texto); border-bottom-color: var(--acento); }

/* ─── Layout general ─── */
.contenido { max-width: 1180px; margin: 0 auto; padding: 1.5rem 1.25rem 3rem; }
.contenido-angosto { max-width: 760px; }

h1 { font-size: 1.6rem; margin: 0 0 0.2rem; letter-spacing: -0.01em; }
h2 { font-size: 1.05rem; margin: 1.2rem 0 0.5rem; }
.sub { color: var(--texto-sec); font-style: italic; margin: 0 0 0.3rem; font-size: 0.95rem; }
.versalita {
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--texto-tenue); margin-bottom: 0.3rem;
}
.mono { font-family: var(--mono); letter-spacing: 0.04em; }
hr { border: none; border-top: 1px solid var(--borde); margin: 1.4rem 0; }

/* ─── Grilla app: consulta (izq) + historial (der) ─── */
.app-grid { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }

.tarjeta {
  background: var(--fondo-tarjeta);
  border: 1px solid var(--borde);
  border-radius: var(--r-lg);
  padding: 1.5rem;
}
.tarjeta + .tarjeta { margin-top: 1.25rem; }

/* ─── Login ─── */
.tarjeta-login { max-width: 380px; margin: 9vh auto 0; }
.tarjeta-login .marca-logo { display: block; text-align: center; margin-bottom: 0.5rem; }
.tarjeta-login h1 { text-align: center; font-size: 1.4rem; }
.tarjeta-login .sub { text-align: center; }

/* ─── Formularios ─── */
label { display: block; margin-bottom: 0.85rem; font-weight: 600; font-size: 0.82rem; color: var(--texto-sec); }
.opcional { font-weight: 400; color: var(--texto-tenue); }
input[type="text"], input[type="email"], input[type="password"] {
  display: block; width: 100%; margin-top: 0.3rem;
  padding: 0.6rem 0.7rem; font-size: 1rem;
  border: 1px solid var(--borde); border-radius: var(--r-md);
  background: var(--fondo-input); color: var(--texto);
  transition: border-color .12s, box-shadow .12s;
}
input.mono { font-family: var(--mono); letter-spacing: 0.08em; text-transform: uppercase; }
input:focus {
  outline: none; border-color: var(--acento);
  box-shadow: 0 0 0 3px rgba(232,119,34,0.12);
}

/* Selector de modo (Por patente / Por DNI) — pills */
.segmentos { display: inline-flex; background: var(--fondo-hover); border-radius: var(--r-md); padding: 3px; margin-bottom: 1.1rem; }
.segmentos label { margin: 0; cursor: pointer; }
.segmentos input { position: absolute; opacity: 0; pointer-events: none; }
.segmentos span {
  display: block; padding: 0.4rem 1rem; border-radius: 8px;
  font-size: 0.85rem; font-weight: 600; color: var(--texto-sec); transition: all .12s;
}
.segmentos input:checked + span { background: var(--fondo-tarjeta); color: var(--texto); box-shadow: 0 1px 2px rgba(0,0,0,0.06); }

.campos-doble { display: grid; grid-template-columns: 1fr; gap: 0 1.2rem; }

/* Jurisdicciones como chips seleccionables */
.juris-grupo { margin-bottom: 1.1rem; }
.juris-chips { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.juris-chip { position: relative; cursor: pointer; margin: 0; }
.juris-chip input { position: absolute; opacity: 0; pointer-events: none; }
.juris-chip span {
  display: inline-flex; align-items: center; gap: 0.4rem;
  padding: 0.45rem 0.85rem; border: 1px solid var(--borde);
  border-radius: 999px; font-size: 0.85rem; font-weight: 600;
  color: var(--texto-sec); background: var(--fondo-tarjeta); transition: all .12s;
}
.juris-chip span::before {
  content: ""; width: 0.7rem; height: 0.7rem; border-radius: 50%;
  border: 1.5px solid var(--borde-fuerte); transition: all .12s;
}
.juris-chip input:checked + span {
  border-color: var(--acento); background: var(--acento-suave); color: var(--texto);
}
.juris-chip input:checked + span::before { background: var(--acento); border-color: var(--acento); }
.juris-chip:hover span { border-color: var(--borde-fuerte); }

/* ─── Botones (planos, hover con lift sutil) ─── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.4rem;
  padding: 0.6rem 1.3rem; border: 1px solid var(--borde); border-radius: var(--r-md);
  background: var(--fondo-tarjeta); color: var(--texto);
  font-size: 0.92rem; font-weight: 600; text-decoration: none; cursor: pointer;
  transition: transform .12s, background .12s, border-color .12s;
}
.btn:hover { transform: translateY(-1px); }
.btn:disabled, .btn[disabled] { opacity: 0.5; cursor: not-allowed; transform: none; }
.btn-primario { background: var(--acento); border-color: var(--acento); color: #fff; }
.btn-primario:hover { background: var(--acento-hover); border-color: var(--acento-hover); }
.btn-bloque { width: 100%; }
.btn-chico { padding: 0.35rem 0.85rem; font-size: 0.82rem; }

/* ─── Panel de progreso ─── */
.progreso-cabecera { display: flex; align-items: center; justify-content: space-between; gap: 0.8rem; flex-wrap: wrap; }
.barra { height: 4px; background: var(--fondo-hover); border-radius: 999px; overflow: hidden; margin: 0.8rem 0 1rem; }
.barra-fill { height: 100%; width: 30%; background: var(--acento); border-radius: 999px; animation: indeterminado 1.4s ease-in-out infinite; }
.barra.detenida .barra-fill { animation: none; width: 100%; background: var(--exito); }
.barra.fallo .barra-fill { animation: none; width: 100%; background: var(--alerta); }
@keyframes indeterminado { 0% { margin-left: -30%; } 100% { margin-left: 100%; } }

.juris-lista { list-style: none; padding: 0; margin: 0.5rem 0 0; }
.juris-lista li {
  display: flex; align-items: center; gap: 0.7rem;
  padding: 0.65rem 0.2rem; border-bottom: 1px solid var(--borde);
}
.juris-lista li:last-child { border-bottom: none; }
.juris-icono { width: 1.3rem; text-align: center; font-size: 1.05rem; flex-shrink: 0; }
.juris-icono.pendiente { color: var(--texto-tenue); }
.juris-icono.proceso { color: var(--acento); }
.juris-icono.ok { color: var(--exito); }
.juris-icono.multas { color: var(--alerta); }
.juris-icono.error { color: var(--alerta); }
.juris-nombre { font-weight: 600; min-width: 12rem; flex-shrink: 0; }
.juris-msg { color: var(--texto-sec); font-style: italic; font-size: 0.9rem; flex: 1; }
.juris-msg.con-multas { color: var(--alerta-texto); font-style: normal; font-weight: 600; }
.juris-msg.sin-multas { color: var(--exito-texto); font-style: normal; }

@media (min-width: 480px) { .juris-nombre { min-width: 15rem; } }

/* Resumen final (total de deuda) */
.resumen-total {
  display: flex; align-items: baseline; justify-content: space-between; gap: 1rem;
  margin-top: 1.1rem; padding-top: 1rem; border-top: 2px solid var(--borde); flex-wrap: wrap;
}
.resumen-total .etiqueta { font-weight: 600; color: var(--texto-sec); }
.resumen-total .monto { font-size: 1.5rem; font-weight: 700; font-variant-numeric: tabular-nums; }
.resumen-total .monto.deuda { color: var(--alerta); }
.resumen-total .monto.limpio { color: var(--exito); }

.descargas { display: flex; gap: 0.7rem; margin-top: 1.2rem; flex-wrap: wrap; }

.cronometro { font-variant-numeric: tabular-nums; color: var(--texto-sec); font-weight: 600; font-size: 0.9rem; }
.cronometro.ok { color: var(--exito); }
.cronometro.fallo { color: var(--alerta); }

/* ─── Chips de estado ─── */
.chip {
  display: inline-block; padding: 0.18rem 0.65rem; border-radius: 999px;
  font-size: 0.78rem; font-weight: 600; white-space: nowrap;
}
.chip-pendiente { background: var(--fondo-hover); color: var(--texto-tenue); }
.chip-en_proceso { background: var(--warn-suave); color: var(--warn-texto); }
.chip-completada { background: var(--exito-suave); color: var(--exito-texto); }
.chip-parcial { background: var(--warn-suave); color: var(--warn-texto); }
.chip-error { background: var(--alerta-suave); color: var(--alerta-texto); }

/* ─── Historial (sidebar) ─── */
.panel-historial .versalita { margin-bottom: 0.1rem; }
.hist-lista { display: flex; flex-direction: column; gap: 0.6rem; margin-top: 0.9rem; }
.hist-card {
  display: block; text-decoration: none; color: inherit;
  border: 1px solid var(--borde); border-radius: var(--r-md);
  padding: 0.7rem 0.85rem; transition: background .12s, border-color .12s;
}
.hist-card:hover { background: var(--fondo-hover); border-color: var(--borde-fuerte); }
.hist-patente { font-weight: 700; font-family: var(--mono); letter-spacing: 0.05em; }
.hist-fecha { color: var(--texto-tenue); font-size: 0.8rem; font-style: italic; margin: 0.1rem 0; }
.hist-estado { font-size: 0.82rem; }
.hist-estado.multas { color: var(--alerta-texto); font-weight: 600; }
.hist-estado.ok { color: var(--exito-texto); }
.hist-estado.proceso { color: var(--warn-texto); }

/* ─── Métricas (cupo) ─── */
.metricas { display: flex; gap: 0.8rem; flex-wrap: wrap; margin-bottom: 0.4rem; }
.metrica {
  background: var(--acento-suave); border: 1px solid var(--borde);
  border-radius: var(--r-md); padding: 0.7rem 1.1rem; flex: 1; min-width: 130px;
}
.metrica-valor { display: block; font-size: 1.5rem; font-weight: 700; color: var(--acento); line-height: 1; }
.metrica-label { color: var(--texto-sec); font-size: 0.8rem; }

/* ─── Avisos ─── */
.aviso { padding: 0.7rem 1rem; border-radius: var(--r-md); margin-bottom: 1rem; font-size: 0.92rem; }
.aviso-error { background: var(--alerta-suave); color: var(--alerta-texto); }
.aviso-ok { background: var(--exito-suave); color: var(--exito-texto); }
.banner-fallo {
  background: var(--fondo-hover); border-left: 3px solid var(--alerta);
  border-radius: var(--r-sm); padding: 0.8rem 1rem; margin-top: 1rem; font-size: 0.88rem;
}
.banner-fallo b { color: var(--alerta-texto); }
.vacio { color: var(--texto-tenue); text-align: center; padding: 2rem 0; font-size: 0.9rem; }

/* ─── Desktop: 2 columnas ─── */
@media (min-width: 900px) {
  .app-grid { grid-template-columns: 1fr 300px; align-items: start; }
  .panel-historial { position: sticky; top: 4.5rem; }
  .campos-doble { grid-template-columns: 1fr 1fr; }
  h1 { font-size: 1.8rem; }
}
