/**************************************
 * Payment Page — Friendly Overrides
 **************************************/

/* Espaciado y ritmo tipográfico más suave */
.payment-intro h2,
.payment-methods h2,
.payment-plans h2,
.insurance-info h2,
.payment-security h2,
.payment-contact h2 {
  letter-spacing: .2px;
}

.payment-intro p,
.payment-methods p,
.payment-plans p,
.insurance-info p,
.payment-security p,
.payment-contact p {
  color: var(--text-light);
  font-size: 1.05rem;
}

/* Imagen introductoria con sombra suave */
.payment-intro img.img-fluid {
  border-radius: 16px;
  box-shadow: 0 10px 30px rgba(0,0,0,.10);
}

/* Tarjetas base (payment-card / plan-card / insurance-card) */
.payment-card,
.plan-card,
.insurance-card,
.security-info {
  background: #fff;
  border: 1px solid var(--border-color);
  border-radius: 16px;
  padding: 1.6rem;
  box-shadow: 0 8px 24px rgba(0,0,0,.06);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.payment-card:hover,
.plan-card:hover,
.insurance-card:hover,
.security-info:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 36px rgba(0,0,0,.10);
  border-color: rgba(18,33,77,.15);
}

/* Iconos dentro de tarjetas */
.payment-icon,
.plan-icon {
  width: 64px;
  height: 64px;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--primary-color), #1d2f6c);
  display: grid;
  place-items: center;
  color: #fff;
  margin: 0 auto 1rem;
  box-shadow: 0 10px 24px rgba(18,33,77,.25);
}
.payment-card h3,
.plan-card h3 {
  margin-top: .25rem;
  margin-bottom: .5rem;
}

/* Listas más amigables dentro de la página */
.payment-card ul,
.plan-card ul,
.insurance-card ul,
.security-info ul,
.billing-policies .policy-list,
.insurance-info .requirements-list {
  list-style: none;
  margin: .75rem 0 0;
  padding: 0;
  display: grid;
  gap: .45rem;
}

.payment-card li,
.plan-card li,
.insurance-card li,
.security-info li,
.billing-policies .policy-list li,
.insurance-info .requirements-list li {
  position: relative;
  padding-left: 26px;
  color: var(--text-dark);
}

.payment-card li::before,
.plan-card li::before,
.insurance-card li::before,
.security-info li::before,
.billing-policies .policy-list li::before,
.insurance-info .requirements-list li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--primary-color);
  font-weight: 700;
}

/* Listas de marcas (Visa, etc.) más limpias */
.card-list,
.digital-wallets {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: .4rem .8rem;
  align-items: center;
}
.card-list li i,
.digital-wallets li i {
  width: 20px;
  display: inline-block;
  text-align: center;
  opacity: .85;
  margin-right: .35rem;
}

/* Notas y microcopy */
.security-note,
.processing-note,
.convenience-note,
.note {
  font-size: .95rem;
  color: var(--text-light);
  margin-top: .5rem;
}

/* Sección de planes en fondo suave */
.payment-plans.bg-light {
  background: var(--light-gray);
}
.plan-card {
  text-align: left;
}
.plan-card h3 i { margin-right: .4rem; color: var(--primary-color); }

/* Insurance card más centrada/limpia */
.insurance-card {
  max-width: 860px;
  margin: 0 auto;
  text-align: left;
}

/* Seguridad: iconos alineados y agradables */
.security-icons {
  display: flex;
  gap: .8rem;
  justify-content: center;
  margin-bottom: .6rem;
}
.security-icons i {
  font-size: 1.25rem;
  background: rgba(18,33,77,.08);
  color: var(--primary-color);
  padding: .6rem;
  border-radius: 10px;
}

/* Contact options: tarjetas pequeñas y consistentes */
.payment-contact .contact-options {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px,1fr));
  gap: 1rem;
  margin-top: 1.2rem;
}
.payment-contact .contact-item {
  background: #fff;
  border: 1px solid var(--border-color);
  border-radius: 14px;
  padding: 1rem;
  box-shadow: 0 8px 24px rgba(0,0,0,.05);
  transition: transform .2s ease, box-shadow .2s ease;
}
.payment-contact .contact-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 32px rgba(0,0,0,.10);
}
.payment-contact .contact-item i {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: rgba(18,33,77,.08);
  color: var(--primary-color);
  margin-bottom: .5rem;
}

/* “Amabilidad” general para la página de pagos */
.payment-methods .payment-card,
.payment-plans .plan-card,
.insurance-info .insurance-card,
.payment-security .security-info {
  border-radius: 18px;
}

/* Encabezados secundarios un poco más suaves en móviles */
@media (max-width: 768px) {
  .payment-intro h2,
  .payment-methods h2,
  .payment-plans h2,
  .insurance-info h2,
  .payment-security h2,
  .payment-contact h2 {
    font-size: 1.75rem;
  }
  .payment-card,
  .plan-card,
  .insurance-card,
  .security-info {
    padding: 1.5rem;
  }
}

/* Pequeños detalles de color/acento en textos importantes */
.text-success { color: #0f9d58; }

/* Separadores suaves entre secciones para descansar la vista */
.payment-methods,
.payment-security,
.billing-policies {
  scroll-margin-top: 80px; /* ancla cómoda si usas links */
}
