/**
 * Content Intro Block Styles
 * Uses the 16-column grid from main.css tokens.
 */

.block-content-intro {
  display: grid;
  grid-template-columns: repeat(var(--grid-columns), 1fr);
  gap: var(--grid-gap);
  background-color: var(--color-primary);
  padding: 7.5em var(--grid-margin);
}

.block-content-intro__left {
  grid-column: span 4;
}

.block-content-intro__right {
  display: flex;
  flex-direction: column;
  gap: 3.5em;
  grid-column: span 7;
  min-width: 0;
}

@media screen and (max-width: 1024px) {
  .block-content-intro__right {
    gap: 1.25em;
  }
}

.block-content-intro__right-description {
  max-width: 18em;
}

/* When only right exists, let it span the full grid */
.block-content-intro:not(:has(.block-content-intro__left)) .block-content-intro__right {
  grid-column: 1 / -1;
}

/* Mobile */
@media screen and (max-width: 1024px) {
  .block-content-intro {
    grid-template-columns: 1fr;
    gap: 4.5em;
    padding: 2.125em var(--grid-margin);
  }

  .block-content-intro__left,
  .block-content-intro__right {
    grid-column: 1 / -1;
  }

  .block-content-intro__right-description {
    max-width: none;
  }
}

.block-content-intro__right-name {
  color: var(--color-2);
  font-family: var(--font-primary);
  text-transform: uppercase;
}

.block-content-intro__right-position {
  color: #03090D50;
  font-family: var(--font-primary);
  text-transform: uppercase;
}
