.header.--fixed + .main .at-banner.--fullwidth:first-of-type {
    padding-top: max(var(--articlePadding), var(--headerHeight));
}

.at-banner.--hasBackground {
    position: relative;
}

.at-banner__inner {
    position: relative;
    padding-inline: var(--pageGutter);
}

.aside .at-banner__inner {
    padding-inline: var(--marginMedium);
}

.at-banner.--fullwidth:not(.--hasBackground) .at-banner__inner {
    padding-inline: 0;
}

.at-banner.--hasBackground.--fullwidth .at-banner__inner {
    position: static;
}

.at-banner.--hasBackground.--fullwidth .g-container__inner {
    max-width: var(--maxBreakoutWidth);
}

.at-banner.--light,
.at-banner.--light *:not(.ctaButton),
.buttonStyle--ghost .at-banner.--light *:not(.ctaButton) {
    color: var(--baseLight100);
}

.at-banner__contentWrapper {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    position: relative;
    width: fit-content;
    padding-block: var(--marginLarge);
    z-index: 10;
}

.at-banner__contentWrapper.--isCenterAligned {
    justify-content: center;
    align-items: center;
    text-align: center;
    margin-inline: auto;
}

.at-banner__contentWrapper.--isRightAligned {
    margin-left: auto;
}

.at-banner__title:not(:only-child) {
    margin-bottom: 1.2rem;
}

.at-banner__title {
    max-width: 20ch;
}

.at-banner__text {
    max-width: clamp(10px, 52ch, 80%);
    margin-bottom: var(--marginMedium);
}

/**
 * Button wrapper
 */

.at-banner__buttonWrapper {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 1rem;
}

.at-banner__contentWrapper.--isCenterAligned .at-banner__buttonWrapper {
    justify-content: center;
}

/*
 * Image wrapper
 */

.at-banner__imageWrapper {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.at-banner__imageWrapper.--hasOverlay .at-banner__image.--grayscale {
    filter: grayscale(1);
}

.at-banner__imageWrapper.--hasOverlay::before {
    content: '';
    position: absolute;
    inset: 0;
    z-index: 10;
}

.Article:not(.--fullwidth) .at-banner__inner {
    overflow: clip;
    border-radius: var(--borderRadiusMedium);
}

.at-banner__image {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/**
 * Fullwidth with a color but without a article background color
 */

.at-banner.--fullwidth [style*='min-height: 15svh;'] {
    padding-block: 0;
}
