/*
  Estilos reutilizables para articulos de guia
  Base: plantilla-articulo-afiliacion.css
*/

.guide-shell {
  display: grid;
  gap: 1.15rem;
}

.guide-lead {
  margin: 0;
  font-size: 1.03rem;
  line-height: 1.72;
  color: var(--text-secondary);
  max-width: 72ch;
}

.guide-section-card {
  display: grid;
  gap: 0.7rem;
}

.guide-section-card h3 {
  margin: 0;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.35rem;
  color: var(--brand);
}

.guide-section-card p {
  margin: 0;
  color: var(--text-secondary);
  line-height: 1.68;
}

.guide-grid-2 {
  display: grid;
  gap: 1rem;
  align-items: stretch;
}

.guide-grid-2 > * {
  width: 100%;
  height: 100%;
}

.note-box {
  border-left: 4px solid var(--brand);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  background: linear-gradient(135deg, rgba(22, 56, 91, 0.08), rgba(255, 255, 255, 0.95));
  padding: 1rem 1.1rem;
}

.note-box p {
  margin: 0;
  color: var(--text-primary);
  font-size: 0.95rem;
  line-height: 1.65;
}

.inline-cta {
  padding: 1.1rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: #f8fbff;
  display: grid;
  gap: 0.8rem;
}

.inline-cta p {
  margin: 0;
  color: var(--text-secondary);
}

.link-bridge {
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, rgba(22, 56, 91, 0.06), rgba(255, 255, 255, 0.95));
  box-shadow: var(--shadow-sm);
  padding: 1.2rem;
  display: grid;
  gap: 0.8rem;
}

.link-bridge h3 {
  margin: 0;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.4rem;
  color: var(--brand);
}

.link-bridge p {
  margin: 0;
  color: var(--text-secondary);
  line-height: 1.65;
}

.guide-examples {
  display: grid;
  gap: 1rem;
}

.guide-examples .example-card {
  border-radius: var(--radius-md);
}

.guide-examples .example-media {
  aspect-ratio: 16 / 10;
}

.media-showcase-frame {
  display: flex;
  justify-content: center;
  padding: 1.2rem 0;
}

.media-showcase-frame img {
  max-width: min(84%, 720px);
  width: 100%;
  border-radius: 20px;
  box-shadow: 0 20px 40px rgba(13, 23, 36, 0.12);
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}

.hero-actions .button {
  min-width: 250px;
}

.cta .button {
  min-width: 280px;
}

/* ── CTA inline post-sección ── */
.section-cta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem;
  margin-top: 1.4rem;
  padding: 0.9rem 1.1rem;
  border-radius: var(--radius-sm);
  background: rgba(22, 56, 91, 0.05);
  border: 1px solid rgba(22, 56, 91, 0.1);
}

.section-cta + .section-header {
  margin-top: 3.35rem;
}

.section-cta-text {
  font-size: 0.92rem;
  color: var(--text-secondary);
}

/* ── Recomendación rápida mid-article ── */
.mid-recommendation {
  border-radius: var(--radius-md);
  border: 2px solid rgba(245, 158, 11, 0.5);
  background: linear-gradient(135deg, #fffbf0 0%, #fff8e1 100%);
  box-shadow: 0 8px 24px rgba(245, 158, 11, 0.15);
  padding: 1.6rem;
  display: grid;
  gap: 1rem;
}

.mid-recommendation-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.28rem 0.72rem;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(245, 158, 11, 0.95), rgba(221, 138, 0, 0.9));
  color: #fff;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  width: fit-content;
}

.mid-recommendation-body {
  display: grid;
  gap: 0.75rem;
}

.mid-recommendation-body h3 {
  margin: 0;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.45rem;
  color: var(--brand);
}

.mid-recommendation-body p {
  margin: 0;
  color: var(--text-secondary);
  line-height: 1.65;
}

.mid-recommendation-rating {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  font-size: 0.9rem;
  font-weight: 700;
}

/* ── Bloque decision rapida ── */
.decision-rapida {
  display: grid;
  gap: 1rem;
  text-align: center;
  padding: 1.6rem;
  border-radius: var(--radius-md);
  border: 2px solid rgba(245, 158, 11, 0.52);
  background: linear-gradient(135deg, #fffaf0 0%, #fff4dc 100%);
  box-shadow: 0 12px 28px rgba(245, 158, 11, 0.18);
}

.decision-rapida-kicker {
  margin: 0;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--brand);
}

.decision-rapida-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.6rem;
}

.decision-rapida-list li {
  color: var(--text-secondary);
  line-height: 1.6;
}

.decision-rapida-cta {
  margin-inline: auto;
  min-width: 260px;
}

/* ── Errores comunes ── */
.errores-grid {
  display: grid;
  gap: 1rem;
}

.error-card {
  display: grid;
  gap: 0.6rem;
  border-left: 4px solid #ef4444;
  background: linear-gradient(135deg, rgba(239, 68, 68, 0.04), #fff);
}

.error-icon {
  font-size: 1.1rem;
  color: #ef4444;
  font-weight: 900;
  line-height: 1;
}

.error-card h3 {
  margin: 0;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.2rem;
  color: var(--brand);
}

.error-card p {
  margin: 0;
  color: var(--text-secondary);
  line-height: 1.65;
}

/* ── Enlace interno visible ── */
.internal-link-block {
  display: grid;
  gap: 0.75rem;
  margin-top: 1.4rem;
  padding: 1rem 1.15rem;
  border-radius: var(--radius-sm);
  background: rgba(22, 56, 91, 0.05);
  border: 1px solid rgba(22, 56, 91, 0.10);
}

.internal-link-block p {
  margin: 0;
  color: var(--text-secondary);
  line-height: 1.65;
}

.internal-link-block a:not(.button) {
  color: var(--brand);
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* ── CTA final agresivo ── */
.cta-aggressive {
  background: linear-gradient(135deg, var(--brand) 0%, #1a4f7a 100%);
  color: #fff;
  border-radius: var(--radius-md);
  padding: 2.8rem 2rem;
  text-align: center;
  display: grid;
  gap: 1.1rem;
  box-shadow: 0 20px 44px rgba(22, 56, 91, 0.3);
}

.cta-eyebrow {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.11em;
  opacity: 0.72;
  margin: 0;
}

.cta-aggressive h2 {
  margin: 0;
  font-family: "Rajdhani", sans-serif;
  font-size: clamp(1.5rem, 4vw, 2.1rem);
  color: #fff;
  line-height: 1.2;
}

.cta-aggressive p {
  margin: 0;
  opacity: 0.88;
  max-width: 58ch;
  margin-inline: auto;
  line-height: 1.65;
}

.cta-trust-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  font-size: 0.82rem;
  font-weight: 700;
  opacity: 0.85;
}

.cta-button-main {
  margin-inline: auto;
  background: #F59E0B !important;
  color: #1a1a1a !important;
  font-size: 1.05rem !important;
  padding: 0.9rem 2rem !important;
  box-shadow: 0 8px 20px rgba(245, 158, 11, 0.4) !important;
}

.cta-button-main:hover {
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 12px 28px rgba(245, 158, 11, 0.55) !important;
}

.cta-disclaimer {
  font-size: 0.74rem;
  opacity: 0.55;
  margin: 0;
}

@media (min-width: 760px) {
  .guide-grid-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .guide-examples {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .errores-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .mid-recommendation {
    grid-template-columns: auto 1fr;
    align-items: start;
  }
}
