/* Hemeroteca predictiva · #76 WOW F */

.hp-modal { display: flex; flex-direction: column; gap: 16px; }
.hp-resumen {
  background: linear-gradient(135deg, #f0f7ff 0%, #fff 100%);
  border: 1px solid #cfe1ff; border-radius: 10px;
  padding: 12px 16px;
}
.hp-evento { font-size: 15px; font-weight: 700; color: var(--brand); }
.hp-ctx { font-size: 12px; color: #506080; margin-top: 4px; }
.hp-coste { margin-left: 12px; font-style: italic; color: #94a0b5; }

.hp-section { background: #fff; border: 1px solid #e2e6ec; border-radius: 10px; padding: 14px 16px; }
.hp-section h3 { margin: 0 0 12px; font-size: 14px; color: var(--brand); }
.hp-section-risks { background: #fef9f2; border-color: #e8c4a0; }
.hp-section-risks h3 { color: #c0792a; }
.hp-section-reco { background: #f0fdf4; border-color: #b8e0c4; }
.hp-section-reco h3 { color: #166534; }
.hp-section-reco p { margin: 0; font-size: 15px; line-height: 1.5; }

.hp-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.hp-table th { text-align: left; color: #506080; font-weight: 600; padding: 6px 8px; border-bottom: 1px solid #e2e6ec; }
.hp-table td { padding: 8px; border-bottom: 1px solid #f1f3f7; vertical-align: top; }
.hp-table tr:last-child td { border-bottom: 0; }
.hp-razon { color: #506080; font-size: 12px; }

.hp-chip {
  display: inline-block; padding: 2px 8px; border-radius: 999px;
  font-size: 11px; font-weight: 700; letter-spacing: .03em;
}

.hp-titular {
  background: #fafbfd; border-left: 3px solid #cfe1ff;
  border-radius: 6px; padding: 10px 12px; margin-bottom: 10px;
}
.hp-titular:last-child { margin-bottom: 0; }
.hp-titular-head { display: flex; align-items: center; gap: 8px; font-size: 12px; color: #506080; margin-bottom: 4px; }
.hp-titular-medio { font-weight: 600; }
.hp-titular-text { font-size: 15px; font-weight: 500; line-height: 1.4; color: #2a3548; font-style: italic; }

.hp-risks { margin: 0; padding-left: 20px; }
.hp-risks li { font-size: 14px; line-height: 1.5; color: #6b3f1a; margin: 6px 0; }

.hp-loading { text-align: center; padding: 50px 30px; color: #506080; }
.hp-spinner {
  width: 36px; height: 36px;
  border: 3px solid #cfe1ff; border-top-color: var(--brand);
  border-radius: 50%; margin: 0 auto 16px;
  animation: hp-spin 0.8s linear infinite;
}
@keyframes hp-spin { to { transform: rotate(360deg); } }
.hp-error { padding: 30px; text-align: center; color: #991b1b; }
.hp-error h3 { margin: 0 0 8px; }
