/* ==========================================================================
   IBSC V6.48 — Auditoría visual y homologación pública
   Este archivo se carga al final y normaliza Inicio, Boletín y Qué creemos.
   ========================================================================== */

:root {
  --ibsc-blue: #0b2d4d;
  --ibsc-blue-2: #0f3b62;
  --ibsc-green: #123f36;
  --ibsc-cream: #f8f4ec;
  --ibsc-cream-2: #fbf8f1;
  --ibsc-gold: #c9a45c;
  --ibsc-gold-soft: #efe1b7;
  --ibsc-text: #1f2933;
  --ibsc-muted: #677284;
  --ibsc-border: rgba(11,45,77,.13);
  --ibsc-shadow: 0 18px 48px rgba(11,45,77,.12);
  --ibsc-radius-xl: 32px;
  --ibsc-radius-lg: 24px;
  --ibsc-radius-md: 18px;
  --ibsc-header-h: 76px;
}

html,
body {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

img,
svg,
video,
iframe,
canvas {
  max-width: 100%;
}

body {
  color: var(--ibsc-text);
  background: var(--ibsc-cream);
}

/* Header unificado */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(255,255,255,.94);
  border-bottom: 1px solid rgba(11,45,77,.08);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.nav-wrapper {
  min-height: var(--ibsc-header-h);
}

.brand-logo {
  flex: 0 0 auto;
}

.main-nav a,
.main-nav .nav-cta {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
}

/* Ofrendar no debe quedar marcado por defecto como CTA principal */
.main-nav a[href*="ofrenda"],
.main-nav a[href*="ofrendar"] {
  background: transparent;
  color: inherit;
}

/* En vivo conserva CTA principal */
.main-nav .nav-cta {
  color: #fff !important;
  background: var(--ibsc-blue) !important;
  border-radius: 999px;
}

/* Héroes públicos homologados: Inicio/Boletín/Qué creemos */
.boletin-hero,
.belief-hero.full-confession-hero,
.belief-hero,
.creemos-hero,
.belief-page-hero {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  color: #fff;
  background:
    radial-gradient(circle at 12% 20%, rgba(234,215,168,.22), transparent 32%),
    linear-gradient(135deg, var(--ibsc-blue) 0%, var(--ibsc-green) 78%) !important;
}

/* Cancelar pseudo overlays viejos que invertían o lavaban el hero */
.boletin-hero::before,
.boletin-hero::after,
.belief-hero::before,
.belief-hero::after,
.creemos-hero::before,
.creemos-hero::after,
.belief-page-hero::before,
.belief-page-hero::after {
  content: none !important;
  display: none !important;
}

/* Fade inferior explícito, igual para Boletín y Qué creemos */
.hero-bottom-fade,
.boletin-hero .hero-bottom-fade,
.belief-hero .hero-bottom-fade,
.creemos-hero .hero-bottom-fade,
.belief-page-hero .hero-bottom-fade {
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  z-index: 1;
  height: clamp(120px, 17vw, 230px);
  pointer-events: none;
  background:
    linear-gradient(
      180deg,
      rgba(248,244,236,0) 0%,
      rgba(248,244,236,.22) 42%,
      rgba(248,244,236,.82) 76%,
      var(--ibsc-cream) 100%
    );
}

.boletin-hero .container,
.belief-hero .container,
.creemos-hero .container,
.belief-page-hero .container,
.boletin-hero-grid,
.belief-hero-grid,
.creemos-hero-grid,
.belief-page-hero-grid {
  position: relative;
  z-index: 2;
}

/* Mismo patrón visual en heroes secundarios */
.boletin-hero,
.belief-hero {
  padding-top: calc(var(--ibsc-header-h) + 74px);
  padding-bottom: 150px;
  min-height: 560px;
  display: flex;
  align-items: center;
}

.boletin-hero-grid,
.belief-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, .9fr);
  gap: clamp(36px, 6vw, 76px);
  align-items: center;
}

.boletin-hero h1,
.belief-hero h1 {
  color: #fff !important;
  text-shadow: 0 16px 34px rgba(0,0,0,.22);
}

.boletin-hero .hero-lead,
.belief-hero .hero-lead {
  color: rgba(255,255,255,.92) !important;
  text-shadow: 0 10px 26px rgba(0,0,0,.20);
}

.boletin-hero .eyebrow,
.belief-hero .eyebrow {
  color: var(--ibsc-gold-soft) !important;
}

/* Tarjetas resumen homologadas */
.belief-summary-card,
.boletin-summary-card {
  background: rgba(255,255,255,.94) !important;
  color: var(--ibsc-blue);
  border: 1px solid rgba(255,255,255,.62);
  border-radius: var(--ibsc-radius-xl);
  box-shadow: 0 26px 70px rgba(0,0,0,.18);
}

.belief-summary-card h2,
.boletin-summary-card h2 {
  color: var(--ibsc-blue) !important;
}

.belief-summary-card p,
.belief-summary-card li,
.boletin-summary-card p,
.boletin-summary-card li {
  color: var(--ibsc-text) !important;
}

/* Botones legibles en fondos oscuros */
.boletin-hero .btn,
.belief-hero .btn {
  text-shadow: none !important;
}

.boletin-hero .btn-primary,
.belief-hero .btn-primary {
  color: #fff !important;
  background: var(--ibsc-blue) !important;
  border-color: var(--ibsc-blue) !important;
}

.boletin-hero .btn-secondary,
.boletin-hero .btn-outline,
.belief-hero .btn-secondary,
.belief-hero .btn-outline {
  color: #fff !important;
  background: rgba(255,255,255,.10) !important;
  border-color: rgba(255,255,255,.68) !important;
}

/* Secciones y tarjetas consistentes */
.section {
  scroll-margin-top: calc(var(--ibsc-header-h) + 18px);
}

.section-heading {
  max-width: 820px;
}

.ministry-card,
.visit-card,
.schedule-main-card,
.weekday-card,
.announcement-card,
.belief-card,
.confession-chapter,
.boletin-stage {
  border: 1px solid var(--ibsc-border);
}

/* Horarios: evitar recortes y mejorar legibilidad */
.schedule-section,
.schedule-layout,
.schedule-main-card,
.schedule-list,
.schedule-item,
.weekday-schedule-grid,
.weekday-card {
  min-width: 0;
  max-width: 100%;
}

.schedule-main-card {
  overflow: hidden;
}

.schedule-day-header {
  background:
    radial-gradient(circle at 88% 16%, rgba(201,164,92,.18), transparent 36%),
    linear-gradient(135deg, var(--ibsc-blue), var(--ibsc-green));
}

.schedule-day-header h3,
.schedule-day-header span {
  color: #fff;
}

/* Confesión: contenido seguro y tablas responsivas */
.belief-page-layout,
.belief-content,
.confession-content,
.confession-chapter,
.confession-chapter * {
  min-width: 0;
}

.confession-chapter {
  max-width: 100%;
  overflow: hidden;
}

.confession-chapter p,
.confession-chapter li,
.confession-chapter a,
.confession-chapter span,
.confession-chapter sup {
  overflow-wrap: anywhere;
  word-break: normal;
}

.confession-chapter table,
.belief-content table {
  width: 100%;
  max-width: 100%;
  border-collapse: collapse;
}

.table-wrap {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* Eliminar definitivamente barras inferiores móviles antiguas */
.mobile-bottom-bar,
.mobile-quickbar,
.mobile-bottom-nav,
.mobile-cta-bar,
.mobile-sticky-cta,
.mobile-floating-cta,
.floating-mobile-actions,
.floating-quick-actions,
.bottom-quick-actions,
.sticky-mobile-actions,
.home-mobile-actions,
.visit-floating-actions,
.visit-sticky-actions {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

/* Mobile */
@media (max-width: 900px) {
  :root {
    --ibsc-header-h: 68px;
  }

  .nav-wrapper {
    min-height: var(--ibsc-header-h);
  }

  .brand {
    min-width: 0;
  }

  .brand-logo {
    width: 46px;
    height: auto;
  }

  .brand-text strong,
  .brand-text small {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .menu-toggle {
    width: 46px;
    height: 46px;
    border-radius: 14px;
  }

  .main-nav {
    position: fixed;
    top: calc(var(--ibsc-header-h) + 10px);
    left: 16px;
    right: 16px;
    width: auto;
    max-height: min(76vh, 620px);
    overflow-y: auto;
    overscroll-behavior: contain;
    padding: 12px;
    background: rgba(255,255,255,.98);
    border: 1px solid rgba(11,45,77,.10);
    border-radius: 22px;
    box-shadow: 0 24px 70px rgba(11,45,77,.22);
  }

  .main-nav a {
    display: flex;
    min-height: 46px;
    padding: 11px 13px;
    border-radius: 15px;
  }
}

@media (max-width: 760px) {
  .container {
    width: min(100% - 28px, var(--container));
    padding-left: 0;
    padding-right: 0;
  }

  .boletin-hero,
  .belief-hero {
    min-height: auto;
    padding-top: calc(var(--ibsc-header-h) + 34px) !important;
    padding-bottom: 112px !important;
  }

  .boletin-hero-grid,
  .belief-hero-grid {
    grid-template-columns: 1fr;
    gap: 22px;
  }

  .boletin-hero h1,
  .belief-hero h1 {
    font-size: clamp(2.2rem, 11.2vw, 3.15rem);
    line-height: 1;
    letter-spacing: -.035em;
  }

  .boletin-hero .hero-lead,
  .belief-hero .hero-lead {
    font-size: 1rem;
    line-height: 1.58;
  }

  .hero-bottom-fade,
  .boletin-hero .hero-bottom-fade,
  .belief-hero .hero-bottom-fade {
    height: 142px;
  }

  .belief-summary-card,
  .boletin-summary-card {
    border-radius: 22px;
    padding: 22px !important;
    box-shadow: 0 16px 40px rgba(0,0,0,.13);
  }

  .hero-actions,
  .boletin-hero-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .hero-actions .btn,
  .boletin-hero-actions .btn {
    width: 100%;
    justify-content: center;
    min-height: 50px;
  }

  .section {
    padding: 50px 0;
  }

  .section-heading {
    text-align: left;
    margin-bottom: 24px;
  }

  .section-heading h2 {
    font-size: clamp(1.85rem, 8.6vw, 2.45rem);
    line-height: 1.08;
  }

  .schedule-main-card,
  .weekday-card,
  .ministry-card,
  .announcement-card,
  .visit-card,
  .belief-card,
  .confession-chapter {
    border-radius: 20px;
    box-shadow: none;
  }

  .schedule-day-header {
    padding: 24px 20px !important;
  }

  .schedule-day-header h3 {
    font-size: clamp(2rem, 10vw, 3rem);
  }

  .schedule-item {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 20px !important;
  }

  .schedule-item time {
    width: fit-content;
  }

  .weekday-schedule-grid {
    grid-template-columns: 1fr !important;
  }

  .belief-page-layout {
    display: block;
  }

  .belief-sidebar {
    display: none;
  }

  .confession-chapter {
    margin-left: 0;
    margin-right: 0;
  }

  .confession-chapter summary {
    padding: 18px !important;
  }

  .confession-chapter > div,
  .chapter-content,
  .chapter-body {
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  .confession-chapter table,
  .belief-content table {
    display: block;
    width: 100%;
    overflow-x: auto;
  }

  body,
  body.has-mobile-quickbar,
  body.has-mobile-bottom-nav,
  body.has-sticky-mobile-actions {
    padding-bottom: 0 !important;
  }
}

@media (max-width: 390px) {
  .container {
    width: min(100% - 22px, var(--container));
  }

  .brand-logo {
    width: 40px;
  }

  .brand-text small {
    display: none;
  }

  .belief-summary-card,
  .boletin-summary-card,
  .confession-chapter > div,
  .chapter-content,
  .chapter-body {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important;
  }
}


/* V6.49 — Boletín: limpiar marco visual innecesario del visor */
.boletin-stage,
.boletin-viewer,
.boletin-pdf-viewer,
.pdf-viewer,
.pdf-shell,
.pdf-stage,
.pdf-container {
  border-color: transparent !important;
}

.boletin-stage {
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.boletin-stage::before,
.boletin-stage::after,
.boletin-viewer::before,
.boletin-viewer::after,
.pdf-viewer::before,
.pdf-viewer::after,
.pdf-shell::before,
.pdf-shell::after {
  display: none !important;
  content: none !important;
}

.boletin-stage canvas,
.boletin-stage iframe,
.boletin-stage embed,
.boletin-stage object,
.boletin-viewer canvas,
.boletin-viewer iframe,
.pdf-viewer canvas,
.pdf-viewer iframe {
  border: 0 !important;
  outline: 0 !important;
  box-shadow: 0 16px 42px rgba(11,45,77,.10);
  border-radius: 18px;
}

@media (max-width: 760px) {
  .boletin-stage {
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
  }

  .boletin-stage canvas,
  .boletin-stage iframe,
  .boletin-stage embed,
  .boletin-stage object,
  .boletin-viewer canvas,
  .boletin-viewer iframe,
  .pdf-viewer canvas,
  .pdf-viewer iframe {
    border-radius: 14px;
    box-shadow: 0 10px 26px rgba(11,45,77,.10);
  }
}


/* V6.50 — Canon bíblico en divs responsive */
.canon-books-panel {
  margin: 26px 0;
  padding: clamp(20px, 4vw, 32px);
  background:
    radial-gradient(circle at 92% 10%, rgba(201,164,92,.14), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(251,248,241,.96));
  border: 1px solid rgba(11,45,77,.12);
  border-radius: 26px;
  box-shadow: 0 18px 42px rgba(11,45,77,.08);
}

.canon-books-intro {
  max-width: 760px;
  margin-bottom: 22px;
}

.canon-books-intro h3 {
  margin: 8px 0 8px;
  color: var(--ibsc-blue, #0b2d4d);
  font-size: clamp(1.35rem, 3vw, 2rem);
  line-height: 1.1;
}

.canon-books-intro p {
  color: var(--ibsc-muted, #677284);
}

.canon-books-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, .9fr);
  gap: 18px;
  align-items: start;
}

.canon-column {
  min-width: 0;
  padding: 18px;
  background: #fff;
  border: 1px solid rgba(11,45,77,.10);
  border-radius: 20px;
}

.canon-column-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(11,45,77,.10);
}

.canon-column-head h4 {
  margin: 0;
  color: var(--ibsc-blue, #0b2d4d);
  font-size: 1.05rem;
}

.canon-column-head span {
  flex: 0 0 auto;
  display: inline-flex;
  padding: 6px 10px;
  color: var(--ibsc-blue, #0b2d4d);
  background: rgba(201,164,92,.18);
  border-radius: 999px;
  font-size: .78rem;
  font-weight: 900;
}

.canon-books-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.canon-nt .canon-books-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.canon-book {
  display: block;
  min-width: 0;
  padding: 8px 10px;
  color: var(--ibsc-text, #1f2933);
  background: var(--ibsc-cream, #f8f4ec);
  border: 1px solid rgba(11,45,77,.06);
  border-radius: 12px;
  font-size: .91rem;
  font-weight: 700;
  line-height: 1.2;
  overflow-wrap: break-word;
}

@media (max-width: 900px) {
  .canon-books-layout {
    grid-template-columns: 1fr;
  }

  .canon-books-panel {
    margin: 20px 0;
    padding: 18px;
    border-radius: 22px;
    box-shadow: none;
  }
}

@media (max-width: 560px) {
  .canon-column {
    padding: 14px;
  }

  .canon-column-head {
    align-items: flex-start;
    flex-direction: column;
    gap: 8px;
  }

  .canon-books-grid,
  .canon-nt .canon-books-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 7px;
  }

  .canon-book {
    padding: 8px;
    font-size: .86rem;
    border-radius: 10px;
  }
}

@media (max-width: 360px) {
  .canon-books-grid,
  .canon-nt .canon-books-grid {
    grid-template-columns: 1fr;
  }
}


/* V6.53 — Mapa discreto en Información para llegar */
.visit-map-card {
  margin-top: 20px;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(248,244,236,.88));
  border: 1px solid rgba(11,45,77,.12);
  border-radius: 22px;
  box-shadow: 0 16px 38px rgba(11,45,77,.08);
}

.visit-map-frame {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 10;
  min-height: 260px;
  background: var(--cream, #f8f4ec);
}

.visit-map-frame iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  filter: saturate(.88) contrast(.96);
}

.visit-map-caption {
  display: grid;
  gap: 4px;
  padding: 14px 16px 16px;
}

.visit-map-caption strong {
  color: var(--blue, #0b2d4d);
  font-size: .98rem;
}

.visit-map-caption span {
  color: var(--muted, #677284);
  font-size: .9rem;
  line-height: 1.45;
}

@media (max-width: 760px) {
  .visit-map-card {
    margin-top: 16px;
    border-radius: 18px;
    box-shadow: none;
  }

  .visit-map-frame {
    aspect-ratio: 1 / 1;
    min-height: 260px;
  }

  .visit-map-caption {
    padding: 12px 14px 14px;
  }
}


/* V6.54 — Íconos SVG oficiales */
.site-icon {
  display: inline-block;
  width: 1.05em;
  height: 1.05em;
  flex: 0 0 auto;
  object-fit: contain;
  vertical-align: -0.16em;
}

a .site-icon,
.footer-link .site-icon,
.social-links .site-icon,
.contact-link .site-icon {
  margin-right: .5rem;
}

.social-links a,
.site-footer a[href^="mailto:"],
.site-footer a[href^="tel:"],
.site-footer a[href*="whatsapp"],
.contact-link {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
}

.social-links a .site-icon {
  width: 1.15rem;
  height: 1.15rem;
  margin-right: .15rem;
}

.site-footer a[href^="mailto:"] .site-icon,
.site-footer a[href^="tel:"] .site-icon,
.site-footer a[href*="whatsapp"] .site-icon {
  width: 1rem;
  height: 1rem;
}

@media (max-width: 760px) {
  .social-links a,
  .site-footer a[href^="mailto:"],
  .site-footer a[href^="tel:"],
  .site-footer a[href*="whatsapp"] {
    min-height: 40px;
  }

  .social-links a .site-icon {
    width: 1.2rem;
    height: 1.2rem;
  }
}


/* V6.55 — Corrección visual de íconos SVG en footer */
.site-footer .social-links {
  display: grid;
  gap: 14px;
}

.site-footer .social-links a,
.site-footer a[href^="mailto:"],
.site-footer a[href^="tel:"],
.site-footer a[href*="whatsapp"] {
  position: relative;
  display: inline-flex !important;
  align-items: center;
  gap: 12px;
  width: fit-content;
  max-width: 100%;
  color: rgba(255,255,255,.88) !important;
  font-weight: 800;
  line-height: 1.25;
  text-decoration: none;
}

/* Desactivar decoraciones/pseudo-círculos anteriores que desfasaban el ícono */
.site-footer .social-links a::before,
.site-footer .social-links a::after,
.site-footer a[href^="mailto:"]::before,
.site-footer a[href^="tel:"]::before,
.site-footer a[href*="whatsapp"]::before {
  content: none !important;
  display: none !important;
}

.site-footer .social-links a span,
.site-footer a[href^="mailto:"] span,
.site-footer a[href^="tel:"] span,
.site-footer a[href*="whatsapp"] span {
  color: rgba(255,255,255,.88) !important;
}

/* Ícono oficial dentro de círculo dorado, alineado */
.site-footer .site-icon,
.site-footer .social-links .site-icon {
  width: 20px !important;
  height: 20px !important;
  min-width: 20px;
  min-height: 20px;
  margin: 0 !important;
  padding: 8px;
  box-sizing: content-box;
  object-fit: contain;
  background: var(--ibsc-gold-soft, #efe1b7);
  border-radius: 999px;
  filter: none !important;
  opacity: 1 !important;
  box-shadow: 0 8px 18px rgba(0,0,0,.16);
}

/* En hover, mantener lectura y elevar sutilmente */
.site-footer .social-links a:hover,
.site-footer a[href^="mailto:"]:hover,
.site-footer a[href^="tel:"]:hover,
.site-footer a[href*="whatsapp"]:hover {
  color: #fff !important;
  transform: translateX(2px);
}

.site-footer .social-links a:hover span,
.site-footer a[href^="mailto:"]:hover span,
.site-footer a[href^="tel:"]:hover span,
.site-footer a[href*="whatsapp"]:hover span {
  color: #fff !important;
}

/* Ajuste específico: evitar texto azul heredado */
.site-footer .social-links a,
.site-footer .social-links a *,
.site-footer .footer-grid a,
.site-footer .footer-grid a * {
  text-shadow: none;
}

.site-footer .social-links a span {
  font-size: 1rem;
}

/* Móvil: más compacto pero táctil */
@media (max-width: 760px) {
  .site-footer .social-links {
    gap: 10px;
  }

  .site-footer .social-links a,
  .site-footer a[href^="mailto:"],
  .site-footer a[href^="tel:"],
  .site-footer a[href*="whatsapp"] {
    min-height: 42px;
    width: 100%;
  }

  .site-footer .site-icon,
  .site-footer .social-links .site-icon {
    width: 19px !important;
    height: 19px !important;
    padding: 7px;
  }
}


/* V6.56 — Footer social icons final */
.site-footer .social-links {
  display: grid;
  gap: 12px;
}

.site-footer .footer-social-link,
.site-footer .social-links a,
.site-footer a[href^="mailto:"],
.site-footer a[href^="tel:"],
.site-footer a[href*="whatsapp"] {
  position: relative;
  display: inline-flex !important;
  align-items: center !important;
  gap: 12px !important;
  width: fit-content;
  max-width: 100%;
  color: rgba(255,255,255,.92) !important;
  text-decoration: none !important;
  font-weight: 850;
  line-height: 1.25;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* Eliminar círculos heredados del enlace */
.site-footer .footer-social-link::before,
.site-footer .footer-social-link::after,
.site-footer .social-links a::before,
.site-footer .social-links a::after,
.site-footer a[href^="mailto:"]::before,
.site-footer a[href^="mailto:"]::after,
.site-footer a[href^="tel:"]::before,
.site-footer a[href^="tel:"]::after,
.site-footer a[href*="whatsapp"]::before,
.site-footer a[href*="whatsapp"]::after {
  content: none !important;
  display: none !important;
}

/* ÚNICO círculo visible */
.site-footer .social-icon-wrap {
  display: inline-grid;
  place-items: center;
  width: 42px;
  height: 42px;
  flex: 0 0 42px;
  background: var(--ibsc-gold-soft, #efe1b7) !important;
  border-radius: 999px;
  box-shadow: 0 8px 18px rgba(0,0,0,.16);
}

/* El SVG no debe traer fondo/círculo adicional */
.site-footer .social-icon-wrap img,
.site-footer .site-icon {
  display: block !important;
  width: 21px !important;
  height: 21px !important;
  min-width: 21px !important;
  min-height: 21px !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  object-fit: contain;
  filter: none !important;
  opacity: 1 !important;
}

.site-footer .social-label,
.site-footer .footer-social-link span:not(.social-icon-wrap) {
  color: rgba(255,255,255,.92) !important;
  font-size: 1rem;
  font-weight: 850;
}

.site-footer .footer-social-link:hover,
.site-footer .social-links a:hover {
  transform: translateX(2px);
}

.site-footer .footer-social-link:hover .social-label,
.site-footer .social-links a:hover .social-label {
  color: #fff !important;
}

@media (max-width: 760px) {
  .site-footer .footer-social-link,
  .site-footer .social-links a {
    width: 100%;
    min-height: 44px;
  }

  .site-footer .social-icon-wrap {
    width: 40px;
    height: 40px;
    flex-basis: 40px;
  }

  .site-footer .social-icon-wrap img,
  .site-footer .site-icon {
    width: 20px !important;
    height: 20px !important;
    min-width: 20px !important;
    min-height: 20px !important;
  }
}
