.flexi-features-section {
  --flexi-features-column-gap: 4rem;

  @media (min-width: 990px) {
    --flexi-features-column-gap: 5rem;
  }
}

.flexi-features-columns {
  display: grid;
  grid-template-columns: 1fr;
  align-items: start;
  gap: var(--flexi-features-column-gap);

  &.flexi-features-columns-centered {
    max-width: 70rem;
    margin: 0 auto;
  }

  @media (min-width: 750px) {
    &.flexi-features-columns-2 {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }
}

.flexi-features-column {
  & .flexi-column__content > .flexi-block {
    margin-bottom: 1.5rem;

    &:last-child {
      margin-bottom: 0;
    }
  }

  & .flexi-button {
    margin-top: 0.5rem;
  }
}

.flexi-feature-group {
  width: 100%;

  &.flexi-feature-group-inline {
    & .flexi-feature-item {
      padding: 0;
      margin: 0.75rem 0;
      background: none;
      box-shadow: none;
      color: rgba(var(--color-foreground));
    }

    & .flexi-feature-icon svg {
      color: rgba(var(--color-foreground));
    }

    & .flexi-feature-title {
      margin-top: 0.3rem;
      color: rgba(var(--color-foreground));
      font-size: calc(var(--font-body-scale) * 1.5rem);
    }

    & .flexi-feature-text {
      color: rgba(var(--color-foreground));
    }

    @media (min-width: 990px) {
      & .flexi-feature-item {
        margin: 0;
      }
    }
  }

  &.flexi-feature-group-icon-small .flexi-feature-icon {
    width: 2.3rem;
    height: 2.3rem;
  }

  &.flexi-feature-group-icon-large .flexi-feature-icon {
    width: 4rem;
    height: 4rem;
  }

  @media (min-width: 990px) {
    &.flexi-feature-group-columns-2 .flexi-feature-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    &.flexi-feature-group-columns-2:not(.flexi-feature-group-inline) {
      & .flexi-feature-grid {
        align-items: stretch;
      }

      & .flexi-feature {
        height: 100%;
      }

      & .flexi-feature-item {
        height: 100%;
      }
    }
  }
}

.flexi-feature-grid {
  display: flex;
  flex-direction: column;
  gap: 1rem;

  @media (min-width: 990px) {
    gap: var(--grid-desktop-horizontal-spacing, 1.5rem);
  }
}

.flexi-feature-item {
  display: flex;
  gap: 1rem;
  padding: 2rem;
  border-radius: var(--border-radius-base);
  background-color: rgba(var(--color-background));
  box-shadow:
    inset 0 0 0 1px rgba(var(--color-border)),
    0 2px 0 rgba(var(--color-box-shadow));

  &.flexi-feature-item-centered {
    align-items: center;
  }
}

.flexi-feature-icon {
  flex: none;
  width: 4rem;
  height: 4rem;
  line-height: 1;

  & svg {
    width: 100%;
    height: 100%;
    color: rgba(var(--color-accent-2));
  }

  & img {
    width: 100%;
    height: auto;
  }
}

.flexi-feature-content {
  flex: 1 1 auto;
  min-width: 0;
  font-size: calc(var(--font-body-scale) * 1.3rem);
}

.flexi-feature-title {
  margin-bottom: 0.2rem;
  color: rgba(var(--color-accent-1));

  &:only-child {
    margin-bottom: 0;
  }
}

.flexi-feature-text {
  line-height: calc(1 + 0.35 / var(--font-body-scale));

  & p {
    margin: 0;
  }
}
