/* ═══════════════════════════════════════════════════
   Compárate — identidad La Segunda Brazada
   Paleta y tipografía oficiales LSB (BaseLayout.css)
   ═══════════════════════════════════════════════════ */

:root {
  --lsb-tinta:        #0F1419;
  --lsb-papel:        #F5F1E8;
  --lsb-piedra:       #6B6F73;
  --lsb-azul:         #1E3A5F;
  --lsb-linea:        #d4ceb9;
  --lsb-font-display: "Playfair Display", Georgia, serif;
  --lsb-font-body:    "Inter", system-ui, sans-serif;
  --lsb-font-mono:    "JetBrains Mono", monospace;

  --card-bg:   #FFFFFF;
  --soft-bg:   #EDE7D6;
  --azul-soft: rgba(30,58,95,.08);
  --azul-line: rgba(30,58,95,.18);
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  background: var(--lsb-papel);
  color: var(--lsb-tinta);
  font-family: var(--lsb-font-body);
  font-weight: 400;
  line-height: 1.6;
  overflow-x: hidden;
  min-height: 100vh;
}

/* Caustics legacy → desactivado en modo claro */
.caustics { display: none; }

.app { position: relative; z-index: 1; max-width: 720px; margin: 0 auto; padding: 2.5rem 1rem 4rem; }

/* ── HEADER ──────────────────────────────────────── */
.header { text-align: center; margin-bottom: 2rem; }
.header-back {
  display: inline-block; font-size: .72rem; letter-spacing: .18em;
  text-transform: uppercase; color: var(--lsb-piedra); opacity: .7;
  text-decoration: none; margin-bottom: 1.5rem; transition: opacity .25s;
}
.header-back:hover { opacity: 1; color: var(--lsb-azul); }
.header-title {
  font-family: var(--lsb-font-display); font-weight: 500;
  font-size: clamp(2rem, 5vw, 3rem); color: var(--lsb-tinta);
  margin-bottom: .5rem; letter-spacing: -0.01em;
}
.header-title em { font-style: italic; color: var(--lsb-azul); }
.header-sub {
  font-size: .95rem; color: var(--lsb-piedra);
  max-width: 540px; margin: 0 auto; line-height: 1.65;
}

/* ── Motivo 8 carriles (divisor LSB) ─────────────── */
.lsb-lanes {
  display: block; width: 100%; max-width: 320px;
  height: 36px; margin: 1.25rem auto 1.75rem;
  opacity: .55;
}
.lsb-lanes line {
  stroke: var(--lsb-linea); stroke-width: 1.5; stroke-linecap: round;
}

/* ── AGE INPUT ───────────────────────────────────── */
.age-panel {
  background: var(--card-bg); border: 1px solid var(--lsb-linea);
  border-radius: 12px; padding: 1.5rem; margin-bottom: 2rem;
  display: flex; align-items: flex-end; gap: 1rem;
  box-shadow: 0 1px 2px rgba(15,20,25,.04);
}
.age-field label, .sex-field label {
  display: block; font-size: .7rem; letter-spacing: .14em;
  text-transform: uppercase; color: var(--lsb-piedra);
  margin-bottom: .5rem; font-weight: 500;
}
.age-field input {
  width: 5ch; max-width: 80px; padding: .75rem .5rem;
  background: var(--lsb-papel); border: 1px solid var(--lsb-linea);
  border-radius: 6px; color: var(--lsb-tinta);
  font-family: var(--lsb-font-mono);
  font-size: 1.5rem; font-weight: 500; text-align: center;
  outline: none; transition: border-color .25s; -moz-appearance: textfield;
}
.age-field input::-webkit-outer-spin-button,
.age-field input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.age-field input:focus { border-color: var(--lsb-azul); }
.age-field input::placeholder { color: rgba(15,20,25,.25); font-weight: 400; }
.sex-options { display: flex; gap: .5rem; }
.sex-btn {
  flex: 1; padding: .55rem .9rem; background: var(--lsb-papel);
  border: 1px solid var(--lsb-linea); border-radius: 6px;
  color: var(--lsb-piedra); font-family: var(--lsb-font-body);
  font-size: .82rem; font-weight: 500; cursor: pointer; transition: all .25s;
}
.sex-btn:hover { border-color: var(--lsb-azul); color: var(--lsb-azul); }
.sex-btn.active {
  border-color: var(--lsb-azul); color: var(--lsb-papel);
  background: var(--lsb-azul);
}
.btn-go {
  padding: .8rem 2rem; background: var(--lsb-azul); color: var(--lsb-papel);
  border: none; border-radius: 6px; font-family: var(--lsb-font-body);
  font-size: .82rem; font-weight: 600; letter-spacing: .1em;
  text-transform: uppercase; cursor: pointer; white-space: nowrap;
  transition: background .2s, transform .2s, box-shadow .2s;
}
.btn-go:hover { background: #16304e; transform: translateY(-1px); box-shadow: 0 6px 18px rgba(30,58,95,.18); }
.age-hint { font-size: .72rem; color: var(--lsb-piedra); opacity: .7; text-align: center; margin-top: .5rem; }

/* ── CATEGORY BANNER ─────────────────────────────── */
.cat-banner { text-align: center; margin-bottom: 1.5rem; display: none; }
.cat-banner.visible { display: block; animation: fadeUp .5s forwards; }
.cat-age { font-family: var(--lsb-font-display); font-size: 1.6rem; color: var(--lsb-tinta); }
.cat-age em { color: var(--lsb-azul); font-style: italic; }
.cat-label {
  font-size: .72rem; color: var(--lsb-piedra); opacity: .75;
  letter-spacing: .12em; text-transform: uppercase; margin-top: .35rem;
}

/* ── EDUCATIONAL INTRO ───────────────────────────── */
.edu-intro { text-align: center; padding: 1rem 0 1.5rem; animation: fadeUp .5s forwards; }
.edu-main { font-family: var(--lsb-font-display); font-size: 1.15rem; color: var(--lsb-tinta); margin-bottom: .5rem; }
.edu-detail { font-size: .88rem; color: var(--lsb-piedra); max-width: 560px; margin: 0 auto; line-height: 1.65; }

/* ── GLOSSARY ────────────────────────────────────── */
.glossary-block {
  background: var(--card-bg); border: 1px solid var(--lsb-linea);
  border-radius: 12px; margin-bottom: 20px; overflow: hidden;
  box-shadow: 0 1px 2px rgba(15,20,25,.04);
}
.glossary-header {
  padding: 14px 24px; font-size: 14px; font-weight: 500;
  color: var(--lsb-azul); cursor: pointer;
  display: flex; align-items: center; gap: 8px; list-style: none;
}
.glossary-header::-webkit-details-marker { display: none; }
.glossary-header::after {
  content: '\25BE'; margin-left: auto; font-size: 12px;
  color: var(--lsb-piedra); transition: transform 0.2s;
}
.glossary-block[open] .glossary-header::after { transform: rotate(180deg); }
.glossary-content {
  padding: 0 24px 16px;
  font-size: 14px; color: var(--lsb-tinta); line-height: 1.7;
}
.glossary-content > p { margin-bottom: 10px; color: var(--lsb-piedra); }
.reference-card {
  background: var(--soft-bg); border-radius: 8px;
  padding: 14px 16px; margin-top: 10px;
}
.reference-card strong { color: var(--lsb-tinta); font-size: 14px; display: block; margin-bottom: 4px; font-weight: 600; }
.reference-card p { font-size: 13px; color: var(--lsb-piedra); line-height: 1.6; margin: 0; }

/* ── PROTAGONIST CARD ────────────────────────────── */
.p-card {
  background: var(--card-bg); border: 1px solid var(--lsb-linea);
  border-radius: 12px; overflow: hidden; margin-bottom: 20px;
  box-shadow: 0 1px 2px rgba(15,20,25,.04);
}
.protagonist-header {
  padding: 20px 24px; display: flex;
  justify-content: space-between; align-items: flex-start; gap: 12px;
  border-bottom: 1px solid var(--lsb-linea);
}
.protagonist-name {
  font-family: var(--lsb-font-display); font-size: 22px;
  font-weight: 500; color: var(--lsb-tinta); margin: 0; line-height: 1.2;
}
.protagonist-hook { font-size: 14px; font-style: italic; color: var(--lsb-azul); margin: 6px 0 0 0; }
.protagonist-age {
  background: var(--azul-soft); border-radius: 20px;
  padding: 4px 14px; font-size: 13px; color: var(--lsb-azul);
  font-family: var(--lsb-font-mono); font-weight: 500;
  white-space: nowrap; flex-shrink: 0;
}

/* Intro */
.protagonist-intro {
  padding: 16px 24px;
  border-left: 3px solid var(--lsb-azul); margin: 12px 0 0 0;
  background: var(--soft-bg);
}
.intro-text { font-size: 14px; color: var(--lsb-tinta); line-height: 1.7; margin: 0; }
.intro-meta { font-size: 12px; color: var(--lsb-piedra); margin: 10px 0 0 0; }

/* Fallback */
.fallback-note {
  background: var(--soft-bg); border-radius: 8px;
  padding: 12px 16px; margin: 12px 24px 0;
  font-size: 13px; color: var(--lsb-piedra); font-style: italic;
}

/* Worlds */
.worlds-list { padding: 12px 24px; display: flex; gap: .4rem; flex-wrap: wrap; }
.world-tag {
  padding: .25rem .65rem; border-radius: 12px;
  background: var(--azul-soft); border: 1px solid var(--azul-line);
  font-size: .68rem; color: var(--lsb-azul); font-weight: 500;
  font-family: var(--lsb-font-mono);
}

/* ── EVENT BLOCKS ────────────────────────────────── */
.event-block { padding: 20px 24px 16px; }
.event-block + .event-block { border-top: 1px solid var(--lsb-linea); }
.event-header { margin-bottom: 14px; }

.event-title-row {
  display: flex; justify-content: space-between;
  align-items: baseline; flex-wrap: wrap; gap: 8px;
}
.event-name {
  font-family: var(--lsb-font-display); font-size: 18px;
  font-weight: 500; color: var(--lsb-tinta); margin: 0; letter-spacing: 0;
}
.event-category { font-size: 12px; color: var(--lsb-piedra); white-space: nowrap; font-family: var(--lsb-font-mono); }
.event-desc { font-size: 13px; color: var(--lsb-piedra); margin: 6px 0 0 0; font-style: italic; }

.event-protagonist { font-size: 14px; color: var(--lsb-piedra); margin: 8px 0 0 0; }

/* Time card */
.protagonist-time-card {
  background: var(--soft-bg); border: 1px solid var(--lsb-linea);
  border-radius: 8px; padding: 16px 20px; margin: 10px 0 16px 0;
  display: flex; justify-content: space-between;
  align-items: center; flex-wrap: wrap; gap: 8px;
}
.time-label { display: none; }
.time-value {
  font-family: var(--lsb-font-mono); font-size: 30px; font-weight: 500;
  color: var(--lsb-azul); letter-spacing: 0.02em;
  font-variant-numeric: tabular-nums;
}

.time-badges { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; }
.badge-mexico { font-size: 13px; color: var(--lsb-azul); font-weight: 600; white-space: nowrap; }
.badge-mundial { font-size: 12px; color: var(--lsb-piedra); white-space: nowrap; }
.mejor-mexico-badge { display: none; }

/* ── STEPS ───────────────────────────────────────── */
.step { padding: 0 4px; margin-bottom: 18px; padding-top: 4px; }
.step-header { display: flex; align-items: center; margin-bottom: 6px; }
.step-marker {
  display: inline-flex; align-items: center; justify-content: center;
  width: 22px; height: 22px; border-radius: 50%;
  font-size: 11px; font-weight: 600; margin-right: 10px;
  font-family: var(--lsb-font-mono);
}
.step-1 .step-marker { background: var(--azul-soft); color: var(--lsb-azul); }
.step-2 .step-marker { background: var(--azul-soft); color: var(--lsb-azul); }
.step-3 .step-marker { background: var(--azul-soft); color: var(--lsb-azul); }
.step-label { font-size: 13px; letter-spacing: .03em; font-weight: 500; color: var(--lsb-piedra); }
.step-1 .step-label, .step-2 .step-label, .step-3 .step-label { color: var(--lsb-azul); }
.step p { margin: 0; line-height: 1.7; font-size: 14px; color: var(--lsb-tinta); }
.step-highlight { color: var(--lsb-azul) !important; font-weight: 500; margin-top: 6px !important; }

.hook-box {
  background: var(--azul-soft); border-left: 3px solid var(--lsb-azul);
  border-radius: 6px; padding: 10px 14px; margin-top: 10px;
  font-size: 13px; color: var(--lsb-tinta); text-align: left;
}

/* ── COMPACT COMPARISONS ─────────────────────────── */
.compact-comparisons p { margin: 0 0 12px 0; padding: 0 4px; line-height: 1.7; }
.comp-mexico, .comp-mundial, .comp-record { font-size: 14px; color: var(--lsb-tinta); }
.comp-mundial-note { font-size: 13px; color: var(--lsb-piedra); font-style: italic; }
.compact-comparisons strong { font-weight: 600; color: var(--lsb-azul); }

.mundial-note { font-size: 13px; color: var(--lsb-piedra); font-style: italic; padding: 0 4px; margin-top: 8px; }

/* ── CIERRE ──────────────────────────────────────── */
.protagonist-close { padding: 20px 24px; text-align: center; border-top: 1px solid var(--lsb-linea); background: var(--soft-bg); }
.protagonist-close p { font-size: 15px; color: var(--lsb-tinta); line-height: 1.8; margin: 0; white-space: pre-line; }
.protagonist-close .tagline { font-size: 13px; color: var(--lsb-piedra); margin-top: 14px; }

/* ── CTA ─────────────────────────────────────────── */
.cta-block { text-align: center; padding: 2.5rem 1rem; margin-top: 2rem; }
.cta-line { width: 60px; height: 1px; background: var(--lsb-azul); opacity: .35; margin: 0 auto 2rem; }
.cta-main { font-family: var(--lsb-font-display); font-style: italic; font-size: 1.45rem; color: var(--lsb-tinta); margin-bottom: .75rem; }
.cta-sub { font-size: .9rem; color: var(--lsb-piedra); max-width: 480px; margin: 0 auto 1.5rem; line-height: 1.65; }
.cta-btn {
  display: inline-block; padding: .75rem 1.8rem;
  background: transparent; border: 1px solid var(--lsb-azul);
  color: var(--lsb-azul); border-radius: 6px;
  font-family: var(--lsb-font-body); font-size: .82rem; font-weight: 600;
  letter-spacing: .1em; text-transform: uppercase;
  text-decoration: none; transition: all .25s;
}
.cta-btn:hover { background: var(--lsb-azul); color: var(--lsb-papel); }

/* ── EMPTY CATEGORY / REFERENCE ──────────────────── */
.empty-category {
  text-align: center; padding: 2rem 1.5rem;
  background: var(--card-bg); border: 1px solid var(--lsb-linea);
  border-radius: 12px; margin-bottom: 1.5rem;
}
.empty-category p { font-size: 14px; color: var(--lsb-tinta); line-height: 1.7; margin: 0 0 10px 0; }
.empty-category p:last-child { margin-bottom: 0; color: var(--lsb-piedra); }

.reference-category { max-width: 680px; margin: 0 auto; }
.reference-intro {
  background: var(--card-bg); border: 1px solid var(--lsb-linea);
  border-radius: 12px; padding: 20px 24px; margin-bottom: 16px;
  font-size: 14px; color: var(--lsb-tinta); line-height: 1.7;
}
.reference-intro strong { color: var(--lsb-azul); }
.reference-event {
  background: var(--card-bg); padding: 20px 24px;
  border: 1px solid var(--lsb-linea); border-bottom: none;
}
.reference-event:first-of-type { border-radius: 12px 12px 0 0; }
.reference-event:last-of-type { border-radius: 0 0 12px 12px; border-bottom: 1px solid var(--lsb-linea); }
.reference-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 14px; }
.ref-stat { background: var(--soft-bg); border-radius: 8px; padding: 12px 14px; }
.ref-label {
  display: block; font-size: 11px; color: var(--lsb-piedra);
  letter-spacing: 0.04em; margin-bottom: 4px; text-transform: uppercase;
}
.ref-value {
  display: block; font-size: 20px; font-weight: 500;
  color: var(--lsb-azul); font-family: var(--lsb-font-mono);
  font-variant-numeric: tabular-nums;
}
.ref-detail { display: block; font-size: 11px; color: var(--lsb-piedra); margin-top: 4px; }
.ref-stat-muted .ref-value { color: var(--lsb-piedra); font-size: 16px; }
.reference-cta { text-align: center; padding: 20px 24px; font-size: 14px; color: var(--lsb-piedra); }

@media (max-width: 600px) {
  .reference-stats { grid-template-columns: 1fr; }
  .reference-event, .reference-intro { padding: 16px; }
}

/* ── LOADING / ERROR ─────────────────────────────── */
.loading {
  text-align: center; padding: 3rem; color: var(--lsb-piedra);
  font-family: var(--lsb-font-display); font-size: 1.05rem;
}
.loading::after {
  content: ''; display: inline-block; width: 18px; height: 18px; margin-left: 10px;
  border: 2px solid var(--lsb-azul); border-top-color: transparent;
  border-radius: 50%; animation: spin .8s linear infinite; vertical-align: middle;
}
.error { text-align: center; padding: 2rem; color: #b13a2f; font-size: .92rem; }

/* ── FOOTER ──────────────────────────────────────── */
.footer-link {
  text-align: center; margin-top: 3rem; padding-top: 2rem;
  border-top: 1px solid var(--lsb-linea);
}
.footer-link a {
  font-size: .78rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--lsb-piedra); opacity: .75; text-decoration: none; transition: opacity .25s;
}
.footer-link a:hover { opacity: 1; color: var(--lsb-azul); }

@keyframes fadeUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
@keyframes spin { to { transform: rotate(360deg); } }

/* ── RESPONSIVE ──────────────────────────────────── */
@media (max-width: 600px) {
  .app { padding: 1.5rem .75rem 3rem; }
  .age-panel { flex-wrap: wrap; gap: .75rem; }
  .age-field { flex: 0 0 auto; }
  .sex-field { flex: 1; }
  .btn-go { flex: 1 0 100%; }
  .protagonist-header { flex-direction: column; gap: 6px; padding: 16px; }
  .protagonist-age { align-self: flex-start; }
  .protagonist-intro { padding: 14px 16px; }
  .event-block { padding: 16px; }
  .protagonist-close { padding: 16px; }
  .protagonist-name { font-size: 20px; }
  .event-name { font-size: 16px; }
  .time-value { font-size: 26px; }
  .fallback-note { margin: 12px 16px 0; }
  .worlds-list { padding: 12px 16px; }
  .event-title-row { flex-direction: column; gap: 2px; }
}
