/* =====================================================================
 * styles.css — Calculadora de Sueldo Líquido Chile
 * Mobile-first, liviano, sin dependencias externas.
 * ===================================================================== */

:root {
  --azul: #0b5cad;
  --azul-osc: #08406f;
  --verde: #14854f;
  --verde-claro: #e6f4ec;
  --gris-fondo: #f4f6f9;
  --gris-borde: #dfe4ea;
  --texto: #1c2733;
  --texto-suave: #5a6675;
  --rojo: #c0392b;
  --radio: 12px;
  --sombra: 0 2px 10px rgba(0, 0, 0, .06);
  --max: 760px;
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  color: var(--texto);
  background: var(--gris-fondo);
  line-height: 1.6;
  font-size: 17px;
}

.contenedor { width: 100%; max-width: var(--max); margin: 0 auto; padding: 0 16px; }

/* ---- Encabezado ---- */
.cabecera {
  background: linear-gradient(135deg, var(--azul) 0%, var(--azul-osc) 100%);
  color: #fff;
  padding: 18px 0;
}
.cabecera a { color: #fff; text-decoration: none; }
.cabecera .marca { font-weight: 700; font-size: 1.15rem; display: inline-flex; align-items: center; gap: 8px; }
.cabecera nav { margin-top: 8px; font-size: .92rem; }
.cabecera nav a { opacity: .9; margin-right: 16px; }
.cabecera nav a:hover { opacity: 1; text-decoration: underline; }

/* ---- Titulares ---- */
h1 { font-size: 1.6rem; line-height: 1.25; margin: 24px 0 8px; }
h2 { font-size: 1.3rem; margin: 32px 0 12px; }
h3 { font-size: 1.1rem; margin: 22px 0 8px; }
.subtitulo { color: var(--texto-suave); margin: 0 0 20px; }

/* ---- Tarjetas ---- */
.tarjeta {
  background: #fff;
  border: 1px solid var(--gris-borde);
  border-radius: var(--radio);
  box-shadow: var(--sombra);
  padding: 20px;
  margin: 18px 0;
}

/* ---- Formulario ---- */
.campo { margin-bottom: 16px; }
label { display: block; font-weight: 600; margin-bottom: 6px; font-size: .95rem; }
.ayuda { font-weight: 400; color: var(--texto-suave); font-size: .85rem; }

input[type="text"], input[type="number"], select {
  width: 100%;
  padding: 12px 14px;
  font-size: 1.05rem;
  border: 1px solid var(--gris-borde);
  border-radius: 10px;
  background: #fff;
  color: var(--texto);
}
input:focus, select:focus { outline: 2px solid var(--azul); border-color: var(--azul); }

.fila { display: flex; gap: 12px; flex-wrap: wrap; }
.fila > * { flex: 1 1 200px; }

.radios { display: flex; gap: 10px; flex-wrap: wrap; }
.radios label {
  flex: 1 1 120px; display: flex; align-items: center; gap: 8px;
  border: 1px solid var(--gris-borde); border-radius: 10px; padding: 10px 12px;
  font-weight: 500; cursor: pointer; margin: 0;
}
.radios input { width: auto; }
.radios label:has(input:checked) { border-color: var(--azul); background: #eef4fb; }

label.check { display: flex; align-items: center; gap: 8px; font-weight: 500; cursor: pointer; }
label.check input { width: auto; }

.boton {
  display: inline-block; width: 100%;
  background: var(--azul); color: #fff; border: 0;
  padding: 14px 18px; font-size: 1.1rem; font-weight: 700;
  border-radius: 10px; cursor: pointer;
}
.boton:hover { background: var(--azul-osc); }

/* ---- Resultado ---- */
.resultado-grande {
  text-align: center; background: #eaf6ef; border: 1px solid #bfe3cf;
  border-radius: var(--radio); padding: 20px; margin: 20px 0;
}
.resultado-grande .etiqueta { color: var(--texto-suave); font-size: .95rem; }
.resultado-grande .monto { color: var(--verde); font-size: 2.3rem; font-weight: 800; line-height: 1.1; margin: 4px 0; }
.resultado-grande .nota { color: var(--texto-suave); font-size: .85rem; }

table.desglose { width: 100%; border-collapse: collapse; margin: 10px 0; }
table.desglose th, table.desglose td { text-align: left; padding: 10px 8px; border-bottom: 1px solid var(--gris-borde); }
table.desglose td.num { text-align: right; font-variant-numeric: tabular-nums; white-space: nowrap; }
table.desglose tr.descuento td.num { color: var(--rojo); }
table.desglose tr.suma td.num { color: var(--verde); }
table.desglose tr.total td { font-weight: 800; border-top: 2px solid var(--texto); border-bottom: 0; }
table.desglose tr.bruto td { font-weight: 700; }
table.desglose .menor { color: var(--texto-suave); font-size: .85rem; font-weight: 400; }

/* ---- Contenido / artículo ---- */
.contenido p, .contenido li { color: var(--texto); }
.contenido ul, .contenido ol { padding-left: 22px; }
.contenido a { color: var(--azul); }

/* ---- FAQ ---- */
details { background: #fff; border: 1px solid var(--gris-borde); border-radius: 10px; padding: 4px 16px; margin: 10px 0; }
details summary { cursor: pointer; font-weight: 600; padding: 12px 0; }
details[open] summary { border-bottom: 1px solid var(--gris-borde); }
details p { margin: 12px 0; }

/* ---- Bloques de anuncios (AdSense) ---- */
.anuncio {
  margin: 24px 0; min-height: 90px;
  display: flex; align-items: center; justify-content: center;
  background: #eef1f5; border: 1px dashed var(--gris-borde); border-radius: 10px;
  color: #9aa6b2; font-size: .8rem;
}

/* ---- Enlaces a otros montos ---- */
.otros-montos { display: flex; flex-wrap: wrap; gap: 8px; }
.otros-montos a {
  background: #fff; border: 1px solid var(--gris-borde); border-radius: 999px;
  padding: 7px 14px; font-size: .9rem; text-decoration: none; color: var(--azul);
}
.otros-montos a:hover { background: #eef4fb; }

/* ---- Aviso / disclaimer ---- */
.aviso { background: #fff8e6; border: 1px solid #f0dca0; border-radius: 10px; padding: 14px 16px; font-size: .9rem; color: #6b5a1f; margin: 18px 0; }

/* ---- Pie ---- */
footer { background: #fff; border-top: 1px solid var(--gris-borde); margin-top: 40px; padding: 26px 0; color: var(--texto-suave); font-size: .88rem; }
footer a { color: var(--azul); }
footer .fuentes { font-size: .82rem; margin-top: 10px; }

/* ---- Utilidades ---- */
.centro { text-align: center; }
.mt0 { margin-top: 0; }
.small { font-size: .85rem; color: var(--texto-suave); }

@media (min-width: 600px) {
  body { font-size: 18px; }
  h1 { font-size: 2rem; }
}
