.gg-community-hero {
    position: relative;
    min-height: min(30rem, 62vh);
    overflow: hidden;
    isolation: isolate;
}

.gg-community-hero__media {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.gg-community-hero__image {
    position: absolute;
    inset: 0;
    background-image: linear-gradient(90deg, rgba(28, 24, 21, 0.68) 0%, rgba(28, 24, 21, 0.46) 44%, rgba(28, 24, 21, 0.24) 78%, rgba(28, 24, 21, 0.34) 100%), linear-gradient(180deg, rgba(50, 45, 40, 0.22) 0%, rgba(50, 45, 40, 0.46) 100%), var(--gg-community-hero-image);
    background-position: center;
    background-size: cover;
    opacity: 0;
    transform: scale(1.03);
    transition: opacity 900ms ease, transform 6s ease;
}

.gg-community-hero__image.is-active {
    opacity: 1;
    transform: scale(1);
}

.gg-community-hero .container,
.gg-community-hero .row,
.gg-community-hero .col-12 {
    position: relative;
    z-index: 1;
}

.gg-community-hero__content {
    max-width: 50rem;
    padding-bottom: 5rem;
}

.gg-community-hero__lede {
    max-width: 39rem;
}

.gg-community-hero .gg-page-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1.5rem;
}

.gg-community-hero .gg-btn-light {
    padding: 0.72rem 1.15rem;
    font-size: 0.84rem;
}

@media (prefers-reduced-motion: reduce) {
    .gg-community-hero__image {
        transition: none;
        transform: none;
    }
}

.gg-community-intro {
    background: #fbf8f3;
}

.gg-community-intro__shell {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 2.6rem 0 2.8rem;
    text-align: center;
}

.gg-community-intro__shell::before {
    content: "";
    position: absolute;
    top: -5.1rem;
    left: 50%;
    width: min(calc(100% - 10rem), 30rem);
    height: 9.6rem;
    background: #fbf8f3;
    border-top-left-radius: 15rem 9.6rem;
    border-top-right-radius: 15rem 9.6rem;
    transform: translateX(-50%);
    z-index: 1;
}

.gg-community-intro__crest {
    position: relative;
    width: min(calc(100% - 10rem), 30rem);
    margin: 0 auto;
    overflow: visible;
    line-height: 0;
    z-index: 2;
}

.gg-community-intro__icon {
    display: block;
    margin: -6.75rem auto 0;
    z-index: 2;
    height: 10.8rem;
    object-fit: contain;
}

.gg-community-intro__text {
    position: relative;
    z-index: 2;
    margin-top: 0;
    padding-top: 0.65rem;
}

.gg-community-intro__text p {
    margin: 0;
    color: rgba(70, 60, 50, 0.5);
    font-family: var(--bs-body-font-family);
    font-size: clamp(1rem, 1.8vw, 1.2rem);
    font-weight: 500;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.gg-community-copy__eyebrow {
    margin: 0 0 0.7rem;
    color: var(--gg-accent-strong);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.gg-community-section__header {
    margin-bottom: 0.9rem;
}

.gg-community-section__header h2 {
    margin: 0;
    color: var(--gg-ink-strong);
    font-size: clamp(1.8rem, 3vw, 2.4rem);
    line-height: 1.12;
}

.gg-community-sections {
    padding-top: 1.5rem;
    padding-bottom: 4.5rem;
}

.gg-community-sections__stack {
    display: grid;
    gap: 2.8rem;
}

.gg-community-section {
    scroll-margin-top: 5.5rem;
}

.gg-community-section + .gg-community-section {
    padding-top: 2.8rem;
    border-top: 1px solid rgba(70, 60, 50, 0.14);
}

.gg-community-item-grid {
    column-count: 2;
    column-gap: 2.5rem;
    margin-top: 1.25rem;
}

.gg-community-item-card {
    display: inline-flex;
    width: 100%;
    flex-direction: column;
    padding: 0;
    margin: 0 0 1.5rem;
    break-inside: avoid;
    page-break-inside: avoid;
}

.gg-community-item-card__body h3 {
    margin: 0;
    color: var(--gg-ink-strong);
    font-size: 1.12rem;
    line-height: 1.3;
}

.gg-community-item-card__body h3 a {
    color: inherit;
    text-decoration: underline;
    text-decoration-color: rgba(141, 104, 64, 0.35);
    text-underline-offset: 0.14em;
}

.gg-community-item-card__body h3 a:hover,
.gg-community-item-card__body h3 a:focus-visible {
    color: var(--gg-accent-strong);
    text-decoration-color: currentColor;
}

.gg-community-item-card__body p {
    margin: 0.75rem 0 0;
    color: var(--gg-ink-soft);
    line-height: 1.7;
}

.gg-community-item-card__body h3 a:focus-visible {
    outline: 3px solid rgba(185, 150, 105, 0.5);
    outline-offset: 3px;
}

@media (max-width: 991.98px) {
    .gg-community-item-grid {
        column-gap: 2rem;
    }
}

@media (max-width: 767.98px) {
    .gg-community-intro__shell {
        padding-top: 2.2rem;
    }

    .gg-community-intro__shell::before {
        top: -3.8rem;
        width: min(calc(100% - 3rem), 21rem);
        height: 7rem;
        border-top-left-radius: 10.5rem 7rem;
        border-top-right-radius: 10.5rem 7rem;
    }

    .gg-community-intro__crest {
        width: min(calc(100% - 3rem), 21rem);
        min-height: 4.4rem;
        margin-top: 0;
        line-height: 0;
    }

    .gg-community-intro__icon {
        height: 9.2rem;
        margin-top: -4.8rem;
    }

    .gg-community-intro__text p {
        font-size: clamp(0.92rem, 4vw, 1.1rem);
    }

    .gg-community-item-grid {
        column-count: 1;
    }

    .gg-community-item-card {
        min-width: 0;
    }
}