/* Mount Inflection cross-page normalization layer */

:root {
  --mi-page-max: 1180px;
  --mi-page-pad-x: 22px;
  --mi-header-gap: 28px;
  --mi-section-gap: 70px;
  --mi-card-radius: 26px;
}

/* Make all pages feel like the same site */
body {
  font-size: 16px;
  line-height: 1.58;
}

.wrap {
  max-width: var(--mi-page-max) !important;
  margin: 0 auto !important;
  padding: 28px var(--mi-page-pad-x) 58px !important;
}

header {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 18px !important;
  margin-bottom: var(--mi-header-gap) !important;
}

.brand img {
  width: 58px !important;
  height: 44px !important;
  object-fit: contain !important;
}

nav {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-end !important;
  gap: 18px !important;
}

nav a {
  font-size: 14px !important;
  line-height: 1.2 !important;
  white-space: nowrap !important;
}

/* Normalize page hero typography */
main h1 {
  font-size: clamp(42px, 5.6vw, 68px) !important;
  line-height: .98 !important;
  letter-spacing: -.055em !important;
  margin-top: 0 !important;
  margin-bottom: 22px !important;
  max-width: 900px;
}

main h2 {
  font-size: clamp(30px, 4vw, 46px) !important;
  line-height: 1.04 !important;
  letter-spacing: -.048em !important;
}

.lead,
.section-lead,
.hero-lead,
.hero-copy {
  font-size: clamp(18px, 2vw, 21px) !important;
  line-height: 1.55 !important;
  color: var(--muted, #bac8d3) !important;
  max-width: 860px !important;
}

/* Normalize content section spacing */
section.content,
.faq-hero,
.tier-hero {
  margin-top: 0 !important;
  margin-bottom: 34px !important;
}

.content {
  max-width: 1180px !important;
}

/* Normalize cards */
.card,
.panel,
.tier,
.faq-card,
.coming-soon-card,
.signup-panel,
.pricing-note,
.faq-boundary,
.faq-final-note {
  border-radius: var(--mi-card-radius) !important;
}

.card p,
.panel p,
.tier p,
.faq-card p,
.coming-soon-card p {
  font-size: 16px !important;
  line-height: 1.58 !important;
}

/* Normalize CTA sizing */
.button,
button.button {
  min-height: 52px !important;
  padding: 14px 22px !important;
  font-size: 15px !important;
  font-weight: 850 !important;
}

/* FAQ page: keep it calm and symmetric */
.faq-grid {
  align-items: stretch !important;
}

.faq-card {
  min-height: 220px;
}

.faq-card h3 {
  font-size: 21px !important;
}

/* Tiers page: keep all tier cards visually balanced */
.tier-grid {
  align-items: stretch !important;
}

.tier {
  min-height: 700px;
}

/* Mobile consistency */
@media (max-width: 860px) {
  header {
    align-items: flex-start !important;
    flex-direction: column !important;
  }

  nav {
    justify-content: flex-start !important;
    gap: 12px !important;
  }

  main h1 {
    font-size: clamp(42px, 12vw, 60px) !important;
  }

  .tier {
    min-height: auto;
  }

  .faq-card {
    min-height: auto;
  }
}

/* Final cross-page symmetry pass */

body {
  min-width: 320px;
}

.wrap {
  width: min(1180px, calc(100% - 44px)) !important;
  max-width: 1180px !important;
  padding-top: 28px !important;
  padding-bottom: 58px !important;
}

header {
  min-height: 58px !important;
  margin-bottom: 42px !important;
}

.brand {
  min-width: max-content;
}

.brand span {
  font-size: 18px !important;
  font-weight: 850 !important;
  letter-spacing: -.025em !important;
}

.brand img {
  width: 52px !important;
  height: 42px !important;
  object-fit: contain !important;
}

nav {
  row-gap: 10px !important;
  column-gap: 18px !important;
}

nav a {
  font-size: 14px !important;
  font-weight: 700 !important;
  opacity: .92;
}

main {
  display: block;
}

main > section:first-child {
  margin-top: 0 !important;
}

.kicker {
  font-size: 12px !important;
  letter-spacing: .14em !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
}

main h1 {
  font-size: clamp(44px, 5.4vw, 68px) !important;
  line-height: .98 !important;
  letter-spacing: -.058em !important;
  margin-bottom: 20px !important;
}

main h2 {
  font-size: clamp(30px, 3.8vw, 44px) !important;
  line-height: 1.04 !important;
  letter-spacing: -.048em !important;
}

main h3 {
  letter-spacing: -.025em !important;
}

.lead,
.hero-lead,
.section-lead {
  font-size: clamp(18px, 1.8vw, 21px) !important;
  line-height: 1.55 !important;
  max-width: 880px !important;
}

.card,
.tier,
.faq-card,
.coming-soon-card,
.signup-panel,
.pricing-note,
.faq-boundary,
.faq-final-note,
.positioning-card {
  border-radius: 26px !important;
}

.button,
button.button,
a.button {
  min-height: 52px !important;
  padding: 14px 22px !important;
  font-size: 15px !important;
  font-weight: 850 !important;
  line-height: 1.1 !important;
}

.cta-row,
.page-actions,
.button-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 14px !important;
  align-items: center !important;
  margin-top: 26px !important;
}

footer {
  margin-top: 72px !important;
  padding-top: 24px !important;
  font-size: 13px !important;
  line-height: 1.65 !important;
}

/* Page-specific symmetry */
.faq-grid,
.tier-grid {
  gap: 18px !important;
}

.faq-card {
  min-height: 220px !important;
}

.tier {
  min-height: 700px !important;
}

.signup-panel {
  align-items: stretch !important;
}

@media (max-width: 940px) {
  .wrap {
    width: min(100% - 32px, 1180px) !important;
  }

  header {
    align-items: flex-start !important;
    flex-direction: column !important;
    margin-bottom: 34px !important;
  }

  nav {
    justify-content: flex-start !important;
  }

  main h1 {
    font-size: clamp(40px, 11vw, 58px) !important;
  }

  .tier,
  .faq-card {
    min-height: auto !important;
  }

  .button,
  button.button,
  a.button {
    width: 100%;
    justify-content: center;
  }
}

/* How-it-works flow polish */
.engine-card {
  align-self: stretch;
}

.compact-flow .flow-step {
  padding: 16px 0;
}

.compact-flow .flow-step span {
  line-height: 1.48;
}

@media (min-width: 920px) {
  .engine-card {
    min-height: 100%;
  }
}


/* How-it-works: non-numbered BrainWave engine overview */
.engine-points {
  gap: 13px !important;
}

.engine-point {
  display: block !important;
  grid-template-columns: none !important;
  padding: 16px 18px !important;
}

.engine-point b {
  font-size: 16px;
  margin-bottom: 5px;
}

.engine-point span {
  display: block;
  line-height: 1.48;
}

.engine-point .flow-num {
  display: none !important;
}













/* How-it-works hero image: larger professional flow visual */
.engine-visual-card {
  padding: 0 !important;
  width: 100% !important;
  max-width: 520px !important;
  justify-self: end !important;
  align-self: center !important;
  aspect-ratio: 0.72 / 1 !important;
  min-height: 0 !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 32px !important;
  background:
    radial-gradient(circle at 88% 0%, rgba(142,233,246,.14), transparent 36%),
    linear-gradient(145deg, rgba(255,255,255,.065), rgba(255,255,255,.028)) !important;
}

.engine-visual-card img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
  display: block !important;
}

/* Keep hero CTAs clean */
.hero .cta {
  border: 0 !important;
  background: transparent !important;
  padding: 0 !important;
  box-shadow: none !important;
  margin-top: 30px !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 14px !important;
}

.hero .cta .button {
  width: auto !important;
}

@media (max-width: 1000px) {
  .engine-visual-card {
    max-width: 100% !important;
    justify-self: stretch !important;
    aspect-ratio: 4 / 5 !important;
  }

  .hero .cta .button {
    width: 100% !important;
  }
}


/* How-it-works hero image: clean vertical infographic */
.engine-visual-card {
  padding: 0 !important;
  width: 100% !important;
  max-width: 500px !important;
  justify-self: end !important;
  align-self: center !important;
  aspect-ratio: 2 / 3 !important;
  min-height: 0 !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 32px !important;
  background:
    radial-gradient(circle at 88% 0%, rgba(142,233,246,.14), transparent 36%),
    linear-gradient(145deg, rgba(255,255,255,.065), rgba(255,255,255,.028)) !important;
}

.engine-visual-card img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
  display: block !important;
}

.hero .cta {
  border: 0 !important;
  background: transparent !important;
  padding: 0 !important;
  box-shadow: none !important;
  margin-top: 30px !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 14px !important;
}

.hero .cta .button {
  width: auto !important;
}

@media (max-width: 1000px) {
  .engine-visual-card {
    max-width: 100% !important;
    justify-self: stretch !important;
  }

  .hero .cta .button {
    width: 100% !important;
  }
}

/* How-it-works: non-numbered signal state cards */
.signal-state-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-top: 26px;
}

.signal-state-card {
  position: relative;
  min-height: 180px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 24px;
  padding: 20px;
  background:
    radial-gradient(circle at 92% 0%, rgba(142,233,246,.10), transparent 34%),
    linear-gradient(145deg, rgba(255,255,255,.070), rgba(255,255,255,.032));
  overflow: hidden;
}

.signal-state-card::after {
  content: "";
  position: absolute;
  right: -44px;
  bottom: -44px;
  width: 140px;
  height: 140px;
  border-radius: 999px;
  background: rgba(32,199,173,.08);
  filter: blur(18px);
}

.signal-state-card h3 {
  position: relative;
  z-index: 1;
  margin: 0 0 8px;
  font-size: 21px;
  letter-spacing: -.035em;
}

.signal-state-card p {
  position: relative;
  z-index: 1;
  color: var(--muted);
  margin: 0;
  font-size: 15px;
  line-height: 1.55;
}

@media (max-width: 1000px) {
  .signal-state-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .signal-state-grid {
    grid-template-columns: 1fr;
  }

  .signal-state-card {
    min-height: auto;
  }
}


/* Homepage Action Flow nutshell section */
.action-flow-section {
  margin-top: 34px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 34px;
  padding: 30px;
  background:
    radial-gradient(circle at 82% 0%, rgba(32,199,173,.12), transparent 36%),
    linear-gradient(145deg, rgba(255,255,255,.060), rgba(255,255,255,.026));
  box-shadow: 0 24px 80px rgba(0,0,0,.28);
}

.action-flow-copy {
  margin-bottom: 22px;
}

.action-flow-copy h2 {
  max-width: 980px;
}

.action-flow-image {
  border: 1px solid rgba(142,233,246,.20);
  border-radius: 30px;
  overflow: hidden;
  background: rgba(0,0,0,.22);
  box-shadow: 0 24px 70px rgba(0,0,0,.30);
}

.action-flow-image img {
  display: block;
  width: 100%;
  height: auto;
}

@media (max-width: 760px) {
  .action-flow-section {
    padding: 22px;
    border-radius: 28px;
  }

  .action-flow-image {
    border-radius: 24px;
  }
}

/* Tiers copy/layout tuning */
.tier h2,
.tier h3 {
  text-wrap: balance;
}

.tier .price:empty,
.tier strong:empty {
  display: none !important;
}

.tier {
  display: flex !important;
  flex-direction: column !important;
}

.tier .button {
  margin-top: auto !important;
}

@media (min-width: 900px) {
  .tier-grid {
    align-items: stretch !important;
  }

  .tier {
    min-height: 720px !important;
  }
}


/* Homepage hero: modern wordless tech-market background */
.hero-full {
  background:
    linear-gradient(90deg, rgba(3,8,13,.94) 0%, rgba(3,8,13,.82) 42%, rgba(3,8,13,.42) 72%, rgba(3,8,13,.22) 100%),
    url("hero_signal_tech_bg.svg") center / cover no-repeat !important;
}

.hero-full-inner {
  max-width: 760px !important;
}

/* Confirm / unsubscribe transition pages */
.confirm-shell,
.unsubscribe-shell {
  position: relative;
  overflow: hidden;
  min-height: 560px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 34px;
  padding: 54px;
  background:
    linear-gradient(90deg, rgba(3,8,13,.94) 0%, rgba(3,8,13,.78) 48%, rgba(3,8,13,.25) 100%),
    url("path_signal_growth.svg") center / cover no-repeat;
  box-shadow: 0 24px 80px rgba(0,0,0,.30);
}

.confirm-shell h1,
.unsubscribe-shell h1 {
  max-width: 760px;
}

.confirm-shell .section-lead,
.unsubscribe-shell .section-lead {
  max-width: 760px;
}

.confirm-status-card {
  margin-top: 28px;
  max-width: 620px;
  border: 1px solid rgba(142,233,246,.20);
  border-radius: 24px;
  padding: 22px;
  background: rgba(0,0,0,.22);
}

.confirm-status-card strong {
  display: block;
  color: var(--text);
  margin-bottom: 6px;
}

.confirm-status-card span {
  color: var(--muted);
}

@media (max-width: 760px) {
  .confirm-shell,
  .unsubscribe-shell {
    padding: 28px;
    min-height: 420px;
  }
}

/* Signup page width correction */
.signup-card,
.signup-panel,
.signup-form-card,
form#free-signup-form {
  max-width: none;
}

.signup-grid,
.signup-box,
.signup-card {
  width: min(100%, 920px) !important;
}

@media (min-width: 900px) {
  .signup-card,
  .signup-box {
    display: grid !important;
    grid-template-columns: .9fr 1.1fr !important;
    gap: 32px !important;
    align-items: center !important;
  }
}

#free-signup-form input[type="email"] {
  width: 100% !important;
}

#free-signup-form button {
  width: 100% !important;
}

/* Signup page: widen and balance the join panel */
.signup-panel {
  width: min(100%, 980px) !important;
  max-width: 980px !important;
  display: grid !important;
  grid-template-columns: .85fr 1.15fr !important;
  gap: 34px !important;
  align-items: center !important;
  padding: 34px !important;
}

.signup-form {
  width: 100% !important;
  max-width: none !important;
}

.signup-form input[type="email"],
.signup-form button {
  width: 100% !important;
}

@media (max-width: 850px) {
  .signup-panel {
    grid-template-columns: 1fr !important;
    padding: 24px !important;
  }
}

/* Premium / Pro coming soon pages */
.coming-card,
.coming-panel,
.launch-card {
  border: 1px solid rgba(255,255,255,.14) !important;
  border-radius: 34px !important;
  padding: 34px !important;
  background:
    radial-gradient(circle at 88% 0%, rgba(32,199,173,.12), transparent 36%),
    linear-gradient(145deg, rgba(255,255,255,.060), rgba(255,255,255,.026)) !important;
  box-shadow: 0 24px 80px rgba(0,0,0,.28) !important;
}

.premium-grid,
.pro-grid,
.coming-grid {
  display: grid !important;
  gap: 16px !important;
}

.premium-grid > *,
.pro-grid > *,
.coming-grid > *,
.feature-row {
  border: 1px solid rgba(255,255,255,.11) !important;
  border-radius: 20px !important;
  padding: 18px 20px !important;
  background: rgba(0,0,0,.18) !important;
}

.premium-grid h3,
.pro-grid h3,
.coming-grid h3,
.feature-row h3 {
  margin-top: 0 !important;
}

/* Signup page: final width/placement correction */
.signup-page .signup-panel,
main .signup-panel {
  width: min(100%, 1040px) !important;
  max-width: 1040px !important;
  margin-right: auto !important;
  display: grid !important;
  grid-template-columns: minmax(280px, .85fr) minmax(420px, 1.15fr) !important;
  gap: 42px !important;
  align-items: center !important;
  padding: 38px !important;
}

.signup-panel .signup-form,
.signup-panel form,
#free-signup-form {
  width: 100% !important;
  max-width: none !important;
}

.signup-panel input,
.signup-panel button,
#free-signup-form input,
#free-signup-form button {
  width: 100% !important;
  max-width: none !important;
}

.signup-panel input[type="email"],
#free-signup-form input[type="email"] {
  min-height: 58px !important;
}

.signup-panel button,
#free-signup-form button {
  min-height: 62px !important;
}

@media (max-width: 900px) {
  .signup-page .signup-panel,
  main .signup-panel {
    grid-template-columns: 1fr !important;
    width: 100% !important;
    padding: 26px !important;
    gap: 22px !important;
  }
}

/* Premium / Pro coming soon: actual card structure */
.coming-soon-card {
  max-width: 1040px !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  border-radius: 34px !important;
  padding: 36px !important;
  background:
    radial-gradient(circle at 88% 0%, rgba(32,199,173,.12), transparent 36%),
    linear-gradient(145deg, rgba(255,255,255,.060), rgba(255,255,255,.026)) !important;
  box-shadow: 0 24px 80px rgba(0,0,0,.28) !important;
}

.coming-soon-card h2 {
  margin: 0 0 24px !important;
  font-size: clamp(32px, 4vw, 48px) !important;
  line-height: 1.05 !important;
  letter-spacing: -.055em !important;
}

.coming-soon-card .feature-row,
.coming-soon-card > div:not(:first-child),
.coming-soon-card li {
  border-radius: 20px !important;
}

.coming-soon-card .feature-row {
  border: 1px solid rgba(255,255,255,.11) !important;
  padding: 18px 20px !important;
  background: rgba(0,0,0,.18) !important;
  margin-bottom: 14px !important;
}

.coming-soon-card .feature-row strong {
  display: block !important;
  margin-bottom: 6px !important;
  font-size: 18px !important;
}

.coming-soon-card .feature-row p {
  margin: 0 !important;
  color: var(--muted) !important;
}

.coming-soon-card .cta,
.coming-soon-card .button-row {
  margin-top: 26px !important;
  display: flex !important;
  gap: 14px !important;
  flex-wrap: wrap !important;
}

@media (max-width: 760px) {
  .coming-soon-card {
    padding: 24px !important;
  }
}

/* Signup page: prevent form/button bleed and rebalance columns */
.hero-full .signup-panel {
  width: min(100%, 860px) !important;
  max-width: 860px !important;
  grid-template-columns: 300px minmax(0, 1fr) !important;
  gap: 34px !important;
  padding: 34px 38px !important;
  align-items: center !important;
  box-sizing: border-box !important;
}

.hero-full .signup-panel > * {
  min-width: 0 !important;
}

.hero-full .signup-form,
.hero-full #free-signup-form {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

.hero-full #free-signup-form input[type="email"],
.hero-full #free-signup-form button {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

@media (max-width: 900px) {
  .hero-full .signup-panel {
    width: 100% !important;
    max-width: 100% !important;
    grid-template-columns: 1fr !important;
    padding: 26px !important;
  }
}

/* FINAL signup card correction: contained form, no visual bleed */
.hero-full .signup-panel {
  width: min(100%, 900px) !important;
  max-width: 900px !important;
  display: grid !important;
  grid-template-columns: 300px 1fr !important;
  gap: 34px !important;
  align-items: center !important;
  padding: 34px 38px !important;
  box-sizing: border-box !important;

  /* make the card feel like its own object, not part of the background */
  background:
    linear-gradient(145deg, rgba(5,11,18,.88), rgba(5,11,18,.70)) !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  border-radius: 30px !important;
  backdrop-filter: blur(8px) !important;
  overflow: hidden !important;
}

.hero-full .signup-panel > * {
  min-width: 0 !important;
}

.hero-full .signup-form {
  width: 100% !important;
  max-width: 520px !important;
  justify-self: end !important;
  box-sizing: border-box !important;
}

.hero-full #free-signup-form {
  width: 100% !important;
  max-width: 520px !important;
  box-sizing: border-box !important;
}

.hero-full #free-signup-form input[type="email"] {
  width: 100% !important;
  max-width: 100% !important;
  min-height: 58px !important;
  box-sizing: border-box !important;
}

.hero-full #free-signup-form button {
  width: 100% !important;
  max-width: 100% !important;
  min-height: 60px !important;
  box-sizing: border-box !important;
  white-space: normal !important;
}

/* dim the hero image behind the signup card so it does not compete */
.signup-page .hero-full,
body:has(#free-signup-form) .hero-full {
  background:
    linear-gradient(90deg, rgba(3,8,13,.96) 0%, rgba(3,8,13,.86) 45%, rgba(3,8,13,.46) 75%, rgba(3,8,13,.28) 100%),
    url("hero_signal_tech_bg.svg") center / cover no-repeat !important;
}

@media (max-width: 900px) {
  .hero-full .signup-panel {
    width: 100% !important;
    max-width: 100% !important;
    grid-template-columns: 1fr !important;
    padding: 26px !important;
    gap: 24px !important;
  }

  .hero-full .signup-form,
  .hero-full #free-signup-form {
    max-width: 100% !important;
    justify-self: stretch !important;
  }
}

/* FINAL signup hero glass-card correction */
body:has(#free-signup-form) .signup-panel,
.hero-full .signup-panel {
  width: min(100%, 900px) !important;
  max-width: 900px !important;
  display: grid !important;
  grid-template-columns: 300px minmax(0, 1fr) !important;
  gap: 34px !important;
  align-items: center !important;
  padding: 34px 38px !important;
  box-sizing: border-box !important;

  /* glass, not slab */
  background:
    linear-gradient(145deg, rgba(5,11,18,.58), rgba(5,11,18,.34)) !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  border-radius: 30px !important;
  backdrop-filter: blur(4px) !important;
  -webkit-backdrop-filter: blur(4px) !important;
  overflow: hidden !important;
  box-shadow: 0 24px 80px rgba(0,0,0,.22) !important;
}

body:has(#free-signup-form) .signup-panel > *,
.hero-full .signup-panel > * {
  min-width: 0 !important;
}

body:has(#free-signup-form) .signup-form,
body:has(#free-signup-form) #free-signup-form,
.hero-full .signup-form,
.hero-full #free-signup-form {
  width: 100% !important;
  max-width: 460px !important;
  min-width: 0 !important;
  justify-self: end !important;
  box-sizing: border-box !important;
}

body:has(#free-signup-form) #free-signup-form input[type="email"],
body:has(#free-signup-form) #free-signup-form button,
.hero-full #free-signup-form input[type="email"],
.hero-full #free-signup-form button {
  width: 100% !important;
  max-width: 460px !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

body:has(#free-signup-form) #free-signup-form button,
.hero-full #free-signup-form button {
  min-height: 58px !important;
  padding-left: 22px !important;
  padding-right: 22px !important;
  white-space: normal !important;
}

/* Let the hero show through more on signup */
body:has(#free-signup-form) .hero-full {
  background:
    linear-gradient(90deg, rgba(3,8,13,.88) 0%, rgba(3,8,13,.70) 42%, rgba(3,8,13,.30) 74%, rgba(3,8,13,.16) 100%),
    url("hero_signal_tech_bg.svg") center / cover no-repeat !important;
}

@media (max-width: 900px) {
  body:has(#free-signup-form) .signup-panel,
  .hero-full .signup-panel {
    grid-template-columns: 1fr !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 26px !important;
    gap: 24px !important;
  }

  body:has(#free-signup-form) .signup-form,
  body:has(#free-signup-form) #free-signup-form,
  .hero-full .signup-form,
  .hero-full #free-signup-form {
    max-width: 100% !important;
    justify-self: stretch !important;
  }

  body:has(#free-signup-form) #free-signup-form input[type="email"],
  body:has(#free-signup-form) #free-signup-form button,
  .hero-full #free-signup-form input[type="email"],
  .hero-full #free-signup-form button {
    max-width: 100% !important;
  }
}
