/* ============================================================
   Un Día Como Hoy — Hoja de estilo
   Identidad: almanaque / periódico vintage.
   Paleta: pergamino/sepia + burdeos + negro. Mobile-first.
   ============================================================ */

:root {
  --pergamino: #f4ecd8;
  --pergamino-osc: #e9ddc2;
  --papel: #fbf7ec;
  --sepia: #7a6a53;
  --sepia-osc: #574a38;
  --tinta: #1f1a14;
  --burdeos: #7b1e26;
  --burdeos-osc: #5c141b;
  --dorado: #b08d57;
  --linea: #c9b892;
  --sombra: rgba(31, 26, 20, 0.14);

  --serif: Georgia, "Times New Roman", "Playfair Display", "Iowan Old Style", "Palatino Linotype", serif;
  --serif-tit: "Playfair Display", "Iowan Old Style", Georgia, "Times New Roman", serif;
  --sans: "Segoe UI", system-ui, -apple-system, Roboto, Helvetica, Arial, sans-serif;

  --ancho: 62rem;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  background-color: var(--pergamino);
  background-image:
    radial-gradient(circle at 20% 15%, rgba(176, 141, 87, 0.10), transparent 55%),
    radial-gradient(circle at 85% 80%, rgba(123, 30, 38, 0.06), transparent 50%);
  color: var(--tinta);
  font-family: var(--serif);
  font-size: 18px;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}

/* ---------- Layout ---------- */
.contenedor { width: 100%; max-width: var(--ancho); margin: 0 auto; padding: 0 1.1rem; }

main { padding: 1.5rem 0 3rem; }

/* ---------- Cabecera / masthead ---------- */
.masthead {
  border-bottom: 3px double var(--sepia-osc);
  background: var(--papel);
  box-shadow: 0 1px 0 var(--linea);
}
.masthead-top {
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--sans); font-size: 0.72rem; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--sepia);
  padding: 0.4rem 0; border-bottom: 1px solid var(--linea);
}
.masthead-top .fecha-larga { font-weight: 600; }
.masthead-brand { text-align: center; padding: 1rem 0 0.7rem; }
.masthead-brand a { text-decoration: none; color: var(--tinta); }
.logo {
  font-family: var(--serif-tit); font-weight: 700;
  font-size: clamp(1.9rem, 7vw, 3.4rem); line-height: 1.05; letter-spacing: 0.01em;
  margin: 0; display: flex; align-items: center; justify-content: center; gap: 0.5rem;
}
.logo .emoji { font-size: 0.85em; }
.tagline {
  font-family: var(--sans); font-size: 0.75rem; letter-spacing: 0.24em;
  text-transform: uppercase; color: var(--burdeos); margin: 0.35rem 0 0;
}

/* ---------- Navegación ---------- */
.nav-principal { background: var(--papel); border-bottom: 1px solid var(--linea); }
.nav-principal ul {
  list-style: none; margin: 0 auto; padding: 0.55rem 1.1rem;
  max-width: var(--ancho); display: flex; flex-wrap: wrap; gap: 0.2rem 1.2rem;
  justify-content: center; font-family: var(--sans);
  font-size: 0.8rem; letter-spacing: 0.06em; text-transform: uppercase;
}
.nav-principal a { color: var(--sepia-osc); text-decoration: none; padding: 0.25rem 0; border-bottom: 2px solid transparent; }
.nav-principal a:hover, .nav-principal a[aria-current="page"] { color: var(--burdeos); border-bottom-color: var(--burdeos); }

/* ---------- Tipografía de contenido ---------- */
h1 {
  font-family: var(--serif-tit); font-weight: 700;
  font-size: clamp(1.7rem, 5vw, 2.6rem); line-height: 1.15;
  color: var(--tinta); margin: 0.2rem 0 0.6rem;
}
h2 {
  font-family: var(--serif-tit); font-weight: 700;
  font-size: clamp(1.3rem, 3.6vw, 1.8rem); color: var(--burdeos-osc);
  margin: 2rem 0 0.7rem; padding-bottom: 0.3rem; border-bottom: 1px solid var(--linea);
}
h3 { font-family: var(--serif-tit); font-size: 1.2rem; color: var(--sepia-osc); margin: 1.4rem 0 0.5rem; }
p { margin: 0 0 1.05rem; }
a { color: var(--burdeos); }
a:hover { color: var(--burdeos-osc); }
strong { color: var(--sepia-osc); }
hr { border: 0; border-top: 1px solid var(--linea); margin: 2rem 0; }

.kicker {
  font-family: var(--sans); font-size: 0.72rem; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--burdeos); margin: 0 0 0.3rem; font-weight: 600;
}
.plomo { font-size: 1.12rem; color: var(--sepia-osc); font-style: italic; }

/* ---------- Herramienta / caja del día ---------- */
.hoy-cabecera { text-align: center; margin-bottom: 1.4rem; }
.hoy-fecha {
  font-family: var(--serif-tit); font-weight: 700;
  font-size: clamp(2.2rem, 8vw, 3.6rem); color: var(--burdeos); line-height: 1.05; margin: 0.2rem 0;
}
.hoy-sub { font-family: var(--sans); text-transform: uppercase; letter-spacing: 0.18em; font-size: 0.8rem; color: var(--sepia); }

/* Selector de fecha */
.selector-fecha {
  display: flex; flex-wrap: wrap; gap: 0.6rem; align-items: flex-end; justify-content: center;
  background: var(--papel); border: 1px solid var(--linea); border-radius: 6px;
  padding: 0.9rem 1rem; margin: 1.2rem auto 1.8rem; max-width: 34rem;
  box-shadow: 0 2px 6px var(--sombra);
}
.campo { display: flex; flex-direction: column; text-align: left; }
.campo label {
  font-family: var(--sans); font-size: 0.68rem; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--sepia); margin-bottom: 0.25rem;
}
.campo select {
  font-family: var(--serif); font-size: 1rem; padding: 0.45rem 0.6rem;
  border: 1px solid var(--sepia); border-radius: 4px; background: var(--pergamino); color: var(--tinta);
  min-width: 6.5rem;
}
.campo select:focus, .btn:focus-visible { outline: 3px solid var(--dorado); outline-offset: 2px; }

.btn {
  font-family: var(--sans); font-size: 0.82rem; letter-spacing: 0.08em; text-transform: uppercase;
  font-weight: 600; cursor: pointer; border: 0; border-radius: 4px;
  background: var(--burdeos); color: #fff; padding: 0.6rem 1.1rem; transition: background 0.15s;
}
.btn:hover { background: var(--burdeos-osc); }
.btn-sec { background: transparent; color: var(--burdeos); border: 1px solid var(--burdeos); }
.btn-sec:hover { background: var(--burdeos); color: #fff; }
.btn-hoy { margin: 0.4rem auto 0; display: block; }

/* Secciones de resultados */
.seccion-dia { margin-bottom: 2rem; }
.seccion-dia > h2 {
  display: flex; align-items: center; gap: 0.55rem;
  margin-top: 1.6rem;
}
.seccion-dia .icono { font-size: 1.1em; }

.lista-efem { list-style: none; margin: 0; padding: 0; }
.lista-efem li {
  display: grid; grid-template-columns: 4.2rem 1fr; gap: 0.9rem;
  padding: 0.75rem 0; border-bottom: 1px dotted var(--linea);
}
.lista-efem li:last-child { border-bottom: 0; }
.lista-efem .anio {
  font-family: var(--serif-tit); font-weight: 700; font-size: 1.15rem;
  color: var(--burdeos); text-align: right; line-height: 1.5;
}
.lista-efem .desc { margin: 0; line-height: 1.55; }

.chips-santoral { display: flex; flex-wrap: wrap; gap: 0.5rem; margin: 0.4rem 0 0; padding: 0; list-style: none; }
.chips-santoral li {
  font-family: var(--sans); font-size: 0.85rem; background: var(--pergamino-osc);
  border: 1px solid var(--linea); border-radius: 999px; padding: 0.3rem 0.85rem; color: var(--sepia-osc);
}

/* Estado vacío */
.vacio {
  text-align: center; background: var(--papel); border: 1px dashed var(--sepia);
  border-radius: 8px; padding: 2rem 1.4rem; margin: 1.5rem 0;
}
.vacio .emoji { font-size: 2.4rem; display: block; margin-bottom: 0.5rem; }

/* ---------- Tarjetas / rejilla ---------- */
.rejilla { display: grid; gap: 1.1rem; grid-template-columns: 1fr; margin: 1.2rem 0; }
.tarjeta {
  background: var(--papel); border: 1px solid var(--linea); border-radius: 8px;
  padding: 1.2rem 1.3rem; box-shadow: 0 2px 5px var(--sombra); transition: transform 0.15s, box-shadow 0.15s;
}
.tarjeta:hover { transform: translateY(-3px); box-shadow: 0 6px 14px var(--sombra); }
.tarjeta h3 { margin-top: 0; }
.tarjeta a.stretch { text-decoration: none; color: inherit; display: block; }
.tarjeta .mas { font-family: var(--sans); font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--burdeos); font-weight: 600; }

/* Rejilla de meses */
.meses-rejilla { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.7rem; margin: 1.2rem 0; }
.mes-btn {
  display: block; text-align: center; text-decoration: none;
  background: var(--papel); border: 1px solid var(--linea); border-radius: 6px;
  padding: 0.9rem 0.5rem; color: var(--sepia-osc); font-family: var(--serif-tit);
  font-size: 1.05rem; transition: background 0.15s, color 0.15s;
}
.mes-btn:hover { background: var(--burdeos); color: #fff; }
.mes-btn .num { display: block; font-family: var(--sans); font-size: 0.7rem; letter-spacing: 0.1em; color: var(--sepia); }
.mes-btn:hover .num { color: #f4d9c0; }

/* Lista de días con datos */
.dias-lista { columns: 2; column-gap: 1.4rem; margin: 1rem 0; padding: 0; list-style: none; }
.dias-lista li { break-inside: avoid; margin-bottom: 0.4rem; }
.dias-lista a { text-decoration: none; }
.dias-lista a:hover { text-decoration: underline; }

/* ---------- Artículo ---------- */
.articulo { max-width: 44rem; margin: 0 auto; }
.articulo p:first-of-type::first-letter {
  font-family: var(--serif-tit); font-size: 3.1rem; line-height: 0.8;
  float: left; padding: 0.1rem 0.55rem 0 0; color: var(--burdeos);
}
.meta-articulo {
  font-family: var(--sans); font-size: 0.78rem; color: var(--sepia);
  letter-spacing: 0.05em; margin-bottom: 1.4rem; border-bottom: 1px solid var(--linea); padding-bottom: 0.8rem;
}
blockquote {
  margin: 1.5rem 0; padding: 0.6rem 1.2rem; border-left: 4px solid var(--burdeos);
  background: var(--papel); font-style: italic; color: var(--sepia-osc);
}

/* ---------- Anuncios (placeholder) ---------- */
.adslot {
  margin: 1.6rem auto; max-width: 100%; min-height: 90px;
  border: 1px dashed var(--linea); border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--sans); font-size: 0.7rem; letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--sepia); background: rgba(255,255,255,0.35);
}

/* ---------- Pie ---------- */
footer {
  border-top: 3px double var(--sepia-osc); background: var(--papel);
  padding: 2rem 0 2.4rem; margin-top: 2rem; font-size: 0.9rem;
}
.footer-cols { display: grid; grid-template-columns: 1fr; gap: 1.3rem; }
.footer-cols h4 { font-family: var(--serif-tit); color: var(--burdeos-osc); margin: 0 0 0.5rem; font-size: 1.05rem; }
.footer-cols ul { list-style: none; margin: 0; padding: 0; }
.footer-cols li { margin-bottom: 0.35rem; }
.footer-cols a { color: var(--sepia-osc); text-decoration: none; }
.footer-cols a:hover { color: var(--burdeos); }
.footer-legal {
  margin-top: 1.6rem; padding-top: 1rem; border-top: 1px solid var(--linea);
  font-family: var(--sans); font-size: 0.74rem; color: var(--sepia); text-align: center;
}

/* ---------- Banner de cookies ---------- */
.cookie-banner {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 50;
  background: var(--tinta); color: var(--pergamino);
  padding: 1rem 1.1rem; font-family: var(--sans); font-size: 0.85rem;
  display: none; box-shadow: 0 -3px 12px rgba(0,0,0,0.3);
}
.cookie-banner.visible { display: block; }
.cookie-inner { max-width: var(--ancho); margin: 0 auto; display: flex; flex-wrap: wrap; gap: 0.8rem; align-items: center; justify-content: space-between; }
.cookie-inner p { margin: 0; flex: 1 1 16rem; }
.cookie-inner a { color: var(--dorado); }
.cookie-acciones { display: flex; gap: 0.6rem; flex-wrap: wrap; }
.cookie-acciones .btn { font-size: 0.74rem; padding: 0.5rem 0.9rem; }

/* ---------- Utilidades ---------- */
.centro { text-align: center; }
.skip-link {
  position: absolute; left: -999px; top: 0; background: var(--burdeos); color: #fff;
  padding: 0.6rem 1rem; z-index: 100; font-family: var(--sans);
}
.skip-link:focus { left: 0.5rem; top: 0.5rem; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }

/* ---------- Responsive ---------- */
@media (min-width: 40rem) {
  .footer-cols { grid-template-columns: repeat(3, 1fr); }
  .meses-rejilla { grid-template-columns: repeat(4, 1fr); }
  .rejilla.dos { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 52rem) {
  .rejilla.tres { grid-template-columns: repeat(3, 1fr); }
}

@media (prefers-reduced-motion: reduce) {
  * { scroll-behavior: auto; transition: none !important; }
}
