/* ===== Newsletter Banner (layout + typography) ===== */
.newsletter_banner_block{ padding:48px 0; }

/* Make the block’s inner container a grid: image + form */
.newsletter_banner_block > .container{
  display:grid;
  grid-template-columns: 1.1fr 1fr;
  gap:40px;
  align-items:center;
}

/* Keep working even if the block used .newsletter-wrap instead of container */
.newsletter_banner_block .newsletter-wrap{
  display:grid;
  grid-template-columns: 1.1fr 1fr;
  gap:40px;
  align-items:center;
}

/* Illustration */
.newsletter_banner_block .newsletter-illustration img{
  width:100%;
  height:auto;
  display:block;
  border-radius:24px;
}

/* Form column width */
.newsletter_banner_block .newsletter-content{
  max-width:520px;
  margin-inline:auto;
}

/* Title + subtitle */
.newsletter_banner_block .newsletter-title{
  font-size:36px;
  line-height:1.2;
  font-weight:800;
  margin:0 0 12px;
}
.newsletter_banner_block .newsletter-subtitle{
  margin:0 0 20px;
  color:#111;
}

/* Inputs */
.newsletter_banner_block .field{ margin-bottom:12px; }
.newsletter_banner_block .form-control{
  width:100%;
  padding:12px 16px;
  border:0;
  border-radius:10px;
  background:#fff;
  font-size:16px;
}

/* ===== “I’m a:” row — keep on one line ===== */
.newsletter_banner_block .nl-aud{
  display:flex;
  align-items:center;
  gap:22px;
  margin:10px 0 18px;
  flex-wrap:nowrap;            /* keep in one line on roomy screens */
}
.newsletter_banner_block .nl-aud__title{
  font-weight:700;
  white-space:nowrap;
  margin-right:2px;
}
.newsletter_banner_block .nl-aud__opt{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin:0;
  line-height:1;
}
.newsletter_banner_block .nl-aud__opt input{
  margin:0;                    /* remove default checkbox offset */
  vertical-align:middle;
}

/* Button */
.newsletter_banner_block .actions .primary,
.newsletter_banner_block button[type="submit"]{
  background:#111;
  color:#fff;
  border:0;
  padding:12px 22px;
  border-radius:999px;
  font-weight:600;
  cursor:pointer;
}

/* ===== Mobile behavior: image ABOVE form ===== */
@media (max-width: 900px){
  .newsletter_banner_block > .container,
  .newsletter_banner_block .newsletter-wrap{
    grid-template-columns:1fr;
    gap:28px;
  }
  /* force order: image first, form second */
  .newsletter_banner_block .newsletter-illustration{ order:1; }
  .newsletter_banner_block .newsletter-content{ order:2; max-width:100%; }

  /* allow the audience row to wrap nicely on narrow screens */
  .newsletter_banner_block .nl-aud{ flex-wrap:wrap; gap:16px 22px; }
}
