/* ════════════════════════════════════════════════════════
   Finbase · Páginas de momentos en estilo pizarra
   Reusa componentes de lapizarra-landing.css y lapizarra.css
   y añade lo específico de las páginas de contenido educativo:
   - Hero con polaroid + texto + post-it badge
   - Secciones split (texto + media a izquierda/derecha)
   - Notepad con slider rápido
   - Mockup de nómina como hoja con clip
   - Tramos IRPF como barras dibujadas a mano
   - Calculadora completa estilo cuaderno
   - Post-its grandes con consejos
   ════════════════════════════════════════════════════════ */

.board-momento {
  background: var(--paper);
}

/* ═══════ HERO ═══════ */
.lm-hero {
  max-width: 1200px;
  margin: 0 auto;
  padding: 40px 30px 60px;
}
/* NOTA: Las clases .lm-hero-grid, .lm-hero-poly, .lm-hero-poly-img y
   .lm-hero-copy se eliminaron en la Fase B del refactor — todos los
   momentos pasaron al hero compacto (.lm-calc-hero, definido más
   abajo). Si en el futuro se reintroduce un hero polaroid en algún
   momento, hay que reescribir el CSS desde cero, no resucitar el
   antiguo "por coincidencia". */
.lm-h1 {
  font-family: var(--font-sans);
  font-size: clamp(40px, 6vw, 64px);
  font-weight: 500;
  letter-spacing: -0.035em;
  line-height: 1.0;
  color: var(--ink);
  margin: 16px 0 18px;
}
.lm-h1 .lm-num {
  font-family: var(--font-hand);
  font-weight: 700;
  color: var(--ink-pen);
  font-size: 1.05em;
  letter-spacing: -0.01em;
}
.lm-h1 .land-h2-hand {
  display: inline-block;
  font-size: 1.05em;
}
.lm-hero-sub {
  font-family: var(--font-sans);
  font-size: 17px;
  line-height: 1.55;
  color: var(--ink-soft);
  margin-bottom: 24px;
  max-width: 520px;
}

/* Post-it badge "IRPF + SS · 20-25%" */
.lm-hero-badge {
  position: relative;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding: 14px 24px 16px;
  background: linear-gradient(180deg, #FFF59D 0%, #FFE873 100%);
  border-radius: 3px;
  box-shadow:
    0 1px 1px rgba(8, 48, 76, 0.08),
    0 8px 16px -6px rgba(8, 48, 76, 0.22);
  transform: rotate(-3deg);
  text-decoration: none;
  color: var(--ink);
  transition: transform 0.45s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.lm-hero-badge:hover { transform: rotate(0deg) translateY(-2px); }
.lm-hero-badge-tape {
  position: absolute;
  top: -6px;
  right: 10px;
  width: 32px;
  height: 12px;
  background: rgba(255, 107, 71, 0.50);
  border-left: 1px solid rgba(255, 107, 71, 0.55);
  border-right: 1px solid rgba(255, 107, 71, 0.55);
  transform: rotate(22deg);
  border-radius: 1px;
}
.lm-hero-badge-label {
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.lm-hero-badge-num {
  font-family: var(--font-hand);
  font-size: 36px;
  font-weight: 700;
  color: var(--ink-pen);
  line-height: 1;
}
.lm-hero-badge-sub {
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--ink-soft);
}

/* ═══════ SECCIONES GENÉRICAS ═══════ */
.lm-section {
  max-width: 1100px;
  margin: 0 auto;
  padding: 60px 30px;
  text-align: center;
}
.lm-section .land-h2 {
  margin: 0 auto 20px;
  max-width: 760px;
}
.lm-desc {
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.6;
  color: var(--ink-soft);
  max-width: 580px;
  margin: 0 0 26px;
  text-align: left;
}
.lm-desc-center {
  text-align: center;
  margin: 0 auto 36px;
}

/* Layout split (texto + media) */
.lm-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
  text-align: left;
}
.lm-split-reverse .lm-split-text { order: 2; }
.lm-split-reverse .lm-split-media { order: 1; }
@media (max-width: 860px) {
  .lm-split { grid-template-columns: 1fr; gap: 40px; }
  .lm-split-reverse .lm-split-text,
  .lm-split-reverse .lm-split-media { order: initial; }
}
.lm-split-text .land-eyebrow { margin-bottom: 14px; }
.lm-split-text .land-h2 { margin-bottom: 14px; text-align: left; }

/* ═══════ CHECKS DIBUJADOS A MANO ═══════ */
.lm-checks {
  list-style: none;
  padding: 0;
  margin: 26px 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
  text-align: left;
  max-width: 560px;
}
.lm-section[id="concepto"] .lm-checks { margin-left: auto; margin-right: auto; }
.lm-checks li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-family: var(--font-sans);
  font-size: 15.5px;
  line-height: 1.55;
  color: var(--ink);
}
.lm-checks li strong {
  font-weight: 600;
  color: var(--ink);
}
.lm-check {
  flex: 0 0 24px;
  width: 24px;
  height: 24px;
  margin-top: -1px;
}
.lm-checks li:nth-child(odd) .lm-check { transform: rotate(-3deg); }
.lm-checks li:nth-child(even) .lm-check { transform: rotate(2deg); }

/* ═══════ SLIDER NOTEPAD (Sección 01) ═══════ */
.lm-slider-notepad {
  position: relative;
  max-width: 640px;
  margin: 36px auto 0;
  padding: 32px 36px 28px 56px;
  background:
    linear-gradient(to right,
      transparent 0,
      transparent 36px,
      rgba(220, 60, 60, 0.45) 36px,
      rgba(220, 60, 60, 0.45) 37.5px,
      transparent 37.5px),
    repeating-linear-gradient(to bottom,
      transparent 0,
      transparent 27px,
      rgba(70, 120, 180, 0.20) 27px,
      rgba(70, 120, 180, 0.20) 28px),
    #FFFFFF;
  border-radius: 3px;
  box-shadow:
    0 1px 1px rgba(8, 48, 76, 0.06),
    0 14px 32px -10px rgba(8, 48, 76, 0.18);
  transform: rotate(-0.4deg);
  text-align: left;
}
.lm-slider-tape {
  position: absolute;
  top: -8px;
  left: 28px;
  width: 70px;
  height: 16px;
  background: rgba(99, 102, 241, 0.42);
  border-left: 1px solid rgba(99, 102, 241, 0.50);
  border-right: 1px solid rgba(99, 102, 241, 0.50);
  transform: rotate(-4deg);
  border-radius: 1px;
  box-shadow: 0 1px 2px rgba(8, 48, 76, 0.10);
}
.lm-slider-label-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--ink-soft);
  margin-bottom: 12px;
}
.lm-slider-label-row strong {
  font-family: var(--font-hand);
  font-size: 24px;
  font-weight: 700;
  color: var(--ink-pen);
}
.lm-range {
  width: 100%;
  height: 6px;
  -webkit-appearance: none;
  appearance: none;
  background: rgba(8, 48, 76, 0.12);
  border-radius: 3px;
  outline: none;
  margin-bottom: 18px;
}
.lm-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--mk-coral);
  cursor: pointer;
  border: 2px solid #fff;
  box-shadow: 0 2px 6px rgba(8, 48, 76, 0.25);
}
.lm-range::-moz-range-thumb {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--mk-coral);
  cursor: pointer;
  border: 2px solid #fff;
  box-shadow: 0 2px 6px rgba(8, 48, 76, 0.25);
}
.lm-slider-results {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 8px;
}
@media (max-width: 600px) {
  .lm-slider-results { grid-template-columns: 1fr; gap: 10px; }
}
.lm-sresult {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.lm-sresult-label {
  font-family: var(--font-sans);
  font-size: 12px;
  color: var(--ink-muted);
}
.lm-sresult-val {
  font-family: var(--font-hand);
  font-size: 22px;
  font-weight: 700;
  color: var(--ink);
}
.lm-sresult-highlight { color: var(--mk-coral); }

/* ═══════ NÓMINA MOCKUP (Sección 02) ═══════ */
.lm-nomina-paper {
  position: relative;
  padding: 32px 28px 28px;
  background: #FFFFFF;
  border-radius: 3px;
  box-shadow:
    0 1px 1px rgba(8, 48, 76, 0.06),
    0 16px 36px -10px rgba(8, 48, 76, 0.22);
  transform: rotate(1deg);
  max-width: 380px;
  margin: 0 auto;
}
.lm-nomina-clip {
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  width: 36px;
  height: 26px;
  background:
    linear-gradient(180deg, #C0C7CC 0%, #8B9298 100%);
  border-radius: 4px 4px 2px 2px;
  box-shadow: 0 2px 4px rgba(8, 48, 76, 0.20);
}
.lm-nomina-clip::before {
  content: "";
  position: absolute;
  inset: 4px 6px 8px 6px;
  background: rgba(255, 255, 255, 0.30);
  border-radius: 2px;
}
.lm-nm-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding-bottom: 10px;
  margin-bottom: 14px;
  border-bottom: 1px solid rgba(8, 48, 76, 0.10);
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--ink-soft);
}
.lm-nm-header strong {
  font-size: 16px;
  color: var(--ink);
  font-weight: 600;
}
.lm-nm-section {
  font-family: var(--font-sans);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin: 14px 0 6px;
}
.lm-nm-row {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--ink);
  padding: 5px 0;
  border-bottom: 1px dashed rgba(8, 48, 76, 0.06);
}
.lm-nm-row:last-child { border-bottom: none; }
.lm-nm-subtotal {
  font-weight: 600;
  padding-top: 8px;
  border-top: 1px solid rgba(8, 48, 76, 0.10);
}
.lm-nm-minus span:last-child { color: rgba(220, 60, 60, 0.80); }
.lm-nm-neto {
  font-family: var(--font-hand);
  font-size: 22px;
  font-weight: 700;
  color: var(--ink-pen);
  padding-top: 12px;
  border-top: 2px solid var(--ink);
  margin-top: 8px;
}
.lm-nm-neto span:last-child { color: var(--mk-coral); }

/* ═══════ TRAMOS IRPF (Sección 03) ═══════ */
.lm-tramos-paper {
  padding: 28px 28px 24px;
  background: linear-gradient(180deg, #FFF8C4 0%, #FFEC8A 100%);
  border-radius: 3px;
  box-shadow:
    0 1px 1px rgba(8, 48, 76, 0.06),
    0 14px 30px -10px rgba(8, 48, 76, 0.20);
  transform: rotate(-0.7deg);
  max-width: 520px;
  margin: 0 auto;
}
.lm-tramos-title {
  font-family: var(--font-hand);
  font-size: 22px;
  font-weight: 700;
  color: var(--ink-pen);
  margin-bottom: 14px;
}
/* Tramos como trazos de rotulador grueso pill — bordes redondeados,
   ligera rotación orgánica, % dentro de la propia barra al final
   en blanco. */
.lm-tramo {
  display: grid;
  grid-template-columns: 150px 1fr;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
  font-family: var(--font-sans);
  font-size: 13px;
}
.lm-tramo-range {
  color: var(--ink-soft);
  font-weight: 500;
  white-space: nowrap; /* nunca dividir el rango en dos lineas */
}
.lm-tramo-bar-wrap {
  position: relative;
  height: 22px;
  background: rgba(8, 48, 76, 0.05);
  border-radius: 12px;
  overflow: visible;
}
/* Barra pill — esquinas redondeadas, gradiente coral simple,
   filter rough para microondulación de boli, rotación leve
   per-tramo para feel orgánico. */
.lm-tramo-bar {
  position: relative;
  height: 100%;
  background: linear-gradient(90deg,
    rgba(255, 107, 71, 0.92) 0%,
    rgba(255, 107, 71, 1) 100%);
  border-radius: 12px;
  filter: url(#rough);
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.lm-tramo-bar--top {
  background: linear-gradient(90deg,
    rgba(255, 107, 71, 0.95) 0%,
    rgba(220, 60, 28, 1) 100%);
}
/* % dentro de la barra, al extremo derecho, texto blanco */
.lm-tramo-pct {
  font-family: var(--font-hand);
  font-size: 17px;
  font-weight: 700;
  color: #fff;
  padding-right: 10px;
  line-height: 1;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.18);
}
.lm-tramos-note {
  font-family: var(--font-sans);
  font-size: 12px;
  color: var(--ink-muted);
  margin-top: 16px;
  font-style: italic;
  line-height: 1.5;
}

/* ═══════ CALCULADORA COMPLETA (Sección 04) ═══════ */
.lm-calc { max-width: 1100px; }
.lm-calc-grid {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 40px;
  margin-top: 24px;
  text-align: left;
}
@media (max-width: 900px) {
  .lm-calc-grid { grid-template-columns: 1fr; }
}

.lm-calc-input {
  padding: 32px 32px 28px;
  background:
    repeating-linear-gradient(to bottom,
      transparent 0,
      transparent 27px,
      rgba(70, 120, 180, 0.18) 27px,
      rgba(70, 120, 180, 0.18) 28px),
    #FFFFFF;
  border-radius: 3px;
  box-shadow:
    0 1px 1px rgba(8, 48, 76, 0.06),
    0 14px 30px -10px rgba(8, 48, 76, 0.20);
  transform: rotate(-0.4deg);
}
.lm-calc-input h3 {
  font-family: var(--font-hand);
  font-size: 28px;
  font-weight: 700;
  color: var(--ink-pen);
  margin: 0 0 18px;
}
.lm-calc-input .input-group { margin-bottom: 18px; }
.lm-calc-input label {
  display: block;
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--ink-soft);
  margin-bottom: 6px;
  font-weight: 500;
}
.lm-calc-slider-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}
.lm-calc-slider-row strong {
  font-family: var(--font-hand);
  font-size: 22px;
  font-weight: 700;
  color: var(--ink-pen);
}
.lm-input {
  width: 100%;
  padding: 10px 12px;
  font-family: var(--font-sans);
  font-size: 15px;
  color: var(--ink);
  background: rgba(255, 255, 255, 0.85);
  border: 1.5px solid rgba(8, 48, 76, 0.15);
  border-radius: 2px;
  outline: none;
  transition: border-color 0.2s ease;
}
.lm-input:focus { border-color: var(--mk-coral); }
.ps-pagas-toggle { display: flex; gap: 8px; }
.ps-pagas-btn {
  flex: 1;
  padding: 8px 14px;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 600;
  color: var(--ink-soft);
  background: rgba(255, 255, 255, 0.7);
  border: 1.5px solid rgba(8, 48, 76, 0.12);
  border-radius: 2px;
  cursor: pointer;
  transition: all 0.2s ease;
}
.ps-pagas-btn:hover { border-color: var(--mk-coral); }
.ps-pagas-btn.active {
  background: var(--ink-pen);
  color: #fff;
  border-color: var(--ink-pen);
}
.ps-pagas-note {
  font-family: var(--font-sans);
  font-size: 12px;
  color: var(--ink-muted);
  margin-top: 8px;
  font-style: italic;
  line-height: 1.5;
}
.lm-calc-extra {
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid rgba(8, 48, 76, 0.10);
}
.lm-calc-extra-row {
  display: flex;
  justify-content: space-between;
  padding: 6px 0;
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--ink-soft);
}
.lm-calc-extra-row strong {
  font-family: var(--font-hand);
  font-size: 18px;
  color: var(--ink-pen);
}

/* Panel resultado — post-it grande */
.lm-calc-result {
  position: relative;
  padding: 38px 32px 28px;
  background: linear-gradient(180deg, #FFF59D 0%, #FFE873 100%);
  border-radius: 3px;
  box-shadow:
    0 1px 1px rgba(8, 48, 76, 0.08),
    0 14px 32px -10px rgba(8, 48, 76, 0.22);
  transform: rotate(0.8deg);
}
.lm-calc-result-tape {
  position: absolute;
  top: -8px;
  left: 50%;
  width: 76px;
  height: 18px;
  background: rgba(255, 107, 71, 0.50);
  border-left: 1px solid rgba(255, 107, 71, 0.55);
  border-right: 1px solid rgba(255, 107, 71, 0.55);
  transform: translateX(-50%) rotate(-3deg);
  border-radius: 1px;
  box-shadow: 0 1px 2px rgba(8, 48, 76, 0.10);
}
.lm-result-highlight {
  text-align: center;
  padding-bottom: 22px;
  margin-bottom: 20px;
  border-bottom: 2px dashed rgba(8, 48, 76, 0.20);
}
.lm-result-highlight .result-label {
  display: block;
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: 8px;
}
.lm-result-big {
  display: block;
  font-family: var(--font-hand);
  font-size: 64px;
  font-weight: 700;
  line-height: 1;
  color: var(--ink-pen);
  margin: 4px 0 6px;
}
.lm-result-highlight .result-note {
  display: block;
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--ink-soft);
  font-style: italic;
}

.lm-desglose .desglose-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 8px 0;
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--ink);
  border-bottom: 1px dashed rgba(8, 48, 76, 0.10);
}
.lm-desglose .desglose-row:last-child { border-bottom: none; }
.lm-desglose .desglose-concepto { display: flex; align-items: center; gap: 4px; }
.lm-desglose .desglose-tag {
  display: inline-block;
  width: 18px;
  text-align: center;
  font-weight: 700;
}
/* Paleta del desglose armonizada con el amarillo del post-it.
   3 hues distintos para mantener diferenciación semántica:
   - Negativos: coral terracota (warm — dinero que sale)
   - Positivos: verde forest oscuro (no mint brillante — dinero que llega)
   - Categorías secundarias: indigo (Seg. Social)
   Los 3 tonos están suficientemente saturados/oscuros para armonizar
   con el amarillo (sin neón) y son hue-distintos entre sí. */
.lm-desglose .desglose-tag--plus { color: #1F6B3B; }
.lm-desglose .desglose-pct {
  font-size: 12px;
  color: var(--ink-muted);
  margin-left: 4px;
}
.lm-desglose .desglose-valor {
  font-family: var(--font-hand);
  font-size: 18px;
  font-weight: 700;
  color: var(--ink);
}
.lm-desglose .desglose-minus { color: rgba(180, 70, 50, 0.90); }
.lm-desglose .desglose-green { color: #1F6B3B; }
.lm-desglose .desglose-neto {
  padding-top: 12px;
  /* Separador suave (ink-soft) en vez de negro puro */
  border-top: 1.5px solid rgba(8, 48, 76, 0.30);
  margin-top: 4px;
}

/* Barra visual: green forest para Neto, coral para IRPF, indigo para SS.
   3 hues distintos (cool-green, warm-orange, cool-blue) — facil diferenciar.
   Border-radius pill + gap entre segmentos para feel "rotuladores separados",
   no progress bar. */
.lm-barra {
  display: flex;
  gap: 3px;
  height: 14px;
  margin-top: 18px;
  background: transparent;
}
.lm-barra .barra-segmento {
  height: 100%;
  border-radius: 999px;
  filter: url(#rough);
}
.lm-barra .barra-neto { background: #1F6B3B; }
.lm-barra .barra-irpf { background: var(--mk-coral); }
.lm-barra .barra-ss { background: var(--mk-indigo); }
.lm-leyenda {
  display: flex;
  gap: 18px;
  justify-content: center;
  margin-top: 10px;
  font-family: var(--font-sans);
  font-size: 12px;
  color: var(--ink-soft);
}
.lm-leyenda .dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  margin-right: 4px;
  vertical-align: middle;
}
.lm-leyenda .dot-neto { background: #1F6B3B; }
.lm-leyenda .dot-irpf { background: var(--mk-coral); }
.lm-leyenda .dot-ss { background: var(--mk-indigo); }

/* Variante de barra para no-me-llega: necesidades / caprichos / futuro.
   Mantiene el mismo lenguaje cromático (3 hues distintos, no traffic light):
   - Necesidades  → indigo (cool, "lo serio")
   - Caprichos    → coral (warm, "lo divertido")
   - Futuro       → verde forest (lo que ahorras) */
.lm-barra .barra-necesidades { background: var(--mk-indigo); }
.lm-barra .barra-caprichos   { background: var(--mk-coral); }
.lm-barra .barra-futuro      { background: #1F6B3B; }
.lm-leyenda .dot-necesidades { background: var(--mk-indigo); }
.lm-leyenda .dot-caprichos   { background: var(--mk-coral); }
.lm-leyenda .dot-futuro      { background: #1F6B3B; }

/* Variante de barra para comprar-coche: coche / intereses / gastos.
   - Coche      → indigo (la inversión principal)
   - Intereses  → coral (el "dolor" del préstamo)
   - Gastos × 5 → verde forest (gasto recurrente del uso) */
.lm-barra .barra-cc-coche     { background: var(--mk-indigo); }
.lm-barra .barra-cc-intereses { background: var(--mk-coral); }
.lm-barra .barra-cc-gastos    { background: #1F6B3B; }
.lm-leyenda .dot-cc-coche     { background: var(--mk-indigo); }
.lm-leyenda .dot-cc-intereses { background: var(--mk-coral); }
.lm-leyenda .dot-cc-gastos    { background: #1F6B3B; }

/* Variante para tarjeta-credito: principal (deuda) / intereses pagados. */
.lm-barra .barra-tc-principal  { background: var(--mk-indigo); }
.lm-barra .barra-tc-intereses  { background: var(--mk-coral); }
.lm-leyenda .dot-tc-principal  { background: var(--mk-indigo); }
.lm-leyenda .dot-tc-intereses  { background: var(--mk-coral); }

/* Variante para irme-de-casa: vivienda / vida / ahorro. */
.lm-barra .barra-idc-viv     { background: var(--mk-indigo); }
.lm-barra .barra-idc-vida    { background: var(--mk-coral); }
.lm-barra .barra-idc-ahorro  { background: #1F6B3B; }
.lm-leyenda .dot-idc-viv     { background: var(--mk-indigo); }
.lm-leyenda .dot-idc-vida    { background: var(--mk-coral); }
.lm-leyenda .dot-idc-ahorro  { background: #1F6B3B; }

/* Variante para comprar-piso: capital + intereses + impuestos&gastos. */
.lm-barra .barra-cp-capital    { background: var(--mk-indigo); }
.lm-barra .barra-cp-intereses  { background: var(--mk-coral); }
.lm-barra .barra-cp-gastos     { background: #1F6B3B; }
.lm-leyenda .dot-cp-capital    { background: var(--mk-indigo); }
.lm-leyenda .dot-cp-intereses  { background: var(--mk-coral); }
.lm-leyenda .dot-cp-gastos     { background: #1F6B3B; }

/* Variante para futuro: aportación tuya / intereses ganados con tiempo. */
.lm-barra .barra-fut-aporte    { background: var(--mk-indigo); }
.lm-barra .barra-fut-intereses { background: #1F6B3B; }
.lm-leyenda .dot-fut-aporte    { background: var(--mk-indigo); }
.lm-leyenda .dot-fut-intereses { background: #1F6B3B; }

/* Variante para autonomo: neto que te queda / cuota / gastos. */
.lm-barra .barra-au-neto    { background: #1F6B3B; }
.lm-barra .barra-au-cuota   { background: var(--mk-coral); }
.lm-barra .barra-au-gastos  { background: var(--mk-indigo); }
.lm-leyenda .dot-au-neto    { background: #1F6B3B; }
.lm-leyenda .dot-au-cuota   { background: var(--mk-coral); }
.lm-leyenda .dot-au-gastos  { background: var(--mk-indigo); }

/* ═══════ NAVEGACIÓN LINEAL (anterior/siguiente) ═══════
   Anula el margin: 28px 0 0 auto del .land-mini-cta base, que está
   pensado para alinear UN CTA a la derecha en la home. En las páginas
   de momentos van DOS CTAs como pareja centrada — el margin auto los
   separaba a los extremos. Aquí dejamos que el flex padre los junte. */
.lm-section .land-mini-cta {
  margin: 0;
}

/* ═══════ HERO de página de calculadora standalone ═══════
   Más sobrio que el hero de momento — sin polaroid, solo texto
   centrado con eyebrow + H1 + lead. Compacto para que la calculadora
   asome sin tener que hacer scroll (above the fold en laptop). */
.lm-calc-hero {
  display: block;
  text-align: center;
  padding: 30px 30px 12px;
  max-width: 920px;
  margin: 0 auto;
}
.lm-calc-hero .land-eyebrow {
  display: inline-block;
  margin-bottom: 14px;
}
.lm-calc-h1 {
  margin: 0 auto 14px;
  max-width: 820px;
  text-align: center;
  font-size: clamp(28px, 4.2vw, 48px);
  line-height: 1.05;
}
.lm-calc-hero .lm-hero-sub {
  font-size: 15px;
  line-height: 1.5;
  margin: 0 auto;
  max-width: 600px;
}

/* Scroll hint debajo del hero, antes de la calculadora.
   Pequeña flecha animada que invita a bajar a la calculadora.
   Disappears (suavemente) cuando el user empieza a bajar. */
.lm-scroll-hint {
  display: block;
  margin: 18px auto 0;
  padding: 8px 18px;
  text-align: center;
  font-family: var(--font-hand);
  font-size: 19px;
  color: var(--ink-soft);
  text-decoration: none;
  letter-spacing: 0.005em;
  animation: scrollBob 2.4s ease-in-out infinite;
  cursor: pointer;
  transition: color 0.25s ease;
}
.lm-scroll-hint:hover { color: var(--mk-coral); }
.lm-scroll-hint-arrow {
  display: inline-block;
  margin-left: 6px;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 17px;
  transform: translateY(2px);
}
@keyframes scrollBob {
  0%, 100% { transform: translateY(0); opacity: 0.80; }
  50%      { transform: translateY(8px); opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  .lm-scroll-hint { animation: none; }
}
/* Oculto cuando #calculadora entra en viewport (lo decide el JS).
   Apple HIG (Motion): la animación debe tener narrativa.
   Una vez el usuario ve la calculadora, la flecha estorba. */
.lm-scroll-hint--hidden {
  animation: none;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.45s ease;
}

/* Calculadora: reducir el padding-top para que asome más */
.lm-calc-hero + .lm-section.lm-calc,
.lm-calc-hero ~ .lm-section.lm-calc {
  padding-top: 20px;
}

/* ═══════ CTA a calculadora standalone (dentro de momento) ═══════
   Reemplaza el bloque calculadora dentro del momento. La calculadora
   completa vive ahora SOLO en /calculadoras/. El momento es educativo,
   la calculadora es operativa.  */
.lm-calc-cta {
  max-width: 760px;
  text-align: center;
  padding: 60px 30px;
}
.lm-calc-cta .land-h2 {
  margin: 14px auto 16px;
}
.lm-calc-cta .lm-desc {
  margin: 0 auto 26px;
}

/* ═══════ BREADCRUMB ═══════
   Indicador de posición discreto bajo el navbar. Da contexto sin
   competir con el hero. Don't Make Me Think — usuario sabe siempre
   dónde está dentro de la estructura. */
.lm-breadcrumb {
  max-width: 1100px;
  margin: 12px auto 0;
  padding: 0 30px;
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--ink-soft);
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.lm-breadcrumb a {
  color: var(--ink-soft);
  text-decoration: none;
  transition: color 0.2s ease;
}
.lm-breadcrumb a:hover {
  color: var(--mk-coral);
}
.lm-breadcrumb-sep {
  color: var(--ink-muted);
  font-weight: 600;
}
.lm-breadcrumb-current {
  color: var(--ink);
  font-weight: 500;
}

/* ═══════ PÁGINA LEGAL ═══════
   Bloques de texto sobrios sobre el fondo paper, separados por
   "Páginas" tipo notepad rayado. Texto serio pero respira. */
.legal-content {
  max-width: 760px;
  text-align: left;
}
.legal-content .legal-block {
  margin-bottom: 40px;
  padding: 28px 32px 24px 48px;
  background:
    linear-gradient(to right,
      transparent 0,
      transparent 32px,
      rgba(220, 60, 60, 0.30) 32px,
      rgba(220, 60, 60, 0.30) 33.5px,
      transparent 33.5px),
    repeating-linear-gradient(to bottom,
      transparent 0,
      transparent 28px,
      rgba(70, 120, 180, 0.12) 28px,
      rgba(70, 120, 180, 0.12) 29px),
    #FFFFFF;
  border-radius: 3px;
  box-shadow:
    0 1px 1px rgba(8, 48, 76, 0.05),
    0 10px 24px -8px rgba(8, 48, 76, 0.14);
}
.legal-content h2 {
  font-family: var(--font-hand);
  font-size: 26px;
  font-weight: 700;
  color: var(--ink-pen);
  margin: 0 0 14px;
}
.legal-content p {
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.65;
  color: var(--ink);
  margin: 0 0 12px;
}
.legal-content p:last-child {
  margin-bottom: 0;
}
.legal-content a {
  color: var(--mk-coral);
  text-decoration: underline;
  text-decoration-thickness: 1.5px;
  text-underline-offset: 2px;
}
.legal-content a:hover {
  color: var(--ink-pen);
}

/* ═══════ RECOMENDACIONES CONTEXTUALES ═══════
   Bloque "según tu resultado" que aparece al final de cada calculadora
   standalone. Tiene dos capas:
   1. .lm-consejo-paper: notepad rayado con consejo dinámico personalizado
      con los números reales del usuario.
   2. .lm-reco-list: 1-2 post-its de momentos relacionados para profundizar.

   Los textos los actualiza el JS de cada calculadora. Cuando no hay
   recomendaciones todavía, el .lm-reco-list está vacío y el consejo
   muestra un placeholder de invitación. */

/* Eyebrow propio del bloque recomendaciones — más prominente y centrado.
   Reemplaza el H2 grande que dominaba demasiado. El notepad es el protagonista. */
.lm-section.lm-reco {
  padding-top: 30px; /* reduce el aire entre calculadora y consejo */
}
.lm-reco-eyebrow {
  display: inline-block;
  margin-bottom: 22px;
}

/* Cartelito intermedio entre el notepad de consejo y los post-its
   de momentos. Genera jerarquía: el consejo es lo principal,
   los post-its son "esto también te ayuda" — opcional, para
   profundizar. Necesita aire arriba para separar del notepad. */
.lm-reco-eyebrow-secundario {
  margin-top: 56px;
  margin-bottom: 28px;
}
.lm-reco .lm-postits {
  margin-top: 0; /* el eyebrow ya da espacio */
}

/* Notepad de consejo personalizado — más ancho y prominente */
.lm-consejo-paper {
  position: relative;
  max-width: 820px;
  margin: 0 auto 40px;
  padding: 36px 44px 32px 64px;
  background:
    linear-gradient(to right,
      transparent 0,
      transparent 46px,
      rgba(220, 60, 60, 0.40) 46px,
      rgba(220, 60, 60, 0.40) 47.5px,
      transparent 47.5px),
    repeating-linear-gradient(to bottom,
      transparent 0,
      transparent 30px,
      rgba(70, 120, 180, 0.18) 30px,
      rgba(70, 120, 180, 0.18) 31px),
    #FFFFFF;
  border-radius: 3px;
  box-shadow:
    0 1px 1px rgba(8, 48, 76, 0.06),
    0 18px 38px -10px rgba(8, 48, 76, 0.22);
  transform: rotate(-0.4deg);
  text-align: left;
}
.lm-consejo-tape {
  position: absolute;
  top: -9px;
  left: 50%;
  width: 84px;
  height: 18px;
  background: rgba(255, 107, 71, 0.50);
  border-left: 1px solid rgba(255, 107, 71, 0.55);
  border-right: 1px solid rgba(255, 107, 71, 0.55);
  transform: translateX(-50%) rotate(-2deg);
  border-radius: 1px;
  box-shadow: 0 1px 2px rgba(8, 48, 76, 0.10);
}
.lm-consejo-main {
  font-family: var(--font-hand);
  font-size: 24px;
  font-weight: 700;
  line-height: 1.25;
  color: var(--ink-pen);
  margin: 0 0 14px;
  letter-spacing: -0.005em;
}
.lm-consejo-action {
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.55;
  color: var(--ink);
  margin: 0;
}
.lm-consejo-action:empty {
  display: none;
}
.lm-consejo-action strong {
  color: var(--mk-coral);
  font-weight: 600;
}
@media (max-width: 600px) {
  .lm-consejo-paper {
    padding: 28px 24px 24px 44px;
    background-size: 100% auto;
  }
  .lm-consejo-main { font-size: 20px; }
  .lm-consejo-action { font-size: 14px; }
}

/* Post-its de momentos al final — solo aparecen si JS los rellena */
.lm-reco .lm-reco-list {
  min-height: 0;
}
.lm-reco .lm-reco-list:empty {
  display: none;
}

/* Verdicto icono compartido (lo mismo que no-me-llega) — reduce peso visual */
.lm-result-highlight #idcVerdictoIcono,
.lm-result-highlight #cpVerdictoIcono {
  font-size: 48px;
  line-height: 1;
  margin: 2px 0 8px;
  color: var(--ink-pen);
}

/* En no-me-llega el "result-big" no es un €€€, es un icono cualitativo
   (✓ / ~ / · / !). Reducimos peso visual para que no compita con
   el desglose y la barra, que son los datos verdaderamente útiles. */
.lm-result-highlight #nmlVerdictoIcono {
  font-size: 48px;
  line-height: 1;
  margin: 2px 0 8px;
  color: var(--ink-pen);
}

/* ═══════ EMPEZAR A AHORRAR · CHART INLINE ═══════ */
.ea-chart-wrap {
  margin-top: 22px;
  padding-top: 18px;
  border-top: 2px dashed rgba(8, 48, 76, 0.18);
}
.ea-chart {
  width: 100%;
  height: 130px;
  display: block;
}
.ea-chart-legend {
  display: flex;
  gap: 18px;
  justify-content: center;
  margin-top: 8px;
  font-family: var(--font-sans);
  font-size: 12px;
  color: var(--ink-soft);
}
.ea-chart-legend .dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  margin-right: 4px;
  vertical-align: middle;
}

/* ═══════ POST-ITS GRANDES (Sección 05) ═══════ */
.lm-postits {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 36px 28px;
  max-width: 1000px;
  margin: 30px auto 0;
}
@media (max-width: 860px) {
  .lm-postits { grid-template-columns: 1fr; }
}
.lm-postit {
  text-align: left;
  padding: 32px 26px 28px;
}
.lm-postit h3 {
  font-family: var(--font-hand);
  font-size: 26px;
  font-weight: 700;
  color: var(--ink-pen);
  margin: 0 0 10px;
  line-height: 1.1;
}
.lm-postit p {
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 1.6;
  color: var(--ink);
  margin: 0;
}
.lm-postit[data-c="yellow"] { background: var(--postit-yellow, #F5E69A); }
.lm-postit[data-c="pink"]   { background: var(--postit-pink, #F2D1D6); }
.lm-postit[data-c="blue"]   { background: var(--postit-blue, #CADBE9); }
.lm-postit:nth-child(1) { transform: rotate(-1.6deg); }
.lm-postit:nth-child(2) { transform: rotate(1.2deg); }
.lm-postit:nth-child(3) { transform: rotate(-0.6deg); }
.lm-postit:hover { transform: rotate(0deg) !important; }

/* A11y (WCAG 1.4.11): separador entre segmentos de barra. */
.lm-barra .barra-segmento:not(:last-child) { box-shadow: 2px 0 0 0 #FCFCFC; }
