:root {
    --ink: #17202a;
    --muted: #5d6775;
    --line: #d9e0e7;
    --paper: #ffffff;
    --soft: #f4f7fa;
    --brand: #02b056;
    --brand-dark: #007a3d;
    --accent: #b33b32;
    --gold: #c59a35;
    --shadow: 0 18px 45px rgba(23, 32, 42, 0.09);
    --radius: 8px;
}

body {
    color: var(--ink);
    font-family: "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    background: var(--paper);
}

a {
    color: var(--brand);
}

a:hover {
    color: var(--brand-dark);
}

.skip-link {
    position: absolute;
    left: 1rem;
    top: -4rem;
    z-index: 2000;
    padding: .75rem 1rem;
    color: var(--paper);
    background: var(--brand);
    border-radius: var(--radius);
}

.skip-link:focus {
    top: 1rem;
}

.topbar {
    color: rgba(255, 255, 255, .86);
    background: var(--brand-dark);
    font-size: .875rem;
    padding: .55rem 0;
}

.topbar__item {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 1040;
}

.site-navbar {
    border-bottom: 1px solid var(--line);
    box-shadow: 0 8px 26px rgba(0, 0, 0, .04);
    position: relative;
    z-index: 1041;
}

.site-navbar .container {
    position: relative;
}

.navbar-brand {
    min-width: 0;
}

.brand-mark {
    height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    background: transparent;
    border-radius: 0;
}

.brand-mark--light {
    width: 48px;
    height: 48px;
    color: var(--brand);
    background: var(--paper);
    border-radius: 50%;
    font-size: 1.35rem;
    font-weight: 800;
}

.brand-mark img {
    display: block;
    width: auto;
    height: 100%;
    max-width: 100%;
    object-fit: contain;
}

.brand-copy {
    display: grid;
    min-width: 0;
    line-height: 1.1;
}

.brand-copy__name {
    font-weight: 800;
    color: var(--brand);
}

.brand-copy__meta {
    max-width: 320px;
    color: var(--muted);
    font-size: .78rem;
    white-space: normal;
}

.navbar-nav .nav-link {
    color: var(--ink);
    font-weight: 600;
    font-size: .93rem;
    padding-inline: .65rem;
    border: 0;
    background: transparent;
}

.navbar-nav .nav-link.active,
.navbar-nav .nav-link:hover {
    color: var(--brand);
}

.navbar-toggler {
    border-color: var(--line);
}

.nav-cta {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
}

.nav-cta.active {
    background: var(--brand-dark);
    border-color: var(--brand-dark);
}

.mega-nav {
    position: static;
}

.mega-menu {
    position: absolute;
    top: calc(100% + .55rem) !important;
    right: 0 !important;
    left: auto !important;
    width: min(820px, calc(100vw - 2rem));
    max-height: calc(100vh - 9rem);
    padding: 0;
    margin-top: 0;
    transform: none !important;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    overflow: auto;
}

.mega-menu[data-bs-popper] {
    top: calc(100% + .55rem) !important;
    right: 0 !important;
    left: auto !important;
    margin-top: 0;
    transform: none !important;
}

.mega-menu__content {
    display: grid;
    gap: .9rem;
    padding: .95rem;
    background: var(--paper);
}

.mega-menu__intro {
    padding: .95rem 1rem;
    background: var(--soft);
    border-left: 4px solid var(--gold);
    border-radius: var(--radius);
}

.mega-menu__eyebrow {
    display: inline-block;
    color: var(--brand-dark);
    font-size: .72rem;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
    margin-bottom: .45rem;
}

.mega-menu__intro h2 {
    color: var(--ink);
    font-size: 1.08rem;
    font-weight: 800;
    line-height: 1.2;
    letter-spacing: 0;
    margin-bottom: .35rem;
}

.mega-menu__intro p {
    color: var(--muted);
    margin-bottom: 0;
    font-size: .9rem;
}

.mega-menu__links {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: .75rem;
}

.mega-menu--count-2 .mega-menu__links {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.mega-menu--count-3 .mega-menu__links {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.mega-menu--count-4 .mega-menu__links {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.mega-menu--count-6 .mega-menu__links {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.mega-menu__item {
    display: grid;
    grid-template-columns: 38px minmax(0, 1fr);
    gap: .75rem;
    align-items: flex-start;
    min-height: 86px;
    padding: .85rem;
    color: var(--ink);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    text-decoration: none;
    background: var(--paper);
    transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease, background .2s ease;
}

.mega-menu__item:hover,
.mega-menu__item.active {
    color: var(--ink);
    border-color: rgba(2, 176, 86, .34);
    background: color-mix(in srgb, var(--brand) 6%, var(--paper));
    box-shadow: 0 12px 28px rgba(23, 32, 42, .08);
    transform: translateY(-2px);
}

.mega-nav .dropdown-toggle.show,
.mega-nav .dropdown-toggle[aria-expanded="true"] {
    color: var(--brand);
}

.mega-menu__icon {
    width: 38px;
    height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--brand-dark);
    background: color-mix(in srgb, var(--brand) 10%, var(--paper));
    border-radius: var(--radius);
    font-size: 1.05rem;
}

.mega-menu__label {
    display: block;
    color: var(--ink);
    font-weight: 800;
    line-height: 1.2;
    margin-bottom: .25rem;
}

.mega-menu__summary {
    display: block;
    color: var(--muted);
    font-size: .86rem;
    line-height: 1.35;
}

.page-hero {
    position: relative;
    min-height: 520px;
    display: flex;
    align-items: center;
    color: var(--paper);
    background-image: var(--hero-image);
    background-position: center;
    background-size: cover;
    overflow: hidden;
}

.page-hero__overlay {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, color-mix(in srgb, var(--brand-dark) 82%, #000 18%) 0%, rgba(0, 122, 61, .78) 46%, rgba(0, 0, 0, .24) 100%),
        linear-gradient(0deg, rgba(0, 0, 0, .18), rgba(0, 0, 0, .18));
}

.page-hero__content {
    max-width: 850px;
    padding: 6rem 0;
}

.page-hero h1 {
    margin-bottom: 1.15rem;
    font-size: 4.75rem;
    line-height: 1.02;
    font-weight: 800;
    letter-spacing: 0;
}

.page-hero .lead {
    max-width: 760px;
    color: rgba(255, 255, 255, .86);
    font-size: 1.2rem;
}

.hero-actions .btn,
.cta-band .btn,
.btn-kiu {
    border-radius: var(--radius);
    font-weight: 700;
    padding: .78rem 1.15rem;
}

.btn-kiu {
    color: var(--paper);
    background: var(--brand);
    border-color: var(--brand);
}

.btn-kiu:hover {
    color: var(--paper);
    background: var(--brand-dark);
    border-color: var(--brand-dark);
}

.drice-breadcrumb {
    --bs-breadcrumb-divider-color: rgba(255, 255, 255, .65);
    color: rgba(255, 255, 255, .7);
    margin-bottom: 1.5rem;
}

.drice-breadcrumb a {
    color: rgba(255, 255, 255, .82);
    text-decoration: none;
}

.drice-breadcrumb .active {
    color: rgba(255, 255, 255, .62);
}

.eyebrow {
    color: var(--brand);
    font-size: .78rem;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.section-space {
    padding: 5rem 0;
}

.section-space--soft {
    background: var(--soft);
}

.section-header {
    max-width: 760px;
    margin-bottom: 2.25rem;
}

.section-header--center {
    margin-inline: auto;
    text-align: center;
}

.section-header h2,
.cta-band h2,
.contact-panel h2 {
    color: var(--ink);
    font-weight: 800;
    line-height: 1.12;
    letter-spacing: 0;
}

.section-header p:last-child,
.cta-band p,
.content-panel p,
.contact-panel li,
.article-body p {
    color: var(--muted);
}

.drice-card {
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 100%;
    padding: 1.45rem;
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: 0 10px 28px rgba(15, 47, 34, .06);
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.drice-card:hover {
    transform: translateY(-4px);
    border-color: rgba(2, 176, 86, .35);
    box-shadow: var(--shadow);
}

.drice-card__icon {
    width: 46px;
    height: 46px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--brand-dark);
    background: color-mix(in srgb, var(--brand) 11%, var(--paper));
    border-radius: var(--radius);
    font-size: 1.35rem;
    margin-bottom: 1rem;
}
.drice-card__media {
    position: relative;
    width: calc(100% + 2.9rem);
    aspect-ratio: 16 / 10;
    margin: -1.45rem -1.45rem 1rem;
    overflow: hidden;
    border-bottom: 1px solid var(--line);
    background: var(--soft);
}

.drice-card__media img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.drice-card--profile .drice-card__media {
    width: calc(100% + 1.9rem);
    aspect-ratio: 1 / 1;
    margin: -.95rem -.95rem .85rem;
    background: var(--paper);
}

.drice-card--profile .drice-card__media img {
    object-fit: contain;
    padding: .45rem;
}

.drice-card--profile h3 {
    display: -webkit-box;
    overflow: hidden;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    margin-bottom: .4rem;
}

.drice-card--profile .drice-card__meta {
    margin-top: 0;
}

.drice-card--profile .drice-card__link {
    margin-top: .65rem;
}

.drice-card--profile {
    padding: .95rem;
}

.drice-card--profile p {
    margin-bottom: .55rem;
    line-height: 1.45;
}

.staff-campus-list {
    display: grid;
    gap: 2.25rem;
}

.staff-campus-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    margin-bottom: 1.6rem;
}

.staff-campus-tab {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .65rem;
    min-height: 46px;
    color: var(--brand-dark);
    background: var(--paper);
    border: 1px solid color-mix(in srgb, var(--brand) 26%, var(--line));
    border-radius: var(--radius);
    font-weight: 850;
    padding: .65rem .95rem;
    transition: background .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease;
}

.staff-campus-tab small {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 28px;
    min-height: 24px;
    color: var(--paper);
    background: var(--brand-dark);
    border-radius: 999px;
    font-size: .75rem;
    line-height: 1;
    padding: .25rem .45rem;
}

.staff-campus-tab:hover,
.staff-campus-tab:focus {
    color: var(--brand-dark);
    background: color-mix(in srgb, var(--brand) 7%, var(--paper));
    border-color: color-mix(in srgb, var(--brand) 48%, var(--line));
}

.staff-campus-tab.active {
    color: var(--paper);
    background: linear-gradient(135deg, var(--brand-dark), var(--brand));
    border-color: transparent;
    box-shadow: 0 12px 28px rgba(2, 176, 86, .16);
}

.staff-campus-tab.active small {
    color: var(--brand-dark);
    background: var(--paper);
}

.staff-campus-group {
    display: grid;
    gap: 1.1rem;
}

.staff-campus-list .staff-campus-group:not(.active) {
    display: none;
}

.staff-campus-list .staff-campus-group.active {
    display: grid;
}

.staff-campus-heading {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    padding-bottom: .85rem;
    border-bottom: 1px solid var(--line);
}

.staff-campus-heading h2 {
    margin: 0;
    color: var(--ink);
    font-weight: 850;
    letter-spacing: 0;
}

.staff-campus-count {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    color: var(--brand-dark);
    background: color-mix(in srgb, var(--brand) 10%, var(--paper));
    border: 1px solid color-mix(in srgb, var(--brand) 26%, var(--line));
    border-radius: 999px;
    font-size: .82rem;
    font-weight: 850;
    padding: .35rem .75rem;
    white-space: nowrap;
}

.staff-member-card__position {
    margin-bottom: .5rem;
    color: var(--muted);
}

.staff-member-card__email {
    position: relative;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    width: fit-content;
    max-width: 100%;
    color: var(--brand-dark);
    font-size: .86rem;
    font-weight: 750;
    text-decoration: none;
    overflow-wrap: anywhere;
}

.staff-member-card__email:hover,
.staff-member-card__email:focus {
    color: var(--brand);
    text-decoration: underline;
}

.staff-profile-main h2 {
    color: var(--ink);
    font-weight: 850;
    line-height: 1.18;
    letter-spacing: 0;
    margin-bottom: 1rem;
}

.staff-profile-biodata p {
    line-height: 1.75;
}

.staff-profile-section {
    margin-top: 2rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--line);
}

.staff-profile-section h3 {
    color: var(--ink);
    font-size: 1.15rem;
    font-weight: 850;
    margin-bottom: 1rem;
}

.staff-profile-interests {
    display: flex;
    flex-wrap: wrap;
    gap: .6rem;
    padding: 0;
    margin: 0;
    list-style: none;
}

.staff-profile-interests li {
    color: var(--brand-dark);
    background: color-mix(in srgb, var(--brand) 9%, var(--paper));
    border: 1px solid color-mix(in srgb, var(--brand) 24%, var(--line));
    border-radius: 999px;
    font-size: .9rem;
    font-weight: 750;
    padding: .4rem .7rem;
}

.drice-card__media.drice-card__media--placeholder {
    display: grid;
    place-items: center;
    background:
        linear-gradient(135deg, rgba(232, 247, 239, .98), rgba(202, 236, 218, .95)),
        repeating-linear-gradient(45deg, rgba(0, 122, 61, .08) 0 2px, transparent 2px 15px);
}

.drice-card__media.drice-card__media--placeholder span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 82px;
    height: 82px;
    color: var(--brand-dark);
    background: rgba(255, 255, 255, .58);
    border: 2px solid rgba(0, 122, 61, .22);
    border-radius: 50%;
    font-size: 1rem;
    font-weight: 800;
    letter-spacing: .08em;
}

.drice-card__tag {
    width: fit-content;
    color: var(--accent);
    background: color-mix(in srgb, var(--gold) 16%, var(--paper));
    border: 1px solid color-mix(in srgb, var(--gold) 28%, var(--paper));
    border-radius: 999px;
    font-size: .72rem;
    font-weight: 800;
    padding: .28rem .62rem;
    margin-bottom: .8rem;
    text-transform: uppercase;
    letter-spacing: .06em;
}

.drice-card h3 {
    color: var(--ink);
    font-size: 1.12rem;
    font-weight: 800;
    line-height: 1.28;
    letter-spacing: 0;
    margin-bottom: .65rem;
}

.drice-card p {
    color: var(--muted);
    margin-bottom: 1rem;
}

.drice-card__meta {
    color: var(--brand-dark);
    font-size: .9rem;
    font-weight: 700;
    margin-top: auto;
}

.drice-card__link {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    width: fit-content;
    margin-top: 1rem;
    font-weight: 800;
    text-decoration: none;
}

.drice-card--profile h3 {
    font-size: 1rem;
    line-height: 1.22;
    margin-bottom: .35rem;
}

.drice-card--profile p {
    margin-bottom: .5rem;
}

.drice-card--profile .drice-card__meta {
    margin-top: 0;
    font-size: .84rem;
}

.drice-card--profile .drice-card__link {
    margin-top: .55rem;
}

.impact-band {
    padding: 3rem 0;
    color: var(--paper);
    background: var(--brand-dark);
}

.impact-band--light {
    color: var(--ink);
    background: color-mix(in srgb, var(--brand) 10%, var(--paper));
}

.impact-stat {
    min-height: 118px;
    display: grid;
    align-content: center;
    padding: 1.2rem;
    border-radius: var(--radius);
    background: rgba(255, 255, 255, .12);
}

.impact-band--light .impact-stat {
    background: var(--paper);
    border: 1px solid var(--line);
}

.impact-stat__value {
    font-size: 2rem;
    font-weight: 850;
    line-height: 1;
}

.impact-stat__label {
    margin-top: .55rem;
    color: inherit;
    opacity: .82;
    font-weight: 600;
}

.cta-band {
    color: var(--paper);
    background:
        linear-gradient(135deg, var(--brand-dark), var(--brand));
    padding: 4rem 0;
}

.cta-band__inner {
    border-left: 5px solid var(--gold);
    padding-left: 1.5rem;
}

.cta-band h2,
.cta-band .eyebrow,
.cta-band p {
    color: var(--paper);
}

.cta-band p {
    max-width: 720px;
    margin-bottom: 0;
    opacity: .86;
}

.home-hero {
    position: relative;
    min-height: 640px;
    display: flex;
    align-items: center;
    color: var(--paper);
    background-image: var(--home-hero-image);
    background-position: center;
    background-size: cover;
    overflow: hidden;
}

.home-hero::after {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 8px;
    background: linear-gradient(90deg, var(--brand), var(--gold), var(--accent));
}

.home-hero__overlay {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(0, 73, 39, .92) 0%, rgba(0, 122, 61, .76) 48%, rgba(23, 32, 42, .42) 100%),
        linear-gradient(0deg, rgba(0, 0, 0, .22), rgba(0, 0, 0, .08));
}

.home-hero__content {
    max-width: 940px;
    padding: 6.5rem 0 7rem;
}

.home-hero__kicker {
    width: fit-content;
    color: color-mix(in srgb, var(--gold) 72%, var(--paper));
    font-size: .8rem;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
    margin-bottom: 1rem;
}

.home-hero h1 {
    max-width: 880px;
    margin-bottom: 1.2rem;
    color: var(--paper);
    font-size: 4.35rem;
    font-weight: 900;
    line-height: 1.02;
    letter-spacing: 0;
}

.home-hero__lead {
    max-width: 760px;
    color: rgba(255, 255, 255, .86);
    font-size: 1.18rem;
    line-height: 1.65;
    margin-bottom: 0;
}

.home-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: .8rem;
    margin-top: 1.7rem;
}

.home-hero__actions .btn {
    display: inline-flex;
    align-items: center;
    min-height: 48px;
    border-radius: var(--radius);
    font-weight: 850;
    padding-inline: 1.2rem;
}

.home-hero__signals {
    display: flex;
    flex-wrap: wrap;
    gap: .65rem;
    margin-top: 2.2rem;
}

.home-hero__signals span {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: .35rem .75rem;
    color: rgba(255, 255, 255, .9);
    background: rgba(255, 255, 255, .1);
    border: 1px solid rgba(255, 255, 255, .22);
    border-radius: 999px;
    font-size: .84rem;
    font-weight: 750;
}

.home-quicklinks {
    position: relative;
    z-index: 2;
    margin-top: -3rem;
}

.home-quicklinks__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: .9rem;
}

.home-quicklink {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr) auto;
    gap: .85rem;
    align-items: center;
    min-height: 118px;
    padding: 1rem;
    color: var(--ink);
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: 0 16px 38px rgba(15, 47, 34, .12);
    text-decoration: none;
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.home-quicklink:hover,
.home-quicklink:focus {
    color: var(--ink);
    border-color: color-mix(in srgb, var(--brand) 38%, var(--line));
    box-shadow: var(--shadow);
    transform: translateY(-3px);
}

.home-quicklink__icon,
.home-featured-item__icon,
.home-focus-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--brand-dark);
    background: color-mix(in srgb, var(--brand) 10%, var(--paper));
    border-radius: var(--radius);
}

.home-quicklink__icon {
    width: 42px;
    height: 42px;
    font-size: 1.2rem;
}

.home-quicklink__body {
    display: grid;
    gap: .25rem;
    min-width: 0;
}

.home-quicklink strong {
    color: var(--ink);
    font-size: 1rem;
    line-height: 1.2;
}

.home-quicklink__body span {
    color: var(--muted);
    font-size: .88rem;
    line-height: 1.35;
}

.home-quicklink__arrow {
    color: var(--gold);
    font-size: 1.3rem;
}

.home-impact {
    padding-top: 4.25rem;
}

.home-impact__intro {
    height: 100%;
    display: grid;
    align-content: center;
    gap: .85rem;
    padding-left: 1.25rem;
    border-left: 5px solid var(--gold);
}

.home-impact__intro h2,
.home-pathway__header h2,
.home-featured__intro h2 {
    color: var(--ink);
    font-weight: 900;
    line-height: 1.12;
    letter-spacing: 0;
    margin-bottom: 0;
}

.home-impact__intro p,
.home-pathway__header p,
.home-featured__intro p {
    color: var(--muted);
    line-height: 1.7;
    margin-bottom: 0;
}

.home-stat-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.home-stat {
    min-height: 160px;
    display: grid;
    align-content: center;
    padding: 1.35rem;
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: 0 12px 30px rgba(15, 47, 34, .06);
}

.home-stat__value {
    color: var(--brand-dark);
    font-size: 2.4rem;
    font-weight: 900;
    line-height: 1;
}

.home-stat__label {
    max-width: 240px;
    color: var(--muted);
    font-weight: 750;
    line-height: 1.35;
    margin-top: .6rem;
}

.home-focus__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.home-focus-card {
    position: relative;
    min-height: 310px;
    display: flex;
    flex-direction: column;
    padding: 1.25rem;
    background: var(--paper);
    border: 1px solid var(--line);
    border-top: 5px solid var(--brand);
    border-radius: var(--radius);
    box-shadow: 0 12px 30px rgba(15, 47, 34, .06);
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.home-focus-card:hover,
.home-focus-card:focus-within {
    border-color: color-mix(in srgb, var(--brand) 36%, var(--line));
    box-shadow: var(--shadow);
    transform: translateY(-3px);
}

.home-focus-card__number {
    color: color-mix(in srgb, var(--brand) 18%, var(--paper));
    font-size: 3rem;
    font-weight: 900;
    line-height: 1;
}

.home-focus-card__icon {
    width: 44px;
    height: 44px;
    margin: -1.7rem 0 1rem auto;
    font-size: 1.2rem;
}

.home-focus-card__tag,
.home-featured-item__tag {
    color: var(--accent);
    font-size: .76rem;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
    margin-bottom: .45rem;
}

.home-focus-card h3,
.home-pathway-step h3,
.home-featured-item h3 {
    color: var(--ink);
    font-weight: 850;
    line-height: 1.2;
    letter-spacing: 0;
}

.home-focus-card p,
.home-pathway-step p,
.home-featured-item p {
    color: var(--muted);
    line-height: 1.6;
}

.home-focus-card__link,
.home-featured-item a {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    color: var(--brand-dark);
    font-weight: 850;
    text-decoration: none;
    margin-top: auto;
}

.home-pathway__header {
    display: grid;
    grid-template-columns: minmax(0, .9fr) minmax(280px, .7fr);
    gap: 2rem;
    align-items: end;
    margin-bottom: 2rem;
}

.home-pathway__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
    counter-reset: pathway;
}

.home-pathway-step {
    position: relative;
    min-height: 250px;
    padding: 1.2rem;
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--radius);
}

.home-pathway-step::after {
    content: "";
    position: absolute;
    top: 2rem;
    right: -1rem;
    width: 1rem;
    height: 2px;
    background: var(--gold);
}

.home-pathway-step:last-child::after {
    display: none;
}

.home-pathway-step__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    color: var(--paper);
    background: var(--brand-dark);
    border-radius: 50%;
    font-weight: 900;
    margin-bottom: 1rem;
}

.home-pathway-step > i {
    display: block;
    color: var(--gold);
    font-size: 1.6rem;
    margin-bottom: 1rem;
}

.home-featured__layout {
    display: grid;
    grid-template-columns: minmax(260px, .72fr) minmax(0, 1.28fr);
    gap: 1.4rem;
    align-items: start;
}

.home-featured__intro {
    display: grid;
    gap: .85rem;
    padding: 1.35rem 0 1.35rem 1.25rem;
    border-left: 5px solid var(--gold);
}

.home-featured__list {
    display: grid;
    gap: .9rem;
}

.home-featured-item {
    display: grid;
    grid-template-columns: 52px minmax(0, 1fr);
    gap: 1rem;
    padding: 1.15rem;
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: 0 12px 30px rgba(15, 47, 34, .05);
}

.home-featured-item__icon {
    width: 52px;
    height: 52px;
    font-size: 1.35rem;
}

.home-featured-item h3 {
    margin-bottom: .45rem;
}

.home-featured-item p {
    margin-bottom: .6rem;
}

@media (max-width: 1199.98px) {
    .home-quicklinks__grid,
    .home-focus__grid,
    .home-pathway__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .home-pathway-step:nth-child(2)::after {
        display: none;
    }
}

@media (max-width: 991.98px) {
    .home-hero {
        min-height: 590px;
    }

    .home-hero__content {
        padding: 5.5rem 0 6.25rem;
    }

    .home-hero h1 {
        font-size: 3.25rem;
    }

    .home-impact__intro {
        height: auto;
    }

    .home-pathway__header,
    .home-featured__layout {
        grid-template-columns: 1fr;
    }

    .home-featured__intro {
        padding-block: 0;
    }
}

@media (max-width: 767.98px) {
    .home-hero {
        min-height: 540px;
    }

    .home-hero__content {
        padding: 4.5rem 0 5.5rem;
    }

    .home-hero h1 {
        font-size: 2.45rem;
    }

    .home-hero__lead {
        font-size: 1rem;
    }

    .home-quicklinks {
        margin-top: 0;
        padding-top: 1rem;
        background: var(--soft);
    }

    .home-quicklinks__grid,
    .home-stat-grid,
    .home-focus__grid,
    .home-pathway__grid {
        grid-template-columns: 1fr;
    }

    .home-quicklink {
        min-height: 100px;
        box-shadow: 0 10px 24px rgba(15, 47, 34, .08);
    }

    .home-impact,
    .home-focus,
    .home-pathway,
    .home-featured {
        padding-block: 3.5rem;
    }

    .home-stat,
    .home-focus-card,
    .home-pathway-step {
        min-height: 0;
    }

    .home-pathway-step::after {
        display: none;
    }

    .home-featured-item {
        grid-template-columns: 44px minmax(0, 1fr);
    }

    .home-featured-item__icon {
        width: 44px;
        height: 44px;
    }
}

.content-panel,
.contact-panel,
.contact-form,
.article-body {
    padding: 2rem;
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: 0 12px 34px rgba(15, 47, 34, .06);
}

.contact-list {
    display: grid;
    gap: 1rem;
    margin: 1.5rem 0 0;
}

.contact-list li,
.footer-contact li {
    display: flex;
    gap: .75rem;
}

.contact-list i,
.footer-contact i {
    color: var(--gold);
    flex: 0 0 auto;
}

.form-control,
.form-select {
    border-color: var(--line);
    border-radius: var(--radius);
    min-height: 48px;
}

.form-control:focus,
.form-select:focus {
    border-color: var(--brand);
    box-shadow: 0 0 0 .2rem rgba(2, 176, 86, .16);
}

.article-meta {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    margin-bottom: 1.5rem;
    color: var(--brand-dark);
    font-weight: 800;
}

.article-detail-layout {
    display: grid;
    grid-template-columns: minmax(0, 2fr) minmax(290px, .9fr);
    gap: 1.5rem;
    align-items: start;
}

.news-index-section {
    padding-bottom: 2rem;
}

.resources-index-section {
    padding-bottom: 2rem;
}

.opportunities-index-section {
    padding-bottom: 2rem;
}

.article-detail-media {
    margin: 0 0 1.5rem;
    overflow: hidden;
    background: var(--soft);
    border: 1px solid var(--line);
    border-radius: var(--radius);
}

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

.article-sidebar-stack {
    top: 110px;
}

.profile-detail-photo {
    margin: 0;
    padding: .75rem;
}

.profile-detail-photo img {
    display: block;
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: contain;
    background: var(--soft);
    border-radius: calc(var(--radius) - 4px);
}

.profile-detail-photo--placeholder {
    display: grid;
    place-items: center;
    aspect-ratio: 1 / 1;
    min-height: 260px;
    background:
        linear-gradient(135deg, rgba(232, 247, 239, .98), rgba(202, 236, 218, .95)),
        repeating-linear-gradient(45deg, rgba(0, 122, 61, .08) 0 2px, transparent 2px 15px);
}

.profile-detail-photo--placeholder span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 104px;
    height: 104px;
    color: var(--brand-dark);
    background: rgba(255, 255, 255, .58);
    border: 2px solid rgba(0, 122, 61, .22);
    border-radius: 50%;
    font-size: 1.25rem;
    font-weight: 900;
    letter-spacing: .08em;
}

.news-side-card--related .project-side-card__body {
    padding: .35rem 0;
}

.related-news-list {
    display: grid;
}

.related-news-link {
    display: grid;
    gap: .3rem;
    padding: .95rem 1rem;
    color: var(--ink);
    border-bottom: 1px solid var(--line);
    text-decoration: none;
    transition: background .18s ease, color .18s ease;
}

.related-news-link:last-child {
    border-bottom: 0;
}

.related-news-link:hover,
.related-news-link:focus {
    color: var(--ink);
    background: color-mix(in srgb, var(--brand) 7%, var(--paper));
    text-decoration: none;
}

.related-news-link__meta {
    color: var(--brand-dark);
    font-size: .76rem;
    font-weight: 850;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.related-news-link__title {
    color: var(--ink);
    font-size: .94rem;
    font-weight: 800;
    line-height: 1.3;
}

.opportunity-detail-main h2,
.content-detail-main h2 {
    color: var(--ink);
    font-weight: 850;
    line-height: 1.18;
    letter-spacing: 0;
    margin-bottom: 1rem;
}

.poster-heading {
    display: grid;
    grid-template-columns: minmax(24px, 1fr) auto minmax(24px, 1fr);
    align-items: center;
    gap: 1rem;
    max-width: 820px;
    margin: 0 auto 2rem;
}

.poster-heading--compact {
    max-width: 680px;
    margin-top: 2.25rem;
    margin-bottom: 1.75rem;
}

.poster-heading__line {
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--brand-dark), transparent);
    position: relative;
}

.poster-heading__line::after {
    content: "";
    position: absolute;
    top: 50%;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--brand-dark);
    transform: translateY(-50%);
}

.poster-heading__line:first-child::after {
    right: 0;
}

.poster-heading__line:last-child::after {
    left: 0;
}

.poster-heading__pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--paper);
    background: linear-gradient(135deg, var(--brand-dark), var(--brand));
    border-radius: var(--radius);
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .04em;
    padding: .5rem 1.25rem;
    box-shadow: 0 10px 24px rgba(0, 122, 61, .18);
}

.cluster-poster-grid {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 1rem;
}

.cluster-poster {
    grid-column: span 4;
    display: flex;
    flex-direction: column;
    min-height: 100%;
    padding: 1.05rem;
    background: var(--paper);
    border: 1px solid color-mix(in srgb, var(--cluster-color, var(--brand-dark)) 42%, var(--line));
    border-radius: var(--radius);
    box-shadow: 0 12px 30px rgba(23, 32, 42, .07);
}

.cluster-poster--red {
    --cluster-color: #d71920;
}

.cluster-poster--gold {
    --cluster-color: #bd7b15;
}

.cluster-poster--blue {
    --cluster-color: #0f68a8;
}

.cluster-poster--orange {
    --cluster-color: #f05a22;
}

.cluster-poster--purple {
    --cluster-color: #5b3f99;
}

.cluster-poster--teal {
    --cluster-color: #00827f;
}

.cluster-poster--maroon {
    --cluster-color: #9b1238;
}

.cluster-poster__topline {
    display: flex;
    align-items: center;
    gap: .6rem;
    margin-bottom: .95rem;
}

.cluster-poster__number {
    width: 38px;
    height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--paper);
    background: var(--cluster-color, var(--brand-dark));
    border-radius: 50%;
    font-size: 1.3rem;
    font-weight: 900;
    line-height: 1;
}

.cluster-poster__label {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    color: var(--paper);
    background: var(--brand-dark);
    border-radius: var(--radius);
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: .06em;
    text-transform: uppercase;
    padding: .4rem .75rem;
}

.cluster-poster h3 {
    color: var(--ink);
    font-size: 1.35rem;
    font-weight: 900;
    line-height: 1.12;
    letter-spacing: 0;
    margin-bottom: .7rem;
}

.cluster-poster p {
    color: var(--muted);
    margin-bottom: .9rem;
}

.cluster-poster__divider {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: .55rem;
    color: var(--brand-dark);
    margin: .35rem 0 .85rem;
}

.cluster-poster__divider span {
    height: 2px;
    background: color-mix(in srgb, var(--cluster-color, var(--brand-dark)) 55%, var(--line));
}

.cluster-poster__divider strong {
    font-size: .72rem;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.sdg-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(118px, 1fr));
    gap: .55rem;
}

.sdg-tile {
    position: relative;
    min-width: 0;
    min-height: 94px;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: .15rem .5rem;
    align-items: start;
    color: var(--paper);
    border-radius: var(--radius);
    padding: .7rem .75rem 2rem;
    overflow: hidden;
}

.sdg-tile__number {
    font-size: 1.65rem;
    font-weight: 900;
    line-height: .95;
}

.sdg-tile__label {
    min-width: 0;
    max-width: 100%;
    font-size: .62rem;
    font-weight: 900;
    line-height: 1.05;
    text-transform: uppercase;
    overflow-wrap: anywhere;
    word-break: normal;
    hyphens: auto;
}

.sdg-tile i {
    position: absolute;
    right: .55rem;
    bottom: .45rem;
    font-size: 1.55rem;
    opacity: .9;
}

.sdg-red {
    background: #e5231b;
}

.sdg-orange-red {
    background: #ef402b;
}

.sdg-navy {
    background: #00558a;
}

.sdg-pink {
    background: #dd1367;
}

.sdg-gold {
    background: #dda63a;
}

.sdg-deep-red {
    background: #c5192d;
}

.sdg-sky {
    background: #26bde2;
}

.sdg-yellow {
    background: #fdb713;
}

.sdg-green {
    background: #3f7e44;
}

.sdg-bright-green {
    background: #56c02b;
}

.sdg-blue {
    background: #0a97d9;
}

.sdg-orange {
    background: #fd6925;
}

.sdg-amber {
    background: #fd9d24;
}

.sdg-brown {
    background: #bf8b2e;
}

.sdg-health {
    background: #4c9f38;
}

.sdg-maroon {
    background: #a21942;
}

.commitment-band {
    padding: 2rem;
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
}

.commitment-band__title {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.commitment-band__title span {
    height: 2px;
    background: var(--brand-dark);
}

.commitment-band__title h2 {
    color: var(--brand-dark);
    font-size: 1.25rem;
    font-weight: 900;
    letter-spacing: .04em;
    text-transform: uppercase;
    margin: 0;
}

.commitment-item {
    text-align: center;
}

.commitment-item__icon,
.unit-function__icon {
    width: 64px;
    height: 64px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--brand-dark);
    background: color-mix(in srgb, var(--brand) 12%, var(--paper));
    border-radius: 50%;
    font-size: 1.85rem;
    margin-bottom: .9rem;
}

.commitment-item h3,
.unit-function h3 {
    color: var(--brand-dark);
    font-size: .95rem;
    font-weight: 900;
    line-height: 1.2;
    text-transform: uppercase;
    letter-spacing: .02em;
}

.commitment-item p,
.unit-function p {
    color: var(--muted);
    font-size: .92rem;
    margin-bottom: 0;
}

.unit-poster {
    position: relative;
    padding: 2rem;
    background:
        radial-gradient(circle at 95% 0%, color-mix(in srgb, var(--brand) 16%, transparent) 0 22%, transparent 23%),
        var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    overflow: hidden;
}

.unit-poster::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 30%;
    height: 38%;
    background: var(--brand-dark);
    border-bottom-left-radius: 100%;
    z-index: 0;
}

.unit-poster > * {
    position: relative;
    z-index: 1;
}

.unit-poster__header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1.5rem;
    align-items: center;
}

.unit-poster__header h2 {
    color: var(--brand-dark);
    max-width: 620px;
    font-size: 4.5rem;
    font-weight: 950;
    line-height: .96;
    letter-spacing: 0;
    text-transform: uppercase;
    margin-bottom: 1rem;
}

.unit-poster__header p:not(.eyebrow) {
    max-width: 560px;
    color: var(--ink);
    font-size: 1.1rem;
}

.unit-poster__mark {
    width: 220px;
    height: 220px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--brand-dark);
    border: 8px solid var(--brand);
    border-radius: 50%;
    font-size: 5rem;
}

.unit-function-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 1.5rem;
    margin-bottom: 2rem;
}

.unit-function {
    grid-column: span 2;
    text-align: center;
    padding: .5rem;
}

.unit-function:nth-child(4),
.unit-function:nth-child(5) {
    grid-column: span 3;
}

.collaboration-strip {
    display: grid;
    grid-template-columns: minmax(180px, 1.3fr) repeat(5, minmax(110px, 1fr));
    align-items: center;
    gap: 1rem;
    color: var(--paper);
    background: linear-gradient(135deg, var(--brand-dark), var(--brand));
    border-radius: var(--radius);
    padding: 1rem;
}

.collaboration-strip strong,
.collaboration-strip span {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
}

.collaboration-strip span {
    justify-content: center;
    min-height: 54px;
    border-left: 1px solid rgba(255, 255, 255, .28);
    font-weight: 700;
}

.collaboration-strip i {
    font-size: 1.45rem;
}

.site-footer {
    position: relative;
    overflow: hidden;
    color: rgba(255, 255, 255, .82);
    background:
        linear-gradient(135deg, rgba(0, 122, 61, .96), rgba(9, 38, 26, .98) 46%, #10251f),
        radial-gradient(circle at 15% 0, rgba(197, 154, 53, .22), transparent 34%);
    padding: 3.5rem 0 1.2rem;
}

.site-footer::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(90deg, transparent 0 92%, rgba(255, 255, 255, .05) 92% 93%, transparent 93% 100%),
        linear-gradient(0deg, transparent 0 92%, rgba(255, 255, 255, .04) 92% 93%, transparent 93% 100%);
    background-size: 52px 52px;
    opacity: .2;
}

.site-footer .container {
    position: relative;
    z-index: 1;
}

.site-footer h2,
.site-footer h3 {
    color: var(--paper);
}

.footer-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(280px, .8fr);
    gap: 2rem;
    align-items: center;
    padding-bottom: 2.2rem;
    border-bottom: 1px solid rgba(255, 255, 255, .16);
}

.footer-brand {
    display: flex;
    align-items: center;
    gap: 1rem;
    min-width: 0;
}

.footer-brand__mark {
    flex: 0 0 76px;
    width: 76px;
    height: 76px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--paper);
    border-radius: var(--radius);
    box-shadow: 0 16px 34px rgba(0, 0, 0, .2);
    padding: .65rem;
}

.footer-brand__mark img {
    display: block;
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.footer-brand__copy {
    min-width: 0;
}

.footer-kicker {
    color: color-mix(in srgb, var(--gold) 78%, var(--paper));
    font-size: .76rem;
    font-weight: 900;
    letter-spacing: .1em;
    text-transform: uppercase;
    margin-bottom: .4rem;
}

.footer-brand h2 {
    font-size: clamp(1.65rem, 2.8vw, 2.55rem);
    font-weight: 900;
    line-height: 1;
    margin-bottom: .35rem;
}

.footer-brand p:not(.footer-kicker),
.footer-cta p {
    margin-bottom: 0;
    color: rgba(255, 255, 255, .78);
}

.footer-cta {
    display: grid;
    justify-items: start;
    gap: 1rem;
    padding: 1.15rem;
    background: rgba(255, 255, 255, .08);
    border: 1px solid rgba(255, 255, 255, .14);
    border-radius: var(--radius);
}

.btn-footer {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    color: var(--brand-dark);
    background: var(--paper);
    border: 1px solid rgba(255, 255, 255, .72);
    font-weight: 850;
}

.btn-footer:hover,
.btn-footer:focus {
    color: var(--ink);
    background: color-mix(in srgb, var(--gold) 18%, var(--paper));
    border-color: var(--paper);
}

.footer-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.6rem;
    padding: 2.2rem 0;
}

.footer-heading {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    font-size: .86rem;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
    margin-bottom: 1rem;
}

.footer-heading::after {
    content: "";
    width: 28px;
    height: 2px;
    background: var(--gold);
}

.footer-links {
    display: grid;
    gap: .35rem;
}

.footer-links a,
.footer-bottom a,
.footer-contact a {
    display: inline-flex;
    align-items: center;
    gap: .2rem;
    color: rgba(255, 255, 255, .78);
    text-decoration: none;
    transition: color .18s ease, transform .18s ease;
}

.footer-links a {
    justify-content: space-between;
    width: 100%;
    min-height: 34px;
    padding: .25rem 0;
}

.footer-links a i {
    color: var(--gold);
    opacity: 0;
    transform: translateX(-5px);
    transition: opacity .18s ease, transform .18s ease;
}

.footer-links a:hover,
.footer-links a:focus,
.footer-bottom a:hover,
.footer-bottom a:focus,
.footer-contact a:hover,
.footer-contact a:focus {
    color: var(--paper);
}

.footer-links a:hover i,
.footer-links a:focus i {
    opacity: 1;
    transform: translateX(0);
}

.footer-contact {
    display: grid;
    gap: .7rem;
}

.footer-contact li {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr);
    align-items: center;
    gap: .7rem;
    min-height: 42px;
}

.footer-contact i {
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--paper);
    background: rgba(255, 255, 255, .11);
    border: 1px solid rgba(255, 255, 255, .14);
    border-radius: var(--radius);
}

.footer-contact span,
.footer-contact a {
    min-width: 0;
    overflow-wrap: anywhere;
}

.footer-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    border-top: 1px solid rgba(255, 255, 255, .14);
    padding-top: 1.25rem;
    font-size: .92rem;
}

.footer-bottom__links {
    display: flex;
    flex-wrap: wrap;
    gap: .9rem;
}

@media (max-width: 991.98px) {
    .footer-hero {
        grid-template-columns: 1fr;
        align-items: start;
    }

    .footer-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .site-footer {
        padding-top: 2.5rem;
    }

    .footer-hero,
    .footer-grid {
        gap: 1.35rem;
    }

    .footer-brand {
        align-items: flex-start;
    }

    .footer-brand__mark {
        flex-basis: 62px;
        width: 62px;
        height: 62px;
        padding: .55rem;
    }

    .footer-grid {
        grid-template-columns: 1fr;
        padding: 1.7rem 0;
    }

    .footer-cta {
        padding: 1rem;
    }

    .footer-bottom {
        align-items: flex-start;
        flex-direction: column;
    }
}

@media (max-width: 1199.98px) {
    .navbar-collapse {
        padding: 1rem 0 .75rem;
    }

    .navbar-nav .nav-link {
        padding: .7rem 0;
    }

    .mega-menu {
        position: static !important;
        width: 100%;
        max-height: none;
        margin: .25rem 0 .75rem;
        right: auto !important;
        left: auto !important;
        transform: none !important;
        border-radius: var(--radius);
        box-shadow: none;
    }

    .mega-menu[data-bs-popper] {
        position: static !important;
        width: 100%;
        margin: .25rem 0 .75rem;
        right: auto !important;
        left: auto !important;
        transform: none !important;
    }

    .mega-menu__content {
        padding: .8rem;
    }

    .mega-menu__intro {
        padding: 1rem;
    }

    .mega-menu__links {
        grid-template-columns: 1fr;
    }

    .mega-menu--count-2 .mega-menu__links,
    .mega-menu--count-3 .mega-menu__links,
    .mega-menu--count-4 .mega-menu__links,
    .mega-menu--count-6 .mega-menu__links {
        grid-template-columns: 1fr;
    }

    .mega-menu__item {
        min-height: 0;
    }

    .nav-cta {
        width: 100%;
        justify-content: center;
        margin-top: .5rem;
    }

    .page-hero h1 {
        font-size: 3.5rem;
    }

    .cluster-poster {
        grid-column: span 6;
    }

    .unit-poster__header {
        grid-template-columns: 1fr;
    }

    .unit-poster__mark {
        width: 150px;
        height: 150px;
        font-size: 3.5rem;
    }

    .unit-poster__header h2 {
        font-size: 3.35rem;
    }

    .unit-function-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .unit-function,
    .unit-function:nth-child(4),
    .unit-function:nth-child(5) {
        grid-column: auto;
    }

    .collaboration-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .collaboration-strip strong {
        grid-column: 1 / -1;
    }
}

@media (max-width: 767.98px) {
    .brand-copy__meta {
        max-width: 210px;
    }

    .page-hero {
        min-height: 460px;
    }

    .page-hero__content {
        padding: 4.5rem 0;
    }

    .page-hero h1 {
        font-size: 2.35rem;
    }

    .page-hero .lead {
        font-size: 1.05rem;
    }

    .section-space {
        padding: 3.5rem 0;
    }

    .content-panel,
    .contact-panel,
    .contact-form,
    .article-body {
        padding: 1.35rem;
    }

    .cta-band__inner {
        padding-left: 1rem;
    }

    .poster-heading {
        grid-template-columns: 1fr;
        gap: .75rem;
        text-align: center;
    }

    .poster-heading__line {
        display: none;
    }

    .cluster-poster {
        grid-column: span 12;
    }

    .cluster-poster h3 {
        font-size: 1.25rem;
    }

    .sdg-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .commitment-band,
    .unit-poster {
        padding: 1.25rem;
    }

    .commitment-band__title {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .commitment-band__title span {
        display: none;
    }

    .unit-poster::before {
        width: 48%;
        height: 22%;
    }

    .unit-poster__header h2 {
        font-size: 2.25rem;
    }

    .unit-function-grid,
    .collaboration-strip {
        grid-template-columns: 1fr;
    }

    .collaboration-strip span {
        justify-content: flex-start;
        border-left: 0;
        border-top: 1px solid rgba(255, 255, 255, .24);
        padding-top: .75rem;
    }
}

.project-detail-layout {
    background: var(--soft);
}

.project-detail-main h2,
.project-section-heading h2 {
    color: var(--ink);
    font-weight: 850;
    letter-spacing: 0;
    line-height: 1.14;
}

.project-detail-image {
    width: 100%;
    max-height: 420px;
    object-fit: cover;
    border-radius: var(--radius);
    margin-bottom: 1.5rem;
    border: 1px solid var(--line);
}

.project-rich-text {
    color: var(--muted);
    line-height: 1.75;
}

.project-rich-text p:last-child,
.project-rich-text ul:last-child,
.project-rich-text ol:last-child {
    margin-bottom: 0;
}

.project-rich-text img {
    max-width: 100%;
    height: auto;
    border-radius: var(--radius);
}

.project-rich-text a {
    overflow-wrap: anywhere;
}

.project-section-heading {
    margin: 2rem 0 1rem;
}

.project-accordion {
    display: grid;
    gap: .8rem;
}

.project-accordion .accordion-item {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: 0 10px 28px rgba(15, 47, 34, .05);
}

.project-accordion .accordion-button {
    color: var(--ink);
    background: var(--paper);
    font-weight: 800;
    letter-spacing: 0;
    box-shadow: none;
}

.project-accordion .accordion-button:not(.collapsed) {
    color: var(--brand-dark);
    background: color-mix(in srgb, var(--brand) 10%, var(--paper));
}

.project-accordion .accordion-body {
    background: var(--paper);
}

.project-sidebar-stack {
    display: grid;
    gap: 1rem;
    position: sticky;
    top: 110px;
}

.project-side-card {
    overflow: hidden;
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: 0 10px 28px rgba(15, 47, 34, .06);
}

.project-side-card__title {
    display: flex;
    align-items: center;
    gap: .55rem;
    color: var(--paper);
    background: linear-gradient(135deg, var(--brand-dark), var(--brand));
    padding: .85rem 1rem;
    font-weight: 850;
}

.project-side-card__body {
    padding: 1rem;
}

.project-meta-list {
    display: grid;
    gap: .85rem;
    margin: 0;
}

.project-meta-list div {
    display: grid;
    gap: .15rem;
}

.project-meta-list dt {
    color: var(--muted);
    font-size: .78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .04em;
}

.project-meta-list dd {
    margin: 0;
    color: var(--ink);
    font-weight: 750;
}

.project-side-card--actions {
    display: grid;
    gap: .75rem;
    padding: 1rem;
}

.project-side-card--related .project-side-card__body {
    padding: 1rem;
}

.project-side-card--related .related-project-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
    gap: .7rem;
}

.project-side-card--related .related-project-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .85rem;
    min-height: 74px;
    padding: .85rem;
    color: var(--ink);
    background: var(--soft);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    text-decoration: none;
    font-size: .94rem;
    line-height: 1.25;
    transition: background .18s ease, border-color .18s ease, color .18s ease, transform .18s ease;
}

.project-side-card--related .related-project-link:hover,
.project-side-card--related .related-project-link:focus {
    color: var(--ink);
    background: color-mix(in srgb, var(--brand) 7%, var(--paper));
    border-color: color-mix(in srgb, var(--brand) 36%, var(--line));
    text-decoration: none;
    transform: translateY(-1px);
}

.related-project-link__content {
    display: grid;
    gap: .35rem;
    min-width: 0;
}

.related-project-link__code {
    width: fit-content;
    color: var(--paper);
    background: var(--brand-dark);
    border-radius: 999px;
    font-size: .67rem;
    font-weight: 850;
    letter-spacing: .06em;
    line-height: 1;
    padding: .3rem .48rem;
    text-transform: uppercase;
}

.related-project-link__title {
    display: block;
    color: var(--ink);
    font-size: .93rem;
    font-weight: 800;
    line-height: 1.28;
}

.related-project-link__icon {
    flex: 0 0 auto;
    color: var(--brand-dark);
    font-size: 1.2rem;
}

.btn-outline-kiu {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .35rem;
    color: var(--brand-dark);
    border: 1px solid color-mix(in srgb, var(--brand) 42%, var(--line));
    border-radius: var(--radius);
    background: var(--paper);
    font-weight: 800;
    padding: .78rem 1.15rem;
    text-decoration: none;
}

.btn-outline-kiu:hover {
    color: var(--paper);
    background: var(--brand-dark);
    border-color: var(--brand-dark);
}

@media (max-width: 991.98px) {
    .article-detail-layout {
        grid-template-columns: 1fr;
    }

    .project-sidebar-stack {
        position: static;
    }
}


.cluster-poster {
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.cluster-poster:hover,
.cluster-poster:focus-within {
    border-color: color-mix(in srgb, var(--cluster-color, var(--brand-dark)) 72%, var(--line));
    box-shadow: 0 18px 42px rgba(15, 47, 34, .11);
    transform: translateY(-2px);
}

.cluster-poster__link {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    align-self: flex-start;
    color: var(--cluster-color, var(--brand-dark));
    font-weight: 850;
    text-decoration: none;
    margin-top: .85rem;
}

.cluster-poster__link:hover,
.cluster-poster__link:focus {
    color: var(--brand-dark);
}

.cluster-detail-layout {
    background: var(--soft);
}

.cluster-detail-main {
    border-top: 5px solid var(--cluster-color, var(--brand));
}

.cluster-detail-main h2,
.cluster-focus-panel h2 {
    color: var(--ink);
    font-weight: 850;
    line-height: 1.14;
    letter-spacing: 0;
}

.cluster-detail-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    color: var(--cluster-color, var(--brand-dark));
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
    margin-bottom: 1rem;
}

.cluster-detail-number {
    width: 40px;
    height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--paper);
    background: var(--cluster-color, var(--brand-dark));
    border-radius: 50%;
    font-size: 1.35rem;
    line-height: 1;
}

.cluster-detail-lead {
    color: var(--ink);
    font-size: 1.16rem;
    font-weight: 650;
    line-height: 1.65;
    margin: .9rem 0 1.25rem;
}

.cluster-detail-copy {
    color: var(--muted);
    line-height: 1.75;
}

.cluster-detail-copy p:last-child {
    margin-bottom: 0;
}

.cluster-focus-panel {
    overflow: hidden;
}

.cluster-focus-item {
    display: flex;
    gap: .85rem;
    height: 100%;
    padding: 1rem;
    background: color-mix(in srgb, var(--brand) 6%, var(--paper));
    border: 1px solid color-mix(in srgb, var(--brand) 20%, var(--line));
    border-radius: var(--radius);
}

.cluster-focus-item i {
    width: 42px;
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    color: var(--brand-dark);
    background: var(--paper);
    border-radius: 50%;
    box-shadow: 0 8px 20px rgba(15, 47, 34, .08);
}

.cluster-focus-item h3 {
    color: var(--ink);
    font-size: 1rem;
    font-weight: 850;
    margin-bottom: .3rem;
}

.cluster-focus-item p {
    color: var(--muted);
    margin-bottom: 0;
}

.cluster-focus-copy > :last-child {
    margin-bottom: 0;
}

.cluster-focus-copy ul,
.cluster-focus-copy ol {
    color: var(--muted);
    margin: 0;
    padding-left: 1.1rem;
}

.cluster-sidebar-stack {
    display: grid;
    gap: 1rem;
    position: sticky;
    top: 110px;
}

.cluster-side-card {
    overflow: hidden;
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: 0 10px 28px rgba(15, 47, 34, .06);
}

.cluster-side-card__title {
    display: flex;
    align-items: center;
    gap: .55rem;
    color: var(--paper);
    background: linear-gradient(135deg, var(--brand-dark), var(--brand));
    padding: .85rem 1rem;
    font-size: 1.05rem;
    font-weight: 850;
    line-height: 1.25;
}

.cluster-side-card > .sdg-grid,
.cluster-side-card > .cluster-action-list {
    padding: 1rem;
}

.cluster-detail-sdgs {
    grid-template-columns: 1fr;
}

.cluster-action-list {
    display: grid;
    gap: .75rem;
    margin: 0;
    padding-left: 0;
    color: var(--muted);
    font-size: 1rem;
    line-height: 1.5;
    list-style: none;
}

.cluster-action-list li {
    display: grid;
    grid-template-columns: .58rem 1fr;
    gap: .7rem;
    align-items: start;
}

.cluster-action-list li::before {
    content: '';
    width: .48rem;
    height: .48rem;
    margin-top: .5rem;
    border-radius: 50%;
    background: var(--brand);
}

.cluster-side-card--actions {
    display: grid;
    gap: .75rem;
    padding: 1rem;
}

@media (max-width: 991.98px) {
    .cluster-sidebar-stack {
        position: static;
    }
}

.publication-archive .section-header {
    max-width: 850px;
}

.publication-filter-panel {
    padding: 1.1rem;
    margin-bottom: 1rem;
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--radius-lg);
    box-shadow: 0 12px 30px rgba(15, 47, 34, .06);
}

.publication-filter-panel__grid {
    display: grid;
    grid-template-columns: minmax(220px, 1.35fr) minmax(190px, 1fr) minmax(150px, .6fr) auto;
    gap: .9rem;
    align-items: end;
}

.publication-filter-panel label {
    display: grid;
    gap: .35rem;
    color: var(--ink);
    font-weight: 750;
}

.publication-filter-panel label span {
    font-size: .92rem;
}

.publication-filter-panel__actions {
    display: flex;
    gap: .65rem;
    align-items: center;
    white-space: nowrap;
}

.publication-count-card {
    display: flex;
    flex-wrap: wrap;
    gap: .45rem .85rem;
    align-items: baseline;
    padding: 1rem 1.1rem;
    margin-bottom: 1rem;
    color: var(--muted);
    background: color-mix(in srgb, var(--brand) 4%, var(--paper));
    border: 1px solid var(--line);
    border-radius: var(--radius-lg);
}

.publication-count-card strong {
    color: var(--ink);
    font-size: 1.05rem;
}

.publication-list {
    display: grid;
    gap: .9rem;
}

.publication-item {
    position: relative;
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: start;
    padding: 1.15rem;
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--radius-lg);
    box-shadow: 0 14px 34px rgba(15, 47, 34, .055);
}


.publication-item--clickable:hover,
.publication-item--clickable:focus-within {
    transform: translateY(-2px);
    border-color: color-mix(in srgb, var(--brand) 34%, var(--line));
    box-shadow: 0 18px 42px rgba(15, 47, 34, .09);
}

.publication-item__overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    border-radius: var(--radius-lg);
}
.publication-item__body {
    min-width: 0;
}

.publication-item__meta {
    display: flex;
    flex-wrap: wrap;
    gap: .45rem;
    margin-bottom: .55rem;
}

.publication-item__meta span {
    display: inline-flex;
    align-items: center;
    min-height: 1.65rem;
    padding: .2rem .6rem;
    color: var(--brand-dark);
    background: color-mix(in srgb, var(--brand) 9%, var(--paper));
    border-radius: 999px;
    font-size: .78rem;
    font-weight: 850;
    line-height: 1.2;
}

.publication-item h3 {
    max-width: 100%;
    margin: 0 0 .45rem;
    color: var(--ink);
    font-size: clamp(1.08rem, 1.2vw, 1.32rem);
    font-weight: 850;
    line-height: 1.28;
    overflow-wrap: anywhere;
    word-break: normal;
}

.publication-item p {
    max-width: 100%;
    overflow-wrap: anywhere;
}

.publication-item__authors,
.publication-item__source,
.publication-item__abstract {
    margin-bottom: .35rem;
    color: var(--muted);
}

.publication-item__authors {
    color: var(--ink-soft);
    font-weight: 700;
}

.publication-item__source {
    font-size: .95rem;
}

.publication-item__abstract {
    margin-bottom: 0;
    line-height: 1.65;
}

.publication-item__actions {
    position: relative;
    z-index: 2;
    display: flex;
    flex-wrap: wrap;
    gap: .55rem;
    justify-content: flex-end;
}

.publication-empty {
    display: grid;
    justify-items: center;
    gap: .45rem;
    padding: 2.5rem 1rem;
    color: var(--muted);
    background: var(--paper);
    border: 1px dashed var(--line);
    border-radius: var(--radius-lg);
    text-align: center;
}

.publication-empty i {
    color: var(--brand);
    font-size: 2rem;
}

.publication-empty strong {
    color: var(--ink);
}

.publication-pagination,
.news-pagination,
.resources-pagination,
.opportunities-pagination {
    margin-top: 1.5rem;
}

.news-pagination,
.resources-pagination,
.opportunities-pagination {
    padding-bottom: 5rem;
}

.publication-pagination .pagination,
.news-pagination .pagination,
.resources-pagination .pagination,
.opportunities-pagination .pagination {
    flex-wrap: wrap;
    gap: .35rem;
    justify-content: center;
}

.publication-pagination .page-link,
.news-pagination .page-link,
.resources-pagination .page-link,
.opportunities-pagination .page-link {
    color: var(--brand-dark);
    border-color: var(--line);
    border-radius: .7rem;
}

.publication-pagination .active .page-link,
.news-pagination .active .page-link,
.resources-pagination .active .page-link,
.opportunities-pagination .active .page-link {
    color: var(--paper);
    background: var(--brand);
    border-color: var(--brand);
}

@media (max-width: 991.98px) {
    .publication-filter-panel__grid,
    .publication-item {
        grid-template-columns: 1fr;
    }

    .publication-filter-panel__actions,
    .publication-item__actions {
        justify-content: flex-start;
    }
}

@media (max-width: 575.98px) {
    .publication-filter-panel__actions {
        display: grid;
        grid-template-columns: 1fr;
    }
}


.publication-detail-main h2 {
    margin-bottom: .75rem;
    color: var(--ink);
    font-size: clamp(1.65rem, 3vw, 2.55rem);
    font-weight: 900;
    line-height: 1.15;
    overflow-wrap: anywhere;
}

.publication-detail-meta {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin-bottom: 1rem;
}

.publication-detail-meta span {
    display: inline-flex;
    align-items: center;
    min-height: 1.8rem;
    padding: .25rem .7rem;
    color: var(--brand-dark);
    background: color-mix(in srgb, var(--brand) 9%, var(--paper));
    border-radius: 999px;
    font-size: .82rem;
    font-weight: 850;
}

.publication-detail-authors {
    color: var(--ink-soft);
    font-weight: 800;
}

.publication-detail-abstract {
    margin-top: 1.35rem;
    padding-top: 1.35rem;
    border-top: 1px solid var(--line);
}

.publication-detail-abstract p {
    margin-bottom: 0;
    color: var(--muted);
    font-size: 1.03rem;
    line-height: 1.8;
    overflow-wrap: anywhere;
}

.publication-detail-sidebar dd {
    overflow-wrap: anywhere;
}
