.sponsors-page {
    min-height: 100vh;
    background: transparent;
}

.sponsors-shell {
    max-width: 1180px;
}

.sponsors-intro {
    display: grid;
    grid-template-columns: minmax(220px, 0.8fr) minmax(0, 1.2fr);
    gap: 24px;
    align-items: end;
    margin-bottom: 28px;
    padding: 24px 0 10px;
    border-bottom: 1px solid rgba(28, 98, 55, 0.16);
    color: var(--rfc-panel-text, #d7f4dc);
}

.sponsors-kicker {
    display: inline-flex;
    align-items: center;
    margin-bottom: 8px;
    color: #176a3a;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.sponsors-intro h2,
.sponsor-cta h3 {
    margin: 0;
    color: var(--rfc-heading-green, #2ecc71);
    font-size: clamp(1.55rem, 3vw, 2.2rem);
    font-weight: 850;
    line-height: 1.08;
    text-shadow: 0 2px 0 rgba(0, 46, 17, 0.8);
}

.sponsors-intro p,
.sponsor-cta p {
    margin: 0;
    color: rgba(247, 255, 249, 0.88);
    font-size: 1rem;
    line-height: 1.65;
}

.sponsors-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.sponsor-card {
    display: flex;
    flex-direction: column;
    min-height: 100%;
    overflow: hidden;
    border: 1px solid var(--rfc-card-border, rgba(117, 217, 145, 0.30));
    border-radius: var(--rfc-card-radius, 16px);
    background: var(--rfc-card-bg, linear-gradient(180deg, rgba(57, 106, 76, 0.94), rgba(27, 78, 47, 0.94)));
    box-shadow: var(--rfc-panel-shadow, 0 12px 32px rgba(0, 0, 0, 0.30));
    color: var(--rfc-panel-text, #d7f4dc);
}

.sponsor-card-header {
    display: flex;
    align-items: center;
    min-height: 44px;
    padding: 10px 16px;
    border-left: 5px solid var(--sponsor-color, #2ecc71);
    border-bottom: 1px solid rgba(28, 98, 55, 0.12);
    background: rgba(7, 57, 31, 0.24);
}

.sponsor-role {
    color: #bfffcf;
    font-size: 0.76rem;
    font-weight: 850;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}

.sponsor-logo-container {
    min-height: 170px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px 22px;
    background: rgba(255, 255, 255, 0.94);
    border-bottom: 1px solid rgba(28, 98, 55, 0.1);
}

.sponsor-logo {
    max-width: 100%;
    max-height: 112px;
    width: auto;
    height: auto;
    object-fit: contain;
}

.sponsor-logo-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    color: #587164;
    text-align: center;
}

.sponsor-logo-placeholder i {
    color: var(--sponsor-color, #2ecc71);
    font-size: 2.6rem;
}

.sponsor-logo-placeholder span {
    font-weight: 800;
}

.sponsor-content {
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: 16px;
    padding: 20px;
}

.sponsor-name {
    margin: 0;
    color: var(--rfc-heading-green, #2ecc71);
    font-size: 1.25rem;
    font-weight: 850;
    line-height: 1.2;
    text-shadow: 0 2px 0 rgba(0, 46, 17, 0.75);
}

.sponsor-description p,
.sponsor-thanks p {
    margin: 0;
    color: rgba(247, 255, 249, 0.88);
    font-size: 0.96rem;
    line-height: 1.6;
}

.sponsor-thanks {
    display: grid;
    grid-template-columns: 22px minmax(0, 1fr);
    gap: 10px;
    margin-top: auto;
    padding: 14px;
    border: 1px solid rgba(46, 204, 113, 0.2);
    border-left: 4px solid var(--sponsor-color, #2ecc71);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.08);
}

.sponsor-thanks i {
    margin-top: 3px;
}

.btn-sponsor-visit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 42px;
    padding: 0 16px;
    border: 1px solid var(--sponsor-color, #2ecc71);
    border-radius: 8px;
    background: var(--sponsor-color, #2ecc71);
    color: #ffffff;
    font-size: 0.94rem;
    font-weight: 800;
    text-decoration: none;
}

.btn-sponsor-visit:hover,
.btn-sponsor-visit:focus {
    color: #ffffff;
    text-decoration: none;
    filter: brightness(0.94);
}

.sponsor-cta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    margin-top: 28px;
    padding: 24px;
    border-radius: 8px;
    background: linear-gradient(135deg, #1e8f4f, #12613d);
    color: #ffffff;
    box-shadow: 0 16px 42px rgba(18, 97, 61, 0.18);
}

.sponsor-cta .sponsors-kicker,
.sponsor-cta h3,
.sponsor-cta p {
    color: #ffffff;
}

.sponsor-cta p {
    max-width: 720px;
    opacity: 0.94;
}

.sponsor-cta .btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    white-space: nowrap;
    border-radius: 8px;
    font-weight: 800;
}

@media (max-width: 991.98px) {
    .sponsors-intro,
    .sponsor-cta {
        grid-template-columns: 1fr;
        align-items: start;
    }

    .sponsors-grid {
        grid-template-columns: 1fr;
    }

    .sponsor-cta {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 575.98px) {
    .sponsors-shell {
        padding-left: 14px;
        padding-right: 14px;
    }

    .sponsors-intro {
        gap: 12px;
        padding-top: 18px;
    }

    .sponsor-logo-container {
        min-height: 140px;
        padding: 20px 16px;
    }

    .sponsor-content {
        padding: 16px;
    }

    .sponsor-cta {
        padding: 18px;
    }
}
/* Sponsor page polish: compact intro, deliberate sponsor panels, aligned page rhythm. */
.sponsors-shell {
    padding-top: clamp(1.1rem, 2.4vw, 2rem) !important;
    padding-bottom: clamp(1.4rem, 2.8vw, 2.4rem) !important;
}

.sponsors-shell .sponsors-intro,
.sponsors-shell .sponsors-hero,
.sponsors-shell .sponsors-lead,
.sponsors-shell .partner-support {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(280px, 1.1fr);
    gap: clamp(1rem, 2.6vw, 2rem);
    align-items: end;
    margin-bottom: clamp(1rem, 2vw, 1.45rem);
}

.sponsors-shell .section-eyebrow,
.sponsors-shell .sponsor-eyebrow,
.sponsors-shell .partner-eyebrow,
.sponsors-shell small.text-uppercase {
    color: rgba(90, 255, 142, 0.72) !important;
    display: inline-flex;
    font-size: clamp(0.68rem, 0.72vw, 0.78rem);
    font-weight: 900;
    letter-spacing: 0.08em;
    margin-bottom: 0.35rem;
    text-transform: uppercase;
}

.sponsors-shell h1,
.sponsors-shell h2 {
    font-size: clamp(1.75rem, 3.15vw, 2.85rem);
    line-height: 1.04;
    margin-bottom: 0.55rem;
}

.sponsors-shell .lead,
.sponsors-shell .sponsors-copy,
.sponsors-shell .partner-copy {
    color: rgba(246, 255, 249, 0.9);
    font-size: clamp(0.94rem, 1.05vw, 1.06rem);
    line-height: 1.62;
    margin-bottom: 0;
}

.sponsors-shell .row {
    row-gap: clamp(0.85rem, 1.55vw, 1.2rem);
}

.sponsor-card,
.sponsors-shell .card {
    border-radius: 12px !important;
    overflow: hidden;
}

.sponsor-card .card-header,
.sponsors-shell .card-header {
    align-items: center;
    display: flex;
    min-height: 2.55rem;
    padding: 0.62rem 0.9rem !important;
}

.sponsor-card .card-body,
.sponsors-shell .card-body {
    padding: clamp(0.9rem, 1.45vw, 1.15rem) !important;
}

.sponsor-card h3,
.sponsors-shell .card h3,
.sponsors-shell .card-title {
    font-size: clamp(1.12rem, 1.45vw, 1.38rem);
    line-height: 1.15;
    margin-bottom: 0.55rem;
}

.sponsor-card .sponsor-logo,
.sponsor-card .sponsor-logo-wrap,
.sponsors-shell .sponsor-logo,
.sponsors-shell .sponsor-logo-wrap {
    align-items: center;
    background: rgba(246, 250, 247, 0.96);
    display: flex;
    justify-content: center;
    min-height: clamp(8rem, 13vw, 10.5rem);
    padding: clamp(0.9rem, 1.5vw, 1.2rem);
}

.sponsor-card .sponsor-logo img,
.sponsors-shell .sponsor-logo img {
    max-height: 5.4rem;
    max-width: 82%;
    object-fit: contain;
}

.sponsor-card .btn,
.sponsors-shell .card .btn {
    margin-top: 0.35rem;
}

@media (max-width: 767.98px) {
    .sponsors-shell .sponsors-intro,
    .sponsors-shell .sponsors-hero,
    .sponsors-shell .sponsors-lead,
    .sponsors-shell .partner-support {
        grid-template-columns: 1fr;
        gap: 0.6rem;
    }

    .sponsors-shell {
        padding-top: 0.9rem !important;
    }
}
