/* ============================== */
.product-information .callout{border-left:4px solid var(#b45309);background:#fff7ed;border:1px solid #fed7aa;border-radius:12px;padding:12px 12px;color:#7c2d12}
.product-information .callout b{color:#7c2d12}

Product table






/* =========================================================
   Generic Peptides Articles — square image + title below
   ========================================================= */

/* Grid spacing */
main .row {
  row-gap: 38px !important;
}

/* Card */
main article.card.mb-13.border-0 {
  height: auto !important;
  min-height: 0 !important;
  margin-bottom: 0 !important;
  padding: 18px !important;
  overflow: hidden !important;

  background: #ffffff !important;
  border: 1px solid #e8edf3 !important;
  border-radius: 18px !important;
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.05) !important;

  display: flex !important;
  flex-direction: column !important;

  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease !important;
}

main article.card.mb-13.border-0:hover {
  transform: translateY(-4px) !important;
  border-color: rgba(11, 134, 209, 0.22) !important;
  box-shadow: 0 18px 42px rgba(15, 23, 42, 0.1) !important;
}

/* IMPORTANT:
   This targets the real image link/wrapper and makes it a square */
main article.card.mb-13.border-0 a:has(img) {
  display: flex !important;
  width: 100% !important;
  aspect-ratio: 1 / 1 !important;
  height: auto !important;

  align-items: center !important;
  justify-content: center !important;

  margin: 0 !important;
  padding: 0 !important;

  background: #f8fafc !important;
  border-radius: 14px !important;
  overflow: hidden !important;
}

/* Actual image inside square */
main article.card.mb-13.border-0 a:has(img) img {
  width: 100% !important;
  height: 100% !important;

  max-width: none !important;
  max-height: none !important;

  object-fit: contain !important;
  object-position: center center !important;

  display: block !important;
  margin: 0 !important;
  padding: 0 !important;

  border-radius: 0 !important;
  background: transparent !important;

  transform: scale(1.9) !important;
  transition: transform 0.22s ease !important;
}

main article.card.mb-13.border-0:hover a:has(img) img {
  transform: scale(2.0) !important;
}

/* Title area directly under image */
main article.card.mb-13.border-0 .card-body {
  padding: 16px 0 0 !important;
  background: transparent !important;
}

/* Title */
main article.card.mb-13.border-0 h4,
main article.card.mb-13.border-0 h4 a {
  margin: 0 !important;

  font-size: 17px !important;
  line-height: 1.38 !important;
  font-weight: 600 !important;
  letter-spacing: -0.02em !important;

  color: #111827 !important;
  text-decoration: none !important;
}

/* Default: show beginning only */
main article.card.mb-13.border-0 h4 {
  display: -webkit-box !important;
  -webkit-line-clamp: 3 !important;
  -webkit-box-orient: vertical !important;

  overflow: hidden !important;
  min-height: 70px !important;
}

/* Hover: show full title */
main article.card.mb-13.border-0:hover h4 {
  display: block !important;
  -webkit-line-clamp: unset !important;
  overflow: visible !important;
  min-height: auto !important;
}

main article.card.mb-13.border-0:hover h4 a {
  color: #0b86d1 !important;
}

/* Hide bad extra text inside cards */
main article.card.mb-13.border-0 p {
  display: none !important;
}

/* Tablet */
@media (max-width: 991px) {
  main article.card.mb-13.border-0 {
    padding: 16px !important;
  }

  main article.card.mb-13.border-0 h4,
  main article.card.mb-13.border-0 h4 a {
    font-size: 16px !important;
  }

  main article.card.mb-13.border-0 a:has(img) img {
    transform: scale(1.75) !important;
  }

  main article.card.mb-13.border-0:hover a:has(img) img {
    transform: scale(1.85) !important;
  }
}

/* Mobile */
@media (max-width: 575px) {
  main article.card.mb-13.border-0 {
    padding: 14px !important;
    border-radius: 16px !important;
  }

  main article.card.mb-13.border-0 h4,
  main article.card.mb-13.border-0 h4 a {
    font-size: 17px !important;
  }

  main article.card.mb-13.border-0 h4 {
    min-height: auto !important;
  }

  main article.card.mb-13.border-0 a:has(img) img {
    transform: scale(1.65) !important;
  }
}




.gp-promo-slogan-v2,
.gp-promo-slogan-v2 * {
  box-sizing: border-box;
}

.gp-promo-slogan-v2 {
  width: 100%;
  max-width: none;
  margin: 44px 0;
  padding: 34px 28px;
  border: none;
  border-radius: 0;
  background: transparent;
  font-family: inherit;
  text-align: center;
  clear: both;
}

.gp-promo-slogan-v2 .gp-kicker-v2 {
  display: inline-block;
  margin: 0 0 12px;
  padding: 6px 16px;
  border-radius: 999px;
  background: #0b8fe8;
  color: #ffffff;
  font-size: 14px;
  line-height: 1.2;
  font-weight: 600;
}

.gp-promo-slogan-v2 .gp-title-v2 {
  margin: 0;
  color: #1f2f3f;
  font-size: clamp(28px, 3vw, 44px);
  line-height: 1.15;
  font-weight: 500;
  letter-spacing: -0.03em;
}

.gp-promo-slogan-v2 .gp-title-v2 strong {
  color: #0b8fe8;
  font-weight: 700;
}

.gp-promo-slogan-v2 .gp-text-v2 {
  max-width: 760px;
  margin: 16px auto 0;
  color: #4b5f73;
  font-size: 16px;
  line-height: 1.65;
  font-weight: 400;
}

.gp-promo-slogan-v2 .gp-mini-points-v2 {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
  margin: 22px 0 0;
  padding: 0;
}

.gp-promo-slogan-v2 .gp-mini-points-v2 span {
  display: inline-block;
  padding: 7px 13px;
  border: 1px solid #dce8f3;
  border-radius: 999px;
  color: #263849;
  background: #f8fbfe;
  font-size: 14px;
  line-height: 1.2;
  font-weight: 500;
}

@media (max-width: 767px) {
  .gp-promo-slogan-v2 {
    margin: 30px auto;
    padding: 28px 18px;
  }

  .gp-promo-slogan-v2 .gp-text-v2 {
    font-size: 15px;
  }

  .gp-promo-slogan-v2 .gp-mini-points-v2 span {
    font-size: 13px;
  }
}

.gp-best-picks-text {
  margin: 44px 0;
  padding: 0 20px;
  text-align: center;
}

.gp-best-picks-text h2 {
  margin: 0 0 14px;
  color: #1f2f3f;
  font-size: clamp(26px, 2.6vw, 38px);
  line-height: 1.2;
  font-weight: 500;
  letter-spacing: -0.02em;
}

.gp-best-picks-text p {
  max-width: 900px;
  margin: 0 auto;
  color: #4b5f73;
  font-size: 16px;
  line-height: 1.7;
}

@media (max-width: 767px) {
  .gp-best-picks-text {
    margin: 32px 0;
    padding: 0 16px;
  }

  .gp-best-picks-text h2 {
    font-size: 26px;
  }

  .gp-best-picks-text p {
    font-size: 15px;
    line-height: 1.65;
  }
}


.gp-about-final-text {
  margin: 64px 0 56px;
  padding: 0 20px;
  text-align: center;
}

.gp-about-final-text h2 {
  margin: 0 0 18px;
  color: #1f2f3f;
  font-size: clamp(28px, 2.8vw, 42px);
  line-height: 1.18;
  font-weight: 500;
  letter-spacing: -0.025em;
}

.gp-about-final-text .gp-about-lead {
  max-width: 960px;
  margin: 0 auto 18px;
  color: #40566c;
  font-size: 17px;
  line-height: 1.75;
}

.gp-about-final-text p {
  max-width: 920px;
  margin: 0 auto 14px;
  color: #4b5f73;
  font-size: 16px;
  line-height: 1.7;
}

.gp-about-final-text .gp-about-points {
  max-width: 980px;
  margin: 28px auto 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  text-align: left;
}

.gp-about-final-text .gp-about-point {
  padding: 20px 18px;
  background: #ffffff;
  border-radius: 6px;
}

.gp-about-final-text .gp-about-point strong {
  display: block;
  margin-bottom: 8px;
  color: #1f2f3f;
  font-size: 16px;
  font-weight: 600;
}

.gp-about-final-text .gp-about-point span {
  display: block;
  color: #4b5f73;
  font-size: 15px;
  line-height: 1.6;
}

@media (max-width: 900px) {
  .gp-about-final-text .gp-about-points {
    grid-template-columns: 1fr;
    text-align: center;
  }
}

@media (max-width: 767px) {
  .gp-about-final-text {
    margin: 44px 0 40px;
    padding: 0 16px;
  }

  .gp-about-final-text h2 {
    font-size: 27px;
  }

  .gp-about-final-text .gp-about-lead,
  .gp-about-final-text p {
    font-size: 15px;
    line-height: 1.65;
  }
}