.packshot-banner {
  position: relative;
  width: 100%;
  min-height: 480px;
  display: flex;
  align-items: stretch;
  background-color: var(--formoline-aqua-2);
  overflow: hidden;
}

.packshot-banner__inner {
  display: flex;
  flex-direction: column;
  width: 100%;
  padding-top: 56px;
  padding-bottom: 56px;
  gap: 40px;
}

/* Header: manually indented to match site content width */
.packshot-banner__header {
  font-family: 'Barlow', sans-serif;
  font-size: clamp(20px, 2.2vw, 32px);
  font-weight: 400;
  color: #ffffff;
  line-height: 1.4;
  margin: 0 auto;
  width: 100%;
  max-width: 1320px;
  padding-left: 24px;
  padding-right: 24px;
  box-sizing: border-box;
}

/* Row: full width, card bleeds left */
.packshot-banner__row {
  display: flex;
  flex-direction: row;
  align-items: center;
  width: 100%;
  gap: 0;
}

/* White card: flush to left, fixed width */
.packshot-banner__card {
  flex: 0 0 42%;
  background: #ffffff;
  padding: 28px 40px;
  /* indent text to align with header above */
  padding-left: calc((100vw - 1320px) / 2 + 24px);
}

.packshot-banner__bodytext {
  font-family: 'Barlow', sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: var(--formoline-aqua-2);
  line-height: 1.5;
}

.packshot-banner__bodytext p {
  margin: 0;
  color: inherit;
  font-size: 28px;
  font-weight: 600;
}

/* Packshot */
.packshot-banner__right {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 40px;
}

.packshot-banner__packshot {
  width: 100%;
  max-width: 520px;
  height: auto;
  display: block;
  object-fit: contain;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 1399px) {
  .packshot-banner__card {
    padding-left: 40px;
  }
}

@media (max-width: 1199px) {
  .packshot-banner__inner {
    padding-top: 48px;
    padding-bottom: 48px;
  }
  .packshot-banner__header {
    padding-left: 40px;
  }
  .packshot-banner__card {
    padding-left: 40px;
  }
}

@media (max-width: 991px) {
  .packshot-banner__row {
    flex-direction: column;
    align-items: stretch;
  }
  .packshot-banner__card {
    flex: unset;
    width: 100%;
    padding: 24px 32px;
  }
  .packshot-banner__header {
    padding-left: 32px;
  }
  .packshot-banner__right {
    padding: 32px 32px 0;
  }
  .packshot-banner__packshot {
    max-width: 360px;
    margin: 0 auto;
  }
}

@media (max-width: 575px) {
  .packshot-banner__inner {
    padding-top: 32px;
    padding-bottom: 32px;
  }
  .packshot-banner__header {
    font-size: 20px;
    padding-left: 24px;
  }
  .packshot-banner__card {
    padding: 20px 24px;
  }
  .packshot-banner__bodytext {
    font-size: 16px;
  }
  .packshot-banner__packshot {
    max-width: 260px;
  }
}