.contrib-page {
    background: #f5f2ec;
}

.contrib-main {
    min-height: 100dvh;
}

.contrib-hero {
    padding: clamp(98px, 14vh, 148px) 0 clamp(32px, 5.2vh, 54px);
    background: linear-gradient(145deg, #f6f3ee 0%, #e9e2d7 54%, #ddd3c4 100%);
    border-bottom: 1px solid rgba(126, 114, 96, 0.22);
}

.contrib-eyebrow {
    margin: 0;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-size: 0.78rem;
    color: #7a6f61;
    font-weight: 700;
}

.contrib-hero h1 {
    margin: 0.38rem 0 0;
    font-size: clamp(2rem, 5vw, 3.6rem);
    line-height: 1.03;
    color: #1f1a16;
}

.contrib-sub {
    margin: 0.95rem 0 0;
    max-width: 900px;
    color: #4f4740;
    line-height: 1.46;
}

.contrib-section {
    padding: clamp(28px, 5vh, 54px) 0;
}

.contrib-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
    gap: clamp(18px, 3.5vw, 34px);
    align-items: start;
}

.contrib-grid-reverse {
    grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
}

.contrib-card {
    border-radius: 18px;
    border: 1px solid rgba(119, 106, 88, 0.22);
    background: rgba(255, 255, 255, 0.78);
    box-shadow: 0 14px 28px rgba(68, 57, 44, 0.12);
    padding: clamp(1rem, 1.8vw, 1.5rem);
}

.contrib-card h2 {
    margin: 0 0 0.85rem;
    color: #27221c;
    font-size: clamp(1.2rem, 2.2vw, 1.7rem);
}

.contrib-card h3 {
    margin: 1.2rem 0 0.55rem;
    color: #302922;
    font-size: 1.03rem;
}

.contrib-card h4 {
    margin: 1rem 0 0.45rem;
    color: #3a3229;
    font-size: 0.97rem;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.contrib-card p,
.contrib-card li {
    color: #4e473f;
    line-height: 1.52;
}

.contrib-card ul {
    margin: 0;
    padding-left: 1.05rem;
    display: grid;
    gap: 0.45rem;
}

.contrib-card a {
    color: #5f574e;
    word-break: break-word;
}

.contrib-kv {
    margin-top: 0.9rem;
    padding-top: 0.75rem;
    border-top: 1px dashed rgba(126, 113, 96, 0.34);
    display: grid;
    gap: 0.4rem;
}

.contrib-kv p {
    margin: 0;
    display: flex;
    justify-content: space-between;
    gap: 0.75rem;
}

.contrib-kv span {
    color: #27211a;
    font-weight: 700;
    text-align: right;
}

.contrib-media-stack {
    display: grid;
    gap: 14px;
}

.contrib-media {
    margin: 0;
    border-radius: 16px;
    border: 1px solid rgba(118, 106, 90, 0.25);
    background: rgba(255, 255, 255, 0.86);
    box-shadow: 0 12px 24px rgba(59, 50, 39, 0.1);
    overflow: hidden;
}

.contrib-media img {
    width: 100%;
    height: auto;
    display: block;
}

.contrib-media figcaption {
    padding: 0.6rem 0.75rem;
    font-size: 0.84rem;
    color: #544c43;
}

.contrib-video {
    border-radius: 16px;
    border: 1px solid rgba(118, 106, 90, 0.25);
    background: rgba(255, 255, 255, 0.86);
    box-shadow: 0 12px 24px rgba(59, 50, 39, 0.1);
    overflow: hidden;
    width: 100%;
    max-width: 100%;
    aspect-ratio: 16 / 9;
}

.contrib-video iframe {
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
}

[data-theme="dark"] .contrib-page {
    background: #0f0f0e;
}

[data-theme="dark"] .contrib-hero {
    background: linear-gradient(145deg, #111110 0%, #201d19 52%, #312b24 100%);
    border-bottom-color: rgba(189, 177, 158, 0.22);
}

[data-theme="dark"] .contrib-eyebrow {
    color: #c8bcac;
}

[data-theme="dark"] .contrib-hero h1 {
    color: #f2ece3;
}

[data-theme="dark"] .contrib-sub {
    color: #d8cec0;
}

[data-theme="dark"] .contrib-card,
[data-theme="dark"] .contrib-media {
    background: rgba(33, 29, 25, 0.82);
    border-color: rgba(190, 178, 158, 0.2);
    box-shadow: 0 14px 30px rgba(0, 0, 0, 0.32);
}

[data-theme="dark"] .contrib-card h2,
[data-theme="dark"] .contrib-card h3,
[data-theme="dark"] .contrib-card h4,
[data-theme="dark"] .contrib-kv span {
    color: #efe7dc;
}

[data-theme="dark"] .contrib-card p,
[data-theme="dark"] .contrib-card li,
[data-theme="dark"] .contrib-media figcaption,
[data-theme="dark"] .contrib-card a {
    color: #d2c7b8;
}

[data-theme="dark"] .contrib-video {
    background: rgba(33, 29, 25, 0.82);
    border-color: rgba(190, 178, 158, 0.2);
    box-shadow: 0 14px 30px rgba(0, 0, 0, 0.32);
}

[data-theme="dark"] .contrib-kv {
    border-top-color: rgba(190, 178, 158, 0.28);
}

@media (max-width: 980px) {
    .contrib-grid,
    .contrib-grid-reverse {
        grid-template-columns: 1fr;
    }

    .contrib-kv p {
        flex-direction: column;
        align-items: flex-start;
    }

    .contrib-kv span {
        text-align: left;
    }
}
/* High contrast overrides */
html[data-contrast="high"] body,
html[data-contrast="high"] section,
html[data-contrast="high"] main,
html[data-contrast="high"] header,
html[data-contrast="high"] footer {
    background: #000000 !important;
    color: #ffffff !important;
}

html[data-contrast="high"] a,
html[data-contrast="high"] p,
html[data-contrast="high"] h1,
html[data-contrast="high"] h2,
html[data-contrast="high"] h3,
html[data-contrast="high"] h4,
html[data-contrast="high"] h5,
html[data-contrast="high"] h6,
html[data-contrast="high"] li,
html[data-contrast="high"] span,
html[data-contrast="high"] strong {
    color: #ffffff !important;
}

html[data-contrast="high"] .card,
html[data-contrast="high"] .panel,
html[data-contrast="high"] .box,
html[data-contrast="high"] .table,
html[data-contrast="high"] .table-wrap,
html[data-contrast="high"] .grid,
html[data-contrast="high"] .content {
    background: #0d0d0d !important;
    border-color: rgba(255, 255, 255, 0.25) !important;
}

html[data-contrast="high"] .contrib-card {
    background: #0d0d0d !important;
    border-color: rgba(255, 255, 255, 0.35) !important;
    box-shadow: none !important;
}

html[data-contrast="high"] .contrib-card h2,
html[data-contrast="high"] .contrib-card h3,
html[data-contrast="high"] .contrib-card h4,
html[data-contrast="high"] .contrib-card p,
html[data-contrast="high"] .contrib-card li,
html[data-contrast="high"] .contrib-card a {
    color: #ffffff !important;
}
