.hub-hero {
    --hero-padding: 42px;
    --offset: 2rem;

    position: relative;
    padding-block: var(--hero-padding);
    background-color: var(--color-blue);
    color: var(--color-white);

    /* temporary */
    &:not(&.no-quick-links) {
        margin-bottom: calc(var(--quick-link-height) - var(--offset));
    }

    @media (min-width: 640px) {
        --quick-link-height: 415px;
    }

    @media (min-width: 768px) {
        --hero-padding: 64px;
        --quick-link-height: 270px;
    }

    @media (min-width: 1024px) {
        --quick-link-height: 150px;
        --offset: 4rem;

        &::before {
            content: "";
            position: absolute;
            inset: 0;
            left: 50%;
            background-image: url("/va-loans/assets/images/wavy-pattern.svg");
            background-repeat: no-repeat;
            background-size: cover;
            background-position: center;
            z-index: 1;
        }

        &::after {
            content: "";
            position: absolute;
            inset: 0;
            background: linear-gradient(to right, var(--color-blue) 50%, transparent 75%);
            z-index: 2;
        }
    }

    &.is-mortgage::before {
        background-image: url("/va-loans/assets/images/mortgage-hub-hero.webp");
    }

    &.is-credit::before {
        background-image: url("/va-loans/assets/images/credit-card-hub-hero.webp");
    }

}

.hub-hero-content {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    z-index: var(--z-above);
    text-align: center;
    padding-bottom: 3rem;
    max-width: var(--wrapper-xs);
    margin-inline-start: auto;
    margin-inline-end: auto;

    @media (min-width: 1024px) {
        max-width: 72ch;
        text-align: left;
        margin-inline-start: 0;
    }

    .hub-hero-content-title {
        font-family: var(--font-display);
        font-size: clamp(30px, 4vw, 40px);
        font-weight: 900;
        line-height: var(--leading-xs);
        text-wrap: pretty;
    }

    .hub-hero-content-subtitle {
        font-size: clamp(16px, 2vw, 22px);
        line-height: var(--leading-sm);
    }
}

.hub-hero-mobile-banner {
    position: relative;
    display: flex;
    aspect-ratio: 2 / 1;
    margin-bottom: calc(var(--hero-padding) * -1);
    width: 100vw;
    transform: translateX(-1rem);

    img {
        height: 100%;
        width: 100%;
        object-fit: cover;
    }

    @media (min-width: 1024px) {
        display: none;
    }
}

.hub-hero-quick-link-layout {
    position: relative;
    display: grid;
    grid-template-columns: repeat(var(--columns, 1), var(--1fr));
    gap: var(--gap, 1rem);
    /*margin-bottom: calc(var(--quick-link-offset) * -1);*/
    margin-bottom: calc(
        ((var(--hero-padding) + var(--quick-link-height)) * -1) - (var(--offset) * -1)
    );
    z-index: var(--z-above);

    @media (min-width: 640px) {
        --columns: 2;
    }
    @media (min-width: 768px) {
        --columns: 3;
    }
    @media (min-width: 1024px) {
        --columns: 6;
        --gap: 1.25rem;
    }
}

.hub-hero-quick-link {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    gap: 0.875rem;
    padding: 1.5rem 1.15rem;
    border-radius: var(--radius-lg);
    background-color: var(--hub-quick-link-bg, var(--color-white));
    color: var(--hub-quick-fg, var(--color-text));
    box-shadow: 0 10px 20px 0 rgb(0 0 0 / 12%);
    transition-property: transform;
    transition-timing-function: var(--ease-out-cubic);
    transition-duration: 0.4s;

    &:hover {
        transform: scale(1.03) translateZ(0px);
    }
    &:active {
        transform: scale(0.99) translateZ(0px);
    }

    @media (min-width: 640px) {
        flex-direction: column;
        justify-content: center;
    }

    .hub-hero-quick-link-icon {
        color: var(--color-blue-light);
        width: 40px;
    }

    .hub-hero-quick-link-label {
        font-family: var(--font-display);
        font-weight: 900;
        font-size: 1.125rem;
        line-height: var(--leading-sm);

        @media (min-width: 640px) {
            text-align: center;
        }
    }
}

.hub-section {
    --hub-section-padding: 3.125rem;
    position: relative;
    padding-block: var(--hub-section-padding, 3.125rem);
    background-color: var(--hub-section-bg, transparent);
    color: var(--hub-section-fg, inherit);

    @media (min-width: 768px) {
        --hub-section-padding: 4.5rem;
    }
}

.hub-section-heading {
    display: flex;
    flex-direction: column;
    gap: 1.125rem;
    justify-content: center;
    align-items: center;
    max-width: var(--wrapper-xs);
    margin-inline: auto;
    text-align: center;

    &.align-left {
        @media (min-width: 768px) {
            align-items: flex-start;
            text-align: left;
        }
    }

    .hub-section-heading-title {
        font-family: var(--font-display);
        font-weight: 900;
        font-size: clamp(28px, 3.5vw, 36px);
        line-height: var(--leading-xs);
        text-wrap: pretty;
        color: var(--color-text);
    }

    .hub-section-heading-subtitle {
        font-size: 18px;
        line-height: var(--leading);
        color: var(--color-marketing-supporting-text);
        text-wrap: pretty;
    }
}

.hub-section-cta-wrapper {
    max-width: var(--wrapper-sm);
    margin-inline: auto;
}

.hub-figure {
    display: flex;
    border-radius: var(--radius-xl);
    overflow: hidden;

    img {
        height: 100%;
        width: 100%;
        object-fit: cover;
    }
}

.hub-footer {
    .related-articles {
        border-top: none;
        padding-inline: 0;
    }

    .related-articles-layout {
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    }

    .related-articles-layout > .article-card::after {
        display: none;
    }
}

.hub-separator {
    border-color: var(--color-border);
    height: 0;
    border-width: 0;
    border-top-width: 1px;
}

/**
 * ------------------------------------------
 * page: loans hub
 * ------------------------------------------
 **/
.hub-section.why-va-loan {
    .why-va-loan-list-layout {
        display: flex;
        align-items: center;
        padding-block: 2rem;

        @media (min-width: 768px) {
            padding-block: 4rem;
            display: grid;
            grid-template-columns: repeat(2, var(--1fr));
            gap: 2.5rem;
        }

        @media (min-width: 1024px) {
            gap: 4.5rem;
        }
    }

    .why-va-loan-list {
        --list-gap: 1.125rem;

        .why-va-loan-list-item {
            font-size: clamp(1.15rem, 2vw, 1.5rem);
            font-weight: 700;
            color: var(--color-marketing-list-item);
            display: inline-flex;
            align-items: center;
            justify-content: flex-start;
            gap: 1.25rem;
            line-height: var(--leading-xs);
        }

        .icon {
            color: var(--color-success);
            width: 32px;
        }
    }

    .why-va-loan-figure {
        display: none;

        @media (min-width: 768px) {
            display: flex;
        }
    }

    .why-va-loan-disclaimer {
        font-size: 0.875rem;
        color: var(--color-text-muted);
        font-style: italic;
        opacity: 0.6;

        @media (min-width: 768px) {
            text-align: center;
        }
    }
}

.hub-section.how-va-loan {
    --hub-section-bg: var(--color-surface-secondary);

    .how-va-loan-list-layout {
        padding-top: 3rem;
    }

    .how-va-loan-list {
        display: grid;
        grid-template-columns: repeat(var(--columns, 1), minmax(0, 1fr));
        gap: 1.5rem;
        place-items: center;

        @media (min-width: 768px) {
            --columns: 5;
            place-items: start;
        }
    }

    .how-va-loan-list-item {
        width: 100%;
        max-width: 300px;

        @media (min-width: 768px) {
            max-width: none;
        }

        span {
            display: block;
            background-color: var(--color-red-light);
            color: var(--color-white);
            padding: 1.5rem 1rem;
            font-size: 32px;
            font-weight: 900;
            font-family: var(--font-display);
            text-align: center;
            line-height: var(--leading-none);
            clip-path: polygon(100% 0, 100% 80%, 50% 100%, 0 80%, 0 0, 50% 20%);

            @media (min-width: 768px) {
                clip-path: polygon(90% 0, 100% 50%, 90% 100%, 0% 100%, 10% 50%, 0% 0%);
                padding: 1rem 1.5rem;
            }
        }

        p {
            font-size: 18px;
            font-weight: 700;
            line-height: var(--leading-xs);
            text-align: center;
            color: var(--color-marketing-list-item);
            padding-top: 1.5rem;
        }
    }
}

/**
 * ------------------------------------------
 * page: credit cards hub
 * ------------------------------------------
 **/
.hub-section.credit-cards-and-military {
    --hub-section-bg: var(--color-surface-secondary);
    --offset: 2.5rem;
    margin-block-end: calc(var(--offset) * 2);

    .hub-section-heading {
        padding-bottom: 2rem;
    }

    .credit-cards-and-military-card {
        max-width: var(--wrapper-xs);
        margin-inline: auto;
        background: linear-gradient(
            to bottom,
            var(--color-blue-light),
            color-mix(in lch, var(--color-blue-light), black 30%)
        );
        color: var(--color-white);
        padding: 2rem;
        border-radius: var(--radius-lg);
        margin-bottom: calc((var(--hub-section-padding) + var(--offset)) * -1);

        .list {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: 1rem;
            font-size: 24px;
            font-weight: 700;
            text-align: center;
        }
    }
}

.hub-section.choosing-the-right-card {
    position: relative;

    .choosing-the-right-card-layout {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 2.25rem;

        @media (min-width: 768px) {
            display: grid;
            grid-template-columns: repeat(2, var(--1fr));
            gap: 4.5rem;
        }
    }

    .choosing-the-right-card-content {
        display: flex;
        flex-direction: column;
        gap: 2.25rem;

        .list {
            --list-bullet-color: var(--color-red);
            --list-gap: calc(var(--spacing) * 4.5);
            font-size: 24px;
            font-weight: 700;
            color: var(--color-marketing-list-item);
        }
    }

    .choosing-the-right-card-figure {
        height: 100%;
        width: 100%;
    }

    .choosing-the-right-card-cta {
        padding-top: 1.5rem;
        font-size: clamp(1.5rem, 2vw, 1.75rem);

        @media (min-width: 768px) {
            padding-top: 5.25rem;
            text-align: center;
        }

        a {
            color: var(--color-blue);
            text-decoration: none;

            &:hover {
                text-decoration: underline;
            }
        }
    }
}
