/* =========================================================
   PRICING INFO – MATCH SCREENSHOT
========================================================= */

.pricing-info {
  margin: 50px auto;
  max-width: 90%;
  overflow: hidden;
}

/* Remove old top bar spacing if present */
.pricing-info__sidebar-top {
  display: none;
}

.pricing-info__top-content {
  margin-bottom: 80px;
}

.conference-top-content__badge {
    display: none;
  }

.pricing-info__sidebar-bottom {
    border: 2px solid #52287e;
    border-radius: 30px;
}

.pricing-info__top-content .conference-date h4 {
  color: #000;
  font-weight: 900;
}

.pricing-info__top-content h1 {
  font-weight: 900;
  color: #000 !important;
}

.pricing-info .pricing-footer-desc a {
  color: #52C4C7 !important;
}

.pricing-info__top-content h4 {
  color: #000;
  font-weight: 900;
  margin: 20px 0 10px;
}

.pricing-info__top-content .pricing-credit-p a {
  color: #52287E;
}

.pricing-info__top-content .pricing-credit-p a:hover {
  color: #52c4c7;
}

/* Title bar (purple gradient) */
.pricing-info .chart-title {
  background: url("/wp-content/uploads/2025/04/sbhpp-purple-bg-d973d1.svg") center / cover no-repeat;
  padding: 18px 28px;
  color: #fff;
  font-weight: 900;
  line-height: 1.1;
  border-radius: 30px 30px 0 0;
  font-family: 'Niveau-Grotesk', niveau-grotesk, sans-serif !important;
}

/* Each pricing row */
.pricing-info__row {
  display: grid;
  grid-template-columns: 300px 1fr 220px; /* left label | tiers | CTA */
  align-items: center;
}

.pricing-info__row + .pricing-info__row {
  border-top: 2px solid #52287e;
}

/* Left label block */
.pricing-info__section-header {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 26px 26px;
  border-right: 2px solid rgba(82, 196, 199, 0.75);
}

.pricing-info__icon {
  width: 38px;
  height: 38px;
  display: block;
}

.pricing-info__section-title {
  margin: 0;
  font-weight: 900;
  color: #111;
}

/* Tiers area */
.pricing-info__columns {
  display: flex;
  align-items: stretch;
}

.pricing-info__cell {
  flex: 1;
  padding: 18px 14px;
  text-align: center;
}

.pricing-info__cell h5 {
  margin: 0;
  font-weight: 900;
  color: #111;
}

.pricing-info__cell h6 {
  margin: 6px 0 10px;
  color: #111;
  font-weight: 500;
  font-family: 'Lato', -apple-system, sans-serif !important;
}

/* Price styling */
.pricing-info__price-box {
  display: flex;
  justify-content: center;
}

.pricing-info__price-box h5 {
  margin: 0;
  font-weight: 900;
  color: #52287e;
}

/* Teal vertical dividers between tiers (the injected .pricing-info__vline) */
.pricing-info__vline {
  width: 0;
  border-left: 2px solid rgba(82, 196, 199, 0.85);
  margin: 18px 0; /* gives top/bottom breathing like screenshot */
}

/* CTA column */
.pricing-info__cta {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 22px;
  border-left: 2px solid rgba(82, 196, 199, 0.0); /* keep clean like screenshot */
}

/* Bonus section (below rows) */
.pricing-info__bonus {
  border-top: 2px solid #52287e;
  padding: 22px 28px;
}

.pricing-info__bonus h4 {
  margin: 0 0 10px;
  font-weight: 900;
}

.pricing-info__bonus-desc p {
  margin: 0 0 8px;
}

/* =========================================================
   RESPONSIVE (stack like a card grid)
========================================================= */
@media (max-width: 1340px) {
  .conference-top-content__badge {
    display: inline-block;
  }
  .pricing-info .intro {
    display:flex;
    justify-content: space-between;
  }

  .pricing-info__top-content {
    max-width: 70%;
  }
}


@media (max-width: 1024px) {
  .pricing-info__row {
    grid-template-columns: 1fr;
  }

  .pricing-info__section-header {
    border-right: 0;
    border-bottom: 2px solid rgba(82, 196, 199, 0.35);
  }

  .pricing-info__columns {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }

  /* .pricing-info__vline {
    display: none !important;
  } */

  .pricing-info__cta {
    padding: 18px;
  }
}

/* BONUS WRAP */
.pricing-info__bonus-wrap {
  border-top: 2px solid #52287e;
}

/* purple bar */
.pricing-info__bonus-bar {
  background: linear-gradient(135deg, #6f2da8 0%, #8a1fbf 100%);
  color: #fff;
  padding: 20px 28px;
}

.pricing-info__bonus-heading {
  margin: 0 0 6px;
  font-weight: 900;
}

.pricing-info__bonus-topcopy h4 {
    color: #fff;
}

.pricing-info__bonus-topcopy p {
  margin: 0 0 6px;
}

/* white body */
.pricing-info__bonus-body {
  padding: 18px 28px 22px;
}

.pricing-info__bonus-bottomcopy p {
  margin: 0 0 12px;
}

/* logos row */
.pricing-info__bonus-logos {
  list-style: none;
  margin: 10px 0 0;
  padding: 0;
  display: flex;
  gap: 26px;
  align-items: center;
  flex-wrap: wrap;
  justify-content: space-between;
}

.pricing-info__bonus-logo img {
  max-height: 40px;
  width: 100%;
  display: block;
  min-height: 40px;
}

.pricing-info__bonus-more span {
  font-weight: 900;
}

/* Ensure rows are solid white so dividers are visible */
.pricing-info__sidebar-bottom .pricing-info__row {
  background: #fff;
  padding: 20px 0;
}

/* Full-width divider between rows (matches screenshot) */
.pricing-info__sidebar-bottom .pricing-info__row--virtual {
  border-top: 2px solid #52287e !important;
}

/* If you want the divider to feel “inset” like the design, use this instead:
.pricing-info__sidebar-bottom .pricing-info__row--virtual {
  box-shadow: inset 0 2px 0 #52287e;
}
*/

.pricing-info__sidebar-bottom > p:empty,
.pricing-info__section-header > p:empty {
  display: none !important;
  margin: 0 !important;
  padding: 0 !important;
}


/* If virtual has 3 tiers, make last span full width on small screens */
@media (max-width: 1024px) {
  .pricing-info__columns--virtual .pricing-info__cell:nth-child(3) {
    grid-column: 1 / -1;
  }
}

/* =========================================================
   DESKTOP DIVIDERS (990px and up) – CSS-based
   No .pricing-info__vline elements needed
========================================================= */
@media (min-width: 991px) {

  /* tier columns: vertical teal dividers between cells */
  .pricing-info__columns {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 1fr;
    align-items: stretch;
  }

  /* reset any mobile borders */
  .pricing-info__cell {
    border: 0;
  }

  /* vertical divider between tier cells */
  .pricing-info__cell + .pricing-info__cell {
    border-left: 2px solid rgba(82, 196, 199, 0.85);
  }
}


@media (max-width: 990px) {

  .pricing-info__row { grid-template-columns: 1fr; }

  .pricing-info__section-header {
    border-right: 0;
    justify-content: center;
    padding: 18px 16px;
    border-bottom: 2px solid rgba(82, 196, 199, 0.35);
  }

  .pricing-info__columns {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    padding: 8px 10px 14px;
    gap: 0;
  }

  /* reset */
  .pricing-info__cell {
    border: 0;
    padding: 18px 12px;
    text-align: center;
  }

  /* vertical divider: all items in column 2 */
  .pricing-info__cell:nth-child(2n) {
    border-left: 2px solid rgba(82, 196, 199, 0.85);
  }

  /* horizontal divider: row 2+ */
  .pricing-info__cell:nth-child(n+3) {
    border-top: 2px solid rgba(82, 196, 199, 0.85);
  }

  /* CTA full width */
  .pricing-info__cta { padding: 0 16px 18px; }
  .pricing-info__button {
    width: 100%;
    justify-content: space-between;
    padding: 14px 16px;
    border-radius: 4px;
  }

  /* Virtual 3 tiers: last spans full width */
  .pricing-info__columns--virtual .pricing-info__cell:nth-child(3) {
    grid-column: 1 / -1;
    border-left: 0;
    border-top: 2px solid rgba(82, 196, 199, 0.85);
  }
}

@media (max-width: 768px) {
.pricing-info .intro {
    flex-wrap: wrap;
  }

  .pricing-info__top-content {
    max-width: 100%;
  }
  .pricing-info__top-content {
    margin-bottom:0;
  }

  .pricing-info .conference-top-content__badge {
    margin: 20px 0 !important;
  }

  .pricing-info .conference-badge span {
    font-family: 'Niveau-Grotesk', niveau-grotesk, sans-serif !important;
    margin-top: 10px;
  }
}