:root {
    /*
     * Eye-catching palette: deep navy base + gold + electric blue + hot pink.
     * (Deliberately not logo-derived.)
     */
    --logo-red: #f59e0b;
    --logo-red-deep: #f97316;
    --logo-blue: #0b1a3a;
    --logo-blue-deep: #08122a;
    --logo-charcoal: #0b1220;
    --logo-charcoal-muted: #526075;

    --bg: #f7f7ff;
    --surface: #ffffff;
    --surface-alt: #eef2ff;
    --surface-dark: #08122a;
    --surface-deep: #020617;
    --text: var(--logo-charcoal);
    --muted: var(--logo-charcoal-muted);
    /* Red theme used for headings/CTAs/background accents */
    --accent: #ff2d55;
    --accent-dark: #b8002b;
    --accent-soft: #ffe5ea;
    --brand-blue: var(--logo-blue);
    --brand-blue-dark: var(--logo-blue-deep);

    --logo-blue-ice: #93c5fd;
    --logo-blue-mist: #bfdbfe;
    --logo-blue-on-dark: #fbbf24;
    --logo-navy-tint: color-mix(in srgb, var(--logo-blue-deep) 92%, transparent);
    --logo-blue-glow: color-mix(in srgb, var(--logo-blue-deep) 42%, transparent);
    --logo-red-glow: color-mix(in srgb, var(--logo-red) 35%, transparent);
    --theme-orb-primary: color-mix(in srgb, var(--logo-blue-deep) 18%, transparent);
    --theme-orb-accent: color-mix(in srgb, var(--accent) 10%, transparent);
    --theme-header-bg: var(--surface-dark);
    --theme-header-bg-deep: var(--surface-deep);
    --theme-hero-base: var(--logo-blue);
    --theme-hero-soft: #eefbff;
    --theme-heading-color: var(--surface-deep);
    --theme-button-bg: var(--accent);
    --theme-button-hover: var(--accent-dark);
    --theme-button-shadow: 0 16px 36px color-mix(in srgb, var(--theme-button-bg) 26%, transparent);

    --border: #dbeafe;
    --shadow: 0 24px 60px color-mix(in srgb, var(--surface-deep) 10%, transparent);

    /* Urdu / Arabic script (stories & updates from CMS) */
    --font-urdu: "Noto Nastaliq Urdu", "Noto Sans Arabic", system-ui, sans-serif;
    --nav-dropdown-shadow: 0 24px 48px color-mix(in srgb, var(--surface-deep) 14%, transparent), 0 0 0 1px color-mix(in srgb, var(--logo-blue-deep) 12%, transparent);
    --nav-ease: cubic-bezier(0.22, 1, 0.36, 1);
}

* {
    box-sizing: border-box;
}

body {
    margin: 0;
    font-family: "Public Sans", sans-serif;
    color: var(--text);
    background:
        radial-gradient(circle at 0% 0%, var(--theme-orb-primary), transparent 34%),
        radial-gradient(circle at 100% 6%, var(--theme-orb-accent), transparent 32%),
        linear-gradient(180deg, color-mix(in srgb, var(--bg) 88%, #ffffff) 0%, var(--bg) 100%);
    line-height: 1.6;
    padding-top: 0;
}

/* CMS stories/updates: Urdu (Nastaliq) + RTL via dir="auto" on wrappers */
.cms-urdu-support {
    font-family: var(--font-urdu);
    font-feature-settings: "kern" 1, "liga" 1, "calt" 1;
    text-align: start;
    line-height: 1.62;
    font-size: 0.9rem;
    word-spacing: normal;
    letter-spacing: normal;
}

.cms-urdu-support h1,
.cms-urdu-support h2,
.cms-urdu-support h3 {
    font-family: var(--font-urdu);
    font-weight: 700;
    line-height: 1.32;
}

/* --- CMS article / story (full page) — compact editorial layout --- */
.page-hero--article {
    /* padding set below after .page-hero so it wins the cascade */
    background:
        radial-gradient(ellipse 90% 70% at 50% -30%, color-mix(in srgb, var(--accent) 14%, transparent) 0%, transparent 58%),
        radial-gradient(ellipse 55% 45% at 100% 20%, color-mix(in srgb, var(--brand-blue-dark) 10%, transparent) 0%, transparent 52%),
        linear-gradient(180deg, color-mix(in srgb, var(--surface-alt) 100%, transparent) 0%, var(--bg) 100%);
    border-bottom: 1px solid color-mix(in srgb, var(--border) 65%, transparent);
}

.article-post__hero-inner {
    max-width: none;
    width: 100%;
    margin: 0;
}

.article-post__breadcrumb {
    margin: 0 0 0.65rem;
}

.article-post__breadcrumb a {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--brand-blue-dark);
    text-decoration: none;
    transition: color 0.15s ease;
}

.article-post__breadcrumb a:hover {
    color: var(--accent-dark);
    text-decoration: underline;
}

.article-post__breadcrumb-icon {
    font-size: 0.9rem;
    line-height: 1;
    opacity: 0.85;
}

.article-post__masthead {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.article-post__labels {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.35rem 0.75rem;
}

.article-post__labels .eyebrow {
    margin: 0;
    letter-spacing: 0.12em;
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--brand-blue-dark) 82%, var(--muted));
}

.article-post__labels .article-post__date {
    position: relative;
    padding-inline-start: 0.85rem;
}

.article-post__labels .article-post__date::before {
    content: "";
    position: absolute;
    inset-inline-start: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: color-mix(in srgb, var(--muted) 70%, transparent);
}

.article-post--story .page-hero--article .article-post__title,
.article-post--story .page-hero--article h1.article-post__title {
    font-family: "Libre Baskerville", serif;
    font-size: clamp(1.2rem, 2.35vw, 1.5rem);
    line-height: 1.28;
    margin: 0;
    color: var(--surface-deep);
    letter-spacing: -0.02em;
    font-weight: 700;
}

.article-post__deck {
    margin: 0.15rem 0 0;
    max-width: none;
    font-size: clamp(0.94rem, 1.35vw, 1.02rem);
    line-height: 1.55;
    font-weight: 500;
    color: color-mix(in srgb, var(--text) 76%, transparent);
}

.article-post__date {
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--brand-blue-dark) 72%, var(--muted));
}

.article-post__main {
    padding-top: clamp(1rem, 2.5vw, 1.5rem);
    padding-bottom: clamp(2rem, 4vw, 3rem);
}

.article-post__container {
    max-width: none;
    width: 100%;
    margin: 0;
    padding-inline: 0;
}

.article-post__sheet {
    background: var(--surface);
    border-radius: clamp(14px, 2vw, 18px);
    border: 1px solid color-mix(in srgb, var(--border) 55%, transparent);
    box-shadow:
        0 2px 0 color-mix(in srgb, var(--surface-deep) 4%, transparent),
        0 18px 48px color-mix(in srgb, var(--surface-deep) 7%, transparent);
    padding: clamp(0.85rem, 2vw, 1.15rem) clamp(0.75rem, 2vw, 1.05rem);
}

.article-post__layout {
    max-width: none;
    width: 100%;
    margin: 0;
}

/* clear floated featured image so footer of card lays out correctly */
.article-post__layout::after {
    content: "";
    display: table;
    clear: both;
}

.article-post__figure {
    margin: 0 0 1rem;
    border-radius: 12px;
    overflow: hidden;
    background: color-mix(in srgb, var(--surface-alt) 92%, white);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--border) 45%, transparent);
}

.article-post__figure img {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    border-radius: 0;
    box-shadow: none;
}

/* Featured image: modest size; text wraps beside (inline-start), then runs full width below */
@media (min-width: 640px) {
    .article-post--story .article-post__layout > .article-post__figure {
        float: inline-start;
        width: min(34%, 240px);
        margin: 0.15rem;
        margin-inline-end: clamp(0.85rem, 2.5vw, 1.1rem);
        margin-block-end: clamp(0.5rem, 1.5vw, 0.75rem);
        shape-outside: margin-box;
        border-radius: 10px;
    }

    .article-post--story .article-post__layout > .article-post__figure img {
        aspect-ratio: 4 / 3;
    }
}

.article-post--story .article-post__body.rich-text.article-body {
    font-family: "Public Sans", system-ui, sans-serif;
    font-size: 1rem;
}

.article-post--story .article-post__body.rich-text.article-body p {
    font-size: 1rem;
    line-height: 1.72;
    margin: 0 0 1rem;
    color: color-mix(in srgb, var(--text) 96%, transparent);
}

.article-post--story .article-post__body.rich-text.article-body > p:first-of-type {
    font-size: 1.03rem;
    line-height: 1.72;
}

.article-post--story .article-post__body.rich-text.article-body h2 {
    font-family: "Libre Baskerville", serif;
    font-size: clamp(1.12rem, 1.9vw, 1.28rem);
    font-weight: 700;
    margin: 1.5rem 0 0.55rem;
    line-height: 1.3;
    color: var(--surface-deep);
    clear: inline-start;
}

.article-post--story .article-post__body.rich-text.article-body h3 {
    font-size: 1.02rem;
    font-weight: 800;
    margin: 1.25rem 0 0.45rem;
    line-height: 1.35;
    color: var(--surface-deep);
    clear: inline-start;
}

.article-post--story .article-post__body.rich-text.article-body ul,
.article-post--story .article-post__body.rich-text.article-body ol {
    margin: 0.65rem 0 1rem;
    padding-left: 1.2rem;
}

.article-post--story .article-post__body.rich-text.article-body li {
    margin-bottom: 0.35rem;
    font-size: 0.98rem;
    line-height: 1.65;
}

.article-post--story .article-post__body.rich-text.article-body blockquote {
    margin: 1.25rem 0;
    padding: 0.85rem 1rem 0.85rem 0.95rem;
    border-left: 3px solid var(--accent);
    background: linear-gradient(
        90deg,
        color-mix(in srgb, var(--accent-soft) 55%, var(--surface)) 0%,
        color-mix(in srgb, var(--surface-alt) 90%, white) 100%
    );
    border-radius: 0 10px 10px 0;
    font-size: 0.98rem;
    line-height: 1.62;
    font-style: italic;
    color: color-mix(in srgb, var(--surface-deep) 90%, transparent);
}

.article-post--story .article-post__body.rich-text.article-body img {
    border-radius: 10px;
    margin: 1rem 0;
    box-shadow: 0 8px 24px color-mix(in srgb, var(--surface-deep) 8%, transparent);
}

.article-post--story .article-post__body.rich-text.article-body table {
    font-size: 0.98rem;
    margin: 1.35rem 0;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 20px color-mix(in srgb, var(--surface-deep) 6%, transparent);
}

.article-post--story .article-post__body.rich-text.article-body th {
    background: color-mix(in srgb, var(--surface-alt) 88%, var(--brand-blue-dark));
    font-weight: 700;
}

/* Urdu full article: add cms-urdu-support next to article-post__body on the same element */
.article-post--story .article-post__body.rich-text.article-body.cms-urdu-support {
    font-family: var(--font-urdu);
}

.article-post--story .article-post__body.rich-text.article-body.cms-urdu-support p {
    font-size: 0.95rem;
    line-height: 1.72;
}

.article-post--story .article-post__body.rich-text.article-body.cms-urdu-support > p:first-of-type {
    font-size: 0.98rem;
}

.news-grid--cms-urdu .news-card__body.cms-urdu-support {
    font-size: 0.86rem;
}

.news-grid--cms-urdu .news-card__body.cms-urdu-support h3 {
    font-size: 0.95rem;
    line-height: 1.28;
}

.news-grid--cms-urdu .news-card__body.cms-urdu-support p {
    line-height: 1.55;
}

.home-updates-mini.cms-urdu-support .home-updates-mini__feature-title,
.home-updates-mini.cms-urdu-support .home-updates-mini__feature-excerpt {
    font-family: var(--font-urdu);
    line-height: 1.42;
}

.home-updates-mini.cms-urdu-support .home-updates-mini__feature-title {
    font-size: 0.92rem;
}

.home-updates-mini.cms-urdu-support .home-updates-mini__feature-excerpt {
    font-size: 0.84rem;
}

.home-updates-mini.cms-urdu-support .home-updates__trigger-text {
    font-family: var(--font-urdu);
    line-height: 1.38;
    font-size: 0.86rem;
}

.home-update-modal__panel.cms-urdu-support .home-update-modal__title,
.home-update-modal__panel.cms-urdu-support .home-update-modal__excerpt {
    font-family: var(--font-urdu);
    line-height: 1.42;
}

.home-update-modal__panel.cms-urdu-support .home-update-modal__title {
    font-size: 0.98rem;
}

.home-update-modal__panel.cms-urdu-support .home-update-modal__excerpt {
    font-size: 0.88rem;
}

.result-card.cms-urdu-support {
    font-size: 0.88rem;
}

.result-card.cms-urdu-support strong {
    font-size: 0.95rem;
    line-height: 1.3;
}

a {
    color: inherit;
    text-decoration: none;
}

img {
    display: block;
    max-width: 100%;
}

main {
    min-height: 60vh;
    padding-top: var(--header-offset, 0px);
}

.container {
    width: min(1180px, calc(100% - 24px));
    margin: 0 auto;
}

.narrow {
    width: min(760px, 100%);
}

/* CMS pages (e.g. About Us): wider than .narrow, still bounded for readability */
.container.container--prose-wide {
    width: min(1100px, calc(100% - 24px));
}

.section--stats-tight .section-heading {
    margin-bottom: 1rem;
}

.eyebrow {
    font-size: 0.82rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--accent);
    margin-bottom: 0.75rem;
    font-weight: 700;
}

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    border-radius: 999px;
    padding: 0.85rem 1.35rem;
    font-weight: 700;
    border: 1px solid transparent;
    transition: 0.2s ease;
}

.btn:hover {
    transform: translateY(-1px);
}

.btn--dark {
    background: var(--surface-dark);
    color: #fff;
}

.btn--primary {
    background: linear-gradient(
        135deg,
        var(--theme-button-hover) 0%,
        var(--theme-button-bg) 100%
    );
    color: #fff;
    box-shadow: var(--theme-button-shadow);
}

.btn--light {
    background: var(--surface);
    color: var(--text);
}

.btn--footer {
    background: transparent;
    border-color: rgba(255, 255, 255, 0.34);
    color: #fff;
}

.btn--ghost {
    border-color: var(--brand-blue);
    color: var(--brand-blue);
}

.btn--sm {
    padding: 0.36rem 0.62rem;
    font-size: 0.76rem;
}

.btn--full {
    width: 100%;
}

.alert-banner {
    background: linear-gradient(90deg, var(--surface-dark), var(--logo-red-deep), var(--accent-dark));
    color: #fff;
    padding: 0.85rem 0;
}

.alert-banner__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.alert-banner__copy {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    align-items: center;
}

.header-shell {
    background: rgba(255, 255, 255, 0.985);
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    z-index: 1100;
    padding-top: env(safe-area-inset-top, 0px);
    padding-left: env(safe-area-inset-left, 0px);
    padding-right: env(safe-area-inset-right, 0px);
}

.header-shell .container {
    width: 100%;
    max-width: 100%;
    padding-left: 0;
    padding-right: 0;
}

.utility-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 34px;
    padding: 0.7rem 0 0.65rem;
    background: linear-gradient(
        102deg,
        var(--theme-header-bg-deep) 0%,
        var(--theme-header-bg) 58%,
        var(--theme-button-hover) 96%
    );
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
    margin-inline: calc(50% - 50vw);
    width: 100vw;
    max-width: 100vw;
    box-sizing: border-box;
    padding-inline: calc((100vw - min(1180px, 100vw - 24px)) / 2);
    transition:
        max-height 0.28s var(--nav-ease),
        opacity 0.22s ease,
        padding 0.24s var(--nav-ease),
        border 0.2s ease;
    max-height: 90px;
    opacity: 1;
    overflow: hidden;
}

.utility-bar__label {
    font-size: 0.8rem;
    letter-spacing: 0.02em;
    text-transform: none;
    color: rgba(255, 255, 255, 0.94);
    font-weight: 600;
    line-height: 1.4;
    max-width: min(100%, 38rem);
    margin: 0;
    flex: 1;
    min-width: 0;
}

.utility-bar__label--rotating {
    position: relative;
    min-height: 1.4em;
}

.utility-bar__tagline-line {
    display: none;
}

.utility-bar__tagline-line.is-active {
    display: inline;
    animation: utilityTaglineFade 0.45s ease;
}

@keyframes utilityTaglineFade {
    from {
        opacity: 0;
        transform: translateY(4px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.utility-bar__end {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 1rem;
    flex-wrap: wrap;
    flex-shrink: 0;
}

.social-links--header {
    gap: 0.45rem;
}

.social-links--header .social-link {
    position: relative;
    display: inline-grid;
    place-items: center;
    width: 2.35rem;
    height: 2.35rem;
    min-width: 2.35rem;
    min-height: 2.35rem;
    padding: 0;
    line-height: 1;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.1);
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.22);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.social-links--header .social-link:hover {
    background: rgba(255, 255, 255, 0.18);
    color: #fff;
    border-color: rgba(255, 255, 255, 0.34);
    transform: translateY(-1px);
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.18);
    border-radius: 999px;
}

.social-links--header .social-link__icon {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    line-height: 0;
    width: 100%;
    height: 100%;
}

.social-links--header .social-link svg {
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    width: 1.15rem;
    height: 1.15rem;
    max-width: 100%;
    max-height: 100%;
    flex-shrink: 0;
    fill: currentColor;
    transform: translate(-50%, -50%);
}

.site-brand {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    width: min(360px, 100%);
    min-height: 84px;
    padding: 0 1.8rem 0 0.8rem;
    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;
}

.site-brand__logo {
    width: auto;
    max-width: 100%;
    height: auto;
    max-height: 40px !important;
    object-fit: contain;
    filter: drop-shadow(0 4px 12px color-mix(in srgb, var(--surface-deep) 8%, transparent));
}

.site-brand__mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 58px;
    height: 58px;
    border-radius: 18px;
    background: linear-gradient(145deg, var(--brand-blue), var(--surface-dark));
    color: #fff;
    font-weight: 800;
    letter-spacing: 0.08em;
}

.footer-brand .site-brand {
    width: auto;
    min-height: 0;
}

.footer-brand .site-brand__logo:not(.site-brand__logo--footer) {
    max-height: 48px;
}

.site-footer .btn {
    padding: 0.5rem 1rem;
    font-size: 0.8rem;
}

.utility-nav,
.main-nav {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.utility-nav {
    gap: 1.15rem;
    padding: 0.1rem 0;
}

.utility-nav__link {
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--muted);
    padding: 0.35rem 0.65rem;
    margin: -0.35rem -0.45rem;
    border-radius: 999px;
    transition: color 0.2s ease, background 0.2s ease;
}

.utility-nav__link:hover {
    color: var(--brand-blue-dark);
    background: color-mix(in srgb, var(--logo-blue-deep) 7%, transparent);
}

.utility-bar .utility-nav__link {
    color: rgba(255, 255, 255, 0.82);
}

.utility-bar .utility-nav__link:hover {
    color: #fff;
    background: color-mix(in srgb, var(--accent) 22%, transparent);
}

.main-nav-wrap {
    min-width: 0;
    background: transparent;
}

.main-nav-wrap.main-nav-wrap--scrolled {
    box-shadow: none;
}

.main-nav {
    justify-content: center;
    padding: 0;
    gap: 1.8rem;
    background: transparent;
    border: 0;
    border-top: 0;
    border-radius: 0;
    box-shadow: none;
    margin-top: 0;
}

.main-nav__links,
.main-nav__actions {
    display: flex;
    align-items: center;
    gap: 1.1rem;
}

.main-nav__links {
    flex-wrap: wrap;
    min-width: 0;
}

.main-nav__actions {
    flex-shrink: 0;
}

.site-header,
.header-shell,
.header-shell .container,
.main-nav-wrap {
    overflow: visible;
}

.nav-item {
    position: relative;
}

.nav-item__top {
    display: flex;
    align-items: center;
    gap: 0.2rem;
    width: 100%;
    min-width: 0;
}

@media (min-width: 961px) {
    .nav-item.has-children .nav-item__top {
        display: contents;
    }
}

.nav-item__link {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-weight: 700;
    color: var(--surface-dark);
    font-size: 0.94rem;
    letter-spacing: 0.01em;
    padding: 0.75rem 0;
    white-space: nowrap;
    position: relative;
    transition: color 0.2s ease;
}

.nav-item.has-children .nav-item__link {
    padding-right: 0;
}

.nav-item__text {
    position: relative;
    display: inline-block;
    max-width: 14rem;
    overflow: hidden;
    text-overflow: ellipsis;
}

.nav-item__text::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -0.2rem;
    width: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--brand-blue), var(--accent));
    transition: width 0.22s var(--nav-ease);
}

.nav-item__link:hover .nav-item__text::after,
.nav-item__link.is-highlight .nav-item__text::after,
.nav-item__link:focus-visible .nav-item__text::after {
    width: 100%;
}

.nav-item__link.is-highlight {
    color: var(--accent);
}

.nav-item__link:hover {
    color: var(--brand-blue);
}

.nav-item__link.is-highlight:hover {
    color: var(--accent-dark);
}

.nav-item__caret {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--brand-blue);
    opacity: 0.72;
    transition:
        color 0.2s ease,
        opacity 0.2s ease,
        transform 0.25s var(--nav-ease);
}

.nav-item__link:hover .nav-item__caret,
.nav-item.has-children:focus-within .nav-item__caret {
    opacity: 1;
    color: var(--brand-blue-dark);
}

.nav-item.has-children:hover .nav-item__caret,
.nav-item.has-children:focus-within .nav-item__caret {
    transform: rotate(-180deg);
}

.nav-item__submenu-btn {
    display: none;
    flex-shrink: 0;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    margin: 0;
    padding: 0;
    border: 1px solid color-mix(in srgb, var(--logo-blue-deep) 18%, transparent);
    border-radius: 12px;
    background: #fff;
    color: var(--brand-blue-dark);
    cursor: pointer;
    transition:
        background 0.2s ease,
        border-color 0.2s ease,
        transform 0.25s var(--nav-ease);
}

.nav-item__submenu-btn:hover {
    background: color-mix(in srgb, var(--logo-blue-deep) 6%, transparent);
    border-color: color-mix(in srgb, var(--logo-blue-deep) 28%, transparent);
}

.nav-item__submenu-btn[aria-expanded="true"] {
    background: color-mix(in srgb, var(--logo-blue-deep) 10%, transparent);
    border-color: color-mix(in srgb, var(--logo-blue-deep) 35%, transparent);
}

.nav-item__submenu-btn[aria-expanded="true"] svg {
    transform: rotate(180deg);
}

.nav-item__submenu-btn svg {
    display: block;
    transition: transform 0.25s var(--nav-ease);
}

@media (min-width: 961px) {
    .main-header > .site-brand {
        flex-shrink: 0;
        min-width: 0;
        width: auto;
        max-width: min(300px, 40vw);
        min-height: 0;
        justify-self: start;
    }

    .main-nav-wrap {
        justify-self: start;
        min-width: 0;
        max-width: 100%;
    }

    .main-nav {
        justify-content: flex-start;
        gap: 0;
        width: 100%;
    }

    .main-nav__links {
        flex-wrap: nowrap;
        justify-content: flex-start;
        gap: clamp(1.1rem, 2vw, 2rem);
    }

    .main-nav .nav-item {
        flex-shrink: 0;
    }

    .main-nav .nav-item__link {
        font-size: clamp(1.02rem, 0.94rem + 0.45vw, 1.14rem);
        padding-top: 0.85rem;
        padding-bottom: 0.85rem;
        letter-spacing: 0.02em;
    }

    .main-nav .nav-item__text {
        max-width: 13rem;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .main-nav .nav-item__caret svg {
        width: 12px;
        height: 12px;
    }

    .main-header .header-actions {
        flex-shrink: 0;
        justify-self: end;
        gap: 0.65rem;
    }

    .main-header .header-actions .btn {
        min-width: 0;
        padding: 0.8rem 1.2rem;
        font-size: 0.9rem;
    }

    .site-header .dropdown__link {
        font-size: 0.98rem;
        padding: 0.82rem 1.05rem;
    }
}

.dropdown {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    transform: translateY(6px) scale(0.98);
    transform-origin: top left;
    min-width: min(288px, calc(100vw - 40px));
    max-width: 360px;
    padding: 0.7rem;
    background: linear-gradient(155deg, #ffffff 0%, #f5f9ff 55%, #eef5ff 100%);
    border: 1px solid color-mix(in srgb, var(--logo-blue-deep) 14%, transparent);
    box-shadow:
        0 8px 16px rgba(44, 58, 71, 0.06),
        0 26px 55px rgba(37, 43, 50, 0.2);
    border-radius: 16px;
    z-index: 200;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition:
        opacity 0.22s var(--nav-ease),
        transform 0.26s var(--nav-ease),
        visibility 0.26s;
}

.dropdown::before {
    content: "";
    position: absolute;
    top: -12px;
    left: 0;
    right: 0;
    height: 12px;
}

.dropdown__inner {
    position: relative;
    z-index: 1;
    padding: 0.35rem;
    display: flex;
    flex-direction: column;
    gap: 0.28rem;
}

.dropdown__inner::before {
    content: "";
    position: absolute;
    left: 0.4rem;
    right: 0.4rem;
    top: 0.15rem;
    height: 2px;
    border-radius: 999px;
    background: linear-gradient(90deg, color-mix(in srgb, var(--logo-blue-deep) 95%, transparent), color-mix(in srgb, var(--accent-dark) 90%, transparent));
    opacity: 0.9;
}

.dropdown__link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.86rem 1rem;
    border-radius: 12px;
    font-weight: 600;
    font-size: 0.92rem;
    line-height: 1.35;
    color: var(--surface-dark);
    letter-spacing: 0.015em;
    transition:
        background 0.18s ease,
        color 0.18s ease,
        box-shadow 0.18s ease,
        transform 0.2s ease,
        border-color 0.18s ease;
    border: 1px solid color-mix(in srgb, var(--logo-blue-deep) 4%, transparent);
}

.dropdown__link-text {
    flex: 1;
    min-width: 0;
}

.dropdown__link-arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--muted);
    opacity: 0.45;
    transition:
        opacity 0.2s ease,
        color 0.2s ease,
        transform 0.22s var(--nav-ease);
}

.dropdown__link:hover {
    background: linear-gradient(90deg, color-mix(in srgb, var(--logo-blue-deep) 11%, transparent), color-mix(in srgb, var(--logo-blue-deep) 6%, transparent));
    color: var(--brand-blue-dark);
    border-color: color-mix(in srgb, var(--logo-blue-deep) 16%, transparent);
    box-shadow: 0 10px 18px rgba(0, 62, 115, 0.12);
    transform: translateX(4px);
}

.dropdown__link:hover .dropdown__link-arrow {
    opacity: 1;
    color: var(--brand-blue);
    transform: translateX(4px);
}

.dropdown__link:focus-visible {
    outline: none;
    border-color: color-mix(in srgb, var(--logo-blue-deep) 28%, transparent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--logo-blue-deep) 18%, transparent);
}

.nav-item.has-children:hover .dropdown,
.nav-item.has-children:focus-within .dropdown {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0) scale(1);
}

@media (hover: none) and (min-width: 961px) {
    .nav-item.has-children:hover .dropdown {
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        transform: translateY(6px) scale(0.98);
    }

    .nav-item.has-children.is-touch-open .dropdown {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        transform: translateY(0) scale(1);
    }

    .nav-item__submenu-btn {
        display: inline-flex;
    }

    .nav-item.has-children .nav-item__top {
        display: flex;
        width: auto;
        gap: 0.35rem;
    }

    .nav-item__caret {
        display: none;
    }
}

.search-form input,
input,
textarea,
select {
    width: 100%;
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 0.85rem 1rem;
    font: inherit;
    background: #fff;
}

.mobile-nav-toggle {
    display: none;
    align-items: center;
    gap: 0.55rem;
    border: 1px solid color-mix(in srgb, var(--logo-blue-deep) 20%, transparent);
    background: linear-gradient(180deg, #ffffff, #f2f7fd);
    border-radius: 999px;
    padding: 0.65rem 1rem 0.65rem 0.85rem;
    font-weight: 700;
    font-size: 0.82rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--brand-blue-dark);
    cursor: pointer;
    box-shadow: 0 8px 20px rgba(44, 58, 71, 0.06);
    transition:
        border-color 0.2s ease,
        box-shadow 0.2s ease,
        transform 0.2s ease;
}

.mobile-nav-toggle:hover {
    border-color: color-mix(in srgb, var(--logo-blue-deep) 35%, transparent);
    box-shadow: 0 10px 24px rgba(44, 58, 71, 0.1);
}

.mobile-nav-toggle__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 16px;
    flex-shrink: 0;
    color: var(--brand-blue-dark);
}

.mobile-nav-toggle__line {
    transform-origin: center;
    transition: transform 0.3s var(--nav-ease), opacity 0.2s ease;
}

.mobile-nav-toggle[aria-expanded="true"] .mobile-nav-toggle__line--top {
    transform: translateY(6px) rotate(45deg);
}

.mobile-nav-toggle[aria-expanded="true"] .mobile-nav-toggle__line--mid {
    opacity: 0;
    transform: scaleX(0);
}

.mobile-nav-toggle[aria-expanded="true"] .mobile-nav-toggle__line--bot {
    transform: translateY(-6px) rotate(-45deg);
}

.main-header {
    display: grid;
    grid-template-columns: minmax(220px, 320px) minmax(0, 1fr) auto;
    align-items: center;
    gap: 2.2rem;
    padding: 0.65rem 1.25rem 0.75rem;
    position: relative;
    top: auto;
    z-index: auto;
    background: rgba(255, 255, 255, 0.97);
    border-bottom: 1px solid color-mix(in srgb, var(--logo-blue-deep) 8%, transparent);
    box-shadow: 0 12px 28px rgba(44, 58, 71, 0.05);
    transition:
        padding 0.25s var(--nav-ease),
        box-shadow 0.25s var(--nav-ease),
        background 0.2s ease;
    width: 100%;
}

.main-header.main-header--scrolled {
    padding: 0.38rem 0 0.44rem;
    background: rgba(255, 255, 255, 0.99);
    box-shadow:
        0 10px 36px rgba(44, 58, 71, 0.14),
        0 2px 0 color-mix(in srgb, var(--logo-blue-deep) 6%, transparent);
}

.site-header--scrolled .utility-bar {
    max-height: 0;
    min-height: 0;
    opacity: 0;
    padding-top: 0;
    padding-bottom: 0;
    margin: 0;
    border-bottom: 0;
    overflow: hidden;
}

.site-header--scrolled .site-brand__logo {
    max-height: 32px !important;
}

.site-header--scrolled .header-actions .btn {
    min-width: 136px;
    padding-top: 0.68rem;
    padding-bottom: 0.68rem;
}

.header-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.85rem;
}

.header-actions .btn {
    min-width: 150px;
    padding-left: 1.25rem;
    padding-right: 1.25rem;
}

.hero,
.page-hero {
    padding: 3rem 0;
}

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

.hero__content h1,
.page-hero h1 {
    font-family: "Libre Baskerville", serif;
    font-size: clamp(2.2rem, 5vw, 4.8rem);
    line-height: 1.05;
    margin: 0 0 1rem;
    color: var(--surface-dark);
}

/* CMS story: wins over generic .page-hero padding (same specificity, later in file) */
.page-hero.page-hero--article {
    padding: clamp(1rem, 2.5vw, 1.5rem) 0 clamp(0.75rem, 2vw, 1.1rem);
}

.hero__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-start;
    gap: 0.85rem 1rem;
    margin-top: 1.1rem;
}

.hero__media img,
.article-image,
.feature-card img,
.news-card img,
.country-card img {
    border-radius: 28px;
    box-shadow: var(--shadow);
    width: 100%;
    object-fit: cover;
}

.section {
    padding: clamp(2.25rem, 4vw, 3rem) 0;
}

.section--light {
    background: var(--surface-alt);
}

.section--home-updates {
    background:
        radial-gradient(circle at 10% 0%, color-mix(in srgb, var(--theme-orb-primary) 70%, transparent) 0%, transparent 50%),
        radial-gradient(circle at 95% 10%, color-mix(in srgb, var(--theme-orb-accent) 65%, transparent) 0%, transparent 45%),
        linear-gradient(180deg, var(--surface-alt) 0%, var(--bg) 100%);
    color: var(--text);
}

.section--home-updates .section-heading {
    text-align: center;
    max-width: 62rem;
    margin-left: auto;
    margin-right: auto;
}

.section--home-updates .section-heading h2 {
    color: var(--surface-dark);
}

.section--home-updates .section-heading > p:not(.eyebrow) {
    color: color-mix(in srgb, var(--text) 78%, transparent);
}

.section--home-updates .news-grid--home {
    margin-top: 0.5rem;
}

.section--accent {
    background: linear-gradient(145deg, color-mix(in srgb, var(--surface-alt) 90%, #ffffff 10%) 0%, color-mix(in srgb, var(--surface) 100%, transparent) 45%, color-mix(in srgb, var(--bg) 100%, transparent) 100%);
}

.section--dark {
    background:
        radial-gradient(circle at 0% 0%, color-mix(in srgb, var(--theme-orb-accent) 80%, transparent) 0%, transparent 52%),
        linear-gradient(135deg, var(--surface-dark), var(--accent-dark));
    color: var(--surface);
}

.section-heading {
    margin-bottom: 1.25rem;
}

.section-heading h2 {
    font-family: "Libre Baskerville", serif;
    font-size: clamp(1.8rem, 3vw, 3rem);
    margin: 0.25rem 0;
}

.stats-grid,
.card-grid,
.news-grid,
.country-grid,
.cta-grid,
.admin-card-grid {
    display: grid;
    gap: 1.15rem;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

/* Keep story cards visually consistent */
.news-grid {
    align-items: start;
    grid-auto-rows: 1fr;
}

.news-grid .news-card {
    display: flex;
    flex-direction: column;
    height: 100%;
    min-height: 0;
}

.news-grid .news-card img {
    width: 100%;
    height: 230px;
    object-fit: cover;
    flex-shrink: 0;
}

/* Homepage stories: equal-height cards, tight copy (no extra min-height padding inside) */
.news-grid.news-grid--home {
    align-items: stretch;
    grid-auto-rows: minmax(0, 1fr);
}

.news-grid--home .news-card {
    height: 100%;
    min-height: 0;
    border-radius: 20px;
    background: color-mix(in srgb, var(--surface) 96%, transparent);
    box-shadow:
        0 14px 38px color-mix(in srgb, var(--surface-deep) 12%, transparent),
        0 0 0 1px color-mix(in srgb, var(--border) 90%, transparent);
    overflow: hidden;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.section--dark .news-grid--home .news-card {
    background: color-mix(in srgb, var(--surface) 5%, var(--surface-deep) 95%);
    box-shadow:
        0 16px 42px color-mix(in srgb, var(--surface-deep) 36%, transparent),
        0 0 0 1px color-mix(in srgb, var(--surface) 12%, transparent);
}

.news-grid--home .news-card:hover {
    transform: translateY(-3px);
    box-shadow:
        0 20px 52px color-mix(in srgb, var(--surface-deep) 22%, transparent),
        0 0 0 1px color-mix(in srgb, var(--accent) 32%, transparent);
}

.news-grid--home .news-card__body {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    padding: 0.48rem 0.65rem 0.52rem !important;
    gap: 0.12rem;
}

.news-grid--home .news-card__body p {
    margin: 0;
    line-height: 1.38;
    -webkit-line-clamp: 3;
    min-height: 0;
}

.news-grid--home .news-card__body h3 {
    min-height: 0;
    line-height: 1.22;
    -webkit-line-clamp: 2;
}

.news-grid--home .news-card__body span {
    min-height: 0;
    line-height: 1.15;
    font-size: 0.82rem;
}

.news-home-more {
    margin: 1.1rem 0 0;
    text-align: center;
}

.news-home-more__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    padding: 0.65rem 1.35rem;
    border-radius: 999px;
    font-size: 0.9rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    text-decoration: none;
    color: #fff;
    border: 1px solid color-mix(in srgb, var(--theme-button-hover) 60%, transparent);
    background: linear-gradient(135deg, var(--theme-button-hover) 0%, var(--theme-button-bg) 100%);
    box-shadow: var(--theme-button-shadow);
    transition:
        background 0.2s ease,
        border-color 0.2s ease,
        transform 0.2s ease,
        box-shadow 0.2s ease;
}

.news-home-more__link::after {
    content: "";
    width: 0.32em;
    height: 0.32em;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(-45deg) translateX(-1px);
    opacity: 0.9;
}

.news-home-more__link:hover {
    background: linear-gradient(135deg, var(--theme-button-bg) 0%, var(--theme-button-hover) 100%);
    border-color: color-mix(in srgb, var(--theme-button-bg) 70%, transparent);
    box-shadow: 0 10px 24px color-mix(in srgb, var(--theme-button-bg) 35%, transparent);
    transform: translateY(-1px);
}

.news-home-more__link:focus-visible {
    outline: 2px solid var(--surface);
    outline-offset: 3px;
}

.news-grid .news-card__body {
    gap: 0.35rem;
    overflow: hidden;
}

.news-card__body {
    padding: 0.9rem 1rem !important;
}

.news-card__body > * {
    margin: 0;
}

.news-card__body p {
    line-height: 1.45;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: calc(1.45em * 4);
}

.news-card__body small {
    margin-top: 0.15rem;
}

.news-card__body h3 {
    margin: 0 !important;
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: calc(1.3em * 2);
}

.news-card__body span {
    display: block;
    line-height: 1.2;
    min-height: 1.2em;
}

.section--map {
    background: transparent;
    padding-bottom: clamp(1.5rem, 3vw, 2.25rem);
}

.section-heading--map {
    margin-bottom: 1.6rem;
}

.act-footprint-split {
    display: block;
    align-items: stretch;
    gap: 0;
    width: 100%;
    margin-top: clamp(0.5rem, 2vw, 1rem);
    background: transparent;
    border: none;
}

.act-footprint-split__map {
    width: 100%;
    min-width: 0;
}

.act-footprint-stage {
    position: relative;
    display: flex;
    align-items: stretch;
    gap: 0;
    padding: 0;
    border-top: 1px solid color-mix(in srgb, var(--logo-blue-deep) 14%, transparent);
    border-bottom: 1px solid color-mix(in srgb, var(--logo-blue-deep) 14%, transparent);
    background: color-mix(in srgb, var(--surface) 92%, #ffffff 8%);
}

.act-footprint-province-block + .act-footprint-province-block {
    margin-top: 0;
    padding-top: 0;
    border-top: 0;
}

.act-footprint-province-block__title {
    margin: 0 0 0.38rem;
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--brand-blue-dark);
}

.act-footprint-district-list {
    list-style: none;
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.2rem;
    margin: 0;
    padding: 0;
}

.act-footprint-district-list li {
    margin: 0;
}

.act-footprint-district-btn {
    display: block;
    width: 100%;
    white-space: normal;
    text-align: left;
    padding: 0.12rem 0.2rem;
    border: 0;
    border-radius: 4px;
    background: transparent;
    font: inherit;
    font-size: 0.78rem;
    font-weight: 600;
    line-height: 1.2;
    color: #0b1220;
    cursor: pointer;
}

.act-footprint-district-btn:hover,
.act-footprint-district-btn:focus-visible {
    background: rgba(255, 255, 255, 0.55);
    outline: none;
}

.act-footprint-district-btn.is-active {
    background: rgba(255, 255, 255, 0.78);
    color: #020617;
}

a.act-footprint-district-link {
    text-decoration: none;
    color: inherit;
    box-sizing: border-box;
}

a.act-footprint-district-link:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--accent, #ff2d55) 50%, transparent);
    outline-offset: 2px;
}

.act-footprint-district-label {
    display: block;
    padding: 0.35rem 0;
    font-weight: 600;
    color: var(--muted);
}

.act-footprint-split__empty {
    margin: 0;
    font-size: 0.92rem;
    color: var(--muted);
}

.pakistan-map-stage--split {
    padding: 0;
}

.act-footprint-split .act-google-map.act-google-map--split {
    height: min(80vh, 1020px);
    min-height: 680px;
    max-height: none;
    border-radius: 0;
    border: none;
    box-shadow: none;
}

.act-footprint-split__map {
    flex: 7 1 70%;
    min-width: 0;
}

.act-footprint-split__aside {
    flex: 3 1 30%;
    min-width: 0;
    max-height: min(80vh, 1020px);
    overflow-y: auto;
    padding: 0.8rem 0.85rem;
    border-left: 1px solid color-mix(in srgb, var(--logo-blue-deep) 12%, transparent);
    background: color-mix(in srgb, var(--surface-alt) 55%, var(--surface) 45%);
}

.act-footprint-district-list {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    gap: 0.32rem;
    margin: 0;
    padding: 0;
}

.act-footprint-district-btn {
    display: inline-flex;
    align-items: center;
    white-space: nowrap;
    text-align: left;
    padding: 0.18rem 0.48rem;
    border: 1px solid color-mix(in srgb, var(--border) 78%, transparent);
    border-radius: 999px;
    background: color-mix(in srgb, var(--surface) 88%, transparent);
    font: inherit;
    font-size: 0.76rem;
    font-weight: 700;
    line-height: 1.2;
    color: var(--brand-blue);
    cursor: pointer;
}

.act-footprint-popup {
    max-width: min(280px, 72vw);
    padding: 0.15rem 0.35rem 0.35rem;
    line-height: 1.45;
}

.act-footprint-popup strong {
    display: block;
    font-size: 0.95rem;
    margin-bottom: 0.35rem;
}

.act-footprint-popup__text {
    margin: 0 0 0.5rem;
    font-size: 0.84rem;
    white-space: pre-wrap;
    color: var(--muted, #4b5563);
}

.act-footprint-popup__body::after {
    content: "";
    display: block;
    clear: both;
}

.act-footprint-popup__img {
    float: left;
    width: 84px;
    height: 62px;
    margin: 0.08rem 0.55rem 0.35rem 0;
    border-radius: 10px;
    object-fit: cover;
}

.act-footprint-popup__link {
    display: inline-flex;
    margin-top: 0.42rem;
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--brand-blue);
    text-decoration: underline;
}

.act-footprint-popup__link:hover {
    color: var(--accent-dark);
}

.org-member-grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
    gap: 0.95rem;
}

.org-member-card {
    width: 100%;
    border: 1px solid color-mix(in srgb, var(--border) 80%, transparent);
    border-radius: 14px;
    background: #fff;
    text-align: left;
    padding: 0.8rem;
    display: grid;
    gap: 0.45rem;
    cursor: pointer;
}

.org-member-card:hover {
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.08);
    border-color: color-mix(in srgb, var(--accent) 30%, transparent);
}

.org-member-card__photo {
    width: 62px;
    height: 62px;
    border-radius: 12px;
    overflow: hidden;
    background: color-mix(in srgb, var(--brand-blue) 16%, #ffffff 84%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--brand-blue-dark);
    font-weight: 700;
}

.org-member-card__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.org-member-card__name {
    font-weight: 800;
    color: var(--brand-blue-dark);
    line-height: 1.25;
}

.org-member-card__designation {
    color: var(--muted);
    font-size: 0.86rem;
    line-height: 1.35;
}

.org-member-modal[hidden] {
    display: none;
}

.org-member-modal {
    position: fixed;
    inset: 0;
    z-index: 1200;
}

.org-member-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(2, 6, 23, 0.56);
}

.org-member-modal__dialog {
    position: relative;
    max-width: 640px;
    margin: 8vh auto 0;
    background: #fff;
    border-radius: 16px;
    padding: 1rem 1rem 0.95rem;
    box-shadow: 0 22px 44px rgba(15, 23, 42, 0.24);
}

.org-member-modal__close {
    position: absolute;
    top: 0.4rem;
    right: 0.6rem;
    border: 0;
    background: transparent;
    font-size: 1.6rem;
    line-height: 1;
    cursor: pointer;
    color: var(--muted);
}

.org-member-modal__head {
    display: grid;
    grid-template-columns: 84px 1fr;
    gap: 0.8rem;
    align-items: center;
    margin-bottom: 0.65rem;
}

.org-member-modal__image {
    width: 84px;
    height: 84px;
    border-radius: 12px;
    overflow: hidden;
}

.org-member-modal__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.org-member-modal__head h3 {
    margin: 0;
    font-size: 1.08rem;
}

.org-member-modal__head p {
    margin: 0.18rem 0 0;
    color: var(--muted);
}

.org-member-modal__body p {
    margin: 0;
    white-space: pre-wrap;
}

.org-structure-overview {
    padding-top: clamp(2rem, 4vw, 3rem);
}

.org-structure-shell {
    display: grid;
    grid-template-columns: minmax(240px, 0.95fr) minmax(0, 1.35fr);
    gap: clamp(1rem, 2.4vw, 1.75rem);
    align-items: start;
}

.org-structure-intro {
    background: linear-gradient(160deg, color-mix(in srgb, var(--brand-blue) 8%, #ffffff), #ffffff);
    border: 1px solid color-mix(in srgb, var(--border) 82%, transparent);
    border-radius: 16px;
    padding: clamp(1rem, 2vw, 1.35rem);
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
}

.org-structure-intro h2 {
    margin: 0.2rem 0 0.55rem;
    color: var(--brand-blue-dark);
}

.org-structure-intro > p {
    margin: 0;
    color: var(--muted);
}

.org-structure-chips {
    list-style: none;
    margin: 0.9rem 0 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.org-structure-chips li {
    border: 1px solid color-mix(in srgb, var(--accent) 28%, transparent);
    background: color-mix(in srgb, var(--accent) 7%, #ffffff);
    color: var(--brand-blue-dark);
    border-radius: 999px;
    padding: 0.28rem 0.62rem;
    font-size: 0.79rem;
    font-weight: 700;
}

.org-structure-copy {
    background: #fff;
    border-radius: 16px;
    border: 1px solid color-mix(in srgb, var(--border) 80%, transparent);
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
    padding: clamp(1rem, 2vw, 1.35rem);
}

.org-structure-copy p {
    margin: 0;
}

.org-structure-copy p + p {
    margin-top: 0.85rem;
}

.org-structure-highlights {
    margin-top: clamp(1rem, 2vw, 1.35rem);
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.85rem;
}

.org-structure-highlight {
    margin: 0;
    background: #fff;
    border-radius: 14px;
    border: 1px solid color-mix(in srgb, var(--border) 82%, transparent);
    padding: 0.9rem 0.95rem;
}

.org-structure-highlight h3 {
    margin: 0;
    font-size: 0.98rem;
    color: var(--brand-blue-dark);
}

.org-structure-highlight p {
    margin: 0.5rem 0 0;
    font-size: 0.89rem;
    color: var(--muted);
    line-height: 1.55;
}

.org-members-intro {
    margin: -0.35rem 0 1rem;
    max-width: 68ch;
    color: var(--muted);
}

.org-hero {
    position: relative;
    isolation: isolate;
    overflow: hidden;
    padding: clamp(2.6rem, 6vw, 4.35rem) 0;
    color: #eef7fb;
    background: linear-gradient(
        135deg,
        var(--surface-deep) 0%,
        var(--surface-dark) 48%,
        color-mix(in srgb, var(--accent-dark) 46%, var(--surface-dark)) 100%
    );
}

.org-hero__mesh {
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    opacity: 0.48;
    background:
        radial-gradient(ellipse 62% 52% at 7% 12%, var(--logo-red-glow), transparent 58%),
        radial-gradient(ellipse 54% 42% at 94% 82%, color-mix(in srgb, var(--brand-blue) 22%, transparent), transparent 54%);
}

.org-hero::after {
    content: "";
    position: absolute;
    inset: auto 0 0;
    z-index: 1;
    height: 48px;
    background: linear-gradient(to bottom, transparent, var(--surface));
    pointer-events: none;
}

.org-hero__grid {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 0.55fr);
    gap: clamp(1.5rem, 4vw, 3rem);
    align-items: center;
}

.org-hero__copy {
    max-width: 48rem;
}

.org-hero__eyebrow,
.org-section-eyebrow {
    margin: 0 0 0.6rem;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.15em;
    text-transform: uppercase;
}

.org-hero__eyebrow {
    color: color-mix(in srgb, var(--accent-soft) 70%, #fff 30%);
}

.org-hero h1 {
    margin: 0;
    font-family: "Libre Baskerville", Georgia, serif;
    font-size: clamp(2rem, 4.5vw, 3rem);
    line-height: 1.12;
    color: #fff;
}

.org-hero__lead {
    max-width: 52ch;
    margin: 1rem 0 0;
    font-size: clamp(1.04rem, 2vw, 1.16rem);
    line-height: 1.65;
    color: color-mix(in srgb, #eef7fb 88%, var(--accent-soft) 12%);
}

.org-hero__panel {
    display: grid;
    gap: 0.75rem;
    padding: 1rem;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.11);
    border: 1px solid rgba(255, 255, 255, 0.18);
    box-shadow: 0 22px 54px color-mix(in srgb, #000 16%, transparent);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

.org-hero__stat {
    padding: 0.95rem 1rem;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.16);
}

.org-hero__stat strong,
.org-hero__stat span {
    display: block;
}

.org-hero__stat strong {
    font-size: clamp(1.45rem, 3vw, 2rem);
    line-height: 1;
    color: #fff;
}

.org-hero__stat span {
    margin-top: 0.25rem;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: color-mix(in srgb, #eef7fb 82%, transparent);
}

.org-governance {
    padding-top: clamp(2.2rem, 4vw, 3rem);
    background: var(--surface);
}

.org-governance__head {
    max-width: 46rem;
    margin-bottom: 1.45rem;
}

.org-section-eyebrow {
    color: var(--accent);
}

.org-governance__head h2,
.org-board__head h2 {
    margin: 0;
    font-family: "Libre Baskerville", Georgia, serif;
    color: var(--surface-deep);
    line-height: 1.2;
}

.org-governance__head h2 {
    font-size: clamp(1.45rem, 3vw, 1.9rem);
}

.org-governance__head p,
.org-board__head p {
    max-width: 62ch;
    margin: 0.7rem 0 0;
    color: var(--muted);
    line-height: 1.65;
}

.org-framework {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.95rem;
    margin-bottom: 1.25rem;
}

.org-framework__card {
    position: relative;
    overflow: hidden;
    padding: 1.1rem 1.15rem;
    border-radius: 18px;
    background: var(--surface);
    border: 1px solid var(--border);
    box-shadow: 0 12px 30px color-mix(in srgb, var(--surface-deep) 5%, transparent);
}

.org-framework__card::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 4px;
    background: linear-gradient(180deg, var(--accent), var(--brand-blue));
}

.org-framework__step {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.2rem;
    height: 2.2rem;
    border-radius: 10px;
    font-size: 0.75rem;
    font-weight: 800;
    color: var(--accent-dark);
    background: color-mix(in srgb, var(--accent-soft) 48%, var(--surface));
}

.org-framework__card h3 {
    margin: 0.85rem 0 0.45rem;
    font-size: 1.02rem;
    color: var(--surface-deep);
}

.org-framework__card p {
    margin: 0;
    font-size: 0.9rem;
    line-height: 1.58;
    color: var(--muted);
}

.org-governance__content {
    display: grid;
    grid-template-columns: minmax(250px, 0.42fr) minmax(0, 0.58fr);
    gap: 1rem;
    align-items: start;
}

.org-governance__summary,
.org-governance__copy {
    border-radius: 18px;
    border: 1px solid var(--border);
    background: var(--surface);
    box-shadow: 0 12px 30px color-mix(in srgb, var(--surface-deep) 5%, transparent);
}

.org-governance__summary {
    padding: 1.2rem 1.25rem;
    background: linear-gradient(150deg, color-mix(in srgb, var(--brand-blue) 8%, var(--surface)), var(--surface));
}

.org-governance__summary h3 {
    margin: 0;
    font-size: 1.08rem;
    color: var(--surface-deep);
}

.org-governance__summary p {
    margin: 0.65rem 0 0;
    line-height: 1.6;
    color: var(--muted);
}

.org-governance__summary ul {
    margin: 0.9rem 0 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 0.5rem;
}

.org-governance__summary li {
    position: relative;
    padding-left: 1.35rem;
    font-size: 0.92rem;
    line-height: 1.45;
    color: var(--text);
}

.org-governance__summary li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.45rem;
    width: 0.45rem;
    height: 0.45rem;
    border-radius: 999px;
    background: var(--accent);
}

.org-governance__copy {
    padding: 1.2rem 1.25rem;
}

.org-governance__copy p {
    margin: 0;
    color: var(--text);
    line-height: 1.7;
}

.org-governance__copy p + p {
    margin-top: 0.9rem;
}

.org-board {
    padding-top: clamp(2rem, 4vw, 3rem);
}

.org-board__head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.35rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid color-mix(in srgb, var(--logo-blue-deep) 12%, transparent);
}

.org-board__head h2 {
    font-size: clamp(1.4rem, 3vw, 1.8rem);
}

.org-board__count {
    flex-shrink: 0;
    padding: 0.4rem 0.72rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--accent-dark);
    background: color-mix(in srgb, var(--accent-soft) 45%, var(--surface));
    border: 1px solid color-mix(in srgb, var(--accent) 22%, transparent);
}

.org-board-grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 280px), 1fr));
    gap: 1rem;
}

.org-board-card {
    width: 100%;
    min-height: 100%;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.9rem;
    align-items: center;
    padding: 1rem;
    border-radius: 18px;
    text-align: left;
    background: var(--surface);
    border: 1px solid var(--border);
    box-shadow: 0 10px 28px color-mix(in srgb, var(--surface-deep) 5%, transparent);
    cursor: pointer;
    transition: transform 0.22s var(--nav-ease), border-color 0.22s ease, box-shadow 0.22s ease;
}

.org-board-card:hover,
.org-board-card:focus-visible {
    transform: translateY(-4px);
    border-color: color-mix(in srgb, var(--accent) 32%, var(--border));
    box-shadow: 0 18px 40px color-mix(in srgb, var(--accent) 8%, transparent);
    outline: none;
}

.org-board-card__avatar {
    grid-row: span 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 4rem;
    height: 4rem;
    overflow: hidden;
    border-radius: 16px;
    color: #fff;
    font-weight: 800;
    letter-spacing: 0.04em;
    background: linear-gradient(135deg, var(--brand-blue-dark), var(--accent-dark));
    box-shadow: 0 12px 24px color-mix(in srgb, var(--surface-deep) 10%, transparent);
}

.org-board-card__avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.org-board-card__body {
    min-width: 0;
    display: grid;
    gap: 0.25rem;
}

.org-board-card__name {
    font-size: 1rem;
    font-weight: 800;
    line-height: 1.3;
    color: var(--surface-deep);
}

.org-board-card__designation {
    font-size: 0.86rem;
    line-height: 1.4;
    color: var(--muted);
}

.org-board-card__action {
    grid-column: 2;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--accent);
}

.org-member-modal__dialog {
    border-radius: 20px;
    border: 1px solid color-mix(in srgb, var(--border) 75%, transparent);
}

.org-member-modal__head h3 {
    color: var(--surface-deep);
}

@media (max-width: 960px) {
    .org-hero__grid,
    .org-framework,
    .org-governance__content {
        grid-template-columns: 1fr;
    }

    .org-hero__panel {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .org-board__head {
        align-items: flex-start;
        flex-direction: column;
    }

    .org-structure-shell {
        grid-template-columns: 1fr;
    }

    .org-structure-highlights {
        grid-template-columns: 1fr;
    }

    .act-footprint-stage {
        padding: 0;
        display: block;
    }

    .act-footprint-split .act-google-map.act-google-map--split {
        height: clamp(520px, 70vh, 780px);
        max-height: none;
        min-height: 480px;
    }

    .act-footprint-split__aside {
        max-height: none;
        border-left: 0;
        border-top: 1px solid color-mix(in srgb, var(--logo-blue-deep) 12%, transparent);
    }
}

@media (max-width: 640px) {
    .act-footprint-district-list {
        gap: 0.28rem;
    }
}

.act-footprint-map-fullbleed {
    width: 100%;
    margin-top: clamp(0.5rem, 2vw, 1rem);
}

.pakistan-map-stage--fullbleed {
    padding: 0;
    margin: 0;
}

.section--partners {
    background: linear-gradient(
        180deg,
        color-mix(in srgb, var(--surface) 96%, #ffffff 4%) 0%,
        color-mix(in srgb, var(--surface-alt) 100%, transparent) 48%,
        color-mix(in srgb, var(--bg) 100%, transparent) 100%
    );
    padding-bottom: clamp(2rem, 4vw, 2.75rem);
}

.section-heading--partners {
    margin-bottom: 1.25rem;
    text-align: center;
}

.partners-heading__title {
    margin: 0.25rem 0 0;
    letter-spacing: -0.02em;
}

.partners-heading__accent {
    color: var(--brand-blue-dark);
}

.partners-marquee {
    position: relative;
    width: 100%;
    margin-top: 0.25rem;
}

.partners-marquee__viewport {
    overflow: hidden;
    width: 100%;
    padding: 0.65rem 0;
}

.partners-marquee__track {
    display: flex;
    align-items: center;
    gap: clamp(2rem, 4vw, 3.25rem);
    width: max-content;
    animation: partners-marquee-scroll 50s linear infinite;
}

.partners-marquee:hover .partners-marquee__track {
    animation-play-state: paused;
}

@keyframes partners-marquee-scroll {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}

.partners-marquee__fade {
    position: absolute;
    top: 0;
    bottom: 0;
    width: min(72px, 12vw);
    z-index: 2;
    pointer-events: none;
}

.partners-marquee__fade--left {
    left: 0;
    background: linear-gradient(90deg, color-mix(in srgb, var(--surface) 96%, transparent) 0%, transparent 100%);
}

.partners-marquee__fade--right {
    right: 0;
    background: linear-gradient(270deg, color-mix(in srgb, var(--surface) 96%, transparent) 0%, transparent 100%);
}

.partners-marquee__item {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Nutrition Intl site SVG is white-on-transparent; show on brand teal */
.partners-marquee__item--ni {
    padding: 0.4rem 0.9rem;
    border-radius: 14px;
    background: linear-gradient(
        135deg,
        color-mix(in srgb, var(--brand-blue-dark) 96%, transparent) 0%,
        color-mix(in srgb, var(--brand-blue) 96%, transparent) 100%
    );
    box-shadow: 0 6px 16px color-mix(in srgb, var(--brand-blue-dark) 20%, transparent);
}

.partners-marquee__logo {
    display: block;
    height: 56px;
    width: auto;
    max-width: 168px;
    object-fit: contain;
    filter: drop-shadow(0 4px 10px color-mix(in srgb, var(--surface-deep) 6%, transparent));
}

@media (prefers-reduced-motion: reduce) {
    .partners-marquee__track {
        animation: none;
    }

    .partners-marquee__viewport {
        overflow-x: auto;
        overscroll-behavior-x: contain;
        padding-inline: 4px;
        -webkit-overflow-scrolling: touch;
    }

    .partners-marquee__fade {
        display: none;
    }
}

.pakistan-map-showcase {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.4rem;
    align-items: stretch;
}

.pakistan-map-stage {
    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;
}

.pakistan-map-stage {
    padding: 1.35rem;
}

.pakistan-map-showcase--simplemaps .pakistan-map-stage {
    padding: 1rem;
}

.act-google-map {
    position: relative;
    width: 100%;
    max-width: 760px;
    min-height: 430px;
    height: 56vh;
    max-height: 620px;
    margin: 0 auto;
    border-radius: 14px;
    overflow: hidden;
    border: 1px solid color-mix(in srgb, var(--logo-blue-deep) 14%, transparent);
    box-shadow: 0 12px 28px rgba(44, 58, 71, 0.12);
    background: transparent;
}

/* Keep map canvas transparent outside Pakistan layer */
.act-google-map .gm-style,
.act-google-map .gm-style > div {
    background: transparent !important;
}

.act-google-map.act-google-map--fullwidth {
    width: 100%;
    max-width: none;
    margin: 0;
    max-height: none;
    height: min(62vh, 720px);
    min-height: 380px;
    border-radius: 0;
    border-left: none;
    border-right: none;
    border-top: 1px solid color-mix(in srgb, var(--logo-blue-deep) 18%, transparent);
    border-bottom: 1px solid color-mix(in srgb, var(--logo-blue-deep) 18%, transparent);
    box-shadow: none;
}

.act-google-map--missing-key {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem 1.25rem;
    text-align: center;
    font-size: 0.9rem;
    color: var(--muted);
    background: var(--surface-alt);
}

.act-google-map--missing-key code {
    font-size: 0.82em;
}

/* Native Maps marker label (anchored above pin by Google) */
.act-google-map .act-footprint-marker-label {
    box-sizing: border-box;
    padding: 3px 7px;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(37, 43, 50, 0.14);
    box-shadow: 0 3px 10px rgba(37, 43, 50, 0.12);
    white-space: nowrap;
    max-width: min(220px, 70vw);
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.2;
    margin-top: 2px;
}

.act-google-map .act-footprint-province-label {
    box-sizing: border-box;
    padding: 1px 5px;
    border-radius: 6px;
    background: rgba(255, 255, 255, 0.85);
    color: #121826;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    margin-top: 2px;
    white-space: nowrap;
    box-shadow: 0 2px 8px rgba(2, 6, 23, 0.14);
}

.pakistan-simplemap {
    width: 100%;
    max-width: 760px;
    min-height: 380px;
    margin: 0 auto;
    border-radius: 0;
    overflow: hidden;
    background: transparent;
    position: relative;
}

.pakistan-simplemap > div,
.pakistan-simplemap svg {
    width: 94% !important;
    height: auto !important;
    margin: 0 auto;
}

.map-district-overlay {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 8;
}

.map-district-label {
    position: absolute;
    transform: translate(calc(-50% + var(--label-offset-x, 0px)), calc(-50% + var(--label-offset-y, 0px)));
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    pointer-events: auto;
}

.map-district-label__dot {
    width: 0.38rem;
    height: 0.38rem;
    border-radius: 999px;
    background: var(--accent);
    box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.92);
    flex-shrink: 0;
    cursor: pointer;
}

.map-district-label__text {
    position: absolute;
    left: 0.45rem;
    top: -0.15rem;
    transform: translateY(-100%);
    padding: 0.15rem 0.36rem;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(37, 43, 50, 0.14);
    color: var(--text);
    font-size: 0.64rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    line-height: 1.1;
    white-space: nowrap;
    box-shadow: 0 4px 12px rgba(37, 43, 50, 0.12);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.15s ease, visibility 0.15s ease;
}

.map-district-label:hover .map-district-label__text,
.map-district-label:focus-within .map-district-label__text {
    opacity: 1;
    visibility: visible;
}

.map-district-overlay-label {
    position: absolute;
    transform: translateY(-100%);
    padding: 0.15rem 0.36rem;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(37, 43, 50, 0.14);
    color: var(--text);
    font-size: 0.64rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    line-height: 1.1;
    white-space: nowrap;
    box-shadow: 0 4px 12px rgba(37, 43, 50, 0.12);
    pointer-events: none;
    z-index: 12;
}

.pakistan-map-shell {
    position: relative;
    aspect-ratio: 2365 / 1890;
    border-radius: 24px;
    overflow: hidden;
    background: linear-gradient(180deg, #f5fbfe 0%, var(--surface-alt) 100%);
    border: 1px solid color-mix(in srgb, var(--logo-blue-deep) 8%, transparent);
}

.pakistan-map-base {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: contain;
    filter: drop-shadow(0 12px 22px rgba(44, 58, 71, 0.14));
}

.province-chip {
    position: absolute;
    padding: 0.38rem 0.7rem;
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #fff;
    box-shadow: 0 12px 24px rgba(44, 58, 71, 0.16);
    z-index: 4;
    transform: translate(-50%, -50%);
}

.province-chip--ajk { background: var(--brand-blue); }
.province-chip--ict { background: var(--surface-deep); }
.province-chip--punjab { background: var(--accent); }
.province-chip--kp { background: var(--logo-red-deep); }
.province-chip--sindh { background: var(--accent-dark); }

.district-marker {
    position: absolute;
    transform: translate(-50%, -50%);
    width: 28px;
    height: 28px;
    padding: 0;
    border: 0;
    background: transparent;
    cursor: pointer;
    z-index: 5;
}

.district-marker__dot,
.district-marker__pulse {
    position: absolute;
    inset: 0;
    border-radius: 999px;
}

.district-marker__dot {
    width: 12px;
    height: 12px;
    inset: 8px;
    background: var(--accent);
    border: 2px solid #fff;
    box-shadow: 0 0 0 5px color-mix(in srgb, var(--accent) 30%, transparent);
}

.district-marker__pulse {
    border: 1px dashed color-mix(in srgb, var(--accent) 55%, transparent);
    animation: districtPulse 2.2s ease-out infinite;
}

.district-marker:hover .district-marker__dot,
.district-marker:focus-visible .district-marker__dot,
.district-marker.is-active .district-marker__dot {
    transform: scale(1.18);
    background: var(--brand-blue);
    box-shadow: 0 0 0 8px color-mix(in srgb, var(--brand-blue) 20%, transparent);
}

.district-marker:focus-visible {
    outline: none;
}

.district-marker__label {
    position: absolute;
    left: 50%;
    bottom: calc(100% + 8px);
    transform: translateX(-50%) translateY(4px);
    white-space: nowrap;
    background: var(--logo-navy-tint);
    color: #fff;
    padding: 0.24rem 0.46rem;
    border-radius: 8px;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.16s ease, transform 0.16s ease;
}

.district-marker:hover .district-marker__label,
.district-marker:focus-visible .district-marker__label,
.district-marker.is-active .district-marker__label {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}

.district-list {
    display: grid;
    gap: 0.6rem;
    margin-top: 1rem;
    font-size: 0.95rem;
    color: var(--muted);
}

.district-list span {
    padding: 0.75rem 0.9rem;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.78);
    border: 1px solid color-mix(in srgb, var(--logo-blue-deep) 8%, transparent);
}

.district-list strong {
    color: var(--surface-dark);
    margin-right: 0.35rem;
}

@keyframes districtPulse {
    0% { transform: scale(0.75); opacity: 0.8; }
    70% { transform: scale(1.4); opacity: 0; }
    100% { transform: scale(1.4); opacity: 0; }
}

/* Home impact stats: single horizontal row (scroll on narrow viewports) */
.stats-grid-scroll {
    overflow-x: auto;
    overscroll-behavior-x: contain;
    margin-inline: -6px;
    padding-inline: 6px;
    padding-bottom: 4px;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
}

.stats-grid--single-row {
    grid-template-columns: repeat(6, minmax(108px, 1fr));
}

.stats-grid--single-row .stat-card {
    display: grid;
    grid-template-columns: 54px 1fr;
    grid-template-rows: auto auto;
    column-gap: 0.8rem;
    row-gap: 0.15rem;
    align-items: center;
    text-align: left;
    padding: 0.95rem 1rem;
    scroll-snap-align: start;
}

.stats-grid--single-row .stat-card__icon {
    position: static;
    grid-column: 1;
    grid-row: 1 / span 2;
    align-self: stretch;
    justify-self: center;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 100%;
    border-right: 1px solid color-mix(in srgb, var(--border) 65%, transparent);
    padding-right: 0.75rem;
    color: var(--theme-button-hover);
    background: transparent;
    box-shadow: none;
    border: 0;
    border-radius: 0;
}

.stats-grid--single-row .stat-card__icon svg {
    width: 2.2rem;
    height: 2.2rem;
    stroke-width: 2.15;
    animation: statIconPulse 2.8s ease-in-out infinite;
}

.stats-grid--single-row .stat-card strong {
    grid-column: 2;
    grid-row: 1;
    font-size: clamp(1.35rem, 2.2vw, 1.85rem);
    margin-bottom: 0;
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.02em;
}

.stats-grid--single-row .stat-card > span:last-of-type {
    grid-column: 2;
    grid-row: 2;
    color: var(--muted);
    font-size: 0.86rem;
    line-height: 1.3;
}

@keyframes statIconPulse {
    0%, 100% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.08); opacity: 0.86; }
}

@media (max-width: 900px) {
    .stats-grid-scroll {
        overflow-x: visible;
        overscroll-behavior-x: auto;
        scroll-snap-type: none;
        margin-inline: 0;
        padding-inline: 0;
    }

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

    .stats-grid--single-row .stat-card {
        scroll-snap-align: none;
    }
}

.stat-card,
.feature-card,
.news-card,
.country-card,
.cta-card,
.admin-card,
.admin-panel,
.form-card,
.result-card,
.login-card,
.message-box {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 24px;
    box-shadow: var(--shadow);
}

.stat-card,
.cta-card,
.admin-card,
.form-card,
.result-card,
.login-card,
.admin-panel,
.message-box {
    padding: 1.5rem;
}

.stat-card strong,
.admin-card strong {
    display: block;
    font-size: 2rem;
    margin-bottom: 0.5rem;
}

.feature-card__body,
.news-card__body,
.country-card__body {
    padding: 1.2rem;
}

.feature-card h3,
.news-card h3,
.country-card h3,
.cta-card h3 {
    margin-top: 0;
}

.band {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.35rem;
    background: rgba(255, 255, 255, 0.55);
    border: 1px solid color-mix(in srgb, var(--logo-blue-deep) 12%, transparent);
    border-radius: 28px;
    padding: 1.35rem 1.5rem;
}

.rich-text p {
    font-size: 1.08rem;
}

.rich-text.article-body > *:first-child {
    margin-top: 0;
}

.rich-text.article-body > *:last-child {
    margin-bottom: 0;
}

.rich-text.article-body h2,
.rich-text.article-body h3 {
    margin: 1.25rem 0 0.65rem;
    line-height: 1.25;
    color: var(--surface-deep);
}

.rich-text.article-body ul,
.rich-text.article-body ol {
    margin: 0.75rem 0;
    padding-left: 1.35rem;
}

.rich-text.article-body img {
    display: inline-block;
    max-width: 100%;
    height: auto;
    border-radius: 12px;
    margin: 1rem 0;
}

/* —— Article: image lightbox —— */
body.image-lightbox-open {
    overflow: hidden;
}

.image-lightbox {
    position: fixed;
    inset: 0;
    z-index: 1200;
}

.image-lightbox__backdrop {
    position: absolute;
    inset: 0;
    background: color-mix(in srgb, #020617 84%, transparent);
    backdrop-filter: blur(6px);
}

.image-lightbox__panel {
    position: relative;
    height: 100%;
    display: grid;
    place-items: center;
    padding: 24px;
}

.image-lightbox__figure {
    margin: 0;
    width: min(1680px, calc(100vw - 72px));
    max-height: calc(100vh - 88px);
    overflow: auto;
    display: flex;
    align-items: center;
    justify-content: center;
    -webkit-overflow-scrolling: touch;
}

.image-lightbox__img {
    display: block;
    width: auto;
    height: auto;
    max-width: 100%;
    max-height: calc(100vh - 88px);
    object-fit: contain;
    border-radius: 12px;
    box-shadow: 0 24px 80px color-mix(in srgb, #000 55%, transparent);
    background: color-mix(in srgb, #0b1220 55%, transparent);
    cursor: zoom-in;
    user-select: none;
    transition: box-shadow 0.2s ease;
}

.image-lightbox__img.image-lightbox__img--zoomed {
    cursor: zoom-out;
    max-width: none !important;
    max-height: none !important;
    border-radius: 4px;
}

.image-lightbox__caption {
    margin-top: 12px;
    font-size: 0.95rem;
    color: color-mix(in srgb, #fff 88%, transparent);
    text-align: center;
}

.image-lightbox--no-caption .image-lightbox__caption {
    display: none !important;
    margin: 0;
}

.image-lightbox__close {
    position: absolute;
    top: 18px;
    right: 18px;
    width: 44px;
    height: 44px;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, #fff 20%, transparent);
    background: color-mix(in srgb, #0b1220 65%, transparent);
    color: #fff;
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
}

.image-lightbox__close:hover,
.image-lightbox__close:focus-visible {
    background: color-mix(in srgb, #0b1220 82%, transparent);
    outline: none;
}

.image-lightbox__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 48px;
    height: 48px;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, #fff 18%, transparent);
    background: color-mix(in srgb, #0b1220 60%, transparent);
    color: #fff;
    font-size: 34px;
    line-height: 1;
    cursor: pointer;
}

.image-lightbox__nav:hover,
.image-lightbox__nav:focus-visible {
    background: color-mix(in srgb, #0b1220 78%, transparent);
    outline: none;
}

.image-lightbox__nav:disabled {
    opacity: 0.45;
    cursor: default;
}

.image-lightbox__nav--prev {
    left: 18px;
}

.image-lightbox__nav--next {
    right: 18px;
}

@media (max-width: 640px) {
    .org-hero__panel {
        grid-template-columns: 1fr;
    }

    .org-board-card {
        grid-template-columns: 1fr;
    }

    .org-board-card__avatar {
        grid-row: auto;
    }

    .org-board-card__action {
        grid-column: 1;
    }

    .admin-dashboard-stats,
    .admin-dashboard-quick-grid {
        grid-template-columns: 1fr;
    }

    .admin-dashboard-panel__head {
        flex-direction: column;
        gap: 0.35rem;
    }

    .image-lightbox__panel {
        padding: 14px;
    }
    .image-lightbox__figure {
        width: calc(100vw - 28px);
        max-height: calc(100vh - 72px);
    }
    .image-lightbox__img {
        max-height: calc(100vh - 72px);
    }
    .image-lightbox__nav--prev {
        left: 10px;
    }
    .image-lightbox__nav--next {
        right: 10px;
    }
    .image-lightbox__close {
        top: 12px;
        right: 12px;
    }
}

.rich-text.article-body table {
    width: 100%;
    border-collapse: collapse;
    margin: 1rem 0;
    font-size: 0.95rem;
}

.rich-text.article-body th,
.rich-text.article-body td {
    border: 1px solid color-mix(in srgb, var(--border) 85%, transparent);
    padding: 0.45rem 0.6rem;
    vertical-align: top;
}

.rich-text.article-body a {
    color: var(--brand-blue-dark);
    text-decoration: underline;
}

.admin-logo-preview-wrap--post {
    margin-top: 0.65rem;
}

.admin-logo-preview-wrap--post .admin-logo-preview {
    max-height: 160px;
    max-width: 100%;
    width: auto;
    object-fit: contain;
}

.admin-tinymce {
    min-height: 280px;
}

.results-grid {
    display: grid;
    gap: 1.5rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.results-column h2 {
    margin-top: 0;
}

.result-card {
    display: block;
    margin-bottom: 1rem;
}

.flash-success,
.flash-error {
    margin-bottom: 1rem;
    padding: 1rem 1.25rem;
    border-radius: 14px;
}

.flash-success {
    background: #e3f5e6;
    color: #14532d;
}

.flash-error {
    background: #fce9e9;
    color: #8a1f1f;
}

.admin-body {
    background: linear-gradient(180deg, #eef3fb 0%, #f6f9ff 100%);
}

.admin-shell {
    display: grid;
    grid-template-columns: 260px 1fr;
    min-height: 100vh;
}

.admin-sidebar {
    background: linear-gradient(180deg, var(--surface-dark), var(--brand-blue-dark));
    color: #fff;
    padding: 1.25rem 1rem;
}

.admin-brand {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    margin-bottom: 1.2rem;
    padding: 0.35rem 0.5rem 0.75rem;
    border-bottom: 1px solid color-mix(in srgb, #fff 18%, transparent);
}

.admin-brand__name {
    font-size: 1.1rem;
    font-weight: 800;
    color: #fff;
}

.admin-brand__meta {
    font-size: 0.76rem;
    color: color-mix(in srgb, #fff 75%, transparent);
}

.admin-nav a {
    display: block;
    padding: 0.58rem 0.68rem;
    color: color-mix(in srgb, #fff 80%, transparent);
    border-radius: 10px;
    transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.admin-nav a:hover {
    background: color-mix(in srgb, #fff 10%, transparent);
    color: #fff;
    transform: translateX(2px);
}

.admin-nav a.is-active {
    background: color-mix(in srgb, #fff 16%, transparent);
    color: #fff;
    font-weight: 700;
}

.admin-nav .admin-nav__logout {
    margin-top: 0.75rem;
    color: color-mix(in srgb, #ffccd5 80%, #fff 20%);
    border-top: 1px solid color-mix(in srgb, #fff 12%, transparent);
    padding-top: 0.8rem;
    border-radius: 0;
}

.admin-content {
    padding: 1.45rem 1.65rem;
}

.admin-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.1rem;
    padding: 0.9rem 1rem;
    background: #fff;
    border: 1px solid color-mix(in srgb, var(--border) 75%, transparent);
    border-radius: 14px;
}

.admin-topbar h1 {
    margin: 0;
    font-size: 1.35rem;
}

.admin-topbar__eyebrow {
    margin: 0 0 0.15rem;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--muted);
}

.admin-topbar__user {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--brand-blue-dark);
    background: color-mix(in srgb, var(--surface-alt) 82%, #fff 18%);
    border: 1px solid color-mix(in srgb, var(--border) 80%, transparent);
    padding: 0.38rem 0.62rem;
    border-radius: 999px;
}

.admin-topbar__actions {
    display: flex;
    align-items: center;
    gap: 0.55rem;
}

.admin-nav-toggle {
    display: none;
    border: 1px solid color-mix(in srgb, var(--border) 80%, transparent);
    background: #fff;
    color: var(--brand-blue-dark);
    border-radius: 999px;
    padding: 0.34rem 0.72rem;
    font-size: 0.8rem;
    font-weight: 700;
}

.admin-actions {
    margin-bottom: 1rem;
}

.admin-actions--quick {
    display: flex;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.admin-help {
    margin: 0.15rem 0 0.7rem;
    color: var(--muted);
    font-size: 0.84rem;
}

.admin-logo-preview-wrap {
    margin-bottom: 0.85rem;
}

.admin-logo-preview {
    max-width: 220px;
    max-height: 120px;
    object-fit: contain;
    background: #fff;
    padding: 12px;
    border: 1px solid #cfdbeb;
    border-radius: 16px;
}

.admin-card a {
    margin-top: 0.45rem;
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--brand-blue-dark);
}

.admin-table {
    width: 100%;
    border-collapse: collapse;
}

.admin-table th,
.admin-table td {
    padding: 0.9rem 0.75rem;
    border-bottom: 1px solid var(--border);
    text-align: left;
}

.admin-table__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.65rem;
}

.admin-inline-form {
    display: inline;
    margin: 0;
}

.admin-link-btn {
    background: none;
    border: 0;
    padding: 0;
    font: inherit;
    color: var(--accent, #c41e3a);
    cursor: pointer;
    text-decoration: underline;
}

.admin-link-btn:hover {
    color: var(--brand-blue-dark);
}

.admin-form label {
    display: block;
    margin: 0.68rem 0 0.35rem;
    font-weight: 700;
}

.admin-form input,
.admin-form select,
.admin-form textarea {
    border: 1px solid color-mix(in srgb, var(--border) 85%, transparent);
    border-radius: 10px;
    padding: 0.58rem 0.68rem;
    background: #fff;
}

.admin-form textarea {
    resize: vertical;
}

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

.checkbox-row {
    display: flex;
    align-items: center;
}

.checkbox-row input {
    width: auto;
    margin-right: 0.5rem;
}

.admin-form__checkbox-row {
    grid-column: 1 / -1;
    padding: 0.35rem 0;
}

.admin-form__checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: 0.55rem;
    margin: 0;
    font-weight: 600;
    line-height: 1.45;
}

.admin-form__checkbox-label input {
    width: auto;
    margin-top: 0.2rem;
    flex-shrink: 0;
}

.form-grid--checkboxes {
    grid-template-columns: 1fr;
}

.admin-badge {
    display: inline-block;
    margin: 0.12rem 0.12rem 0 0;
    padding: 0.18rem 0.45rem;
    border-radius: 6px;
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    background: color-mix(in srgb, var(--logo-red) 14%, var(--surface));
    color: var(--logo-red);
    border: 1px solid color-mix(in srgb, var(--logo-red) 28%, transparent);
}

.admin-badge--muted {
    background: color-mix(in srgb, var(--brand-blue-dark) 10%, var(--surface));
    color: var(--brand-blue-dark);
    border-color: color-mix(in srgb, var(--brand-blue-dark) 22%, transparent);
}

.admin-badge--off {
    background: transparent;
    color: var(--muted);
    border-color: color-mix(in srgb, var(--border) 90%, transparent);
    font-weight: 600;
    text-transform: none;
    letter-spacing: normal;
}

.admin-dashboard-hero {
    position: relative;
    overflow: hidden;
    display: grid;
    grid-template-columns: minmax(180px, 260px) minmax(0, 1fr) auto;
    gap: 1.25rem;
    align-items: center;
    margin-bottom: 1rem;
    padding: clamp(1.1rem, 2vw, 1.5rem);
    border-radius: 22px;
    color: var(--surface-deep);
    background:
        radial-gradient(ellipse 48% 62% at 0% 0%, color-mix(in srgb, var(--accent) 12%, transparent), transparent 55%),
        linear-gradient(135deg, #fff 0%, color-mix(in srgb, var(--surface-alt) 72%, #fff) 100%);
    border: 1px solid color-mix(in srgb, var(--border) 76%, transparent);
    box-shadow: 0 18px 44px color-mix(in srgb, var(--surface-deep) 8%, transparent);
}

.admin-dashboard-hero::after {
    content: "";
    position: absolute;
    inset: auto -10% -44px 42%;
    height: 110px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--brand-blue) 12%, transparent);
    filter: blur(10px);
    pointer-events: none;
}

.admin-dashboard-hero__brand {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 118px;
    padding: 1rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid color-mix(in srgb, var(--border) 78%, transparent);
}

.admin-dashboard-hero__brand img {
    display: block;
    width: min(210px, 100%);
    height: auto;
}

.admin-dashboard-hero__copy,
.admin-dashboard-hero__actions {
    position: relative;
    z-index: 1;
}

.admin-dashboard-hero__eyebrow,
.admin-dashboard-panel__eyebrow {
    margin: 0 0 0.35rem;
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--accent);
}

.admin-dashboard-hero h2 {
    margin: 0;
    font-family: "Libre Baskerville", Georgia, serif;
    font-size: clamp(1.45rem, 3vw, 2rem);
    line-height: 1.16;
}

.admin-dashboard-hero p:last-child {
    max-width: 58ch;
    margin: 0.65rem 0 0;
    color: var(--muted);
    line-height: 1.6;
}

.admin-dashboard-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    justify-content: flex-end;
}

.admin-dashboard-stats,
.admin-dashboard-quick-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.85rem;
}

.admin-dashboard-stats {
    margin-bottom: 1rem;
}

.admin-dashboard-stat,
.admin-dashboard-panel,
.admin-dashboard-quick-card,
.admin-dashboard-shortcut {
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid color-mix(in srgb, var(--border) 78%, transparent);
    box-shadow: 0 10px 28px color-mix(in srgb, var(--surface-deep) 5%, transparent);
}

.admin-dashboard-stat {
    position: relative;
    overflow: hidden;
    padding: 1rem;
    border-radius: 18px;
}

.admin-dashboard-stat::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 4px;
    background: linear-gradient(180deg, var(--accent), var(--brand-blue));
}

.admin-dashboard-stat__label {
    display: block;
    margin-bottom: 0.35rem;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--muted);
}

.admin-dashboard-stat strong {
    display: block;
    margin: 0;
    font-size: clamp(1.55rem, 3vw, 2rem);
    line-height: 1.05;
    color: var(--surface-deep);
}

.admin-dashboard-stat a,
.admin-dashboard-panel__head > a {
    display: inline-block;
    margin-top: 0.65rem;
    font-size: 0.78rem;
    font-weight: 800;
    color: var(--brand-blue-dark);
    text-decoration: none;
}

.admin-dashboard-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(320px, 0.65fr);
    gap: 1rem;
    align-items: start;
    margin-bottom: 1rem;
}

.admin-dashboard-panel {
    padding: 1.15rem;
    border-radius: 20px;
}

.admin-dashboard-panel--wide {
    min-width: 0;
}

.admin-dashboard-panel__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.admin-dashboard-panel__head h2 {
    margin: 0;
    font-size: 1.08rem;
    line-height: 1.25;
    color: var(--surface-deep);
}

.admin-dashboard-quick-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.admin-dashboard-quick-card {
    display: flex;
    flex-direction: column;
    min-height: 132px;
    padding: 1rem;
    border-radius: 16px;
    color: inherit;
    text-decoration: none;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.admin-dashboard-quick-card:hover,
.admin-dashboard-shortcut:hover {
    transform: translateY(-3px);
    border-color: color-mix(in srgb, var(--accent) 30%, var(--border));
    box-shadow: 0 16px 34px color-mix(in srgb, var(--accent) 9%, transparent);
}

.admin-dashboard-quick-card__title {
    font-weight: 800;
    color: var(--surface-deep);
}

.admin-dashboard-quick-card__desc {
    margin-top: 0.35rem;
    font-size: 0.82rem;
    line-height: 1.45;
    color: var(--muted);
}

.admin-dashboard-quick-card__arrow {
    margin-top: auto;
    padding-top: 0.85rem;
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--accent);
}

.admin-dashboard-shortcuts {
    display: grid;
    gap: 0.62rem;
}

.admin-dashboard-shortcut {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.85rem;
    padding: 0.85rem;
    border-radius: 14px;
    color: inherit;
    text-decoration: none;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.admin-dashboard-shortcut strong,
.admin-dashboard-shortcut small {
    display: block;
}

.admin-dashboard-shortcut strong {
    color: var(--surface-deep);
    line-height: 1.3;
}

.admin-dashboard-shortcut small {
    margin-top: 0.18rem;
    color: var(--muted);
    line-height: 1.35;
}

.admin-dashboard-shortcut em {
    flex-shrink: 0;
    min-width: 2.15rem;
    padding: 0.28rem 0.48rem;
    border-radius: 999px;
    font-style: normal;
    font-size: 0.76rem;
    font-weight: 800;
    text-align: center;
    color: var(--accent-dark);
    background: color-mix(in srgb, var(--accent-soft) 42%, var(--surface));
}

.admin-dashboard-columns {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    align-items: start;
}

.admin-dashboard-table-panel {
    overflow-x: auto;
}

.admin-dashboard-table-panel .admin-table {
    min-width: 520px;
}

@media (max-width: 640px) {
    .admin-dashboard-stats,
    .admin-dashboard-quick-grid {
        grid-template-columns: 1fr;
    }

    .admin-dashboard-panel__head {
        flex-direction: column;
        gap: 0.35rem;
    }
}

.login-body {
    display: grid;
    place-items: center;
    min-height: 100vh;
    background: linear-gradient(135deg, var(--surface-alt), #e0f2fe);
}

.login-card {
    width: min(420px, calc(100% - 32px));
}

@media (max-width: 960px) {
    .act-google-map {
        min-height: 320px;
        height: 48vh;
    }

    .act-google-map.act-google-map--fullwidth {
        min-height: 300px;
        height: 52vh;
    }

    .pakistan-simplemap {
        min-height: 280px;
    }

    .pakistan-map-shell {
        aspect-ratio: 2365 / 1890;
    }

    .hero__grid,
    .contact-grid,
    .footer-grid,
    .results-grid,
    .admin-shell,
    .form-grid {
        grid-template-columns: 1fr;
    }

    .admin-content {
        padding: 1rem;
    }

    .admin-sidebar {
        position: fixed;
        top: 0;
        left: 0;
        bottom: 0;
        width: min(82vw, 290px);
        z-index: 90;
        transform: translateX(-102%);
        transition: transform 0.25s ease;
        overflow-y: auto;
        box-shadow: 0 24px 54px color-mix(in srgb, #020617 28%, transparent);
    }

    .admin-sidebar.is-open {
        transform: translateX(0);
    }

    .admin-topbar {
        margin-bottom: 0.85rem;
        padding: 0.72rem 0.8rem;
    }

    .admin-topbar__user {
        font-size: 0.78rem;
        padding: 0.28rem 0.5rem;
    }

    .admin-nav-toggle {
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }

    .admin-panel {
        padding: 0.95rem;
        border-radius: 16px;
    }

    .admin-form label {
        margin: 0.55rem 0 0.3rem;
    }

    .admin-actions--quick {
        gap: 0.45rem;
    }

    .admin-dashboard-hero,
    .admin-dashboard-grid,
    .admin-dashboard-columns {
        grid-template-columns: 1fr;
    }

    .admin-dashboard-hero {
        gap: 0.9rem;
    }

    .admin-dashboard-hero__brand {
        justify-content: flex-start;
        min-height: auto;
    }

    .admin-dashboard-hero__brand img {
        width: min(180px, 100%);
    }

    .admin-dashboard-hero__actions {
        justify-content: flex-start;
    }

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

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

    .mobile-nav-toggle {
        display: inline-flex;
    }

    .utility-bar {
        justify-content: flex-end;
        min-height: auto;
        padding-top: 0.65rem;
        padding-bottom: 0.35rem;
    }

    .utility-bar__label,
    .utility-nav {
        display: none;
    }

    .utility-bar__end {
        width: 100%;
        justify-content: center;
        gap: 0.65rem;
    }

    .main-header {
        grid-template-columns: 1fr auto;
        gap: 1rem;
        align-items: center;
        padding: 0.75rem 0 0.95rem;
    }

    .main-nav-wrap {
        display: none;
        grid-column: 1 / -1;
    }

    .main-nav-wrap.is-open {
        display: block;
    }

    .main-nav {
        align-items: stretch;
        padding: 1rem;
        border: 1px solid color-mix(in srgb, var(--logo-blue-deep) 12%, transparent);
        border-radius: 18px;
        background: #fff;
        justify-content: flex-start;
    }

    .main-nav__links {
        flex-direction: column;
        align-items: flex-start;
    }

    .site-brand {
        width: 100%;
        min-height: 0;
    }

    .site-brand__logo {
        max-height: 58px;
    }

    .header-actions .header-donate-btn {
        padding: 0.65rem 1rem;
        font-size: 0.8rem;
        font-weight: 700;
    }

    .nav-item__submenu-btn {
        display: inline-flex;
    }

    .nav-item__caret {
        display: none;
    }

    .nav-item.has-children .nav-item__top {
        width: 100%;
    }

    .nav-item.has-children .nav-item__link {
        flex: 1;
        min-width: 0;
        white-space: normal;
        align-items: flex-start;
    }

    .nav-item.has-children:hover .dropdown,
    .nav-item.has-children:focus-within .dropdown {
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        transform: none;
    }

    .dropdown {
        position: static;
        transform: none;
        max-height: 0;
        margin: 0;
        padding: 0;
        opacity: 0;
        visibility: hidden;
        overflow: hidden;
        pointer-events: none;
        left: auto;
        min-width: 0;
        max-width: none;
        width: 100%;
        border: 0;
        border-radius: 0;
        background: transparent;
        box-shadow: none;
        transition:
            max-height 0.4s var(--nav-ease),
            opacity 0.28s ease,
            margin 0.28s ease,
            visibility 0.28s;
    }

    .dropdown::before {
        display: none;
    }

    .nav-item.has-children.is-submenu-open .dropdown {
        max-height: 100rem;
        margin-top: 0.35rem;
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
    }

    .dropdown__inner {
        padding: 0.55rem 0.65rem;
        gap: 0.2rem;
        background: rgba(255, 255, 255, 0.92);
        border-radius: 14px;
        box-shadow:
            inset 0 0 0 1px color-mix(in srgb, var(--logo-blue-deep) 10%, transparent),
            0 10px 28px rgba(44, 58, 71, 0.08);
    }

    .dropdown__inner::before {
        left: 0.5rem;
        right: 0.5rem;
        top: 0.2rem;
    }

    .dropdown__link {
        font-size: 0.92rem;
        padding: 0.72rem 0.85rem;
    }

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

/* Final presentation refresh */
.main-header {
    backdrop-filter: blur(14px);
    grid-template-columns: auto minmax(0, 1fr) auto;
    column-gap: clamp(2.4rem, 4.8vw, 4.8rem);
    row-gap: 0.5rem;
    align-items: center;
}

.site-brand__logo {
    max-height: 40px !important;
}

.main-nav-wrap {
    justify-self: start;
    min-width: 0;
    max-width: 100%;
}

.hero {
    padding: 3.25rem 0 2.5rem;
}

.hero__grid {
    align-items: center;
    gap: 2rem;
}

.hero__content p:not(.eyebrow) {
    max-width: 640px;
    font-size: 1.08rem;
    color: var(--muted);
}

.hero__media {
    position: relative;
}

.hero__media::before {
    content: "";
    position: absolute;
    inset: auto auto -18px -18px;
    width: 140px;
    height: 140px;
    background: linear-gradient(135deg, color-mix(in srgb, var(--logo-blue-deep) 22%, transparent), color-mix(in srgb, var(--accent) 14%, transparent));
    border-radius: 28px;
    z-index: 0;
}

.hero__media img {
    position: relative;
    z-index: 1;
    min-height: 420px;
}

.hero-trust,
.value-grid {
    display: grid;
    gap: 1rem;
}

.hero-trust {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: 1.35rem;
}

.hero-trust__item,
.value-card {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    background: rgba(255, 255, 255, 0.95);
    border: 1px solid color-mix(in srgb, var(--logo-blue-deep) 22%, transparent);
    border-radius: 22px;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.08);
}

.hero-trust__item {
    padding: 1rem 1.1rem;
}

.hero-trust__item strong,
.value-card h3 {
    display: block;
    margin: 0 0 0.3rem;
    color: var(--surface-deep);
}

.hero-trust__item span:last-child {
    color: var(--muted);
    font-size: 0.92rem;
}

.hero-trust__icon,
.value-card__icon,
.feature-card__icon,
.cta-card__icon,
.stat-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: 14px;
    flex-shrink: 0;
    font-weight: 800;
    color: #fff;
    background: linear-gradient(135deg, var(--accent), var(--brand-blue));
    box-shadow: 0 12px 24px color-mix(in srgb, var(--logo-red) 22%, transparent);
}

.hero-trust__icon svg,
.value-card__icon svg,
.feature-card__icon svg,
.cta-card__icon svg,
.stat-card__icon svg {
    width: 20px;
    height: 20px;
    stroke: currentColor;
    fill: none;
    stroke-width: 1.9;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.section--compact {
    padding-top: 0;
}

.value-card {
    padding: 1.35rem;
}

.value-card p {
    margin: 0;
    color: var(--muted);
}

.feature-card,
.news-card,
.country-card,
.cta-card {
    overflow: hidden;
}

.feature-card__body,
.news-card__body,
.country-card__body {
    padding: 1.35rem;
}

.feature-card__icon,
.cta-card__icon {
    margin-bottom: 1rem;
}

.stat-card {
    position: relative;
    padding-top: 3.5rem;
}

.stat-card__icon {
    position: absolute;
    top: 1.2rem;
    left: 1.2rem;
}

.cta-card a,
.news-card h3 a,
.country-card h3 a {
    color: var(--brand-blue-dark);
}

.cta-card a {
    font-weight: 700;
}

.site-footer {
    --footer-fg: rgba(248, 250, 252, 0.88);
    --footer-fg-muted: rgba(226, 232, 240, 0.72);
    --footer-fg-soft: rgba(148, 163, 184, 0.85);
    margin-top: clamp(1.5rem, 4vw, 2.75rem);
    position: relative;
    overflow: hidden;
    color: var(--footer-fg);
    background:
        radial-gradient(ellipse 80% 55% at 100% 0%, color-mix(in srgb, var(--accent) 18%, transparent), transparent 52%),
        radial-gradient(ellipse 55% 40% at 0% 100%, color-mix(in srgb, var(--logo-blue-ice) 12%, transparent), transparent 50%),
        linear-gradient(165deg, #030712 0%, #0f172a 42%, #020617 100%);
    padding: 0 0 clamp(1.25rem, 3vw, 1.85rem);
    border-top: 1px solid color-mix(in srgb, var(--accent) 35%, transparent);
}

.site-footer::after {
    content: "";
    position: absolute;
    inset: auto -20% -40% auto;
    width: min(520px, 90vw);
    height: min(520px, 70vw);
    background: radial-gradient(circle, color-mix(in srgb, var(--accent) 14%, transparent), transparent 68%);
    pointer-events: none;
    z-index: 0;
}

.site-footer__glow {
    height: 3px;
    width: 100%;
    background: linear-gradient(
        90deg,
        transparent 0%,
        color-mix(in srgb, var(--logo-blue-on-dark) 85%, transparent) 22%,
        color-mix(in srgb, var(--accent) 90%, transparent) 50%,
        color-mix(in srgb, var(--logo-blue-ice) 70%, transparent) 78%,
        transparent 100%
    );
    opacity: 0.95;
}

.site-footer__inner {
    position: relative;
    z-index: 1;
    padding-top: clamp(1.35rem, 3.2vw, 2rem);
}

.footer-grid {
    display: grid;
    gap: clamp(1.25rem, 3vw, 2rem) clamp(1.5rem, 4vw, 2.75rem);
    grid-template-columns: minmax(260px, 1.45fr) minmax(140px, 0.95fr) minmax(180px, 1.1fr);
    align-items: start;
    position: relative;
    z-index: 1;
    padding: 0;
}

.footer-brand {
    padding-right: clamp(0rem, 2vw, 0.75rem);
}

.site-brand--footer {
    display: inline-block;
    margin-bottom: 0.35rem;
}

.site-brand__logo-frame {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.55rem 1rem 0.5rem;
    border-radius: 14px;
    background: #f8fafc;
    border: 1px solid rgba(255, 255, 255, 0.55);
    box-shadow:
        0 1px 0 rgba(255, 255, 255, 0.65) inset,
        0 12px 32px rgba(0, 0, 0, 0.28);
}

.site-brand__logo--footer {
    display: block;
    max-height: 52px !important;
    width: auto;
    object-fit: contain;
    filter: none;
}

.site-brand__mark--footer {
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.35);
}

.footer-brand__tagline {
    color: var(--footer-fg-muted);
    font-size: clamp(0.9rem, 1.5vw, 0.98rem);
    line-height: 1.55;
    margin: 0.35rem 0 0;
    max-width: min(100%, 36rem);
    text-align: start;
}

.footer-contact-list {
    margin: 0;
    padding: 0;
}

.site-footer .footer-contact-compact {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    margin: 0;
    padding: 0;
    line-height: 1.15;
}

.site-footer .footer-contact-compact > .footer-contact-line {
    margin: 0;
    padding: 0;
    color: var(--footer-fg-muted);
    font-size: 0.8rem;
    line-height: 1.2;
}

.site-footer .footer-contact-compact > .footer-contact-line + .footer-contact-line {
    margin-top: 0.12rem;
}

.site-footer .footer-contact-compact .footer-contact-line strong,
.site-footer .footer-contact-compact .footer-contact-line a {
    line-height: inherit;
}

.footer-contact-line {
    margin: 0;
    padding: 0;
    color: var(--footer-fg-muted);
    font-size: 0.8rem;
    line-height: 1.2;
}

.footer-contact-line strong {
    color: rgba(255, 255, 255, 0.92);
    font-weight: 700;
    margin-right: 0.3rem;
}

.footer-contact-line__sep {
    color: var(--footer-fg-soft);
    font-weight: 400;
}

.footer-contact-line a {
    color: #fff;
    font-weight: 600;
    text-decoration: none;
    text-underline-offset: 2px;
}

.footer-contact-line a:hover {
    color: #fff;
    text-decoration: underline;
}

.footer-column {
    padding-top: 0.15rem;
    min-height: 100%;
    border-left: 1px solid rgba(255, 255, 255, 0.08);
    padding-left: clamp(0.85rem, 2.5vw, 1.35rem);
}

.footer-column--links {
    border-left: 0;
    padding-left: 0;
}

.footer-brand + .footer-column--links {
    border-left: 1px solid rgba(255, 255, 255, 0.08);
    padding-left: clamp(0.85rem, 2.5vw, 1.35rem);
}

.footer-social-wrap {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.footer-social-label {
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--footer-fg-soft);
    margin: 0 0 0.45rem;
    line-height: 1.2;
}

.footer-title {
    margin: 0 0 0.65rem;
    padding-bottom: 0.45rem;
    color: #fff;
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    border-bottom: 2px solid color-mix(in srgb, var(--accent) 55%, transparent);
    display: inline-block;
    min-width: 5rem;
}

.site-footer .footer-column > .footer-title {
    margin-bottom: 0.55rem;
}

.footer-links {
    display: flex;
    flex-direction: column;
    gap: 0.28rem;
}

.footer-link {
    display: block;
    font-size: 0.875rem;
    line-height: 1.35;
    text-decoration: none;
    color: var(--footer-fg-muted);
    padding: 0.12rem 0;
    border-radius: 6px;
    margin-left: -0.15rem;
    padding-left: 0.15rem;
    transition: color 0.18s ease, background 0.18s ease;
}

.footer-column--links .footer-title {
    margin-bottom: 0.5rem;
}

.footer-link:hover {
    color: #fff;
    background: rgba(255, 255, 255, 0.06);
    text-decoration: none;
}

.social-links {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    align-items: center;
}

.social-links li {
    margin: 0;
    padding: 0;
}

.social-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.4rem;
    height: 2.4rem;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.1);
    color: var(--surface);
    border: 1px solid rgba(255, 255, 255, 0.2);
    transition:
        background 0.2s ease,
        color 0.2s ease,
        transform 0.2s ease,
        border-color 0.2s ease;
}

.social-link:hover {
    background: rgba(255, 255, 255, 0.2);
    border-color: rgba(255, 255, 255, 0.35);
    transform: translateY(-2px);
    color: var(--surface);
}

.site-footer .social-link__icon {
    display: flex;
    align-items: center;
    justify-content: center;
}

.site-footer .social-link {
    width: 2.1rem;
    height: 2.1rem;
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.18);
}

.site-footer .social-link svg {
    width: 0.95rem;
    height: 0.95rem;
}

.site-footer .social-links {
    gap: 0.5rem;
}

.footer-bottom {
    margin-top: clamp(1.25rem, 3vw, 1.75rem);
    padding-top: 1rem;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem 1rem;
    flex-wrap: wrap;
    font-size: 0.8125rem;
}

.footer-bottom__copy {
    color: var(--footer-fg-soft);
}

.footer-bottom__link {
    color: #fff;
    font-weight: 600;
    text-decoration: none;
    padding: 0.35rem 0.85rem;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--accent) 45%, rgba(255, 255, 255, 0.25));
    background: color-mix(in srgb, var(--accent) 22%, transparent);
    transition: background 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.footer-bottom__link:hover {
    color: #fff;
    background: color-mix(in srgb, var(--accent) 38%, transparent);
    border-color: color-mix(in srgb, var(--accent) 65%, rgba(255, 255, 255, 0.35));
    transform: translateY(-1px);
}

.contact-page__details {
    margin: 1.25rem 0 0;
}

.contact-page__details p {
    margin: 0.55rem 0;
    color: var(--muted);
}

.contact-page__details a {
    color: var(--brand-blue-dark);
    font-weight: 600;
}

.contact-page__details a:hover {
    color: var(--accent);
}

.contact-points__phones .contact-points__phone-sep {
    color: var(--muted);
    font-weight: 400;
}

.contact-page__social {
    margin-top: 1.5rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--border);
}

.contact-page__social-label {
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--muted);
    margin: 0 0 0.75rem;
}

.contact-page__social .social-link {
    background: color-mix(in srgb, var(--logo-blue-deep) 8%, transparent);
    color: var(--brand-blue-dark);
    border-color: color-mix(in srgb, var(--logo-blue-deep) 22%, transparent);
}

.contact-page__social .social-link:hover {
    background: color-mix(in srgb, var(--logo-blue-deep) 15%, transparent);
    color: var(--surface-dark);
    border-color: color-mix(in srgb, var(--logo-blue-deep) 35%, transparent);
}

.page-hero--contact {
    position: relative;
    overflow: hidden;
    padding: clamp(2.5rem, 5vw, 3.75rem) 0;
    background: linear-gradient(
        135deg,
        color-mix(in srgb, var(--surface-deep) 92%, var(--brand-blue) 8%) 0%,
        var(--surface-dark) 55%,
        color-mix(in srgb, var(--surface-deep) 90%, var(--accent) 10%) 100%
    );
    color: #eef7fb;
}

.page-hero--contact .eyebrow {
    color: color-mix(in srgb, var(--accent) 70%, #fff 30%);
}

.page-hero--contact h1 {
    color: #fff;
    font-family: "Libre Baskerville", serif;
    font-size: clamp(1.85rem, 4vw, 2.75rem);
    line-height: 1.15;
    margin: 0 0 0.85rem;
}

.page-hero--contact__mesh {
    position: absolute;
    inset: 0;
    opacity: 0.4;
    background:
        radial-gradient(ellipse 65% 55% at 15% 25%, var(--logo-blue-glow), transparent 55%),
        radial-gradient(ellipse 50% 45% at 92% 75%, var(--logo-red-glow), transparent 48%);
    pointer-events: none;
}

.page-hero--contact__inner {
    position: relative;
    z-index: 1;
}

.page-hero--contact__lead {
    margin: 0;
    max-width: 42ch;
    font-size: 1.05rem;
    line-height: 1.55;
    color: color-mix(in srgb, #eef7fb 90%, var(--accent-soft) 10%);
}

.contact-page-main {
    padding-top: clamp(2rem, 4vw, 2.75rem);
}

.contact-page-layout {
    display: grid;
    gap: clamp(1.75rem, 3vw, 2.5rem);
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
    align-items: start;
}

.contact-inquiries-card {
    padding: 1.35rem 1.5rem;
    border-radius: 18px;
    background: var(--surface);
    border: 1px solid var(--border);
    box-shadow: 0 14px 36px rgba(44, 58, 71, 0.08);
}

.contact-inquiries-card h2 {
    margin: 0 0 1rem;
    font-size: 1.05rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--brand-blue-dark);
}

.contact-inquiries-card__address {
    margin: 0 0 1.15rem;
    font-size: 1.02rem;
    font-style: normal;
    line-height: 1.55;
    color: var(--text);
}

.contact-inquiries-card__lines {
    margin: 0;
}

.contact-inquiries-card__row {
    display: grid;
    grid-template-columns: 5.5rem 1fr;
    gap: 0.35rem 1rem;
    margin: 0 0 0.65rem;
    font-size: 0.95rem;
}

.contact-inquiries-card__row:last-child {
    margin-bottom: 0;
}

.contact-inquiries-card__row dt {
    margin: 0;
    font-weight: 700;
    color: var(--muted);
}

.contact-inquiries-card__row dd {
    margin: 0;
}

.contact-inquiries-card__row a {
    color: var(--brand-blue-dark);
    font-weight: 600;
    text-decoration: none;
}

.contact-inquiries-card__row a:hover {
    color: var(--accent);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.contact-page__intro {
    margin: 1.25rem 0 0;
    line-height: 1.6;
    color: var(--muted);
}

.contact-form-card__title {
    margin: 0 0 1rem;
    font-family: "Libre Baskerville", serif;
    font-size: 1.35rem;
    color: var(--text);
}

.contact-form .contact-form__submit {
    margin-top: 0.35rem;
    width: 100%;
}

.contact-map-section {
    padding-top: clamp(1.5rem, 3vw, 2.25rem);
    padding-bottom: clamp(2.25rem, 4vw, 3rem);
    background: linear-gradient(180deg, var(--surface) 0%, var(--surface-alt) 100%);
    border-top: 1px solid var(--border);
}

.contact-map-section__head {
    margin-bottom: 1rem;
}

.contact-map-section__head h2 {
    margin: 0 0 0.35rem;
    font-family: "Libre Baskerville", serif;
    font-size: clamp(1.35rem, 2.5vw, 1.75rem);
    color: var(--text);
}

.contact-map-section__address {
    margin: 0;
    font-size: 0.95rem;
    color: var(--muted);
}

.contact-map__frame {
    position: relative;
    width: 100%;
    border-radius: 20px;
    overflow: hidden;
    border: 1px solid var(--border);
    box-shadow: 0 18px 44px rgba(44, 58, 71, 0.1);
    aspect-ratio: 16 / 10;
    max-height: min(420px, 55vh);
    background: var(--border);
}

.contact-map__frame iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

.contact-map-section__footnote {
    margin: 0.85rem 0 0;
    font-size: 0.88rem;
}

.contact-map-section__footnote a {
    color: var(--brand-blue-dark);
    font-weight: 600;
}

.contact-map-section__footnote a:hover {
    color: var(--accent);
}

@media (max-width: 960px) {
    .contact-page-layout {
        grid-template-columns: 1fr;
    }

    .main-header {
        grid-template-columns: 1fr auto;
        gap: 1rem;
    }

    .hero-trust,
    .value-grid,
    .footer-grid {
        grid-template-columns: 1fr;
    }

    .site-brand__logo {
        max-height: 62px;
    }

    .hero__media img {
        min-height: 0;
    }

    .utility-bar {
        border-bottom: 0;
    }

    .hero--home {
        padding-bottom: 0;
    }

    .hero--home__layout {
        grid-template-columns: 1fr;
        gap: 2.5rem;
    }

    .hero--home__ribbon-inner {
        grid-template-columns: 1fr;
        text-align: center;
        gap: 1.25rem;
    }

    .hero--home__stat:not(:last-child) {
        border-right: 0;
        border-bottom: 1px solid rgba(255, 255, 255, 0.12);
        padding-bottom: 1rem;
        margin-bottom: 0.25rem;
    }

    .hero--home__badge {
        position: relative;
        bottom: auto;
        right: auto;
        margin-top: 1rem;
        align-self: center;
    }
}

/* —— Home page hero —— */
.hero.hero--home {
    position: relative;
    padding: 0 0 0;
    margin-bottom: 0;
    overflow: hidden;
}

.hero--home__bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(ellipse 90% 70% at 15% 20%, color-mix(in srgb, var(--theme-hero-base) 22%, transparent), transparent 55%),
        radial-gradient(ellipse 70% 55% at 85% 10%, color-mix(in srgb, var(--theme-button-bg) 13%, transparent), transparent 50%),
        radial-gradient(ellipse 60% 50% at 70% 85%, color-mix(in srgb, var(--theme-hero-base) 14%, transparent), transparent 45%),
        linear-gradient(165deg, #f8fbff 0%, var(--theme-hero-soft) 42%, #f2f7ff 100%);
}

.hero--home__orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(60px);
    opacity: 0.55;
}

.hero--home__orb--1 {
    width: min(420px, 55vw);
    height: min(420px, 55vw);
    top: -12%;
    left: -8%;
    background: color-mix(in srgb, var(--accent) 40%, transparent);
}

.hero--home__orb--2 {
    width: min(320px, 42vw);
    height: min(320px, 42vw);
    top: 20%;
    right: -5%;
    background: color-mix(in srgb, var(--logo-red) 22%, transparent);
}

.hero--home__orb--3 {
    width: min(280px, 40vw);
    height: min(280px, 40vw);
    bottom: 5%;
    left: 35%;
    background: rgba(179, 0, 43, 0.22);
}

.hero--home__grid {
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(color-mix(in srgb, var(--accent) 7%, transparent) 1px, transparent 1px),
        linear-gradient(90deg, color-mix(in srgb, var(--accent) 5%, transparent) 1px, transparent 1px);
    background-size: 48px 48px;
    mask-image: radial-gradient(ellipse 75% 65% at 50% 40%, #000 20%, transparent 75%);
    opacity: 0.85;
}

.hero--home__layout {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
    gap: clamp(1.5rem, 3vw, 2.75rem);
    align-items: center;
    padding: clamp(2.25rem, 5vw, 3.75rem) 0 clamp(1.75rem, 4vw, 2.65rem);
}

.hero--home__eyebrow {
    margin-bottom: 0.65rem;
    text-transform: none;
    letter-spacing: 0.02em;
    font-size: clamp(0.95rem, 1.2vw, 1.05rem);
    font-weight: 600;
    line-height: 1.45;
    max-width: 36rem;
    color: var(--brand-blue-dark);
}

.hero--home__title {
    font-family: "Libre Baskerville", serif;
    font-size: clamp(1.65rem, 3.2vw, 2.3rem);
    line-height: 1.08;
    margin: 0 0 0.85rem;
    color: var(--surface-deep);
    letter-spacing: -0.02em;
    max-width: none;
}

.hero--home__title-line {
    display: block;
    white-space: nowrap;
}

.hero--home__lead {
    font-size: clamp(1.05rem, 1.35vw, 1.2rem);
    line-height: 1.6;
    color: var(--muted);
    margin: 0 0 1.1rem;
    max-width: 38rem;
}

.hero--home__lead:empty {
    display: none;
}

.hero--home__actions {
    margin-top: 0;
}

.hero--home__actions .btn {
    flex: 0 0 auto;
    align-self: center;
    min-height: 3.15rem;
    padding-top: 0.82rem;
    padding-bottom: 0.82rem;
    padding-left: 1.35rem;
    padding-right: 1.35rem;
    line-height: 1.2;
}

.hero--home__cta-primary {
    box-shadow:
        0 16px 40px color-mix(in srgb, var(--surface-deep) 26%, transparent),
        0 16px 40px color-mix(in srgb, var(--logo-red) 20%, transparent);
}

.hero--home__cta-secondary {
    background: rgba(255, 255, 255, 0.75);
    border-color: color-mix(in srgb, var(--logo-blue-deep) 32%, transparent);
    backdrop-filter: blur(8px);
}

.hero--home__trust {
    margin-top: 1.5rem;
}

.hero--home__visual {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: stretch;
}

.hero--home__frame {
    position: relative;
    border-radius: clamp(20px, 3vw, 32px);
    overflow: hidden;
    box-shadow:
        0 28px 60px rgba(37, 43, 50, 0.18),
        0 0 0 1px rgba(255, 255, 255, 0.65) inset;
}

.hero--home__frame-accent {
    position: absolute;
    inset: -40% -20% auto 40%;
    height: 85%;
    background: linear-gradient(145deg, color-mix(in srgb, var(--logo-blue-deep) 16%, transparent), color-mix(in srgb, var(--accent) 10%, transparent));
    border-radius: 40% 60% 55% 45%;
    z-index: 0;
    pointer-events: none;
}

.hero--home__frame img {
    position: relative;
    z-index: 1;
    width: 100%;
    display: block;
    min-height: clamp(280px, 42vw, 440px);
    object-fit: cover;
    border-radius: inherit;
}

.hero--home__badge {
    position: absolute;
    bottom: 1.25rem;
    right: 1.25rem;
    z-index: 2;
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    padding: 1rem 1.25rem;
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid color-mix(in srgb, var(--logo-red) 18%, transparent);
    border-radius: 16px;
    box-shadow: 0 16px 40px rgba(15, 23, 42, 0.1);
    backdrop-filter: blur(12px);
}

.hero--home__badge-line {
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--brand-blue);
}

.hero--home__badge-strong {
    font-family: "Libre Baskerville", serif;
    font-size: 1.15rem;
    color: var(--surface-deep);
    font-weight: 700;
}

.hero--home__ribbon {
    position: relative;
    z-index: 2;
    background: linear-gradient(95deg, var(--surface-deep) 0%, #0c4a6e 42%, var(--brand-blue-dark) 100%);
    color: #fff;
    padding: 1rem 0;
    box-shadow: 0 -1px 0 rgba(255, 255, 255, 0.08) inset;
}

.hero--home__ribbon::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.06), transparent);
    pointer-events: none;
}

.hero--home__ribbon-inner {
    position: relative;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.25rem;
    align-items: center;
}

.hero--home__stat {
    text-align: center;
    padding: 0 0.75rem;
    border-right: 1px solid rgba(255, 255, 255, 0.15);
}

.hero--home__stat:last-child {
    border-right: 0;
}

.hero--home__stat-value {
    display: block;
    font-family: "Libre Baskerville", serif;
    font-size: clamp(1.15rem, 2vw, 1.45rem);
    font-weight: 700;
    margin-bottom: 0.35rem;
    color: #fff;
}

.hero--home__stat-label {
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.78);
    line-height: 1.45;
}

/* —— Home: scrolling updates bar + modal —— */
.home-updates {
    position: relative;
    z-index: 3;
    margin-top: -1px;
}

.home-updates__bar {
    background: linear-gradient(90deg, var(--surface-dark) 0%, #134e4a 48%, var(--brand-blue-dark) 100%);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 12px 40px rgba(15, 23, 42, 0.15);
}

.home-updates__bar-inner {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 1rem 1.35rem;
    align-items: stretch;
    padding: 0.65rem 0;
}

.home-updates__label {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.35rem 0;
    flex-shrink: 0;
}

.home-updates__label-icon {
    display: inline-flex;
    color: var(--logo-blue-on-dark);
    filter: drop-shadow(0 0 10px rgba(94, 234, 212, 0.35));
}

.home-updates__label-text {
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.92);
    white-space: nowrap;
}

.home-updates__viewport {
    position: relative;
    min-height: 2.85rem;
    max-height: 2.85rem;
    overflow: hidden;
    mask-image: linear-gradient(180deg, transparent 0%, #000 12%, #000 88%, transparent 100%);
}

.home-updates__track {
    display: flex;
    flex-direction: column;
    animation: home-updates-scroll-up 22s linear infinite;
}

.home-updates__viewport:hover .home-updates__track {
    animation-play-state: paused;
}

@keyframes home-updates-scroll-up {
    from {
        transform: translateY(0);
    }
    to {
        transform: translateY(-50%);
    }
}

.home-updates__list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.home-updates__item {
    margin: 0;
    padding: 0.2rem 0;
}

.home-updates__trigger {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    width: 100%;
    margin: 0;
    padding: 0.35rem 0.5rem 0.35rem 0.35rem;
    border: none;
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.95);
    font: inherit;
    font-size: 0.9rem;
    font-weight: 600;
    text-align: left;
    cursor: pointer;
    transition:
        background 0.2s ease,
        transform 0.2s ease,
        box-shadow 0.2s ease;
}

.home-updates__trigger:hover,
.home-updates__trigger:focus-visible {
    background: rgba(255, 255, 255, 0.14);
    outline: none;
    box-shadow: 0 0 0 2px rgba(94, 234, 212, 0.45);
}

.home-updates__trigger:focus-visible {
    transform: translateX(2px);
}

.home-updates__dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    flex-shrink: 0;
    background: linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 62%, white));
    box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.2);
}

.home-updates__trigger-text {
    flex: 1;
    min-width: 0;
    line-height: 1.35;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
}

.home-updates__chev {
    flex-shrink: 0;
    color: rgba(255, 255, 255, 0.55);
    transition: color 0.2s ease, transform 0.2s ease;
}

.home-updates__trigger:hover .home-updates__chev,
.home-updates__trigger:focus-visible .home-updates__chev {
    color: var(--logo-blue-on-dark);
    transform: translateX(2px);
}

.home-update-modal {
    position: fixed;
    inset: 0;
    z-index: 2000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.25rem;
    box-sizing: border-box;
}

.home-update-modal[hidden] {
    display: none !important;
}

.home-update-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.55);
    backdrop-filter: blur(6px);
}

.home-update-modal__panel {
    position: relative;
    z-index: 1;
    width: min(520px, 100%);
    max-height: min(90vh, 640px);
    overflow: auto;
    padding: 1.5rem 1.5rem 1.35rem;
    border-radius: 20px;
    background: var(--surface);
    box-shadow: var(--shadow), 0 0 0 1px color-mix(in srgb, var(--logo-red) 12%, transparent);
}

.home-update-modal__close {
    position: absolute;
    top: 0.85rem;
    right: 0.85rem;
    width: 2.35rem;
    height: 2.35rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: none;
    border-radius: 10px;
    background: var(--surface-alt);
    color: var(--text);
    cursor: pointer;
    transition: background 0.2s ease, color 0.2s ease;
}

.home-update-modal__close:hover,
.home-update-modal__close:focus-visible {
    background: var(--accent-soft);
    color: var(--accent-dark);
    outline: none;
}

.home-update-modal__media {
    margin: 0 0 1rem;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: var(--shadow);
}

.home-update-modal__media[hidden] {
    display: none !important;
}

.home-update-modal__media img {
    width: 100%;
    height: auto;
    max-height: 220px;
    object-fit: cover;
    display: block;
}

.home-update-modal__meta {
    margin: 0 0 0.35rem;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--brand-blue-dark);
}

.home-update-modal__title {
    font-family: "Libre Baskerville", serif;
    font-size: clamp(1.25rem, 2.5vw, 1.55rem);
    line-height: 1.25;
    margin: 0 0 0.75rem;
    color: var(--surface-deep);
    padding-right: 2.5rem;
}

.home-update-modal__excerpt {
    margin: 0 0 1.25rem;
    font-size: 0.98rem;
    line-height: 1.6;
    color: var(--muted);
    white-space: pre-line;
}

.home-update-modal__cta {
    width: 100%;
    text-align: center;
}

@media (max-width: 720px) {
    .home-updates__bar-inner {
        grid-template-columns: 1fr;
        gap: 0.35rem;
    }

    .home-updates__label {
        padding-bottom: 0;
    }

    .home-updates__viewport {
        min-height: 3.1rem;
        max-height: 3.1rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .home-updates__track {
        animation: none;
    }

    .home-updates__list--clone {
        display: none !important;
    }

    .home-updates__viewport {
        max-height: 6.5rem;
        overflow-y: auto;
        mask-image: none;
        scrollbar-width: thin;
    }
}

/* —— Home: mini updates in hero —— */
.hero--home__frame .home-updates-mini-wrap {
    position: relative;
    z-index: 1;
    height: 100%;
}

.home-updates-mini-wrap--mobile {
    display: none;
}

.hero--home__frame .home-updates-mini {
    min-height: auto;
}

.home-updates-mini {
    height: 100%;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding: 1.05rem 1.05rem 1.0rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid color-mix(in srgb, var(--logo-red) 18%, transparent);
    box-shadow:
        0 26px 70px rgba(15, 23, 42, 0.12),
        0 0 0 1px rgba(255, 255, 255, 0.5) inset;
    backdrop-filter: blur(10px);
}

.home-updates-mini__header {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    flex-shrink: 0;
}

.home-updates-mini__icon {
    display: inline-flex;
    color: var(--logo-blue-on-dark);
    filter: drop-shadow(0 0 10px color-mix(in srgb, var(--logo-red) 28%, transparent));
}

.home-updates-mini__text {
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--surface-deep);
}

.home-updates-mini__feature {
    display: grid;
    grid-template-columns: 86px minmax(0, 1fr);
    gap: 0.95rem;
    align-items: stretch;
    padding: 0.18rem 0 0.12rem;
}

.home-updates-mini__feature-media {
    width: 86px;
    height: 86px;
    border-radius: 16px;
    overflow: hidden;
    background: color-mix(in srgb, var(--surface-alt) 82%, #ffffff 18%);
    box-shadow: 0 10px 26px color-mix(in srgb, var(--surface-deep) 8%, transparent);
}

.home-updates-mini__feature-media img {
    width: 100%;
    height: 100%;
    min-height: 0;
    object-fit: cover;
}

.home-updates-mini__feature-copy {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0.35rem;
    min-width: 0;
}

.home-updates-mini__feature-label {
    margin: 0;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--accent-dark);
}

.home-updates-mini__feature-title {
    margin: 0;
    font-family: "Libre Baskerville", serif;
    font-size: 0.92rem;
    line-height: 1.3;
    color: var(--surface-deep);
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
}

.home-updates-mini__feature-excerpt {
    margin: 0;
    font-size: 0.82rem;
    line-height: 1.45;
    color: var(--muted);
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
}

.home-updates-mini .home-updates__trigger {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.6rem;
}

.home-updates-mini .home-updates__thumb {
    width: 34px;
    height: 34px;
    border-radius: 8px;
    overflow: hidden;
    background: color-mix(in srgb, var(--surface-alt) 88%, #ffffff 12%);
    border: 1px solid color-mix(in srgb, var(--accent) 14%, transparent);
    flex: 0 0 auto;
}

.home-updates-mini .home-updates__thumb img {
    width: 100%;
    height: 100%;
    min-height: 0;
    object-fit: cover;
    display: block;
}

.home-updates-mini .home-updates__thumb-fallback {
    display: block;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, color-mix(in srgb, var(--theme-hero-base) 18%, transparent), color-mix(in srgb, var(--theme-button-bg) 22%, transparent));
}

.home-updates-mini .home-updates__dot {
    display: none;
}

.home-updates__viewport--mini {
    min-height: 0;
    max-height: clamp(10.5rem, 22vw, 13rem);
}

/* Overrides for mini widget (the base ticker styles were built for dark bars) */
.home-updates-mini .home-updates__trigger {
    background: color-mix(in srgb, var(--surface-deep) 4%, transparent);
    color: var(--surface-deep);
}

.home-updates-mini .home-updates__trigger:hover,
.home-updates-mini .home-updates__trigger:focus-visible {
    background: color-mix(in srgb, var(--logo-blue-deep) 14%, transparent);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 26%, transparent);
}

.home-updates-mini .home-updates__chev {
    color: color-mix(in srgb, var(--surface-deep) 45%, transparent);
}

.home-updates-mini .home-updates__trigger:hover .home-updates__chev,
.home-updates-mini .home-updates__trigger:focus-visible .home-updates__chev {
    color: var(--brand-blue-dark);
}

.home-updates-mini .home-updates__dot {
    box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.72);
}

@media (max-width: 960px) {
    .hero--home__frame .home-updates-mini {
        min-height: auto;
    }

    .home-updates-mini__feature {
        grid-template-columns: 1fr;
    }

    .home-updates-mini__feature-media {
        width: 78px;
        height: 78px;
    }

    .home-updates__viewport--mini {
        min-height: 0;
        max-height: clamp(8.5rem, 34vw, 10.5rem);
    }
}

.main-nav__links .nav-item.has-children:last-child .dropdown {
    left: auto;
    right: 0;
    transform-origin: top right;
    transform: translateY(6px) scale(0.98);
}

.main-nav__links .nav-item.has-children:last-child:hover .dropdown,
.main-nav__links .nav-item.has-children:last-child:focus-within .dropdown,
.main-nav__links .nav-item.has-children:last-child.is-touch-open .dropdown {
    transform: translateY(0) scale(1);
}

/* ---------- About Us ---------- */

.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.page-hero--about {
    padding: clamp(2.5rem, 5vw, 4rem) 0;
    background: linear-gradient(180deg, #f4f8fc 0%, var(--surface) 100%);
}

.page-hero--about-has-bg {
    position: relative;
    isolation: isolate;
    overflow: hidden;
    background: #fff1f4;
}

.page-hero--about-has-bg::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    background: var(--about-hero-image) center / cover no-repeat;
    opacity: 0.42;
    transform: scale(1.03);
}

.page-hero--about-has-bg::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    background: linear-gradient(
        100deg,
        rgba(255, 255, 255, 0.94) 0%,
        rgba(255, 255, 255, 0.88) 38%,
        rgba(248, 251, 255, 0.72) 72%,
        rgba(244, 248, 252, 0.6) 100%
    );
}

.page-hero--about .about-hero__copy {
    position: relative;
    z-index: 1;
    max-width: min(52rem, 100%);
}

.page-hero--about__lead {
    max-width: 58ch;
    font-size: 1.12rem;
    line-height: 1.55;
    color: var(--muted);
    margin: 0 0 1.25rem;
}

.page-hero--about-has-bg .page-hero--about__lead {
    color: var(--muted);
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.65);
}

.page-hero--about-has-bg h1 {
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.85);
}

.about-hero__copy {
    min-width: 0;
}

.about-intro__split {
    display: grid;
    gap: 1.75rem;
    align-items: start;
    grid-template-columns: 1fr;
}

@media (min-width: 768px) {
    .about-intro__split {
        grid-template-columns: minmax(240px, 0.42fr) minmax(0, 1fr);
        gap: 2.25rem;
        align-items: center;
    }
}

.about-intro__figure {
    margin: 0;
}

.about-intro__frame {
    border-radius: 22px;
    overflow: hidden;
    box-shadow: var(--shadow);
    border: 1px solid color-mix(in srgb, var(--accent) 16%, transparent);
}

.about-intro__frame img {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 5 / 3;
    object-fit: cover;
}

.about-intro__caption {
    margin: 0.65rem 0 0;
    font-size: 0.88rem;
    line-height: 1.5;
    color: var(--muted);
    font-style: italic;
    padding-right: 0.25rem;
}

.about-intro__prose {
    min-width: 0;
}

.about-vm__photo {
    margin: -1.55rem -1.6rem 1.15rem -1.6rem;
    border-radius: 24px 24px 0 0;
    overflow: hidden;
    aspect-ratio: 16 / 10;
    max-height: clamp(180px, 28vw, 240px);
    background: color-mix(in srgb, var(--accent) 8%, transparent);
}

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

.section--about-focus {
    position: relative;
}

.section--about-focus-has-bg {
    isolation: isolate;
    overflow: hidden;
    padding-top: clamp(2.35rem, 4.5vw, 3.15rem);
    padding-bottom: clamp(2.35rem, 4.5vw, 3.15rem);
    background: #fff1f4;
}

.section--about-focus-has-bg::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    background: var(--about-focus-image) center / cover no-repeat;
    opacity: 0.38;
    transform: scale(1.04);
}

.section--about-focus-has-bg::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    background: linear-gradient(
        180deg,
        rgba(255, 255, 255, 0.93) 0%,
        rgba(252, 253, 255, 0.88) 45%,
        rgba(245, 249, 253, 0.82) 100%
    );
}

.about-focus__inner {
    position: relative;
    z-index: 1;
}

.about-focus__content {
    min-width: 0;
    max-width: min(48rem, 100%);
}

.section--about-focus-has-bg .about-section-title,
.section--about-focus-has-bg .about-focus__lead {
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.75);
}

.section--about-focus-has-bg .about-focus__lead {
    color: var(--text);
}

.section--about-focus-has-bg .about-pill-list li {
    background: rgba(255, 255, 255, 0.78);
    border-color: color-mix(in srgb, var(--accent) 22%, transparent);
    backdrop-filter: blur(6px);
}

.section--about-focus-has-bg .about-check-list li {
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.5);
}

.about-partners__figure {
    margin: 0 0 1.75rem;
}

.about-partners__frame {
    border-radius: 20px;
    overflow: hidden;
    box-shadow: var(--shadow);
    border: 1px solid var(--border);
}

.about-partners__frame img {
    display: block;
    width: 100%;
    height: auto;
    max-height: 340px;
    object-fit: cover;
}

.about-partners__caption {
    margin: 0.55rem 0 0;
    font-size: 0.9rem;
    color: var(--muted);
    line-height: 1.5;
    text-align: center;
    max-width: 58ch;
    margin-left: auto;
    margin-right: auto;
}

.about-partners__prose .about-section-title {
    margin-top: 0;
}

.about-prose p {
    margin: 0 0 1.1rem;
    font-size: 1.06rem;
    line-height: 1.65;
    color: var(--text);
}

.about-prose p:last-child {
    margin-bottom: 0;
}

.about-section-title {
    font-family: "Libre Baskerville", serif;
    font-size: clamp(1.45rem, 3vw, 2rem);
    margin: 0 0 1rem;
    color: var(--surface-deep);
}

.section--about-vm {
    padding-top: clamp(2.5rem, 5vw, 3.25rem);
    padding-bottom: clamp(2.5rem, 5vw, 3.25rem);
    background:
        radial-gradient(120% 80% at 10% 0%, color-mix(in srgb, var(--accent) 10%, transparent) 0%, transparent 55%),
        radial-gradient(90% 70% at 95% 100%, color-mix(in srgb, var(--accent-dark) 6%, transparent) 0%, transparent 50%),
        var(--surface-alt);
}

.about-vm-section__eyebrow {
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--accent);
    margin: 0 0 0.45rem;
    text-align: center;
}

.about-vm-section__title {
    font-family: "Libre Baskerville", serif;
    font-size: clamp(1.5rem, 3.2vw, 2.05rem);
    text-align: center;
    margin: 0 auto 2rem;
    max-width: 20ch;
    color: var(--surface-deep);
    letter-spacing: -0.02em;
}

.about-vm {
    display: grid;
    gap: 1.35rem;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 300px), 1fr));
    align-items: stretch;
}

.about-vm__card {
    position: relative;
    margin: 0;
    border-radius: clamp(22px, 2.5vw, 28px);
    padding: 1px;
    background: linear-gradient(
        145deg,
        color-mix(in srgb, var(--accent) 30%, transparent) 0%,
        rgba(255, 255, 255, 0.65) 38%,
        rgba(255, 255, 255, 0.4) 100%
    );
    box-shadow:
        0 24px 56px rgba(37, 43, 50, 0.1),
        0 8px 20px rgba(37, 43, 50, 0.06),
        0 0 0 1px rgba(255, 255, 255, 0.6) inset;
    transition:
        transform 0.3s ease,
        box-shadow 0.3s ease;
}

.about-vm__card--mission {
    background: linear-gradient(
        145deg,
        color-mix(in srgb, var(--accent) 30%, transparent) 0%,
        rgba(255, 255, 255, 0.7) 42%,
        rgba(255, 255, 255, 0.45) 100%
    );
}

.about-vm__card:hover {
    transform: translateY(-6px);
    box-shadow:
        0 32px 64px rgba(37, 43, 50, 0.14),
        0 12px 28px rgba(37, 43, 50, 0.08),
        0 0 0 1px rgba(255, 255, 255, 0.75) inset;
}

.about-vm__card-inner {
    position: relative;
    height: 100%;
    border-radius: inherit;
    padding: 1.55rem 1.6rem 1.65rem;
    overflow: hidden;
    background: linear-gradient(165deg, #ffffff 0%, #fbfdff 48%, #f5f9fd 100%);
}

.about-vm__card--mission .about-vm__card-inner {
    background: linear-gradient(165deg, #ffffff 0%, #fffbfb 48%, #fff8f8 100%);
}

.about-vm__card-inner::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 4px;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--accent), var(--accent-dark));
    opacity: 0.95;
}

.about-vm__card--mission .about-vm__card-inner::before {
    background: linear-gradient(90deg, var(--accent), var(--accent-dark));
}

.about-vm__card-inner::after {
    content: "";
    position: absolute;
    width: 160px;
    height: 160px;
    top: -50px;
    right: -40px;
    border-radius: 50%;
    background: radial-gradient(circle, color-mix(in srgb, var(--accent) 10%, transparent) 0%, transparent 68%);
    pointer-events: none;
}

.about-vm__card--mission .about-vm__card-inner::after {
    background: radial-gradient(circle, color-mix(in srgb, var(--accent) 9%, transparent) 0%, transparent 68%);
    right: auto;
    left: -35px;
}

.about-vm__head {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1.2rem;
    padding-bottom: 1.15rem;
    border-bottom: 1px solid color-mix(in srgb, var(--accent) 14%, transparent);
}

.about-vm__card--mission .about-vm__head {
    border-bottom-color: color-mix(in srgb, var(--accent) 14%, transparent);
}

.about-vm__icon-wrap {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 58px;
    height: 58px;
    border-radius: 18px;
    flex-shrink: 0;
    color: #fff;
    background: linear-gradient(145deg, var(--accent) 0%, var(--accent-dark) 100%);
    box-shadow:
        0 14px 28px color-mix(in srgb, var(--accent) 25%, transparent),
        0 2px 6px rgba(0, 40, 80, 0.12) inset;
}

.about-vm__card--mission .about-vm__icon-wrap {
    background: linear-gradient(145deg, var(--accent) 0%, var(--accent-dark) 100%);
    box-shadow:
        0 14px 28px color-mix(in srgb, var(--accent) 24%, transparent),
        0 2px 6px rgba(90, 10, 18, 0.15) inset;
}

.about-vm__icon-wrap svg {
    width: 24px;
    height: 24px;
    stroke: currentColor;
    fill: none;
    stroke-width: 1.85;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.about-vm__head-text {
    min-width: 0;
    padding-top: 0.15rem;
}

.about-vm__kicker {
    display: block;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--accent) 55%, transparent);
    margin-bottom: 0.28rem;
}

.about-vm__card--mission .about-vm__kicker {
    color: color-mix(in srgb, var(--accent) 62%, transparent);
}

.about-vm__title {
    margin: 0;
    font-family: "Libre Baskerville", serif;
    font-size: clamp(1.35rem, 2.5vw, 1.65rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--surface-deep);
    line-height: 1.15;
}

.about-vm__statement {
    position: relative;
    z-index: 1;
    margin: 0;
    padding-left: 0.85rem;
    border-left: 3px solid color-mix(in srgb, var(--accent) 25%, transparent);
    font-family: "Libre Baskerville", serif;
    font-size: clamp(1.02rem, 2vw, 1.16rem);
    line-height: 1.6;
    color: var(--text);
}

.about-vm__card--mission .about-vm__statement {
    border-left-color: color-mix(in srgb, var(--accent) 30%, transparent);
}

@media (prefers-reduced-motion: reduce) {
    .about-vm__card:hover {
        transform: none;
    }
}

.about-focus__lead {
    margin: 0 0 0.65rem;
    font-weight: 600;
    color: var(--surface-deep);
}

.about-focus__lead--spaced {
    margin-top: 1.75rem;
}

.about-pill-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 0.6rem;
}

.about-pill-list li {
    padding: 0.4rem 0.9rem;
    border-radius: 999px;
    font-size: 0.92rem;
    font-weight: 600;
    color: var(--accent-dark);
    background: color-mix(in srgb, var(--accent) 8%, transparent);
    border: 1px solid color-mix(in srgb, var(--accent) 14%, transparent);
}

.about-check-list {
    margin: 0;
    padding-left: 1.2rem;
    max-width: 52ch;
}

.about-check-list li {
    margin-bottom: 0.45rem;
    line-height: 1.55;
    padding-left: 0.15rem;
}

.about-check-list li::marker {
    color: var(--accent);
    font-weight: 700;
}

.section--about-stats {
    background: linear-gradient(165deg, var(--surface-deep) 0%, #4c0f1e 45%, var(--accent-dark) 100%);
    color: #fff;
    padding-top: clamp(2.5rem, 5vw, 3.25rem);
    padding-bottom: clamp(2.5rem, 5vw, 3.25rem);
}

.about-stats__intro {
    text-align: center;
    max-width: 640px;
    margin: 0 auto 2rem;
}

.about-stats__intro .eyebrow--on-dark {
    color: rgba(255, 255, 255, 0.75);
}

.about-stats__intro h2 {
    font-family: "Libre Baskerville", serif;
    font-size: clamp(1.6rem, 3.5vw, 2.35rem);
    margin: 0.35rem 0 0.75rem;
    color: #fff;
}

.about-stats__intro p {
    margin: 0;
    font-size: 1.02rem;
    line-height: 1.55;
    color: rgba(255, 255, 255, 0.82);
}

.about-stat-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.about-stat-card {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 1rem 1.1rem;
    align-items: center;
    margin: 0;
    padding: 1.05rem 1.2rem;
    min-height: 100%;
    background: #fff;
    border: 1px solid rgba(15, 40, 70, 0.12);
    border-radius: 16px;
    box-shadow:
        0 4px 14px rgba(0, 0, 0, 0.08),
        0 0 0 1px rgba(255, 255, 255, 0.5) inset;
}

.about-stat-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    border-radius: 14px;
    color: var(--surface-deep);
    background: color-mix(in srgb, var(--accent) 8%, transparent);
    border: 1px solid color-mix(in srgb, var(--accent) 14%, transparent);
    flex-shrink: 0;
}

.about-stat-card__icon svg {
    width: 24px;
    height: 24px;
    stroke: currentColor;
    fill: none;
    stroke-width: 1.85;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.about-stat-card__body {
    min-width: 0;
}

.about-stat-card__headline {
    display: block;
    font-family: "Libre Baskerville", serif;
    font-size: clamp(1.35rem, 2.4vw, 1.65rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--surface-deep);
    line-height: 1.15;
    margin-bottom: 0.35rem;
}

.about-stat-card__body p {
    margin: 0;
    font-size: 0.92rem;
    line-height: 1.45;
    color: var(--muted);
}

.section--about-partners .about-section-title {
    margin-bottom: 1.15rem;
}

/* --- Our Partners page --- */
.partners-hero {
    background: linear-gradient(180deg, #f4f8fc 0%, var(--surface) 42%);
}

.partners-hero__banner {
    position: relative;
    overflow: hidden;
    color: #fff;
}

.partners-hero__banner-bg {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(125deg, var(--logo-blue-deep) 0%, var(--logo-blue) 48%, color-mix(in srgb, var(--logo-blue) 82%, var(--accent) 18%) 100%);
}

.partners-hero__banner-bg::before {
    content: "";
    position: absolute;
    inset: 0;
    opacity: 0.35;
    background:
        radial-gradient(ellipse 50% 55% at 92% 18%, var(--logo-red-glow), transparent 62%),
        radial-gradient(ellipse 42% 48% at 8% 88%, var(--logo-blue-glow), transparent 58%);
}

.partners-hero__banner-bg::after {
    content: "";
    position: absolute;
    inset: 0;
    opacity: 0.08;
    background-image:
        linear-gradient(rgba(255, 255, 255, 0.5) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.5) 1px, transparent 1px);
    background-size: 48px 48px;
    mask-image: linear-gradient(180deg, #000 0%, transparent 85%);
}

.partners-hero__banner-inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(14rem, 0.65fr);
    align-items: end;
    gap: clamp(1.5rem, 4vw, 2.75rem);
    padding: clamp(2.75rem, 6vw, 4.25rem) 0 clamp(3.5rem, 7vw, 5rem);
}

.partners-hero__copy {
    max-width: 40rem;
}

.partners-hero__eyebrow {
    margin: 0 0 0.75rem;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: color-mix(in srgb, #fff 68%, var(--logo-blue-on-dark) 32%);
}

.partners-hero__banner h1 {
    margin: 0 0 0.85rem;
    font-family: "Libre Baskerville", serif;
    font-size: clamp(2.1rem, 4.5vw, 3.25rem);
    line-height: 1.1;
    color: #fff;
    text-wrap: balance;
}

.partners-hero__lead {
    margin: 0 0 0.85rem;
    font-size: clamp(1.02rem, 1.6vw, 1.15rem);
    line-height: 1.55;
    font-weight: 600;
    color: color-mix(in srgb, #fff 94%, var(--logo-blue-on-dark) 6%);
    max-width: 46ch;
}

.partners-hero__summary {
    margin: 0 0 1.5rem;
    font-size: 1rem;
    line-height: 1.65;
    color: color-mix(in srgb, #fff 82%, var(--logo-blue-on-dark) 18%);
    max-width: 52ch;
}

.partners-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem 1rem;
}

.partners-hero__btn-ghost.btn--ghost {
    color: #fff;
    border-color: rgba(255, 255, 255, 0.42);
    background: rgba(255, 255, 255, 0.08);
}

.partners-hero__btn-ghost.btn--ghost:hover {
    color: var(--logo-blue-deep);
    background: #fff;
    border-color: #fff;
}

.partners-hero__highlights {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    align-self: stretch;
    justify-content: flex-end;
}

.partners-hero__highlight-card {
    padding: 1.15rem 1.25rem;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.18);
    backdrop-filter: blur(10px);
}

.partners-hero__highlight-value {
    display: block;
    font-size: clamp(2rem, 4vw, 2.65rem);
    font-weight: 800;
    line-height: 1;
    letter-spacing: -0.02em;
    color: #fff;
}

.partners-hero__highlight-label {
    display: block;
    margin-top: 0.35rem;
    font-size: 0.82rem;
    font-weight: 600;
    color: color-mix(in srgb, #fff 78%, var(--logo-blue-on-dark) 22%);
}

.partners-hero__highlight-list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}

.partners-hero__highlight-list li span {
    display: block;
    padding: 0.5rem 0.85rem;
    border-radius: 10px;
    font-size: 0.8rem;
    font-weight: 600;
    color: #fff;
    background: rgba(255, 255, 255, 0.08);
    border-left: 3px solid var(--accent);
}

.partners-hero__showcase-outer {
    position: relative;
    z-index: 2;
    margin-top: clamp(-2.75rem, -5vw, -2rem);
    padding-bottom: clamp(1.5rem, 3vw, 2.25rem);
}

.partners-hero__showcase {
    padding: clamp(1.35rem, 3vw, 2rem);
    border-radius: 20px;
    background: #fff;
    border: 1px solid var(--border);
    box-shadow:
        0 24px 48px color-mix(in srgb, var(--surface-deep) 10%, transparent),
        0 0 0 1px rgba(255, 255, 255, 0.8) inset;
}

.partners-hero__showcase-head {
    margin-bottom: clamp(1.15rem, 2.5vw, 1.5rem);
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border);
}

.partners-hero__showcase-kicker {
    margin: 0 0 0.35rem;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--accent);
}

.partners-hero__showcase-title {
    margin: 0;
    font-family: "Libre Baskerville", serif;
    font-size: clamp(1.25rem, 2.2vw, 1.5rem);
    color: var(--heading, var(--text));
}

.partners-hero__group {
    display: grid;
    grid-template-columns: minmax(7.5rem, 10.5rem) minmax(0, 1fr);
    gap: clamp(0.85rem, 2vw, 1.25rem);
    align-items: center;
    padding: clamp(0.85rem, 2vw, 1.1rem) 0;
    border-bottom: 1px solid color-mix(in srgb, var(--border) 80%, transparent);
}

.partners-hero__group:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.partners-hero__group:first-of-type {
    padding-top: 0;
}

.partners-hero__group-label {
    padding-right: 0.5rem;
}

.partners-hero__group-title {
    display: block;
    font-size: 0.78rem;
    font-weight: 700;
    line-height: 1.35;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--logo-blue-deep);
}

.partners-hero__group-logos {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.65rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.partners-hero__tile {
    flex: 0 1 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 6.5rem;
    min-height: 3.75rem;
    padding: 0.55rem 0.85rem;
    border-radius: 12px;
    background: #f8fafc;
    border: 1px solid color-mix(in srgb, var(--border) 90%, transparent);
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.partners-hero__tile:hover {
    border-color: color-mix(in srgb, var(--logo-blue) 30%, var(--border));
    box-shadow: 0 8px 20px color-mix(in srgb, var(--surface-deep) 8%, transparent);
    transform: translateY(-1px);
}

.partners-hero__tile--ni {
    background: linear-gradient(
        145deg,
        color-mix(in srgb, var(--brand-blue-dark) 96%, #fff 4%) 0%,
        color-mix(in srgb, var(--brand-blue) 94%, #fff 6%) 100%
    );
    border-color: color-mix(in srgb, var(--brand-blue) 35%, var(--border));
}

.partners-hero__tile-logo {
    display: block;
    width: auto;
    max-width: 7.5rem;
    max-height: 2.5rem;
    height: auto;
    object-fit: contain;
}

@media (max-width: 900px) {
    .partners-hero__banner-inner {
        grid-template-columns: 1fr;
        align-items: start;
    }

    .partners-hero__highlights {
        flex-direction: row;
        flex-wrap: wrap;
        align-items: stretch;
    }

    .partners-hero__highlight-card {
        flex: 1 1 10rem;
    }

    .partners-hero__highlight-list {
        flex: 1 1 12rem;
        flex-direction: row;
        flex-wrap: wrap;
    }

    .partners-hero__group {
        grid-template-columns: 1fr;
        gap: 0.65rem;
    }
}

@media (max-width: 560px) {
    .partners-hero__actions {
        flex-direction: column;
    }

    .partners-hero__actions .btn {
        width: 100%;
    }

    .partners-hero__tile {
        min-width: calc(50% - 0.35rem);
        flex: 1 1 calc(50% - 0.35rem);
    }

    .partners-hero__showcase {
        padding: 1rem;
        border-radius: 16px;
    }
}

/* Final Our Partners hero treatment: clean copy with a compact featured-logo panel. */
.partners-hero {
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(ellipse 42% 55% at 92% 12%, color-mix(in srgb, var(--accent) 16%, transparent), transparent 62%),
        linear-gradient(180deg, #f6f9fc 0%, #ffffff 78%);
    border-bottom: 1px solid var(--border);
}

.partners-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    opacity: 0.55;
    background:
        linear-gradient(90deg, color-mix(in srgb, var(--logo-blue-deep) 8%, transparent) 1px, transparent 1px),
        linear-gradient(color-mix(in srgb, var(--logo-blue-deep) 7%, transparent) 1px, transparent 1px);
    background-size: 44px 44px;
    mask-image: linear-gradient(180deg, #000 0%, transparent 78%);
    pointer-events: none;
}

.partners-hero__inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(20rem, 0.95fr);
    align-items: center;
    gap: clamp(2rem, 5vw, 4rem);
    padding: clamp(3rem, 7vw, 5.25rem) 0 clamp(2.75rem, 6vw, 4.5rem);
}

.partners-hero__copy {
    max-width: 42rem;
}

.partners-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin: 0 0 1rem;
    color: var(--accent);
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.partners-hero__eyebrow::before {
    content: "";
    width: 2.5rem;
    height: 2px;
    border-radius: 999px;
    background: currentColor;
}

.partners-hero__copy h1 {
    margin: 0 0 1rem;
    max-width: 10ch;
    color: var(--surface-deep);
    font-family: "Libre Baskerville", serif;
    font-size: clamp(2.6rem, 6vw, 5rem);
    line-height: 0.98;
    letter-spacing: -0.04em;
}

.partners-hero__lead {
    margin: 0 0 0.85rem;
    max-width: 48ch;
    color: color-mix(in srgb, var(--surface-deep) 86%, var(--muted) 14%);
    font-size: clamp(1.05rem, 1.7vw, 1.22rem);
    font-weight: 650;
    line-height: 1.55;
}

.partners-hero__summary {
    margin: 0 0 1.65rem;
    max-width: 56ch;
    color: var(--muted);
    font-size: 1rem;
    line-height: 1.7;
}

.partners-hero__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-start;
    gap: 0.8rem 1rem;
}

.partners-hero__btn-ghost.btn--ghost {
    color: var(--logo-blue-deep);
    border-color: color-mix(in srgb, var(--logo-blue-deep) 24%, var(--border));
    background: #fff;
}

.partners-hero__btn-ghost.btn--ghost:hover {
    color: #fff;
    background: var(--logo-blue-deep);
    border-color: var(--logo-blue-deep);
}

.partners-hero__panel {
    position: relative;
    padding: clamp(1.1rem, 2.5vw, 1.5rem);
    border-radius: 26px;
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(255, 255, 255, 0.86);
    box-shadow:
        0 30px 70px color-mix(in srgb, var(--surface-deep) 13%, transparent),
        0 0 0 1px color-mix(in srgb, var(--logo-blue-deep) 7%, transparent);
}

.partners-hero__panel::before {
    content: "";
    position: absolute;
    inset: -1px;
    z-index: -1;
    border-radius: inherit;
    background: linear-gradient(135deg, color-mix(in srgb, var(--logo-blue) 18%, #fff), color-mix(in srgb, var(--accent) 18%, #fff));
}

.partners-hero__panel-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
    padding-bottom: 0.9rem;
    border-bottom: 1px solid var(--border);
}

.partners-hero__panel-head span {
    color: var(--accent);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.partners-hero__panel-head strong {
    color: var(--logo-blue-deep);
    font-size: 0.82rem;
    font-weight: 800;
}

.partners-hero__featured-logos {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.8rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.partners-hero__featured-logo {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 5rem;
    padding: 0.8rem;
    border-radius: 16px;
    background: #fff;
    border: 1px solid var(--border);
    box-shadow: 0 10px 22px color-mix(in srgb, var(--surface-deep) 5%, transparent);
}

.partners-hero__featured-logo--ni {
    background: linear-gradient(135deg, var(--brand-blue-dark), var(--brand-blue));
    border-color: color-mix(in srgb, var(--brand-blue) 40%, var(--border));
}

.partners-hero__featured-logo img {
    display: block;
    width: auto;
    max-width: 100%;
    max-height: 3rem;
    height: auto;
    object-fit: contain;
}

@media (max-width: 900px) {
    .partners-hero__inner {
        grid-template-columns: 1fr;
    }

    .partners-hero__copy h1 {
        max-width: 12ch;
    }
}

@media (max-width: 560px) {
    .partners-hero__inner {
        padding-top: 2.5rem;
    }

    .partners-hero__copy h1 {
        font-size: clamp(2.35rem, 13vw, 3.5rem);
    }

    .partners-hero__panel-head {
        align-items: flex-start;
        flex-direction: column;
        gap: 0.3rem;
    }

    .partners-hero__featured-logos {
        gap: 0.55rem;
    }

    .partners-hero__featured-logo {
        min-height: 4.35rem;
        padding: 0.65rem;
    }
}

.section--partners-intro {
    padding-top: clamp(1rem, 2vw, 1.5rem);
    padding-bottom: clamp(1.25rem, 3vw, 2rem);
}

.partners-intro__prose p:first-child {
    font-size: 1.12rem;
    font-weight: 500;
    color: var(--text);
}

.section-heading--partners-page {
    text-align: left;
    max-width: none;
    margin-bottom: clamp(1.25rem, 3vw, 1.75rem);
}

.partners-category__title {
    margin: 0 0 0.5rem;
    font-size: clamp(1.35rem, 2.5vw, 1.65rem);
    font-family: var(--font-serif, "Libre Baskerville", Georgia, serif);
    color: var(--heading, var(--text));
}

.partners-category__description {
    margin: 0;
    max-width: 62ch;
    font-size: 1rem;
    line-height: 1.6;
    color: var(--muted);
}

.partners-logo-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 11.5rem), 1fr));
    gap: clamp(0.85rem, 2vw, 1.15rem);
    margin: 0;
    padding: 0;
    list-style: none;
}

.partners-logo-grid__item {
    margin: 0;
}

.partners-logo-grid__card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.65rem;
    min-height: 8.5rem;
    padding: 1.1rem 1rem;
    border-radius: 16px;
    border: 1px solid var(--border);
    background: #fff;
    box-shadow: 0 8px 24px color-mix(in srgb, var(--surface-deep) 6%, transparent);
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.partners-logo-grid__card:hover {
    border-color: color-mix(in srgb, var(--logo-blue) 35%, var(--border));
    box-shadow: 0 12px 28px color-mix(in srgb, var(--surface-deep) 10%, transparent);
    transform: translateY(-2px);
}

.partners-logo-grid__logo {
    display: block;
    width: auto;
    max-width: 100%;
    max-height: 3.25rem;
    height: auto;
    object-fit: contain;
    object-position: center;
}

.partners-logo-grid__item--ni .partners-logo-grid__logo {
    max-height: 2.75rem;
}

.partners-logo-grid__name {
    font-size: 0.78rem;
    line-height: 1.35;
    text-align: center;
    color: var(--muted);
    font-weight: 500;
}

.section--partners-category {
    padding-top: clamp(1.5rem, 3vw, 2.25rem);
    padding-bottom: clamp(1.5rem, 3vw, 2.25rem);
}

.section--partners-alliances .about-section-title {
    margin-top: 0;
}

.partners-page-cta {
    margin: 1.75rem 0 0;
}

@media (max-width: 640px) {
    .partners-logo-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .partners-logo-grid__card {
        min-height: 7.5rem;
        padding: 0.85rem 0.65rem;
    }

    .partners-logo-grid__logo {
        max-height: 2.5rem;
    }
}

/* --- Our Work (programmes) --- */
.page-hero--our-work {
    position: relative;
    overflow: hidden;
    background: linear-gradient(
        145deg,
        color-mix(in srgb, var(--surface-deep) 94%, var(--accent) 6%) 0%,
        var(--surface-dark) 48%,
        color-mix(in srgb, var(--surface-deep) 88%, var(--accent) 12%) 100%
    );
    color: #eef7fb;
    padding: clamp(2.5rem, 5vw, 4rem) 0;
}

.page-hero--our-work .eyebrow {
    color: color-mix(in srgb, var(--accent-soft) 75%, #fff 25%);
}

.page-hero--our-work h1 {
    color: #fff;
}

.page-hero--our-work .page-hero--about__lead {
    color: color-mix(in srgb, #eef7fb 88%, var(--accent-soft) 12%);
    max-width: 52ch;
}

.our-work-hero__mesh {
    position: absolute;
    inset: 0;
    opacity: 0.35;
    background:
        radial-gradient(ellipse 70% 50% at 12% 20%, var(--logo-red-glow), transparent 55%),
        radial-gradient(ellipse 55% 45% at 88% 70%, var(--logo-red-glow), transparent 50%);
    pointer-events: none;
}

.our-work-hero__inner {
    position: relative;
    z-index: 1;
}

.our-work-intro__text {
    margin: 0;
    font-size: clamp(1.02rem, 2vw, 1.12rem);
    line-height: 1.65;
    color: var(--text);
}

.our-work-overview {
    padding-top: 0.5rem;
}

.our-work-filters-wrap {
    padding-top: 0;
    padding-bottom: 0.5rem;
}

.our-work-filters {
    padding: 1.15rem 1.2rem;
    border: 1px solid var(--border);
    border-radius: 18px;
    background: var(--surface);
    box-shadow: 0 12px 28px rgba(44, 58, 71, 0.07);
}

.our-work-filters__controls {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.9rem 1rem;
    align-items: end;
}

.our-work-filter-field label {
    display: block;
    margin: 0 0 0.35rem;
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--accent-dark);
}

.our-work-filter-field select {
    width: 100%;
    min-height: 2.9rem;
    border: 1px solid color-mix(in srgb, var(--border) 85%, transparent);
    border-radius: 12px;
    padding: 0.7rem 0.8rem;
    background: #fff;
    color: var(--text);
}

.our-work-filter-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.our-work-filters__status {
    margin: 0.9rem 0 0;
    color: var(--muted);
    line-height: 1.5;
}

.our-work-stat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 1rem;
}

.our-work-stat {
    padding: 1.1rem 1.15rem;
    border: 1px solid var(--border);
    border-radius: 16px;
    background: var(--surface);
    box-shadow: 0 10px 24px rgba(44, 58, 71, 0.06);
}

.our-work-stat__label {
    margin: 0 0 0.4rem;
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--muted);
}

.our-work-stat__value {
    margin: 0;
    font-size: clamp(1.5rem, 4vw, 2rem);
    font-weight: 800;
    color: var(--accent-dark);
    line-height: 1;
}

.our-work-stat__value--stacked {
    display: grid;
    gap: 0.5rem;
    font-size: 1rem;
    line-height: 1.2;
}

.our-work-stat__currency-total {
    display: grid;
    gap: 0.1rem;
}

.our-work-stat__currency-label {
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--muted);
}

.our-work-stat__currency-amount {
    font-size: clamp(1rem, 2.5vw, 1.25rem);
    font-weight: 800;
    line-height: 1.3;
    color: var(--accent-dark);
    word-break: break-word;
}

.our-work-toc-wrap {
    position: sticky;
    top: var(--header-offset, 0px);
    z-index: 8;
    padding: 0.65rem 0;
    background: color-mix(in srgb, var(--surface) 92%, var(--bg) 8%);
    border-bottom: 1px solid var(--border);
    box-shadow: 0 6px 18px rgba(44, 58, 71, 0.06);
}

.our-work-toc__label {
    margin: 0 0 0.4rem;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--muted);
}

.our-work-toc {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem 0.55rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.our-work-toc a {
    display: inline-block;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--accent-dark);
    background: color-mix(in srgb, var(--accent) 8%, var(--surface) 92%);
    border: 1px solid color-mix(in srgb, var(--accent) 20%, transparent);
    transition:
        background 0.18s ease,
        color 0.18s ease,
        border-color 0.18s ease;
}

.our-work-toc a:hover {
    background: color-mix(in srgb, var(--accent) 16%, var(--surface) 84%);
    border-color: color-mix(in srgb, var(--accent) 35%, transparent);
    color: var(--surface-deep);
}

.our-work-program {
    scroll-margin-top: calc(var(--header-offset, 0px) + 4.5rem);
}

.our-work-program--a {
    background: var(--surface);
}

.our-work-program--b {
    background: linear-gradient(180deg, var(--surface-alt) 0%, var(--surface) 100%);
}

.our-work-program__head {
    margin-bottom: 1.25rem;
    padding-bottom: 0;
}

.our-work-program__head::after {
    content: "";
    display: block;
    height: 3px;
    margin-top: 0.85rem;
    border-radius: 2px;
    background: linear-gradient(90deg, var(--accent-dark), var(--accent));
}

.our-work-program__head h2 {
    margin: 0.35rem 0 0;
    font-family: "Libre Baskerville", serif;
    font-size: clamp(1.35rem, 2.8vw, 1.75rem);
    line-height: 1.25;
    color: var(--text);
}

.our-work-project-list {
    display: grid;
    gap: 1rem;
}

.our-work-project {
    border: 1px solid var(--border);
    border-radius: 18px;
    background: var(--surface);
    box-shadow: 0 12px 28px rgba(44, 58, 71, 0.07);
    overflow: hidden;
}

.our-work-project[open] {
    border-color: color-mix(in srgb, var(--accent) 28%, var(--border));
    box-shadow: 0 16px 36px color-mix(in srgb, var(--accent) 10%, transparent);
}

.our-work-project__summary {
    list-style: none;
    cursor: pointer;
    padding: 1.2rem 1.3rem;
    display: grid;
    grid-template-columns: minmax(150px, 200px) minmax(0, 1fr) minmax(180px, 230px) auto;
    gap: 1rem 1.1rem;
    align-items: center;
}

.our-work-project__summary::-webkit-details-marker {
    display: none;
}

.our-work-project__visual {
    min-height: 150px;
    padding: 1rem;
    border-radius: 16px;
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--accent) 12%, var(--surface) 88%), color-mix(in srgb, var(--surface-deep) 12%, #fff 88%)),
        linear-gradient(180deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0));
    border: 1px solid color-mix(in srgb, var(--accent) 12%, var(--border));
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 0.75rem;
}

.our-work-project__visual img {
    width: 100%;
    max-width: 128px;
    height: 52px;
    object-fit: contain;
    object-position: left center;
}

.our-work-project__visual-initials {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 4rem;
    height: 4rem;
    border-radius: 16px;
    background: color-mix(in srgb, var(--accent) 16%, #fff 84%);
    color: var(--accent-dark);
    font-size: 1.35rem;
    font-weight: 800;
    letter-spacing: 0.08em;
}

.our-work-project__visual-label {
    display: block;
    font-size: 0.82rem;
    line-height: 1.45;
    color: var(--accent-dark);
}

.our-work-project__visual-tag {
    display: inline-flex;
    align-self: flex-start;
    padding: 0.32rem 0.62rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.72);
    color: var(--surface-deep);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.our-work-project__summary-main {
    min-width: 0;
}

.our-work-project__eyebrow {
    margin: 0 0 0.35rem;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--accent-dark);
}

.our-work-project__summary h3 {
    margin: 0;
    font-size: clamp(1.05rem, 2vw, 1.25rem);
    line-height: 1.35;
    color: var(--text);
}

.our-work-project__theme {
    margin: 0.45rem 0 0;
    color: var(--muted);
    line-height: 1.5;
}

.our-work-project__highlights {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.8rem;
}

.our-work-project__highlights span {
    display: inline-flex;
    align-items: center;
    padding: 0.34rem 0.66rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--accent) 8%, var(--surface) 92%);
    border: 1px solid color-mix(in srgb, var(--accent) 14%, transparent);
    color: var(--accent-dark);
    font-size: 0.78rem;
    line-height: 1.4;
}

.our-work-project__summary-side {
    min-width: 0;
}

.our-work-project__summary-meta {
    margin: 0;
    font-size: 0.92rem;
    font-weight: 600;
    line-height: 1.5;
    color: var(--accent-dark);
}

.our-work-project__summary-cta {
    display: inline-block;
    margin-top: 0.7rem;
    color: var(--muted);
    font-size: 0.84rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.our-work-project__toggle {
    width: 2.25rem;
    height: 2.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--accent-dark);
    background: color-mix(in srgb, var(--accent) 10%, var(--surface) 90%);
}

.our-work-project[open] .our-work-project__toggle {
    color: #fff;
    background: var(--accent-dark);
}

.our-work-project[open] .our-work-project__toggle::before {
    content: "-";
}

.our-work-project__toggle::before {
    content: "+";
}

.our-work-project__body {
    padding: 0 1.3rem 1.3rem;
    border-top: 1px solid color-mix(in srgb, var(--border) 80%, transparent);
}

.our-work-project__facts {
    margin: 1rem 0 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 0.85rem;
}

.our-work-project__facts div {
    padding: 0.95rem 1rem;
    border-radius: 14px;
    background: color-mix(in srgb, var(--surface-alt) 76%, var(--surface) 24%);
    border: 1px solid color-mix(in srgb, var(--border) 82%, transparent);
}

.our-work-project__facts dt {
    margin: 0 0 0.35rem;
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--muted);
}

.our-work-project__facts dd {
    margin: 0;
    color: var(--text);
    line-height: 1.55;
    white-space: pre-line;
}

.our-work-project__details {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border);
}

.our-work-project__details h4 {
    margin: 0 0 0.55rem;
    font-size: 0.98rem;
    color: var(--accent-dark);
}

.our-work-project__details p {
    margin: 0;
    line-height: 1.65;
    color: var(--text);
    white-space: pre-line;
}

.our-work-empty {
    padding: 1.25rem 1.3rem;
    border: 1px solid var(--border);
    border-radius: 16px;
    background: var(--surface);
    margin-top: 1rem;
}

@media (max-width: 1080px) {
    .our-work-project__summary {
        grid-template-columns: minmax(140px, 180px) minmax(0, 1fr) auto;
    }

    .our-work-project__summary-side {
        grid-column: 2 / 3;
    }
}

.our-work-prose {
    max-width: min(52rem, 100%);
}

.our-work-prose p {
    margin: 0 0 1rem;
    line-height: 1.65;
    color: var(--text);
}

.our-work-subheading {
    margin: 1.5rem 0 0.65rem;
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--accent-dark);
}

.our-work-list {
    margin: 0 0 1rem;
    padding-left: 1.2rem;
    color: var(--text);
}

.our-work-list li {
    margin-bottom: 0.45rem;
    line-height: 1.5;
}

.our-work-list li::marker {
    color: var(--accent);
}

.our-team-section {
    padding-top: 2rem;
    padding-bottom: 2.75rem;
}

.our-team-intro {
    margin: 0 0 1.75rem;
    max-width: min(48rem, 100%);
    line-height: 1.65;
    color: var(--text);
}

.our-team-heading {
    margin: 0 0 1.25rem;
    font-size: clamp(1.25rem, 2.5vw, 1.5rem);
    font-weight: 800;
    color: var(--accent-dark);
    letter-spacing: -0.02em;
}

.team-grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 1rem 1.25rem;
}

.team-card {
    margin: 0;
    padding: 1.15rem 1.25rem;
    border-radius: 14px;
    border: 1px solid var(--border);
    background: var(--surface);
    box-shadow: 0 10px 28px rgba(44, 58, 71, 0.07);
    transition:
        border-color 0.2s ease,
        box-shadow 0.2s ease,
        transform 0.2s ease;
}

.team-card:hover {
    border-color: color-mix(in srgb, var(--accent) 35%, transparent);
    box-shadow: 0 14px 36px color-mix(in srgb, var(--accent) 12%, transparent);
    transform: translateY(-2px);
}

.team-card__name {
    margin: 0 0 0.35rem;
    font-size: 1.02rem;
    font-weight: 800;
    color: var(--surface-dark);
    line-height: 1.3;
}

.team-card__role {
    margin: 0;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--muted);
    line-height: 1.45;
}

.our-work-figure {
    margin: 0 0 1rem;
    border-radius: 14px;
    overflow: hidden;
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
    background: var(--surface);
}

.our-work-figure a {
    display: block;
    line-height: 0;
}

.our-work-figure img {
    width: 100%;
    height: auto;
    vertical-align: middle;
}

@media (min-width: 720px) {
    .our-work-figure--right {
        float: right;
        width: min(42%, 380px);
        margin: 0 0 1rem 1.25rem;
    }

    .our-work-figure--left {
        float: left;
        width: min(42%, 380px);
        margin: 0 1.25rem 1rem 0;
    }

    .our-work-prose::after {
        content: "";
        display: table;
        clear: both;
    }
}

.our-work-gallery {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 0.65rem;
    margin-top: 1.5rem;
}

.our-work-gallery__item {
    display: block;
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid var(--border);
    box-shadow: 0 8px 20px rgba(44, 58, 71, 0.08);
    transition:
        transform 0.18s ease,
        box-shadow 0.18s ease;
}

.our-work-gallery__item:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 28px color-mix(in srgb, var(--accent) 15%, transparent);
}

.our-work-gallery__item img {
    width: 100%;
    height: 120px;
    object-fit: cover;
    display: block;
}

.our-work-teaser-grid {
    display: grid;
    gap: 1rem;
    margin: 0;
    padding: 0;
    list-style: none;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
}

.our-work-teaser-card {
    margin: 0;
    padding: 1.1rem 1.15rem;
    border-radius: 16px;
    background: color-mix(in srgb, var(--surface-deep) 88%, var(--accent) 12%);
    border: 1px solid color-mix(in srgb, var(--accent) 22%, transparent);
    box-shadow: 0 12px 28px rgba(37, 43, 50, 0.2);
}

.our-work-teaser-card__kicker {
    display: block;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--accent-soft);
    margin-bottom: 0.45rem;
}

.our-work-teaser-card__title {
    margin: 0;
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.35;
}

.our-work-teaser-card__title a {
    color: #fff;
    text-decoration: none;
}

.our-work-teaser-card__title a:hover {
    text-decoration: underline;
    text-underline-offset: 3px;
    color: var(--accent-soft);
}

@media (max-width: 719px) {
    .our-work-toc-wrap {
        position: relative;
        top: auto;
    }

    .our-work-filters__controls {
        grid-template-columns: 1fr;
    }

    .our-work-filter-actions {
        justify-content: flex-start;
    }

    .our-work-project__summary {
        padding: 1rem;
        grid-template-columns: 1fr;
    }

    .our-work-project__body {
        padding: 0 1rem 1rem;
    }

    .our-work-figure--right,
    .our-work-figure--left {
        float: none;
        width: 100%;
        margin: 0 0 1rem;
    }
}

/* --- Publications / downloads page (pub-*) --- */
.pub-hero {
    position: relative;
    overflow: hidden;
    padding: clamp(2.25rem, 5vw, 3.5rem) 0 clamp(2rem, 4vw, 2.75rem);
    background: linear-gradient(
        125deg,
        color-mix(in srgb, var(--surface-deep) 92%, var(--brand-blue) 8%) 0%,
        var(--surface-dark) 48%,
        color-mix(in srgb, var(--surface-deep) 86%, var(--accent) 14%) 100%
    );
    color: #eef7fb;
}

.pub-hero__mesh {
    position: absolute;
    inset: 0;
    opacity: 0.42;
    background:
        radial-gradient(ellipse 55% 48% at 12% 18%, var(--logo-blue-glow), transparent 55%),
        radial-gradient(ellipse 42% 40% at 88% 82%, var(--logo-red-glow), transparent 50%);
    pointer-events: none;
}

.pub-hero__inner {
    position: relative;
    z-index: 1;
    max-width: 42rem;
}

.pub-hero__eyebrow {
    margin: 0 0 0.5rem;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--accent) 70%, #fff 30%);
}

.pub-hero__title {
    margin: 0 0 0.75rem;
    font-family: "Libre Baskerville", serif;
    font-size: clamp(1.85rem, 4vw, 2.55rem);
    line-height: 1.12;
    color: #fff;
}

.pub-hero__lead {
    margin: 0 0 1rem;
    font-size: 1.04rem;
    line-height: 1.55;
    max-width: 48ch;
    color: color-mix(in srgb, #eef7fb 88%, var(--accent-soft) 12%);
}

.pub-hero__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-bottom: 1.1rem;
}

.pub-hero__pill {
    display: inline-block;
    padding: 0.28rem 0.65rem;
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: color-mix(in srgb, #eef7fb 92%, var(--accent) 8%);
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.16);
}

.pub-hero__cta {
    margin-top: 0.15rem;
}

.pub-toolbar-wrap {
    position: sticky;
    top: var(--header-offset, 0px);
    z-index: 8;
    padding: 0.85rem 0;
    background: color-mix(in srgb, var(--surface) 94%, var(--bg) 6%);
    border-bottom: 1px solid var(--border);
    box-shadow: 0 8px 22px rgba(44, 58, 71, 0.06);
}

.pub-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 1rem 1.75rem;
}

.pub-toolbar__intro {
    flex: 1 1 16rem;
    min-width: min(100%, 16rem);
    margin: 0;
    font-size: clamp(0.98rem, 1.8vw, 1.06rem);
    line-height: 1.6;
    color: var(--text);
}

.pub-toc {
    flex: 2 1 18rem;
    min-width: 0;
}

.pub-toc__label {
    display: block;
    margin: 0 0 0.45rem;
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--muted);
}

.pub-toc__list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem 0.5rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.pub-toc__link {
    display: inline-block;
    padding: 0.32rem 0.72rem;
    border-radius: 999px;
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    text-decoration: none;
    color: var(--brand-blue-dark);
    background: color-mix(in srgb, var(--brand-blue) 9%, var(--surface) 91%);
    border: 1px solid color-mix(in srgb, var(--logo-blue-deep) 18%, transparent);
    transition:
        background 0.18s ease,
        border-color 0.18s ease,
        color 0.18s ease;
}

.pub-toc__link:hover {
    background: color-mix(in srgb, var(--brand-blue) 15%, var(--surface) 85%);
    border-color: color-mix(in srgb, var(--logo-blue-deep) 30%, transparent);
    color: var(--surface-deep);
}

.pub-section {
    scroll-margin-top: calc(var(--header-offset, 0px) + 5rem);
    padding: clamp(1.85rem, 3.2vw, 2.5rem) 0;
}

.pub-section--alt {
    background: var(--surface-alt);
}

.pub-section__head {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: space-between;
    gap: 0.75rem 1.25rem;
    margin-bottom: 1.25rem;
    padding-bottom: 0.85rem;
    border-bottom: 1px solid color-mix(in srgb, var(--logo-blue-deep) 12%, transparent);
}

.pub-section__eyebrow {
    margin: 0 0 0.3rem;
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--muted);
}

.pub-section__title {
    margin: 0;
    font-family: "Libre Baskerville", serif;
    font-size: clamp(1.22rem, 2.5vw, 1.48rem);
    line-height: 1.2;
    color: var(--text);
}

.pub-section__count {
    flex-shrink: 0;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--muted);
    padding: 0.35rem 0.65rem;
    border-radius: 8px;
    background: color-mix(in srgb, var(--brand-blue) 7%, var(--surface) 93%);
    border: 1px solid color-mix(in srgb, var(--logo-blue-deep) 10%, transparent);
}

.pub-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 300px), 1fr));
    gap: clamp(0.85rem, 2vw, 1.1rem);
}

.pub-card {
    display: grid;
    grid-template-columns: 6.5rem minmax(0, 1fr);
    gap: 0.85rem 1rem;
    align-items: stretch;
    min-width: 0;
    padding: 0.85rem 0.95rem;
    border-radius: 16px;
    background: linear-gradient(165deg, #fff, color-mix(in srgb, var(--surface) 94%, var(--surface-alt) 6%));
    border: 1px solid color-mix(in srgb, var(--logo-blue-deep) 11%, transparent);
    box-shadow: 0 8px 22px rgba(44, 58, 71, 0.07);
    transition:
        transform 0.18s ease,
        box-shadow 0.18s ease,
        border-color 0.18s ease;
}

.pub-card:hover,
.pub-card:focus-within {
    transform: translateY(-2px);
    border-color: color-mix(in srgb, var(--accent) 24%, transparent);
    box-shadow: 0 14px 32px rgba(44, 58, 71, 0.11);
}

.pub-card__thumb {
    display: block;
    align-self: start;
    width: 6.5rem;
    height: 9.55rem;
    border-radius: 10px;
    overflow: hidden;
    flex-shrink: 0;
    background:
        radial-gradient(circle at 20% 12%, color-mix(in srgb, var(--accent) 12%, transparent), transparent 45%),
        linear-gradient(150deg, color-mix(in srgb, var(--surface-alt) 88%, #fff 12%), #fff);
    text-decoration: none;
}

.pub-card__thumb img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.22s ease;
}

.pub-card:hover .pub-card__thumb img,
.pub-card:focus-within .pub-card__thumb img {
    transform: scale(1.03);
}

.pub-card__thumb-fallback {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    font-size: 1.35rem;
    font-weight: 900;
    letter-spacing: 0.12em;
    color: color-mix(in srgb, var(--brand-blue-dark) 72%, #fff 28%);
}

.pub-card__body {
    display: flex;
    flex-direction: column;
    min-width: 0;
    padding: 0.1rem 0 0;
}

.pub-card__title {
    margin: 0 0 0.4rem;
    font-size: 0.95rem;
    line-height: 1.35;
    font-weight: 700;
    color: var(--text);
}

.pub-card__title-link {
    color: inherit;
    text-decoration: none;
    transition: color 0.15s ease;
}

.pub-card__title-link:hover {
    color: var(--brand-blue-dark);
}

.pub-card__title-link:focus-visible {
    outline: 2px solid var(--brand-blue);
    outline-offset: 3px;
    border-radius: 2px;
}

.pub-card__meta {
    margin: 0 0 auto 0;
    padding-bottom: 0.65rem;
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--muted);
}

.pub-card__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    align-self: flex-start;
    margin-top: auto;
    min-height: 38px;
    padding: 0.38rem 0.85rem;
    border-radius: 10px;
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    text-decoration: none;
    color: #fff;
    background: linear-gradient(135deg, var(--brand-blue), var(--brand-blue-dark));
    border: 1px solid rgba(255, 255, 255, 0.12);
    box-shadow: 0 3px 12px color-mix(in srgb, var(--logo-blue-deep) 22%, transparent);
    transition:
        filter 0.15s ease,
        box-shadow 0.15s ease;
}

.pub-card__btn:hover {
    filter: brightness(1.06);
    color: #fff;
    box-shadow: 0 5px 16px color-mix(in srgb, var(--logo-blue-deep) 28%, transparent);
}

.pub-card__btn:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
}

.pub-card__btn svg {
    flex-shrink: 0;
}

@media (max-width: 719px) {
    .pub-toolbar-wrap {
        position: relative;
        top: auto;
    }

    .pub-toc__list {
        flex-wrap: nowrap;
        overflow-x: auto;
        padding-bottom: 0.25rem;
        margin: 0 -0.25rem;
        padding-left: 0.25rem;
        padding-right: 0.25rem;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: thin;
    }

    .pub-toc__list li {
        flex-shrink: 0;
    }
}

@media (max-width: 380px) {
    .pub-card {
        grid-template-columns: 5.5rem minmax(0, 1fr);
        gap: 0.65rem 0.75rem;
        padding: 0.75rem 0.8rem;
    }

    .pub-card__thumb {
        width: 5.5rem;
        height: 8.1rem;
    }
}

.theme-picker {
    position: fixed;
    right: 1rem;
    bottom: 1rem;
    z-index: 1205;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.75rem;
}

.theme-picker__toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.78rem 1rem;
    border: 0;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--surface-dark), var(--logo-red-deep), var(--accent-dark));
    color: #fff;
    cursor: pointer;
    box-shadow:
        0 18px 36px color-mix(in srgb, var(--surface-deep) 24%, transparent),
        0 10px 24px color-mix(in srgb, var(--logo-red) 16%, transparent);
}

.theme-picker__toggle:hover {
    transform: translateY(-1px);
}

.theme-picker__toggle-icon {
    display: inline-grid;
    grid-template-columns: repeat(3, 0.6rem);
    gap: 0.22rem;
}

.theme-picker__toggle-icon span {
    width: 0.6rem;
    height: 0.6rem;
    border-radius: 999px;
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.28) inset;
}

.theme-picker__toggle-icon span:nth-child(1) {
    background: var(--surface-dark);
}

.theme-picker__toggle-icon span:nth-child(2) {
    background: var(--logo-red-deep);
}

.theme-picker__toggle-icon span:nth-child(3) {
    background: var(--accent);
}

.theme-picker__toggle-text {
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.theme-picker__panel {
    width: min(320px, calc(100vw - 2rem));
    padding: 1rem;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid color-mix(in srgb, var(--logo-blue-deep) 12%, transparent);
    box-shadow: 0 24px 56px color-mix(in srgb, var(--surface-deep) 18%, transparent);
    backdrop-filter: blur(16px);
}

.theme-picker__panel[hidden] {
    display: none;
}

.theme-picker__panel-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.theme-picker__eyebrow {
    margin: 0;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--accent);
}

.theme-picker__hint {
    margin: 0.45rem 0 0.95rem;
    font-size: 0.92rem;
    line-height: 1.5;
    color: var(--muted);
}

.theme-picker__close {
    width: 2rem;
    height: 2rem;
    border: 1px solid color-mix(in srgb, var(--logo-blue-deep) 12%, transparent);
    border-radius: 999px;
    background: #fff;
    color: var(--surface-dark);
    font-size: 1.1rem;
    line-height: 1;
    cursor: pointer;
}

.theme-picker__options {
    display: grid;
    gap: 0.65rem;
}

.theme-picker__option {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    width: 100%;
    padding: 0.72rem 0.8rem;
    border: 1px solid color-mix(in srgb, var(--logo-blue-deep) 10%, transparent);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.85);
    color: var(--text);
    cursor: pointer;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.theme-picker__option:hover,
.theme-picker__option[aria-pressed="true"] {
    border-color: color-mix(in srgb, var(--accent) 24%, transparent);
    box-shadow: 0 12px 26px color-mix(in srgb, var(--surface-deep) 8%, transparent);
    transform: translateY(-1px);
}

.theme-picker__swatches {
    display: inline-grid;
    grid-template-columns: repeat(4, 0.95rem);
    gap: 0.34rem;
    flex-shrink: 0;
}

.theme-picker__swatches span {
    width: 0.95rem;
    height: 0.95rem;
    border-radius: 999px;
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--logo-blue-deep) 8%, transparent) inset;
}

.theme-picker__label {
    font-size: 0.9rem;
    font-weight: 700;
}

.theme-picker__reset {
    width: 100%;
    margin-top: 0.85rem;
    padding: 0.72rem 0.95rem;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--logo-blue-deep) 12%, transparent);
    background: color-mix(in srgb, var(--logo-blue-deep) 4%, transparent);
    color: var(--surface-dark);
    font-weight: 700;
    cursor: pointer;
}

.theme-picker__divider {
    height: 1px;
    margin: 0.95rem 0;
    background: color-mix(in srgb, var(--logo-blue-deep) 12%, transparent);
}

.theme-picker__custom {
    display: grid;
    gap: 0.75rem;
}

.theme-picker__custom-title {
    margin: 0;
    font-size: 0.82rem;
    font-weight: 900;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--accent-dark);
}

.theme-picker__field {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.theme-picker__field label {
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--surface-dark);
}

.theme-picker__field input[type="color"] {
    width: 2.75rem;
    height: 2.2rem;
    padding: 0;
    border: 0;
    border-radius: 12px;
    background: transparent;
    cursor: pointer;
}

.theme-picker__custom-actions {
    margin-top: 0.15rem;
}

.theme-picker__save {
    width: 100%;
    padding: 0.72rem 0.95rem;
    border-radius: 999px;
    border: 0;
    background: linear-gradient(135deg, var(--brand-blue), var(--accent));
    color: #fff;
    font-weight: 800;
    font-size: 0.88rem;
    letter-spacing: 0.04em;
    cursor: pointer;
    transition: transform 0.2s ease, opacity 0.2s ease, background 0.2s ease;
}

.theme-picker__save:hover {
    transform: translateY(-1px);
}

.theme-picker__save--done {
    opacity: 0.95;
    background: var(--surface-dark);
}

.theme-picker__status {
    min-height: 1.25rem;
    margin: 0.15rem 0 0;
    font-size: 0.8rem;
    line-height: 1.4;
    color: var(--muted);
}

.theme-picker__presets {
    margin: 0;
    border: 0;
}

.theme-picker__presets-summary {
    cursor: pointer;
    font-size: 0.88rem;
    font-weight: 700;
    color: var(--muted);
    list-style: none;
}

.theme-picker__presets-summary::-webkit-details-marker {
    display: none;
}

.theme-picker__presets[open] .theme-picker__presets-summary {
    margin-bottom: 0.5rem;
    color: var(--text);
}

.theme-picker__presets .theme-picker__options {
    margin-top: 0.35rem;
}

@media (max-width: 640px) {
    .theme-picker {
        right: 0.75rem;
        bottom: 0.75rem;
    }

    .theme-picker__toggle-text {
        display: none;
    }

    .theme-picker__toggle {
        padding: 0.82rem;
    }
}

/* ---- Sitewide responsive hardening pass ---- */
html,
body {
    overflow-x: clip;
}

@media (max-width: 960px) {
    body.act-primary-nav-open {
        overflow: hidden;
        overscroll-behavior: none;
    }
}

iframe,
table {
    max-width: 100%;
}

video {
    max-width: 100%;
    height: auto;
}

.rich-text pre {
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.container,
.container.narrow,
.container--prose-wide {
    width: min(100%, calc(100% - 2rem));
}

@media (max-width: 1100px) {
    .container,
    .container.narrow,
    .container--prose-wide {
        width: min(100%, calc(100% - 1.6rem));
    }
}

@media (max-width: 960px) {
    .container,
    .container.narrow,
    .container--prose-wide {
        width: min(100%, calc(100% - 1.25rem));
    }

    .section {
        padding-top: clamp(1.8rem, 6vw, 2.4rem);
        padding-bottom: clamp(1.8rem, 6vw, 2.4rem);
    }

    .page-hero {
        padding-top: clamp(2rem, 7vw, 2.7rem);
        padding-bottom: clamp(2rem, 7vw, 2.7rem);
    }

    .section-heading h2,
    .page-hero h1,
    .hero--home__title {
        line-height: 1.18;
    }

    .theme-picker__panel {
        right: 0;
        width: min(92vw, 360px);
        max-height: min(74vh, 540px);
        overflow-y: auto;
    }

    .utility-bar__end {
        row-gap: 0.5rem;
    }

    .main-header {
        grid-template-columns: 1fr auto;
        align-items: start;
    }

    .header-actions {
        justify-content: flex-end;
        flex-wrap: wrap;
        gap: 0.5rem;
        min-width: 0;
    }

    .header-actions .btn {
        min-width: 0;
    }

    .footer-grid {
        grid-template-columns: 1fr;
        gap: 1.35rem;
    }

    .footer-column,
    .footer-brand + .footer-column--links {
        border-left: 0;
        padding-left: 0;
    }

    .footer-brand {
        padding-right: 0;
    }

    .footer-brand__tagline {
        max-width: 100%;
        text-align: left;
    }

    .footer-bottom {
        justify-content: flex-start;
        gap: 0.45rem 0.8rem;
    }

    .hero--home__layout,
    .hero__grid,
    .contact-grid,
    .contact-page-layout,
    .our-work-prose,
    .about-intro__split,
    .about-vm,
    .why-context__bento,
    .why-impact-grid,
    .about-stat-grid {
        grid-template-columns: 1fr;
    }

    .hero--home__copy {
        order: 2;
    }

    .hero--home__visual {
        order: 1;
    }

    .hero--home__title-line {
        display: inline;
    }

    .hero--home__trust {
        margin-top: 1rem;
    }

    .hero-trust__item {
        align-items: flex-start;
    }

    .partners-marquee__item {
        min-width: 130px;
    }

    .partners-marquee__logo {
        max-height: 46px;
    }

    .news-grid,
    .country-grid,
    .card-grid,
    .cta-grid {
        grid-template-columns: 1fr;
    }

    .about-hero__copy,
    .our-work-hero__inner,
    .why-hero__shell {
        text-align: left;
    }

    .about-intro__figure,
    .about-partners__figure,
    .why-context__visual,
    .why-bridge {
        margin-inline: auto;
    }

    .about-pill-list,
    .about-check-list,
    .our-work-list,
    .why-impact__list {
        padding-left: 1.05rem;
    }

    .why-hero__chips {
        flex-wrap: wrap;
        gap: 0.4rem;
    }

    .why-band__inner {
        gap: 0.6rem;
        white-space: normal;
        justify-content: flex-start;
    }

    .why-pillar-track {
        grid-template-columns: 1fr;
    }

    .why-strategic-card__content,
    .contact-page__primary,
    .contact-form-card {
        min-width: 0;
    }

    .contact-inquiries-card__row {
        grid-template-columns: 1fr;
        gap: 0.15rem;
    }

    .contact-inquiries-card__row dt {
        font-size: 0.8rem;
    }

    .contact-form .btn,
    .contact-map-section__footnote a {
        width: 100%;
    }

    .article-image,
    .article-post__figure {
        border-radius: 14px;
    }

    .rich-text,
    .news-card__body,
    .country-card__body {
        min-width: 0;
    }

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

    .news-card img,
    .country-card img {
        aspect-ratio: 16 / 10;
        object-fit: cover;
    }

    .stats-grid--single-row {
        grid-template-columns: 1fr;
    }

    .stats-grid--single-row .stat-card {
        grid-template-columns: 42px 1fr;
        padding: 0.85rem 0.8rem;
    }

    .stats-grid--single-row .stat-card strong {
        font-size: 1.35rem;
    }

    .section--map .section-heading.section-heading--map {
        margin-bottom: 0.8rem;
    }

    .our-work-toc-wrap .container {
        overflow-x: auto;
        padding-bottom: 0.35rem;
    }

    .our-work-toc {
        flex-wrap: nowrap;
        min-width: max-content;
    }

    .our-work-figure {
        float: none;
        margin: 0.5rem 0 0.8rem;
        max-width: 100%;
    }

    .contact-map__frame iframe,
    .act-google-map,
    .act-google-map.act-google-map--fullwidth {
        height: clamp(280px, 48vh, 420px);
    }

    .admin-topbar {
        gap: 0.55rem;
    }

    .admin-topbar__actions {
        width: 100%;
        justify-content: space-between;
    }

    .admin-topbar h1 {
        font-size: 1.12rem;
    }

    .admin-table {
        display: block;
        overflow-x: auto;
        white-space: nowrap;
    }

    .admin-actions--quick .btn {
        flex: 1 1 auto;
        min-width: 0;
    }

    .admin-form .form-grid > div {
        min-width: 0;
    }

    .admin-form textarea {
        min-height: 120px;
    }
}

@media (max-width: 640px) {
    .section-heading p,
    .hero--home__lead,
    .page-hero p {
        font-size: 0.95rem;
        line-height: 1.55;
        text-align: left;
        word-break: normal;
        overflow-wrap: anywhere;
    }

    .hero__actions .btn,
    .why-hero__actions .btn,
    .news-home-more__link,
    .contact-form .btn,
    .admin-actions--quick .btn {
        width: 100%;
        justify-content: center;
    }

    .header-actions {
        width: 100%;
    }

    .mobile-nav-toggle {
        margin-left: auto;
    }

    .hero--home__frame {
        border-radius: 18px;
    }

    .our-work-gallery {
        grid-template-columns: 1fr;
    }

    .why-hero__actions {
        display: grid;
        grid-template-columns: 1fr;
        gap: 0.55rem;
    }

    .why-hero__actions .btn {
        width: 100%;
    }

    .about-vm__card,
    .why-pillar,
    .why-impact,
    .contact-inquiries-card,
    .form-card {
        border-radius: 16px;
    }

    .admin-content {
        padding: 0.8rem;
    }

    .admin-sidebar {
        width: min(88vw, 300px);
    }

    .admin-card-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .main-header {
        grid-template-columns: 1fr;
        row-gap: 0.7rem;
        padding: 0.65rem 0 0.8rem;
    }

    .site-brand {
        padding-right: 0;
    }

    .header-actions {
        width: 100%;
        justify-content: flex-start;
    }

    .header-actions .btn {
        width: auto;
        min-width: 130px;
    }

    .mobile-nav-toggle {
        margin-left: auto;
    }

    .footer-brand__tagline {
        font-size: 0.92rem;
        line-height: 1.35;
        text-align: left;
    }

    .footer-column--links .footer-link {
        font-size: 0.92rem;
        line-height: 1.28;
    }

    .footer-column--links .footer-title {
        font-size: 0.78rem;
    }

    .footer-link {
        font-size: 0.86rem;
    }

    .footer-contact-line {
        font-size: 0.82rem;
        line-height: 1.2;
    }
}

@media (max-width: 480px) {
    .container,
    .container.narrow,
    .container--prose-wide {
        width: min(100%, calc(100% - 0.9rem));
    }

    .section-heading h2,
    .page-hero h1,
    .hero--home__title {
        font-size: clamp(1.45rem, 7.8vw, 1.9rem);
    }

    .main-nav {
        padding: 0.75rem;
    }

    .dropdown__link {
        padding: 0.62rem 0.72rem;
        font-size: 0.88rem;
    }

    .header-actions .btn {
        min-width: 118px;
        padding-inline: 0.8rem;
        font-size: 0.78rem;
    }

    .stats-grid--single-row .stat-card {
        grid-template-columns: 34px 1fr;
        column-gap: 0.55rem;
        padding: 0.75rem 0.68rem;
    }

    .stats-grid--single-row .stat-card__icon svg {
        width: 1.55rem;
        height: 1.55rem;
    }

    .stats-grid--single-row .stat-card strong {
        font-size: 1.18rem;
    }

    .theme-picker__panel {
        width: min(95vw, 340px);
        max-height: min(70vh, 500px);
    }
}

@media (max-width: 420px) {
    .main-header {
        padding-left: max(0.65rem, env(safe-area-inset-left, 0px));
        padding-right: max(0.65rem, env(safe-area-inset-right, 0px));
    }

    .header-actions {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 0.45rem;
        width: 100%;
    }

    .header-actions .header-contact-btn {
        grid-column: 1;
        grid-row: 1;
    }

    .header-actions .header-donate-btn {
        grid-column: 2;
        grid-row: 1;
    }

    .header-actions .mobile-nav-toggle {
        grid-column: 1 / -1;
        grid-row: 2;
        margin-left: 0;
        width: 100%;
        justify-content: center;
    }

    .header-actions .btn {
        min-width: 0;
        width: 100%;
        padding-inline: 0.65rem;
        font-size: 0.76rem;
    }
}

/* ---- Mobile emergency layout fixes (home) ---- */
@media (max-width: 900px) {
    .hero--home__copy {
        display: flex;
        flex-direction: column;
    }

    .hero--home__copy .hero--home__title {
        order: 1;
    }

    .hero--home__copy .hero--home__lead {
        order: 2;
    }

    .home-updates-mini-wrap--mobile {
        display: block;
        margin: 0.7rem 0 0.8rem;
        order: 4;
    }

    .hero--home__trust {
        order: 5;
    }

    .home-updates-mini-wrap--desktop {
        display: none;
    }

    .hero--home__actions {
        order: 3;
    }

    .hero--home__visual {
        display: none;
    }

    .hero--home__layout {
        grid-template-columns: 1fr !important;
        gap: 1rem !important;
        padding-top: 1.1rem !important;
        padding-bottom: 1.1rem !important;
    }

    .hero--home__copy,
    .hero--home__visual {
        width: 100%;
        max-width: 100%;
    }

    .hero--home__title {
        font-size: clamp(1.7rem, 8vw, 2.4rem);
        line-height: 1.12;
        margin-bottom: 0.65rem;
        max-width: 100%;
        overflow-wrap: anywhere;
    }

    .hero--home__title-line {
        white-space: normal;
    }

    .hero--home__lead {
        font-size: 1rem;
        line-height: 1.45;
        margin-bottom: 0.75rem;
    }

    .hero--home__frame {
        border-radius: 14px;
        max-width: 100%;
        overflow: hidden;
    }

    .home-updates-mini {
        padding: 0.75rem;
        gap: 0.7rem;
    }

    .home-updates-mini__feature {
        grid-template-columns: 1fr;
        gap: 0.55rem;
    }

    .home-updates-mini__feature-media {
        width: 100%;
        height: auto;
        aspect-ratio: 16 / 9;
    }

    .home-updates-mini__feature-title {
        font-size: 1.02rem;
        line-height: 1.28;
        color: var(--surface-deep);
        -webkit-line-clamp: 3;
    }

    .home-updates-mini__feature-excerpt,
    .home-updates-mini .home-updates__trigger-text {
        color: var(--muted);
    }

    .home-updates-mini .home-updates__trigger {
        grid-template-columns: 30px minmax(0, 1fr);
        padding: 0.45rem 0.5rem;
    }

    .home-updates-mini .home-updates__chev {
        display: none;
    }

    .home-updates-mini .home-updates__trigger-text {
        font-size: 0.96rem;
        line-height: 1.35;
        -webkit-line-clamp: 2;
    }

    .home-updates__viewport--mini {
        max-height: none;
    }

    .section--partners .container {
        overflow: visible;
    }

    .partners-marquee {
        overflow: hidden;
    }

    .partners-marquee__viewport {
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
        padding-bottom: 0.25rem;
        touch-action: pan-x;
        overscroll-behavior-x: contain;
    }

    .partners-marquee__track {
        animation: partners-marquee-scroll 50s linear infinite !important;
        display: flex;
        flex-direction: row;
        width: max-content;
        gap: 0.6rem;
    }

    .partners-marquee__item {
        min-width: 120px;
        max-width: 120px;
        height: 66px;
    }

    .partners-marquee__logo {
        max-height: 44px;
        width: auto;
    }
}

@media (max-width: 480px) {
    .hero--home__title-line {
        white-space: normal;
    }

    .home-updates-mini .home-updates__trigger {
        grid-template-columns: 28px minmax(0, 1fr);
    }

    .home-updates-mini .home-updates__thumb {
        width: 28px;
        height: 28px;
    }
}

/* Articles: wider band than generic .container (must load after .container media queries) */
.article-post--story .container.article-post__hero-inner,
.article-post--story .container.article-post__container {
    width: min(100%, calc(100% - 1rem));
}

@media (max-width: 960px) {
    .article-post--story .container.article-post__hero-inner,
    .article-post--story .container.article-post__container {
        width: min(100%, calc(100% - 0.85rem));
    }
}

@media (max-width: 480px) {
    .article-post--story .container.article-post__hero-inner,
    .article-post--story .container.article-post__container {
        width: min(100%, calc(100% - 0.7rem));
    }
}

.gallery-hero {
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at top right, color-mix(in srgb, var(--theme-orb-accent) 55%, transparent) 0%, transparent 40%),
        linear-gradient(135deg, color-mix(in srgb, var(--surface-alt) 96%, #ffffff 4%), color-mix(in srgb, var(--surface) 95%, transparent));
}

.gallery-hero--pictures {
    background:
        radial-gradient(circle at 10% 20%, color-mix(in srgb, var(--theme-orb-primary) 70%, transparent) 0%, transparent 35%),
        radial-gradient(circle at 90% 5%, color-mix(in srgb, var(--theme-orb-accent) 62%, transparent) 0%, transparent 32%),
        linear-gradient(140deg, #f8fbff 0%, #eef4fb 38%, #ffffff 100%);
}

.gallery-hero__mesh {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, color-mix(in srgb, var(--border) 22%, transparent) 1px, transparent 1px),
        linear-gradient(color-mix(in srgb, var(--border) 18%, transparent) 1px, transparent 1px);
    background-size: 34px 34px;
    mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.4), transparent 85%);
    pointer-events: none;
}

.gallery-hero__inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(360px, 0.95fr);
    gap: 2rem;
    align-items: center;
}

.gallery-hero__copy {
    max-width: 46rem;
}

.gallery-hero__visual {
    position: relative;
}

.gallery-hero__lead {
    font-size: 1.08rem;
    line-height: 1.75;
    color: color-mix(in srgb, var(--text) 82%, transparent);
    max-width: 44rem;
}

.gallery-hero__stats {
    display: flex;
    flex-wrap: wrap;
    gap: 0.9rem;
    list-style: none;
    padding: 0;
    margin: 1.35rem 0 0;
}

.gallery-hero__stats li {
    min-width: 132px;
    padding: 0.95rem 1rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.84);
    backdrop-filter: blur(16px);
    box-shadow:
        0 18px 48px color-mix(in srgb, var(--surface-deep) 10%, transparent),
        0 0 0 1px color-mix(in srgb, var(--border) 78%, transparent);
}

.gallery-hero__stats strong {
    display: block;
    font-family: "Libre Baskerville", serif;
    font-size: 1.55rem;
    line-height: 1;
    color: var(--surface-dark);
}

.gallery-hero__stats span {
    display: block;
    margin-top: 0.35rem;
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--muted);
}

.gallery-hero__panel {
    position: relative;
    padding: 1.35rem 1.4rem;
    border-radius: 28px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.82)),
        linear-gradient(135deg, color-mix(in srgb, var(--brand-blue-dark) 8%, #ffffff 92%), #ffffff);
    backdrop-filter: blur(18px);
    box-shadow:
        0 24px 64px color-mix(in srgb, var(--surface-deep) 12%, transparent),
        0 0 0 1px color-mix(in srgb, var(--border) 78%, transparent);
}

.gallery-collage {
    position: relative;
    min-height: 520px;
    padding: 1rem;
    border-radius: 34px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.78), rgba(255, 255, 255, 0.92)),
        linear-gradient(135deg, color-mix(in srgb, var(--brand-blue-dark) 10%, #ffffff 90%), #ffffff);
    box-shadow:
        0 30px 80px color-mix(in srgb, var(--surface-deep) 14%, transparent),
        0 0 0 1px color-mix(in srgb, var(--border) 82%, transparent);
}

.gallery-collage__item {
    position: absolute;
    overflow: hidden;
    border-radius: 26px;
    box-shadow:
        0 16px 38px color-mix(in srgb, var(--surface-deep) 18%, transparent),
        0 0 0 1px rgba(255, 255, 255, 0.24);
}

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

.gallery-collage__item--1 {
    top: 0;
    left: 0;
    width: 58%;
    height: 58%;
}

.gallery-collage__item--2 {
    top: 0;
    right: 0;
    width: 38%;
    height: 34%;
}

.gallery-collage__item--3 {
    bottom: 0;
    left: 0;
    width: 38%;
    height: 34%;
}

.gallery-collage__item--4 {
    right: 0;
    bottom: 0;
    width: 58%;
    height: 58%;
}

.gallery-collage__item::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 30%, rgba(7, 18, 42, 0.24) 100%);
}

.gallery-collage__card {
    position: absolute;
    left: 50%;
    top: 50%;
    z-index: 2;
    width: min(280px, calc(100% - 4rem));
    padding: 1rem 1.05rem;
    border-radius: 22px;
    background: rgba(7, 18, 42, 0.82);
    color: #fff;
    backdrop-filter: blur(14px);
    transform: translate(-50%, -50%);
    box-shadow:
        0 18px 44px rgba(7, 18, 42, 0.25),
        0 0 0 1px rgba(255, 255, 255, 0.08);
}

.gallery-collage__label {
    margin: 0 0 0.4rem;
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: color-mix(in srgb, #ffffff 78%, transparent);
}

.gallery-collage__card strong {
    display: block;
    line-height: 1.45;
}

.gallery-hero__panel::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    padding: 1px;
    background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 28%, transparent), color-mix(in srgb, var(--brand-blue-dark) 20%, transparent));
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
}

.gallery-hero__panel > * {
    position: relative;
    z-index: 1;
}

.gallery-hero__panel h2 {
    margin: 0.3rem 0 0.75rem;
    font-family: "Libre Baskerville", serif;
    font-size: clamp(1.4rem, 2.2vw, 2rem);
}

.gallery-hero__panel p {
    margin: 0;
    color: color-mix(in srgb, var(--text) 82%, transparent);
}

.gallery-hero__panel-label,
.gallery-group__eyebrow,
.gallery-card__meta {
    display: inline-block;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--logo-red);
}

.gallery-hero__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    margin-top: 1.1rem;
}

.gallery-hero__chips a,
.gallery-toc__links a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0.68rem 1rem;
    border-radius: 999px;
    text-decoration: none;
    font-weight: 700;
    color: var(--brand-blue-dark);
    background: color-mix(in srgb, var(--surface-alt) 88%, #ffffff 12%);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--border) 82%, transparent);
    transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.gallery-hero__chips a:hover,
.gallery-toc__links a:hover {
    transform: translateY(-1px);
    background: #fff;
    box-shadow:
        0 14px 30px color-mix(in srgb, var(--surface-deep) 10%, transparent),
        0 0 0 1px color-mix(in srgb, var(--accent) 22%, transparent);
}

.gallery-toc {
    position: relative;
    z-index: 2;
    margin-top: -0.9rem;
}

.gallery-toc .container {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
    padding: 1rem 1.2rem;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(16px);
    box-shadow:
        0 20px 50px color-mix(in srgb, var(--surface-deep) 10%, transparent),
        0 0 0 1px color-mix(in srgb, var(--border) 80%, transparent);
}

.gallery-toc__label {
    margin: 0;
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--muted);
}

.gallery-toc__links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.7rem;
}

.section--gallery-list {
    padding-top: clamp(2.7rem, 4.5vw, 3.5rem);
}

.gallery-overview-grid,
.gallery-album-grid,
.video-gallery-grid,
.gallery-photo-grid,
.admin-media-grid {
    display: grid;
    gap: 1.15rem;
}

.gallery-overview-grid {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.gallery-overview-card,
.gallery-card,
.video-card,
.gallery-empty-state,
.admin-media-card {
    border-radius: 24px;
    background: #fff;
    box-shadow:
        0 20px 60px color-mix(in srgb, var(--surface-deep) 12%, transparent),
        0 0 0 1px color-mix(in srgb, var(--border) 88%, transparent);
}

.gallery-overview-card,
.gallery-empty-state {
    padding: 1.4rem;
}

.gallery-overview-card__eyebrow {
    display: inline-block;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--logo-red);
}

.gallery-overview-card__stats,
.gallery-meta {
    display: flex;
    gap: 0.85rem;
    flex-wrap: wrap;
    color: var(--muted);
}

.gallery-overview-card__stats {
    list-style: none;
    padding: 0;
    margin: 1rem 0 1.25rem;
}

.gallery-stack {
    display: grid;
    gap: 2.2rem;
}

.gallery-group {
    position: relative;
    display: grid;
    gap: 1.3rem;
    padding: clamp(1.15rem, 2vw, 1.5rem);
    border-radius: 32px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(255, 255, 255, 0.98)),
        linear-gradient(135deg, color-mix(in srgb, var(--surface-alt) 80%, #ffffff 20%), #ffffff);
    box-shadow:
        0 26px 70px color-mix(in srgb, var(--surface-deep) 10%, transparent),
        0 0 0 1px color-mix(in srgb, var(--border) 82%, transparent);
}

.gallery-group__intro {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr);
    gap: 1.25rem;
    align-items: stretch;
}

.gallery-group__copy {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.gallery-group__copy h2 {
    margin: 0.25rem 0 0.7rem;
    font-family: "Libre Baskerville", serif;
    font-size: clamp(1.8rem, 3vw, 2.7rem);
    line-height: 1.08;
}

.gallery-group__text {
    margin: 0 0 1rem;
    max-width: 44rem;
    color: color-mix(in srgb, var(--text) 82%, transparent);
}

.gallery-meta span {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.52rem 0.8rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--surface-alt) 86%, #ffffff 14%);
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--border) 84%, transparent);
}

.gallery-group__feature {
    position: relative;
    min-height: 320px;
    border-radius: 26px;
    overflow: hidden;
    background: color-mix(in srgb, var(--surface-alt) 92%, #ffffff 8%);
}

.gallery-showcase {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 180px;
    gap: 0.9rem;
    height: 100%;
}

.gallery-showcase__lead,
.gallery-showcase__mini {
    position: relative;
    display: block;
    overflow: hidden;
    border-radius: 22px;
    text-decoration: none;
    color: inherit;
    background: color-mix(in srgb, var(--surface-alt) 88%, #ffffff 12%);
}

.gallery-showcase__lead {
    min-height: 320px;
}

.gallery-showcase__lead img,
.gallery-showcase__mini img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.gallery-showcase__lead-overlay,
.gallery-group__feature-placeholder {
    position: absolute;
    inset: auto 0 0 0;
    display: flex;
    flex-direction: column;
    gap: 0.22rem;
    padding: 1.15rem 1.2rem;
    color: #fff;
    background: linear-gradient(180deg, transparent 0%, rgba(7, 18, 42, 0.82) 100%);
}

.gallery-showcase__rail {
    display: grid;
    gap: 0.9rem;
    grid-template-rows: repeat(2, minmax(0, 1fr));
}

.gallery-showcase__mini::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 30%, rgba(7, 18, 42, 0.64) 100%);
}

.gallery-showcase__mini span {
    position: absolute;
    left: 0.9rem;
    right: 0.9rem;
    bottom: 0.85rem;
    z-index: 1;
    font-size: 0.92rem;
    font-weight: 700;
    line-height: 1.35;
    color: #fff;
}

.gallery-group__feature-kicker {
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: color-mix(in srgb, #ffffff 82%, transparent);
}

.gallery-showcase__lead-overlay strong {
    font-size: 1.15rem;
}

.gallery-group__feature-placeholder {
    inset: 0;
    align-items: center;
    justify-content: center;
    text-align: center;
    background:
        radial-gradient(circle at top, color-mix(in srgb, var(--theme-orb-accent) 34%, transparent) 0%, transparent 38%),
        linear-gradient(135deg, color-mix(in srgb, var(--brand-blue-dark) 92%, #0d1d3f 8%), color-mix(in srgb, var(--accent-dark) 78%, #0d1d3f 22%));
}

.gallery-group--reverse .gallery-group__intro {
    grid-template-columns: minmax(280px, 0.9fr) minmax(0, 1.1fr);
}

.gallery-group--reverse .gallery-group__copy {
    order: 2;
}

.gallery-group--reverse .gallery-group__feature {
    order: 1;
}

.gallery-album-grid,
.video-gallery-grid {
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}

.video-gallery-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.gallery-card,
.video-card,
.admin-media-card {
    overflow: hidden;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.gallery-card:hover,
.video-card:hover {
    transform: translateY(-3px);
    box-shadow:
        0 28px 72px color-mix(in srgb, var(--surface-deep) 16%, transparent),
        0 0 0 1px color-mix(in srgb, var(--accent) 18%, transparent);
}

.gallery-card__media,
.gallery-card__placeholder,
.video-card__player,
.admin-media-card__thumb {
    display: block;
    width: 100%;
}

.gallery-card__media img,
.gallery-photo-card img,
.admin-media-card__thumb {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.gallery-card__media {
    position: relative;
    aspect-ratio: 4 / 3;
    background: color-mix(in srgb, var(--surface-alt) 90%, #ffffff 10%);
}

.gallery-card__media::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 35%, rgba(7, 18, 42, 0.34) 100%);
    pointer-events: none;
}

.gallery-card__placeholder {
    display: grid;
    place-items: center;
    min-height: 220px;
    font-weight: 700;
    color: var(--muted);
}

.gallery-card__body,
.video-card__body,
.admin-media-card__meta,
.admin-media-card__actions {
    padding: 1rem 1.05rem;
}

.gallery-card__body {
    display: flex;
    flex-direction: column;
    min-height: 205px;
}

.gallery-card__body h3,
.video-card__body h2 {
    margin: 0.3rem 0 0.55rem;
}

.gallery-card__body h3 a {
    color: inherit;
    text-decoration: none;
}

.gallery-card__body h3 a:hover,
.gallery-card__cta:hover {
    color: var(--accent-dark);
}

.gallery-card__body p:last-child,
.video-card__body p:last-child {
    margin-bottom: 0;
}

.gallery-card__body p {
    color: color-mix(in srgb, var(--text) 82%, transparent);
}

.gallery-card__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    margin-top: auto;
    padding-top: 0.9rem;
    font-weight: 700;
    text-decoration: none;
    color: var(--brand-blue-dark);
}

.gallery-card__cta::after {
    content: "";
    width: 0.45rem;
    height: 0.45rem;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(-45deg);
}

.gallery-album-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.1rem;
}

.gallery-photo-grid {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.gallery-photo-card {
    margin: 0;
    overflow: hidden;
    border-radius: 22px;
    background: #fff;
    box-shadow:
        0 18px 48px color-mix(in srgb, var(--surface-deep) 12%, transparent),
        0 0 0 1px color-mix(in srgb, var(--border) 88%, transparent);
}

.gallery-photo-card__open {
    display: block;
    width: 100%;
    margin: 0;
    padding: 0;
    border: 0;
    cursor: zoom-in;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    border-radius: 22px 22px 0 0;
    background: color-mix(in srgb, var(--surface-alt) 88%, #0f172a 12%);
    text-align: left;
}

.gallery-photo-card__open:focus-visible {
    outline: 3px solid color-mix(in srgb, var(--accent) 65%, transparent);
    outline-offset: 2px;
}

.gallery-photo-card figcaption {
    padding: 0.75rem 1rem 0.95rem;
    color: var(--muted);
    font-size: 0.88rem;
    line-height: 1.45;
}

.video-card__player {
    aspect-ratio: 16 / 9;
    background: #000;
}

.video-card__player iframe,
.video-card__player video {
    width: 100%;
    height: 100%;
    border: 0;
}

.admin-media-grid {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    margin-top: 1rem;
}

.admin-media-card--single {
    max-width: 320px;
    margin-top: 1rem;
}

.admin-media-card__thumb {
    aspect-ratio: 4 / 3;
}

.admin-media-card__meta {
    display: flex;
    justify-content: space-between;
    gap: 0.75rem;
    align-items: center;
}

.admin-media-card__meta span {
    color: var(--muted);
    font-size: 0.88rem;
}

.admin-media-card__actions {
    padding-top: 0;
}

@media (max-width: 960px) {
    .gallery-hero__inner,
    .gallery-group__intro,
    .gallery-group--reverse .gallery-group__intro {
        grid-template-columns: 1fr;
    }

    .gallery-group--reverse .gallery-group__copy,
    .gallery-group--reverse .gallery-group__feature {
        order: initial;
    }

    .gallery-collage {
        min-height: 460px;
    }
}

@media (max-width: 768px) {
    .gallery-album-toolbar,
    .gallery-toc .container {
        flex-direction: column;
        align-items: flex-start;
    }

    .gallery-hero__stats li {
        min-width: 0;
        flex: 1 1 140px;
    }

    .gallery-showcase {
        grid-template-columns: 1fr;
    }

    .gallery-showcase__rail {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        grid-template-rows: none;
    }

    .gallery-showcase__mini {
        min-height: 150px;
    }

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

@media (max-width: 640px) {
    .gallery-overview-grid,
    .gallery-album-grid,
    .gallery-photo-grid,
    .admin-media-grid {
        grid-template-columns: 1fr;
    }

    .video-gallery-grid {
        grid-template-columns: 1fr;
    }

    .gallery-group {
        padding: 1rem;
        border-radius: 24px;
    }

    .gallery-hero__panel {
        padding: 1.1rem;
    }

    .gallery-collage {
        min-height: 420px;
        padding: 0.7rem;
    }

    .gallery-collage__item--1,
    .gallery-collage__item--4 {
        width: 57%;
        height: 55%;
    }

    .gallery-collage__item--2,
    .gallery-collage__item--3 {
        width: 39%;
        height: 31%;
    }

    .gallery-collage__card {
        width: min(230px, calc(100% - 2rem));
        padding: 0.9rem;
    }
}


.gallery-page {
    --gallery-thumb-ratio: 4 / 3;
    --gallery-hero-thumb: min(176px, 30vw);
    background: linear-gradient(180deg, #e8edf5 0%, #f4f6fa 22%, #ffffff 55%, #fafbfc 100%);
}

.gallery-page--pictures {
    --gallery-page-max: min(1240px, calc(100% - 24px));
}

.gallery-page__container {
    width: var(--gallery-page-max);
    max-width: 100%;
}

.gallery-page__hero {
    position: relative;
    overflow: hidden;
    padding: clamp(1.5rem, 3vw, 2rem) 0 clamp(2rem, 4vw, 3rem);
    background:
        radial-gradient(ellipse 100% 90% at 0% 0%, color-mix(in srgb, var(--theme-orb-accent) 38%, transparent) 0%, transparent 52%),
        radial-gradient(ellipse 80% 70% at 100% 0%, color-mix(in srgb, var(--theme-orb-primary) 32%, transparent) 0%, transparent 48%),
        linear-gradient(152deg, #040a18 0%, #0c1f3f 45%, #102a52 100%);
    color: #fff;
}

.gallery-page__hero .gallery-page__container {
    position: relative;
    z-index: 1;
}

.gallery-page__hero-glow {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(255, 255, 255, 0.05) 1px, transparent 1px),
        linear-gradient(rgba(255, 255, 255, 0.04) 1px, transparent 1px);
    background-size: 40px 40px;
    opacity: 0.28;
    pointer-events: none;
}

.gallery-page__crumb {
    margin-bottom: clamp(1rem, 2.5vw, 1.5rem);
}

.gallery-page__crumb-list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem 0.5rem;
    margin: 0;
    padding: 0;
    list-style: none;
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: color-mix(in srgb, #ffffff 72%, transparent);
}

.gallery-page__crumb-list li {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.gallery-page__crumb-list li:not(:last-child)::after {
    content: "/";
    font-weight: 500;
    opacity: 0.55;
    pointer-events: none;
}

.gallery-page__crumb-list a {
    color: color-mix(in srgb, #ffffff 92%, transparent);
    text-decoration: none;
    border-bottom: 1px solid color-mix(in srgb, #ffffff 35%, transparent);
    transition: color 0.15s ease, border-color 0.15s ease;
}

.gallery-page__crumb-list a:hover {
    color: #fff;
    border-bottom-color: color-mix(in srgb, #ffffff 70%, transparent);
}

.gallery-page__crumb-list [aria-current="page"] {
    color: color-mix(in srgb, #ffffff 88%, transparent);
    font-weight: 700;
}

.gallery-page__hero-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.12fr) minmax(220px, 0.88fr);
    gap: clamp(1.25rem, 3.5vw, 2.5rem);
    align-items: center;
}

.gallery-page__hero-copy h1 {
    margin: 0.15rem 0 0.75rem;
    color: #fff;
    font-size: clamp(2rem, 4.2vw, 3.6rem);
    line-height: 1.05;
}

.gallery-page__eyebrow {
    margin: 0;
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: color-mix(in srgb, #ffffff 76%, transparent);
}

.gallery-page__lead {
    max-width: 40rem;
    margin: 0;
    font-size: 1rem;
    line-height: 1.72;
    color: color-mix(in srgb, #ffffff 84%, transparent);
}

.gallery-page__stats {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    margin-top: 1.25rem;
}

.gallery-page__stats div {
    min-width: 112px;
    padding: 0.72rem 0.9rem;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.09);
    backdrop-filter: blur(12px);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.1);
}

.gallery-page__stats strong {
    display: block;
    font-family: "Libre Baskerville", serif;
    font-size: 1.35rem;
    line-height: 1;
    color: #fff;
}

.gallery-page__stats span {
    display: block;
    margin-top: 0.28rem;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: color-mix(in srgb, #ffffff 70%, transparent);
}

.gallery-page__hero-visual {
    display: flex;
    justify-content: center;
    align-items: center;
}

.gallery-page__hero-strip {
    display: flex;
    flex-wrap: nowrap;
    gap: 0.65rem;
    width: 100%;
    max-width: calc(3 * var(--gallery-hero-thumb) + 2 * 0.65rem);
    margin-inline: auto;
    justify-content: center;
}

.gallery-page__hero-cell {
    flex: 1 1 var(--gallery-hero-thumb);
    max-width: var(--gallery-hero-thumb);
    min-width: 0;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    text-decoration: none;
    color: #fff;
    border-radius: 16px;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.08);
    box-shadow:
        0 16px 40px rgba(2, 6, 18, 0.45),
        inset 0 0 0 1px rgba(255, 255, 255, 0.12);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.gallery-page__hero-cell:hover {
    transform: translateY(-3px);
    box-shadow:
        0 22px 50px rgba(2, 6, 18, 0.55),
        inset 0 0 0 1px rgba(255, 255, 255, 0.2);
}

.gallery-page__hero-cell:focus-visible {
    outline: 2px solid #fff;
    outline-offset: 3px;
}

.gallery-page__hero-cell-frame {
    position: relative;
    aspect-ratio: var(--gallery-thumb-ratio);
    width: 100%;
    background: rgba(0, 0, 0, 0.2);
}

.gallery-page__hero-cell-frame img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.gallery-page__hero-cell-cap {
    display: flex;
    flex-direction: column;
    gap: 0.12rem;
    padding: 0.55rem 0.6rem 0.65rem;
    background: linear-gradient(180deg, rgba(6, 14, 32, 0.55), rgba(4, 10, 24, 0.92));
}

.gallery-page__hero-cell-title {
    font-size: 0.78rem;
    font-weight: 700;
    line-height: 1.25;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
}

.gallery-page__hero-cell-meta {
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: color-mix(in srgb, #ffffff 72%, transparent);
}

.gallery-page__hero-strip--note {
    max-width: 28rem;
}

.gallery-page__hero-placeholder {
    width: 100%;
    padding: 1.25rem 1.1rem;
    border-radius: 16px;
    text-align: center;
    background: rgba(255, 255, 255, 0.07);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.1);
}

.gallery-page__hero-placeholder strong {
    font-family: "Libre Baskerville", serif;
    font-size: 1.05rem;
    display: block;
}

.gallery-page__hero-placeholder span {
    display: block;
    margin-top: 0.4rem;
    font-size: 0.86rem;
    color: color-mix(in srgb, #ffffff 78%, transparent);
    line-height: 1.5;
}

.gallery-page__toolbar-wrap {
    position: relative;
    z-index: 2;
    margin-top: -0.75rem;
    padding-bottom: 0.5rem;
}

.gallery-page__toolbar {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) auto;
    grid-template-areas:
        "field actions"
        "status status";
    gap: 0.75rem 1.25rem;
    align-items: end;
    padding: 1rem 1.1rem;
    border-radius: 18px;
    background: #fff;
    box-shadow:
        0 14px 36px color-mix(in srgb, var(--surface-deep) 10%, transparent),
        0 0 0 1px color-mix(in srgb, var(--border) 82%, transparent);
}

.gallery-page__toolbar-field {
    grid-area: field;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    min-width: 0;
}

.gallery-page__toolbar-actions {
    grid-area: actions;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem 0.65rem;
    justify-content: flex-end;
}

.gallery-page__toolbar-label {
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--muted);
}

.gallery-page__toolbar-label--inline {
    margin: 0;
}

.gallery-page__toolbar-input {
    width: 100%;
    min-height: 44px;
    padding: 0.55rem 0.85rem;
    border-radius: 12px;
    border: 1px solid color-mix(in srgb, var(--border) 88%, transparent);
    font-size: 0.95rem;
    font-family: inherit;
    background: color-mix(in srgb, var(--surface-alt) 55%, #ffffff 45%);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.gallery-page__toolbar-input:focus {
    outline: none;
    border-color: color-mix(in srgb, var(--accent) 45%, var(--border));
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 18%, transparent);
}

.gallery-page__toolbar-select {
    min-height: 44px;
    padding: 0.45rem 2rem 0.45rem 0.75rem;
    border-radius: 12px;
    border: 1px solid color-mix(in srgb, var(--border) 88%, transparent);
    font-size: 0.86rem;
    font-weight: 600;
    font-family: inherit;
    color: var(--brand-blue-dark);
    background-color: #fff;
    cursor: pointer;
}

.gallery-page__toolbar-link {
    display: inline-flex;
    align-items: center;
    min-height: 44px;
    padding: 0 0.95rem;
    border-radius: 12px;
    font-size: 0.82rem;
    font-weight: 700;
    text-decoration: none;
    color: var(--brand-blue-dark);
    background: color-mix(in srgb, var(--surface-alt) 82%, #ffffff 18%);
    border: 1px solid color-mix(in srgb, var(--border) 82%, transparent);
    transition: background 0.15s ease, border-color 0.15s ease;
}

.gallery-page__toolbar-link:hover {
    background: color-mix(in srgb, var(--accent) 10%, #ffffff 90%);
    border-color: color-mix(in srgb, var(--accent) 30%, transparent);
}

.gallery-page__toolbar-status {
    grid-area: status;
    margin: 0;
    font-size: 0.8rem;
    color: color-mix(in srgb, var(--text) 72%, transparent);
}

.gallery-page__filter-empty {
    margin: 0.65rem 0 0;
    padding: 0.75rem 1rem;
    border-radius: 12px;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--brand-blue-dark);
    background: color-mix(in srgb, var(--logo-red) 8%, #ffffff 92%);
    border: 1px solid color-mix(in srgb, var(--logo-red) 22%, transparent);
}

.gallery-page__nav {
    position: relative;
    z-index: 1;
    margin-top: -0.5rem;
    margin-bottom: 0.15rem;
}

.gallery-page__nav-inner {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem 0.55rem;
    padding: 0.65rem 0.8rem;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(12px);
    box-shadow:
        0 12px 32px color-mix(in srgb, var(--surface-deep) 11%, transparent),
        0 0 0 1px color-mix(in srgb, var(--border) 78%, transparent);
}

.gallery-page__nav-inner a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 36px;
    padding: 0.38rem 0.8rem;
    border-radius: 999px;
    text-decoration: none;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    color: var(--brand-blue-dark);
    background: color-mix(in srgb, var(--surface-alt) 84%, #ffffff 16%);
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--border) 80%, transparent);
    transition: background 0.15s ease, box-shadow 0.15s ease;
}

.gallery-page__nav-inner a:hover {
    background: color-mix(in srgb, var(--accent) 12%, #ffffff 88%);
    box-shadow:
        inset 0 0 0 1px color-mix(in srgb, var(--accent) 32%, transparent),
        0 3px 12px color-mix(in srgb, var(--surface-deep) 7%, transparent);
}

.section--gallery-pictures {
    padding: clamp(1rem, 2.5vw, 1.5rem) 0 clamp(2.25rem, 4.5vw, 3rem);
}

.gallery-page__body {
    padding-top: 0;
}

.gallery-page__sections {
    display: flex;
    flex-direction: column;
    gap: clamp(1.1rem, 2.2vw, 1.55rem);
}

.gallery-section {
    margin: 0;
}

.gallery-section[data-gallery-section].gallery-section--hidden {
    display: none;
}

.gallery-section__panel {
    padding: clamp(1rem, 2vw, 1.45rem);
    border-radius: 20px;
    background: linear-gradient(168deg, rgba(255, 255, 255, 0.99) 0%, rgba(252, 253, 255, 0.96) 100%);
    box-shadow:
        0 12px 32px color-mix(in srgb, var(--surface-deep) 7%, transparent),
        0 0 0 1px color-mix(in srgb, var(--border) 84%, transparent);
}

.gallery-section:nth-child(even) .gallery-section__panel {
    background: linear-gradient(168deg, color-mix(in srgb, var(--surface-alt) 28%, #ffffff 72%) 0%, #ffffff 100%);
}

.gallery-section__head {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.85rem 1.25rem;
    padding-bottom: clamp(0.8rem, 1.6vw, 1.05rem);
    margin-bottom: clamp(0.75rem, 1.5vw, 1rem);
    border-bottom: 1px solid color-mix(in srgb, var(--border) 72%, transparent);
}

.gallery-section__head-main {
    flex: 1 1 min(100%, 26rem);
    min-width: 0;
}

.gallery-section__eyebrow {
    margin: 0;
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--logo-red);
}

.gallery-section__head-main h2 {
    margin: 0.28rem 0 0.42rem;
    font-family: "Libre Baskerville", serif;
    font-size: clamp(1.28rem, 2vw, 1.85rem);
    line-height: 1.16;
    color: var(--theme-heading-color, var(--brand-blue-dark));
}

.gallery-section__text {
    margin: 0;
    max-width: 46rem;
    color: color-mix(in srgb, var(--text) 82%, transparent);
    line-height: 1.58;
    font-size: 0.94rem;
}

.gallery-section__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    flex: 0 0 auto;
    align-items: flex-start;
    justify-content: flex-end;
}

.gallery-section__meta span {
    display: inline-flex;
    align-items: center;
    padding: 0.38rem 0.65rem;
    border-radius: 999px;
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    white-space: nowrap;
    color: var(--brand-blue-dark);
    background: color-mix(in srgb, var(--surface-alt) 78%, #ffffff 22%);
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--border) 78%, transparent);
}

.gallery-section__albums {
    display: grid;
    gap: clamp(0.75rem, 1.4vw, 1rem);
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 240px), 1fr));
}

.gallery-album-tile {
    display: flex;
    flex-direction: column;
    height: 100%;
    min-height: 0;
    text-decoration: none;
    color: inherit;
    border-radius: 16px;
    overflow: hidden;
    background: #fff;
    box-shadow:
        0 10px 28px color-mix(in srgb, var(--surface-deep) 8%, transparent),
        0 0 0 1px color-mix(in srgb, var(--border) 86%, transparent);
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.gallery-album-tile:hover {
    transform: translateY(-3px);
    box-shadow:
        0 18px 44px color-mix(in srgb, var(--surface-deep) 13%, transparent),
        0 0 0 1px color-mix(in srgb, var(--accent) 22%, transparent);
}

.gallery-album-tile:focus-visible {
    outline: 3px solid color-mix(in srgb, var(--accent) 55%, transparent);
    outline-offset: 2px;
}

.gallery-album-tile[hidden] {
    display: none !important;
}

.gallery-album-tile__thumb {
    position: relative;
    flex: 0 0 auto;
    aspect-ratio: var(--gallery-thumb-ratio);
    width: 100%;
    background: color-mix(in srgb, var(--surface-alt) 88%, #ffffff 12%);
}

.gallery-album-tile__img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.35s ease;
}

.gallery-album-tile:hover .gallery-album-tile__img {
    transform: scale(1.04);
}

.gallery-album-tile__placeholder {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    font-size: 0.85rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--muted);
}

.gallery-album-tile__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 42%, rgba(5, 12, 28, 0.55) 100%);
    pointer-events: none;
}

.gallery-album-tile__badge {
    position: absolute;
    right: 0.55rem;
    bottom: 0.55rem;
    z-index: 1;
    padding: 0.28rem 0.5rem;
    border-radius: 8px;
    font-size: 0.65rem;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: #fff;
    background: rgba(5, 14, 32, 0.78);
    backdrop-filter: blur(6px);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
}

.gallery-album-tile__body {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    padding: 0.75rem 0.85rem 0.9rem;
    min-height: 6.5rem;
}

.gallery-album-tile__title {
    margin: 0;
    font-size: 1.02rem;
    font-weight: 700;
    line-height: 1.3;
    font-family: "Public Sans", system-ui, sans-serif;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    color: var(--theme-heading-color, var(--brand-blue-dark));
}

.gallery-album-tile__desc {
    margin: 0;
    font-size: 0.82rem;
    line-height: 1.45;
    color: color-mix(in srgb, var(--text) 76%, transparent);
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    flex: 1 1 auto;
}

.gallery-album-tile__cta {
    margin-top: auto;
    padding-top: 0.25rem;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--brand-blue-dark);
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.gallery-album-tile__cta::after {
    content: "";
    width: 0.38rem;
    height: 0.38rem;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(-45deg);
}

.gallery-page__to-top {
    position: fixed;
    right: 1rem;
    bottom: 5.5rem;
    z-index: 50;
    width: 48px;
    height: 48px;
    border: none;
    border-radius: 50%;
    font-size: 1.15rem;
    line-height: 1;
    cursor: pointer;
    color: #fff;
    background: linear-gradient(145deg, var(--brand-blue-dark), color-mix(in srgb, var(--brand-blue-dark) 70%, #000 30%));
    box-shadow:
        0 10px 28px color-mix(in srgb, var(--surface-deep) 25%, transparent),
        0 0 0 1px rgba(255, 255, 255, 0.12);
    transition: transform 0.15s ease, opacity 0.2s ease;
}

.gallery-page__to-top:hover {
    transform: translateY(-2px);
}

.gallery-page__to-top:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 3px;
}

.gallery-page__empty {
    padding: 1rem 1.1rem;
    border-radius: 16px;
    background: #fff;
    box-shadow:
        0 12px 32px color-mix(in srgb, var(--surface-deep) 8%, transparent),
        0 0 0 1px color-mix(in srgb, var(--border) 86%, transparent);
}

.gallery-page__empty p,
.gallery-page__empty h2 {
    margin: 0;
}

.gallery-page__empty--standalone {
    padding: 1.25rem 1.3rem;
}

@media (max-width: 960px) {
    .gallery-page__hero-layout {
        grid-template-columns: 1fr;
    }

    .gallery-page__hero-strip {
        max-width: min(100%, calc(3 * min(140px, 28vw) + 1.3rem));
    }

    .gallery-page__toolbar {
        grid-template-columns: 1fr;
        grid-template-areas:
            "field"
            "actions"
            "status";
    }

    .gallery-page__toolbar-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 768px) {
    .gallery-page__hero-strip {
        flex-wrap: wrap;
        max-width: 100%;
    }

    .gallery-page__hero-cell {
        flex: 1 1 calc(33.333% - 0.5rem);
        max-width: calc(33.333% - 0.5rem);
        min-width: 96px;
    }

    .gallery-section__head {
        flex-direction: column;
        align-items: stretch;
    }

    .gallery-section__meta {
        justify-content: flex-start;
    }

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

    .gallery-page__nav-inner {
        padding: 0.6rem 0.7rem;
    }
}

@media (max-width: 520px) {
    .gallery-section__albums {
        grid-template-columns: 1fr;
    }

    .gallery-page__hero-cell {
        flex: 1 1 100%;
        max-width: 160px;
    }
}

@media (min-width: 900px) {
    .gallery-section__albums {
        grid-template-columns: repeat(auto-fill, minmax(min(100%, 260px), 1fr));
    }
}

/* Premium navigation refresh */
.site-header {
    --menu-surface: rgba(255, 255, 255, 0.9);
    --menu-surface-strong: rgba(255, 255, 255, 0.96);
    --menu-border: color-mix(in srgb, var(--logo-blue-deep) 14%, transparent);
    --menu-shadow:
        0 16px 38px rgba(7, 18, 42, 0.08),
        0 0 0 1px rgba(255, 255, 255, 0.45);
    /* Two-column mega tray + open tab (uses theme picker: hero soft + accent + nav shadow) */
    --mega-tray-bg: linear-gradient(
        165deg,
        var(--surface) 0%,
        color-mix(in srgb, var(--theme-hero-soft) 70%, var(--surface)) 46%,
        color-mix(in srgb, var(--theme-hero-soft) 42%, var(--accent-soft)) 100%
    );
    --mega-tray-border: color-mix(in srgb, var(--brand-blue-dark) 14%, transparent);
    --mega-tray-shadow: var(--nav-dropdown-shadow);
    --mega-tray-heading: color-mix(in srgb, var(--brand-blue-dark) 65%, var(--muted));
    --mega-tray-link: var(--theme-heading-color, var(--surface-deep));
    --mega-tray-link-hover: var(--accent);
    --mega-tray-divider: color-mix(in srgb, var(--brand-blue-dark) 11%, transparent);
    --mega-nav-tab-bg: color-mix(in srgb, var(--theme-hero-soft) 62%, var(--surface) 38%);
    --mega-nav-tab-fg: var(--brand-blue-dark);
    --mega-nav-caret-fg: var(--brand-blue-dark);
    --mega-nav-caret-bg: color-mix(in srgb, var(--accent-soft) 55%, transparent);
    --mega-nav-submenu-btn-bg: color-mix(in srgb, var(--theme-hero-soft) 78%, var(--surface));
}

.main-header {
    position: relative;
    padding: 0.85rem 1rem 0.95rem;
    border-radius: 24px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(255, 255, 255, 0.9)),
        linear-gradient(135deg, color-mix(in srgb, var(--theme-header-bg, var(--brand-blue-dark)) 8%, #ffffff 92%), #ffffff);
    box-shadow: var(--menu-shadow);
    border: 1px solid var(--menu-border);
    transition:
        background 0.28s ease,
        box-shadow 0.28s ease,
        border-color 0.28s ease,
        transform 0.28s ease;
}

.main-header::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    padding: 1px;
    background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 20%, transparent), color-mix(in srgb, var(--logo-blue-deep) 16%, transparent));
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    pointer-events: none;
}

.main-header > * {
    position: relative;
    z-index: 1;
}

.main-header--scrolled,
.site-header--scrolled .main-header {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(255, 255, 255, 0.95)),
        linear-gradient(135deg, color-mix(in srgb, var(--theme-header-bg, var(--brand-blue-dark)) 9%, #ffffff 91%), #ffffff);
    box-shadow:
        0 22px 50px rgba(7, 18, 42, 0.12),
        0 0 0 1px color-mix(in srgb, var(--logo-blue-deep) 12%, transparent);
}

.main-nav__links {
    gap: clamp(0.5rem, 1vw, 0.9rem);
}

.nav-item {
    position: relative;
}

.nav-item__link {
    position: relative;
    gap: 0.5rem;
    min-height: 48px;
    padding: 0.8rem 1rem;
    border-radius: 16px;
    font-weight: 800;
    letter-spacing: 0.01em;
    transition:
        color 0.22s ease,
        background 0.22s ease,
        transform 0.22s ease,
        box-shadow 0.22s ease;
}

.nav-item.has-children .nav-item__link {
    padding-right: 0.7rem;
}

.nav-item__link::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: linear-gradient(135deg, color-mix(in srgb, var(--logo-blue-deep) 10%, transparent), color-mix(in srgb, var(--accent) 7%, transparent));
    opacity: 0;
    transform: scale(0.92);
    transition: opacity 0.22s ease, transform 0.22s ease;
}

.nav-item__link::after {
    content: "";
    position: absolute;
    left: 1rem;
    right: 1rem;
    bottom: 0.48rem;
    height: 3px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--brand-blue-dark), var(--accent));
    opacity: 0;
    transform: scaleX(0.38);
    transform-origin: center;
    transition: opacity 0.22s ease, transform 0.22s ease;
}

.nav-item__link > * {
    position: relative;
    z-index: 1;
}

.nav-item__text {
    max-width: none;
    overflow: visible;
    text-overflow: clip;
}

.nav-item__text::after {
    bottom: -0.08rem;
    height: 2px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--brand-blue-dark), var(--accent));
}

.nav-item__link:hover,
.nav-item__link:focus-visible,
.nav-item.is-current .nav-item__link,
.nav-item__link.is-current {
    color: var(--brand-blue-dark);
    transform: translateY(-1px);
}

.nav-item__link:hover::before,
.nav-item__link:focus-visible::before,
.nav-item.is-current .nav-item__link::before,
.nav-item__link.is-current::before {
    opacity: 1;
    transform: scale(1);
}

.nav-item__link:hover::after,
.nav-item__link:focus-visible::after,
.nav-item.is-current .nav-item__link::after,
.nav-item__link.is-current::after {
    opacity: 1;
    transform: scaleX(1);
}

.nav-item.is-current .nav-item__link,
.nav-item__link.is-current {
    box-shadow:
        inset 0 0 0 1px color-mix(in srgb, var(--logo-blue-deep) 12%, transparent),
        0 10px 24px rgba(7, 18, 42, 0.08),
        0 0 0 1px color-mix(in srgb, var(--accent) 10%, transparent);
}

.main-header--scrolled .nav-item.is-current .nav-item__link,
.site-header--scrolled .nav-item.is-current .nav-item__link {
    box-shadow:
        inset 0 0 0 1px color-mix(in srgb, var(--logo-blue-deep) 14%, transparent),
        0 14px 30px rgba(7, 18, 42, 0.12),
        0 0 24px color-mix(in srgb, var(--accent) 12%, transparent);
}

.nav-item__caret {
    width: 1.3rem;
    height: 1.3rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--logo-blue-deep) 8%, transparent);
    opacity: 1;
}

.nav-item__link:hover .nav-item__caret,
.nav-item.has-children.is-hover-open .nav-item__caret,
.nav-item.has-children:focus-within .nav-item__caret,
.nav-item.is-current .nav-item__caret {
    color: var(--brand-blue-dark);
    background: color-mix(in srgb, var(--logo-blue-deep) 12%, transparent);
}

.nav-item.has-children:hover .nav-item__caret,
.nav-item.has-children:focus-within .nav-item__caret,
.nav-item.has-children.is-hover-open .nav-item__caret {
    transform: rotate(-180deg);
}

.nav-item__submenu-btn {
    width: 2.7rem;
    height: 2.7rem;
    border-radius: 14px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 248, 255, 0.96));
    box-shadow:
        0 10px 24px rgba(7, 18, 42, 0.08),
        inset 0 0 0 1px color-mix(in srgb, var(--logo-blue-deep) 12%, transparent);
}

.nav-item__submenu-btn:hover,
.nav-item__submenu-btn[aria-expanded="true"] {
    background:
        linear-gradient(180deg, rgba(245, 249, 255, 1), rgba(237, 244, 255, 1));
    transform: translateY(-1px);
}

.dropdown {
    top: calc(100% + 10px);
    min-width: min(620px, calc(100vw - 40px));
    max-width: 720px;
    padding: 0.8rem;
    border-radius: 22px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 250, 255, 0.98)),
        linear-gradient(155deg, #ffffff 0%, #f5f9ff 55%, #eef5ff 100%);
    border: 1px solid color-mix(in srgb, var(--logo-blue-deep) 16%, transparent);
    box-shadow:
        0 18px 32px rgba(12, 24, 48, 0.08),
        0 32px 64px rgba(12, 24, 48, 0.16);
    transform: translateY(12px) scale(0.96);
    backdrop-filter: blur(18px);
}

.dropdown::after {
    content: "";
    position: absolute;
    top: -8px;
    left: 24px;
    width: 16px;
    height: 16px;
    border-top: 1px solid color-mix(in srgb, var(--logo-blue-deep) 16%, transparent);
    border-left: 1px solid color-mix(in srgb, var(--logo-blue-deep) 16%, transparent);
    background: #fdfefe;
    transform: rotate(45deg);
}

.dropdown__inner {
    padding: 0.45rem;
}

.dropdown__inner::before {
    left: 0.65rem;
    right: 0.65rem;
    top: 0.18rem;
    height: 2px;
    background: linear-gradient(90deg, color-mix(in srgb, var(--brand-blue-dark) 92%, transparent), color-mix(in srgb, var(--accent) 88%, transparent));
}

.dropdown__link {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 0.35rem;
    padding: 0.95rem 1rem;
    border-radius: 16px;
    font-size: 0.95rem;
    font-weight: 700;
    line-height: 1.35;
    border: 1px solid color-mix(in srgb, var(--logo-blue-deep) 8%, transparent);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(247, 250, 255, 0.96));
    transform: translateY(8px);
    opacity: 0;
    transition:
        background 0.18s ease,
        color 0.18s ease,
        box-shadow 0.18s ease,
        transform 0.24s ease,
        border-color 0.18s ease,
        opacity 0.24s ease;
}

.dropdown__link::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: linear-gradient(135deg, color-mix(in srgb, var(--logo-blue-deep) 12%, transparent), color-mix(in srgb, var(--accent) 9%, transparent));
    opacity: 0;
    transition: opacity 0.2s ease;
}

.dropdown__link::after {
    content: "";
    position: absolute;
    left: 1rem;
    right: 1rem;
    bottom: 0.72rem;
    height: 2px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--brand-blue-dark), var(--accent));
    opacity: 0;
    transform: scaleX(0.42);
    transform-origin: left center;
    transition: opacity 0.22s ease, transform 0.22s ease;
}

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

.dropdown__layout {
    display: grid;
    grid-template-columns: minmax(220px, 0.95fr) minmax(260px, 1.35fr);
    gap: 0.8rem;
    align-items: stretch;
}

.dropdown__intro {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0.65rem;
    min-height: 100%;
    padding: 1.15rem 1.1rem;
    border-radius: 18px;
    background:
        radial-gradient(circle at top left, color-mix(in srgb, var(--accent) 14%, transparent), transparent 48%),
        linear-gradient(165deg, color-mix(in srgb, var(--theme-header-bg, var(--brand-blue-dark)) 94%, #ffffff 6%), color-mix(in srgb, var(--brand-blue-dark) 88%, black 12%));
    color: rgba(255, 255, 255, 0.94);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.dropdown__eyebrow {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    padding: 0.4rem 0.7rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.12);
    color: rgba(255, 255, 255, 0.84);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.dropdown__title {
    margin: 0;
    font-size: 1.35rem;
    line-height: 1.1;
    color: #fff;
}

.dropdown__summary {
    margin: 0;
    color: rgba(255, 255, 255, 0.78);
    font-size: 0.92rem;
    line-height: 1.55;
}

.dropdown__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-height: 42px;
    padding: 0.7rem 1rem;
    margin-top: 0.15rem;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.14);
    color: #fff;
    font-weight: 800;
    letter-spacing: 0.01em;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.12);
    transition: transform 0.2s ease, background 0.2s ease;
}

.dropdown__cta:hover,
.dropdown__cta:focus-visible {
    color: #fff;
    background: rgba(255, 255, 255, 0.2);
    transform: translateY(-1px);
}

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

/* Brand mega menu: two columns, navy / ice surface, accent hovers */
.nav-item.has-children:hover .nav-item__link,
.nav-item.has-children:focus-within .nav-item__link,
.nav-item.has-children.is-hover-open .nav-item__link,
.nav-item.has-children.is-submenu-open .nav-item__link {
    background: var(--mega-nav-tab-bg);
    color: var(--mega-nav-tab-fg);
    box-shadow: none;
    transform: none;
}

.nav-item.has-children:hover .nav-item__link::before,
.nav-item.has-children:focus-within .nav-item__link::before,
.nav-item.has-children.is-hover-open .nav-item__link::before,
.nav-item.has-children.is-submenu-open .nav-item__link::before,
.nav-item.has-children:hover .nav-item__link::after,
.nav-item.has-children:focus-within .nav-item__link::after,
.nav-item.has-children.is-hover-open .nav-item__link::after,
.nav-item.has-children.is-submenu-open .nav-item__link::after {
    opacity: 0;
}

.nav-item.has-children:hover .nav-item__caret,
.nav-item.has-children:focus-within .nav-item__caret,
.nav-item.has-children.is-hover-open .nav-item__caret,
.nav-item.has-children.is-submenu-open .nav-item__caret {
    color: var(--mega-nav-caret-fg);
    background: var(--mega-nav-caret-bg);
}

.nav-item.has-children:hover .nav-item__submenu-btn,
.nav-item.has-children:focus-within .nav-item__submenu-btn,
.nav-item.has-children.is-hover-open .nav-item__submenu-btn,
.nav-item.has-children.is-submenu-open .nav-item__submenu-btn {
    background: var(--mega-nav-submenu-btn-bg);
    box-shadow: inset 0 0 0 1px var(--mega-tray-border);
}

.dropdown.dropdown--mega-irc {
    min-width: min(880px, calc(100vw - 2rem));
    max-width: min(1040px, calc(100vw - 1.5rem));
    padding: 0;
    border-radius: 16px;
    background: var(--mega-tray-bg);
    border: 1px solid var(--mega-tray-border);
    box-shadow: var(--mega-tray-shadow);
    backdrop-filter: blur(12px);
}

.dropdown.dropdown--mega-irc::after {
    display: none;
}

.dropdown.dropdown--mega-irc .dropdown__inner--mega-irc {
    padding: 0;
}

.dropdown.dropdown--mega-irc .dropdown__inner::before {
    display: none;
}

.dropdown-mega {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0 2.5rem;
    padding: 1.65rem 2.25rem 1.85rem;
}

.dropdown.dropdown--mega-irc.dropdown--mega-single {
    min-width: min(300px, calc(100vw - 2rem));
    max-width: min(380px, calc(100vw - 2rem));
}

.dropdown-mega.dropdown-mega--single {
    grid-template-columns: 1fr;
    gap: 1.15rem 0;
    padding: 1.35rem 1.65rem 1.5rem;
}

.dropdown-mega__heading {
    margin: 0 0 0.85rem;
    font-size: 0.94rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    color: var(--mega-tray-heading);
}

.dropdown-mega__list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.dropdown-mega__item {
    margin: 0;
    border-bottom: 1px solid var(--mega-tray-divider);
}

.dropdown-mega__item:last-child {
    border-bottom: 0;
}

.dropdown-mega__link {
    display: block;
    padding: 0.62rem 0;
    font-size: 1.06rem;
    font-weight: 700;
    line-height: 1.28;
    color: var(--mega-tray-link);
    text-decoration: none;
    opacity: 1;
    transform: none;
    transition:
        color 0.15s ease,
        opacity 0.15s ease;
}

.dropdown-mega__link:hover,
.dropdown-mega__link:focus-visible {
    color: var(--mega-tray-link-hover);
    text-decoration: underline;
    text-decoration-color: var(--mega-tray-link-hover);
    text-decoration-thickness: 2px;
    text-underline-offset: 0.18em;
}

.dropdown-mega__link.is-current {
    color: var(--mega-tray-link-hover);
    text-decoration: underline;
    text-decoration-color: color-mix(in srgb, var(--mega-tray-link-hover) 85%, var(--brand-blue-dark));
    text-decoration-thickness: 2px;
    text-underline-offset: 0.18em;
}

.dropdown.dropdown--mega-irc.dropdown--where-accordion {
    left: 50%;
    right: auto;
    transform: translateX(-50%) translateY(12px) scale(0.96);
    transform-origin: top center;
    min-width: min(920px, calc(100vw - 2rem));
    max-width: min(920px, calc(100vw - 2rem));
}

.nav-item.has-children:hover .dropdown.dropdown--where-accordion,
.nav-item.has-children:focus-within .dropdown.dropdown--where-accordion {
    transform: translateX(-50%) translateY(0) scale(1);
}

@media (hover: none) and (min-width: 961px) {
    .nav-item.has-children:hover .dropdown.dropdown--where-accordion {
        transform: translateX(-50%) translateY(12px) scale(0.96);
    }

    .nav-item.has-children.is-touch-open .dropdown.dropdown--where-accordion {
        transform: translateX(-50%) translateY(0) scale(1);
    }
}

.where-accordion {
    padding: 0.35rem 0 0.15rem;
}

.where-accordion__overview {
    display: block;
    padding: 0.85rem 1.35rem;
    font-size: 1.05rem;
    font-weight: 700;
    line-height: 1.3;
    color: var(--mega-tray-link);
    text-decoration: none;
    border-bottom: 1px solid var(--mega-tray-divider);
}

.where-accordion__overview:hover,
.where-accordion__overview:focus-visible {
    color: var(--mega-tray-link-hover);
    text-decoration: underline;
    text-decoration-color: var(--mega-tray-link-hover);
    text-decoration-thickness: 2px;
    text-underline-offset: 0.18em;
}

.where-accordion__overview.is-current {
    color: var(--mega-tray-link-hover);
}

.where-accordion__block {
    border-bottom: 1px solid var(--mega-tray-divider);
}

.where-accordion__block:last-child {
    border-bottom: 0;
}

.where-accordion__head {
    display: flex;
    align-items: stretch;
    gap: 0.35rem;
    min-height: 3.1rem;
}

.where-accordion__province {
    flex: 1;
    display: flex;
    align-items: center;
    padding: 0.75rem 0.35rem 0.75rem 1.35rem;
    font-size: 1.05rem;
    font-weight: 700;
    line-height: 1.3;
    color: var(--mega-tray-link);
    text-decoration: none;
}

.where-accordion__province:hover,
.where-accordion__province:focus-visible {
    color: var(--mega-tray-link-hover);
    text-decoration: underline;
    text-decoration-color: var(--mega-tray-link-hover);
    text-decoration-thickness: 2px;
    text-underline-offset: 0.18em;
}

.where-accordion__province.is-current {
    color: var(--mega-tray-link-hover);
}

.where-accordion__toggle {
    flex: 0 0 auto;
    width: 3.1rem;
    margin: 0.35rem 0.65rem 0.35rem 0;
    border: 0;
    border-radius: 12px;
    background: color-mix(in srgb, var(--brand-blue-dark) 6%, transparent);
    color: var(--mega-tray-link);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition:
        background 0.15s ease,
        color 0.15s ease;
}

.where-accordion__toggle:hover,
.where-accordion__toggle:focus-visible {
    background: color-mix(in srgb, var(--accent) 14%, transparent);
    color: var(--mega-tray-link-hover);
    outline: none;
}

.where-accordion__toggle-icon {
    font-size: 1.35rem;
    font-weight: 800;
    line-height: 1;
}

.where-accordion__toggle-icon::before {
    content: "+";
}

.where-accordion__toggle[aria-expanded="true"] .where-accordion__toggle-icon::before {
    content: "\2212";
}

.where-accordion__panel {
    margin: 0 0.35rem 0.5rem;
    padding: 0;
    border-radius: 0 0 14px 14px;
    border: 1px solid color-mix(in srgb, var(--mega-tray-divider) 72%, transparent);
    background: color-mix(in srgb, var(--surface) 55%, var(--theme-hero-soft) 45%);
    box-shadow: inset 0 1px 0 color-mix(in srgb, white 55%, transparent);
}

.where-accordion__cities {
    list-style: none;
    margin: 0;
    padding: 0.95rem 1.15rem 1.1rem;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    column-gap: 1.75rem;
    row-gap: 0.42rem;
    align-items: start;
}

.where-accordion__city-item {
    margin: 0;
    padding: 0;
    min-width: 0;
}

.where-accordion__city-link {
    display: block;
    padding: 0.28rem 0;
    font-size: 0.95rem;
    font-weight: 700;
    line-height: 1.35;
    color: var(--mega-tray-link);
    text-decoration: none;
    overflow-wrap: anywhere;
}

.where-accordion__city-link:hover,
.where-accordion__city-link:focus-visible {
    color: var(--mega-tray-link-hover);
    text-decoration: underline;
    text-decoration-thickness: 2px;
    text-underline-offset: 0.18em;
}

.where-accordion__city-link.is-current {
    color: var(--mega-tray-link-hover);
}

.where-accordion__city-muted {
    display: block;
    padding: 0.28rem 0;
    font-size: 0.95rem;
    font-weight: 700;
    line-height: 1.35;
    color: color-mix(in srgb, var(--mega-tray-link) 52%, var(--muted));
    overflow-wrap: anywhere;
}

@media (max-width: 900px) {
    .where-accordion__cities {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        column-gap: 1.25rem;
    }
}

@media (max-width: 1024px) {
    .dropdown.dropdown--mega-irc {
        min-width: min(640px, calc(100vw - 2rem));
        max-width: min(720px, calc(100vw - 1.5rem));
    }

    .dropdown.dropdown--mega-irc.dropdown--mega-single {
        min-width: min(300px, calc(100vw - 2rem));
        max-width: min(380px, calc(100vw - 2rem));
    }

    .dropdown.dropdown--mega-irc.dropdown--where-accordion {
        min-width: min(640px, calc(100vw - 2rem));
        max-width: min(720px, calc(100vw - 1.5rem));
    }

    .dropdown-mega {
        gap: 0 1.75rem;
        padding: 1.35rem 1.5rem 1.55rem;
    }
}

.dropdown__link-kicker {
    display: inline-flex;
    align-items: center;
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--brand-blue-dark) 70%, white 30%);
}

.dropdown__link-text {
    display: block;
    font-size: 1rem;
    font-weight: 800;
    color: var(--surface-deep);
}

.dropdown__link-meta {
    display: block;
    font-size: 0.84rem;
    font-weight: 600;
    line-height: 1.5;
    color: var(--muted);
}

.nav-item.has-children:hover .dropdown__link,
.nav-item.has-children:focus-within .dropdown__link,
.nav-item.has-children.is-touch-open .dropdown__link,
.nav-item.has-children.is-submenu-open .dropdown__link,
.nav-item.has-children.is-hover-open .dropdown__link {
    opacity: 1;
    transform: translateY(0);
}

.dropdown__link:nth-child(1) { transition-delay: 0.02s; }
.dropdown__link:nth-child(2) { transition-delay: 0.045s; }
.dropdown__link:nth-child(3) { transition-delay: 0.07s; }
.dropdown__link:nth-child(4) { transition-delay: 0.095s; }
.dropdown__link:nth-child(5) { transition-delay: 0.12s; }
.dropdown__link:nth-child(6) { transition-delay: 0.145s; }
.dropdown__link:nth-child(7) { transition-delay: 0.17s; }
.dropdown__link:nth-child(8) { transition-delay: 0.195s; }

.dropdown__link:hover,
.dropdown__link:focus-visible,
.dropdown__link.is-current {
    color: var(--brand-blue-dark);
    border-color: color-mix(in srgb, var(--logo-blue-deep) 18%, transparent);
    box-shadow:
        0 12px 24px rgba(0, 62, 115, 0.1),
        0 0 0 1px color-mix(in srgb, var(--logo-blue-deep) 10%, transparent);
    transform: translateY(0) translateX(4px);
}

.dropdown__link:hover::before,
.dropdown__link:focus-visible::before,
.dropdown__link.is-current::before {
    opacity: 1;
}

.dropdown__link:hover::after,
.dropdown__link:focus-visible::after,
.dropdown__link.is-current::after {
    opacity: 1;
    transform: scaleX(1);
}

.dropdown__link.is-current {
    background: linear-gradient(90deg, color-mix(in srgb, var(--logo-blue-deep) 12%, transparent), color-mix(in srgb, var(--accent) 8%, transparent));
    border-color: color-mix(in srgb, var(--accent) 18%, transparent);
    box-shadow:
        0 14px 28px rgba(0, 62, 115, 0.12),
        0 0 0 1px color-mix(in srgb, var(--accent) 12%, transparent),
        0 0 24px color-mix(in srgb, var(--accent) 10%, transparent);
}

.dropdown__link.is-current .dropdown__link-kicker {
    color: var(--accent-dark);
}

.dropdown__link.is-current .dropdown__link-text {
    color: var(--brand-blue-dark);
}

.mobile-nav-toggle {
    min-height: 48px;
    padding: 0.7rem 1rem;
    border-radius: 16px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(244, 248, 255, 0.94));
    box-shadow:
        0 12px 28px rgba(7, 18, 42, 0.08),
        inset 0 0 0 1px color-mix(in srgb, var(--logo-blue-deep) 12%, transparent);
}

.mobile-nav-toggle:hover {
    transform: translateY(-1px);
}

@media (max-width: 960px) {
    .main-header {
        padding: 0.85rem 0.9rem 0.95rem;
        border-radius: 22px;
    }

    .main-nav-wrap.is-open {
        animation: menuPanelIn 0.28s ease;
        max-height: min(72vh, calc(100dvh - var(--header-offset, 120px) - 0.75rem));
        overflow-x: hidden;
        overflow-y: auto;
        overscroll-behavior: contain;
        -webkit-overflow-scrolling: touch;
        margin-top: 0.35rem;
        padding-bottom: max(0.5rem, env(safe-area-inset-bottom, 0px));
        scrollbar-gutter: stable;
    }

    .main-nav {
        padding: 0.9rem;
        border-radius: 20px;
        background:
            linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 255, 0.98));
        box-shadow:
            0 18px 44px rgba(7, 18, 42, 0.08),
            inset 0 0 0 1px color-mix(in srgb, var(--logo-blue-deep) 10%, transparent);
    }

    .main-nav__links {
        gap: 0.35rem;
        width: 100%;
    }

    .main-nav .nav-item {
        width: 100%;
    }

    .main-nav .nav-item__link {
        width: 100%;
        min-height: 50px;
        padding: 0.85rem 0.95rem;
        border-radius: 14px;
    }

    .nav-item.has-children .nav-item__top {
        align-items: stretch;
        gap: 0.5rem;
    }

    .dropdown {
        border-radius: 0;
    }

    .dropdown::after {
        display: none;
    }

    .dropdown__layout {
        grid-template-columns: 1fr;
        gap: 0.55rem;
    }

    .dropdown__intro {
        padding: 1rem;
        border-radius: 16px;
    }

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

    .dropdown__title,
    .dropdown__summary,
    .dropdown__link-text,
    .dropdown__link-meta {
        overflow-wrap: anywhere;
        word-break: break-word;
    }

    .dropdown__inner {
        padding: 0.5rem;
        border-radius: 16px;
    }

    .dropdown__link {
        transform: none;
        opacity: 1;
        font-size: 0.92rem;
    }

    .dropdown__link::after {
        left: 0.95rem;
        right: 0.95rem;
        bottom: 0.68rem;
    }

    .dropdown.dropdown--mega-irc {
        min-width: 100%;
        max-width: none;
    }

    .dropdown.dropdown--mega-irc .dropdown__inner--mega-irc {
        background: transparent;
        box-shadow: none;
        border-radius: 0;
        padding: 0;
    }

    .dropdown-mega {
        grid-template-columns: 1fr;
        gap: 1.25rem 0;
        padding: 1.1rem 1rem 1.25rem;
    }

    .dropdown-mega__link {
        font-size: 1rem;
        padding: 0.58rem 0;
    }

    .where-accordion {
        padding: 0.15rem 0 0;
    }

    .where-accordion__overview {
        padding: 0.75rem 0.85rem;
    }

    .where-accordion__province {
        padding: 0.65rem 0.35rem 0.65rem 0.85rem;
    }

    .where-accordion__panel {
        margin: 0 0 0.35rem;
        border-radius: 0 0 12px 12px;
    }

    .where-accordion__cities {
        grid-template-columns: 1fr;
        padding: 0.75rem 0.85rem 0.9rem;
        column-gap: 0;
        row-gap: 0.35rem;
    }

    .nav-item.has-children.is-submenu-open .nav-item__link,
    .nav-item.has-children.is-submenu-open .nav-item__submenu-btn {
        background: var(--mega-nav-tab-bg);
        color: var(--mega-nav-tab-fg);
        box-shadow: none;
    }
}

@keyframes menuPanelIn {
    from {
        opacity: 0;
        transform: translateY(-8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@media (prefers-reduced-motion: reduce) {
    .main-nav-wrap.is-open {
        animation: none;
    }
}

/* --- Where We Work (provincial hub) --- */
.where-district-figure {
    margin: 0;
}

.where-district-figure__img {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 18px;
    box-shadow:
        0 18px 40px rgba(12, 24, 48, 0.1),
        0 0 0 1px color-mix(in srgb, var(--logo-blue-deep) 10%, transparent);
}

/* Where We Work — hero collage background (www-) */
.www-hero {
    position: relative;
    isolation: isolate;
    overflow: hidden;
    min-height: clamp(380px, 52vh, 520px);
    padding: clamp(2.75rem, 6vw, 4rem) 0 clamp(2.25rem, 4.5vw, 3rem);
    background: #f4f8fc;
}

.www-hero__collage {
    position: absolute;
    inset: 0;
    z-index: 0;
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    grid-template-rows: repeat(2, 1fr);
    gap: 4px;
    background: var(--surface-deep);
}

.www-hero__collage-cell {
    background-size: cover;
    background-position: center;
    opacity: 0.52;
    filter: saturate(0.92) brightness(0.94);
    transition: opacity 0.4s ease;
}

.www-hero__collage-cell--1 {
    grid-column: 1 / 3;
    grid-row: 1 / 2;
}

.www-hero__collage-cell--2 {
    grid-column: 3 / 5;
    grid-row: 1 / 2;
}

.www-hero__collage-cell--3 {
    grid-column: 5 / 7;
    grid-row: 1 / 2;
}

.www-hero__collage-cell--4 {
    grid-column: 1 / 3;
    grid-row: 2 / 3;
}

.www-hero__collage-cell--5 {
    grid-column: 3 / 5;
    grid-row: 2 / 3;
}

.www-hero__collage-cell--6 {
    grid-column: 5 / 7;
    grid-row: 2 / 3;
}

.www-hero__overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    background: linear-gradient(
        108deg,
        rgba(255, 255, 255, 0.97) 0%,
        rgba(255, 255, 255, 0.94) 28%,
        rgba(248, 251, 255, 0.86) 48%,
        rgba(244, 248, 252, 0.72) 68%,
        rgba(240, 246, 252, 0.5) 100%
    );
}

.www-hero__mesh {
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    opacity: 0.65;
    background:
        radial-gradient(ellipse 45% 38% at 4% 20%, color-mix(in srgb, var(--accent) 14%, transparent), transparent 58%),
        radial-gradient(ellipse 40% 36% at 96% 80%, color-mix(in srgb, var(--logo-blue-deep) 10%, transparent), transparent 55%);
}

.www-hero::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 3;
    height: 48px;
    pointer-events: none;
    background: linear-gradient(to bottom, transparent, var(--surface));
}

.www-hero__grid {
    position: relative;
    z-index: 4;
    display: flex;
    align-items: center;
    min-height: clamp(280px, 38vh, 400px);
}

.www-hero__panel {
    max-width: min(40rem, 100%);
    padding: clamp(1.35rem, 3vw, 2rem);
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(255, 255, 255, 0.95);
    box-shadow:
        0 28px 64px color-mix(in srgb, var(--surface-deep) 10%, transparent),
        0 1px 0 rgba(255, 255, 255, 0.9) inset;
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
}

.www-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin: 0 0 0.75rem;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--accent);
}

.www-hero__eyebrow-dot {
    width: 0.45rem;
    height: 0.45rem;
    border-radius: 999px;
    background: var(--accent);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 22%, transparent);
}

.www-hero__title {
    margin: 0;
    font-family: "Libre Baskerville", Georgia, serif;
    font-size: clamp(2rem, 4.5vw, 2.85rem);
    font-weight: 700;
    line-height: 1.1;
    color: var(--surface-deep);
    text-wrap: balance;
}

.www-hero__lead {
    margin: 1rem 0 0;
    max-width: 48ch;
    font-size: clamp(1.02rem, 2vw, 1.12rem);
    line-height: 1.65;
    color: var(--muted);
}

.www-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    margin: 1.35rem 0 0;
    padding: 0;
}

.www-hero__cta {
    margin: 0;
    box-shadow: 0 12px 28px color-mix(in srgb, var(--accent) 28%, transparent);
}

.www-hero__cta-secondary {
    margin: 0;
    color: var(--accent-dark);
    border-color: color-mix(in srgb, var(--accent) 35%, var(--border));
    background: rgba(255, 255, 255, 0.75);
}

.www-hero__cta-secondary:hover {
    background: color-mix(in srgb, var(--accent-soft) 40%, var(--surface));
    border-color: var(--accent);
}

@media (max-width: 720px) {
    .www-hero {
        min-height: auto;
        padding: clamp(2rem, 5vw, 2.75rem) 0;
    }

    .www-hero__grid {
        min-height: 0;
    }

    .www-hero__collage {
        grid-template-columns: repeat(3, 1fr);
        grid-template-rows: repeat(4, 1fr);
    }

    .www-hero__collage-cell--1 { grid-column: 1 / 3; grid-row: 1 / 2; }
    .www-hero__collage-cell--2 { grid-column: 3 / 4; grid-row: 1 / 3; }
    .www-hero__collage-cell--3 { grid-column: 1 / 2; grid-row: 2 / 3; }
    .www-hero__collage-cell--4 { grid-column: 2 / 3; grid-row: 2 / 3; }
    .www-hero__collage-cell--5 { grid-column: 1 / 3; grid-row: 3 / 4; }
    .www-hero__collage-cell--6 { grid-column: 3 / 4; grid-row: 3 / 5; }

    .www-hero__overlay {
        background: linear-gradient(
            180deg,
            rgba(255, 255, 255, 0.96) 0%,
            rgba(255, 255, 255, 0.92) 55%,
            rgba(248, 251, 255, 0.82) 100%
        );
    }

    .www-hero__panel {
        width: 100%;
    }
}

.where-we-work-subnav {
    position: sticky;
    top: 0;
    z-index: 30;
    background: color-mix(in srgb, var(--surface, #ffffff) 92%, transparent);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid color-mix(in srgb, var(--text, #0b1220) 8%, transparent);
}

.where-we-work-subnav__inner {
    display: flex;
    flex-wrap: wrap;
    gap: 0.28rem 0.35rem;
    padding: 0.5rem 0;
    align-items: center;
}

.where-we-work-subnav__link {
    display: inline-flex;
    align-items: center;
    padding: 0.28rem 0.55rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text, #0b1220);
    text-decoration: none;
    border: 1px solid transparent;
    transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.where-we-work-subnav__link:hover {
    background: color-mix(in srgb, var(--accent, #ff2d55) 10%, transparent);
    border-color: color-mix(in srgb, var(--accent, #ff2d55) 35%, transparent);
}

.where-we-work-subnav__link.is-active {
    background: var(--header, #08122a);
    color: #f8fafc;
    border-color: transparent;
}

.where-we-work-map-section {
    padding-top: 0.5rem;
}

/* Where we work pages: heading + map centred; map above district list */
.where-we-work-map-section .section-heading.section-heading--map {
    text-align: center;
}

.where-we-work-map-section .section-heading.section-heading--map p {
    margin-left: auto;
    margin-right: auto;
    max-width: 42rem;
}

/* stretch cross-axis so map column keeps full width; center was shrinking %width children to ~0 */
.where-we-work-map-section .act-footprint-stage {
    flex-direction: column;
    align-items: stretch;
}

.where-we-work-map-section .act-footprint-split__map {
    flex: 0 0 auto;
    width: 100%;
    max-width: min(1072px, 100%);
    margin-inline: auto;
}

.where-we-work-map-section .act-footprint-split__aside {
    flex: 0 0 auto;
    width: 100%;
    max-width: min(1072px, 100%);
    margin-inline: auto;
    max-height: none;
    border-left: none;
    border-top: 1px solid color-mix(in srgb, var(--logo-blue-deep) 12%, transparent);
}

.page-hero--about__actions {
    margin-top: 0.75rem;
}

/* IRC-style header layout */
.site-header .header-shell {
    padding: 0;
}

.site-header .container {
    max-width: 100%;
    padding-left: 0;
    padding-right: 0;
}

.site-header .utility-bar {
    background: #050505 !important;
    border-radius: 0;
    min-height: 1.6rem;
    padding: 0.22rem clamp(1.25rem, 4vw, 3rem);
    display: flex;
    gap: 0.7rem;
    align-items: center;
    justify-content: space-between;
}

.utility-bar__alert {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    color: #ffffff;
    font-size: 0.76rem;
    line-height: 1.2;
    min-width: 0;
}

.utility-bar__alert-prefix {
    color: #d7d7d7;
    text-transform: lowercase;
}

.utility-bar__alert-text {
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.site-header .utility-bar__end {
    margin-left: auto;
    gap: 0.45rem;
}

.site-header .utility-bar .social-links.social-links--header .social-link {
    position: relative !important;
    display: inline-grid !important;
    place-items: center !important;
    width: 2.45rem !important;
    height: 2.45rem !important;
    min-width: 2.45rem !important;
    min-height: 2.45rem !important;
    padding: 0 !important;
    line-height: 1 !important;
    background: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(255, 255, 255, 0.24) !important;
    border-radius: 999px !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
}

.site-header .utility-bar .social-links.social-links--header .social-link:hover,
.site-header .utility-bar .social-links.social-links--header .social-link:focus-visible {
    background: rgba(255, 255, 255, 0.18) !important;
    border-color: rgba(255, 255, 255, 0.36) !important;
    border-radius: 999px !important;
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.18) !important;
    transform: translateY(-1px) !important;
}

.site-header .utility-bar .social-links.social-links--header .social-link svg {
    display: block !important;
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    width: 1.1rem !important;
    height: 1.1rem !important;
    transform: translate(-50%, -50%) !important;
}

.site-header .utility-bar .social-links.social-links--header .social-link__icon {
    position: absolute !important;
    inset: 0 !important;
    display: grid !important;
    place-items: center !important;
    width: 100% !important;
    height: 100% !important;
    line-height: 0 !important;
}

.site-header .utility-nav {
    gap: 0.85rem;
    align-items: center;
}

.site-header .utility-bar .utility-nav__link {
    color: #f4f4f4;
    font-size: 0.75rem;
    font-weight: 500;
    opacity: 0.9;
    position: relative;
    padding: 0 0.1rem;
}

.site-header .utility-bar .utility-nav__link--login {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.site-header .utility-bar .utility-nav__status {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.75rem;
    font-weight: 600;
    color: #ffffff;
    opacity: 0.95;
}

.site-header .utility-bar .utility-nav__status-dot {
    width: 0.45rem;
    height: 0.45rem;
    border-radius: 50%;
    background: #4ade80;
    box-shadow: 0 0 0 2px rgba(74, 222, 128, 0.35);
    flex-shrink: 0;
}

.site-header .utility-bar .utility-nav__link--admin {
    font-weight: 600;
}

.site-header .utility-bar .utility-nav__link--logout {
    opacity: 0.85;
}

.site-header .utility-bar .utility-nav__icon {
    display: inline-flex;
    line-height: 0;
    opacity: 0.9;
}

.site-header .utility-bar .utility-nav__link:hover {
    color: #ffffff;
    opacity: 1;
}

.site-header .utility-bar .utility-nav__link + .utility-nav__link {
    margin-left: 0.55rem;
}

.site-header .utility-bar .utility-nav__link + .utility-nav__link::before {
    content: "";
    position: absolute;
    left: -0.6rem;
    top: 50%;
    width: 1px;
    height: 0.72rem;
    background: rgba(255, 255, 255, 0.28);
    transform: translateY(-50%);
}

.site-header .main-header {
    border-radius: 0;
    border: 0;
    border-bottom: 1px solid rgba(0, 0, 0, 0.12);
    box-shadow: none;
    background: #ffffff;
    padding: 0;
    min-height: 4.5rem;
}

.site-header .main-header::before {
    display: none;
}

.site-header .site-brand {
    background: transparent;
    align-self: center;
    min-height: 0;
    width: auto;
    min-width: 0;
    max-width: min(320px, 42vw);
    justify-content: flex-start;
    padding: 0.35rem 0.75rem 0.35rem 1rem;
    margin-right: 0;
    border-right: none;
}

.site-header .site-brand__logo {
    max-height: 3.8rem !important;
    width: auto !important;
}

.site-header .main-nav {
    padding-right: 0;
}

.site-header .main-nav__links {
    gap: 0;
    align-items: stretch;
}

.site-header .nav-item__link {
    min-height: 4.5rem;
    border-radius: 0;
    font-size: clamp(0.9rem, 0.82rem + 0.22vw, 1rem);
    font-weight: 600;
    color: #1a1a1a;
    letter-spacing: 0.015em;
    padding: 0 1.15rem;
    text-transform: none;
    transition:
        background 0.2s ease,
        color 0.18s ease;
}

.site-header .nav-item + .nav-item .nav-item__link {
    border-left: 1px solid rgba(0, 0, 0, 0.06);
}

.site-header .nav-item__link::before,
.site-header .nav-item__link::after {
    display: none;
}

.site-header .nav-item__link:hover,
.site-header .nav-item__link:focus-visible,
.site-header .nav-item.is-current .nav-item__link {
    color: #0a0a0a;
    background: color-mix(in srgb, var(--brand-blue) 7%, #ffffff);
    box-shadow: none;
    transform: none;
}

.site-header .nav-item.is-current .nav-item__link {
    font-weight: 700;
    color: var(--brand-blue-dark, #0d3a6d);
    background: color-mix(in srgb, var(--brand-blue) 10%, #ffffff);
}

.site-header--scrolled .utility-bar {
    display: none;
}

.site-header--scrolled .main-header {
    min-height: 3.55rem;
}

.site-header--scrolled .site-brand {
    min-height: 0;
}

.site-header--scrolled .site-brand__logo {
    max-height: 2.75rem !important;
}

.site-header--scrolled .nav-item__link {
    min-height: 3.55rem;
    padding-left: 0.86rem;
    padding-right: 0.86rem;
}

.site-header--scrolled .header-actions .header-donate-btn {
    min-height: 3.55rem;
    min-width: 8.4rem;
    padding-left: 1.15rem;
    padding-right: 1.15rem;
}

.header-actions {
    align-self: stretch;
    gap: 0;
}

.header-actions .header-contact-btn {
    display: none;
}

/* Inline expanding search: icon strip grows into field + actions */
.header-search-expand {
    align-self: stretch;
    display: flex;
    align-items: stretch;
    flex-shrink: 0;
    max-width: 3.5rem;
    overflow: hidden;
    transition: max-width 0.32s cubic-bezier(0.4, 0, 0.2, 1);
    border-left: 1px solid rgba(0, 0, 0, 0.12);
    border-right: 1px solid rgba(0, 0, 0, 0.12);
    box-sizing: border-box;
}

.site-header--scrolled .header-search-expand:not(.is-open) {
    max-width: 2.95rem;
}

.header-search-expand.is-open {
    max-width: min(440px, calc(100vw - 11rem));
}

.header-search-expand__form {
    display: flex;
    align-items: stretch;
    height: 100%;
    min-height: 100%;
}

.header-search-expand__toggle {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3.5rem;
    margin: 0;
    padding: 0;
    color: #111111;
    background: transparent;
    border: 0;
    border-radius: 0;
    cursor: pointer;
    font: inherit;
    line-height: 0;
}

.site-header--scrolled .header-search-expand:not(.is-open) .header-search-expand__toggle {
    width: 2.95rem;
}

.header-search-expand__toggle:hover {
    color: #000000;
    background: rgba(0, 0, 0, 0.04);
}

.header-search-expand__toggle:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--theme-button-bg, var(--brand-blue)) 65%, #ffffff);
    outline-offset: -2px;
}

.header-search-expand.is-open .header-search-expand__toggle {
    display: none;
}

.header-search-expand__expanded {
    display: none;
    align-items: stretch;
    flex: 1 1 auto;
    gap: 0.35rem;
    min-width: 0;
    padding-right: 0.25rem;
}

.header-search-expand.is-open .header-search-expand__expanded {
    display: flex;
}

.header-search-expand__prefix {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 2rem;
    color: rgba(0, 0, 0, 0.42);
    padding-left: 0.35rem;
}

.header-search-expand__field {
    display: flex;
    align-items: stretch;
    flex: 1;
    min-width: 0;
}

.header-search-expand__input {
    width: 100%;
    box-sizing: border-box;
    padding: 0.45rem 0.55rem;
    border: 1px solid rgba(0, 0, 0, 0.14);
    border-radius: 8px;
    font-size: 0.92rem;
    font-family: inherit;
    background: #ffffff;
    color: #111111;
}

.header-search-expand__input::placeholder {
    color: rgba(0, 0, 0, 0.38);
}

.header-search-expand__input:focus {
    outline: none;
    border-color: color-mix(in srgb, var(--theme-button-bg, var(--brand-blue)) 55%, rgba(0, 0, 0, 0.25));
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--theme-button-bg, var(--brand-blue)) 18%, transparent);
}

.header-search-expand__close {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.35rem;
    margin: 0;
    padding: 0;
    border: 0;
    border-radius: 8px;
    background: transparent;
    color: rgba(0, 0, 0, 0.52);
    cursor: pointer;
    align-self: center;
}

.header-search-expand__close:hover {
    color: #111111;
    background: rgba(0, 0, 0, 0.06);
}

@media (max-width: 980px) {
    .header-search-expand.is-open {
        max-width: min(380px, calc(100vw - 8.5rem));
    }
}

@media (max-width: 640px) {
    .header-search-expand.is-open {
        max-width: calc(100vw - 5.25rem);
        flex: 1 1 auto;
        min-width: 0;
    }

    .header-search-expand__prefix {
        display: none;
    }
}

@media (max-width: 420px) {
    .site-header .header-actions {
        display: flex;
        flex-wrap: nowrap;
        align-items: stretch;
        gap: 0;
        width: auto;
        min-width: 0;
    }
}

.header-actions .header-donate-btn {
    align-self: stretch;
    min-height: 4.5rem;
    min-width: 9.2rem;
    border-radius: 0;
    padding: 0 1.4rem;
    background: linear-gradient(
        135deg,
        var(--theme-button-hover, var(--brand-blue-dark)) 0%,
        var(--theme-button-bg, var(--brand-blue)) 100%
    );
    color: #ffffff;
    font-weight: 700;
    box-shadow: none;
    border-left: 1px solid color-mix(in srgb, var(--theme-header-bg, var(--brand-blue-dark)) 22%, transparent);
}

.header-actions .header-donate-btn:hover {
    background: linear-gradient(
        135deg,
        color-mix(in srgb, var(--theme-button-hover, var(--brand-blue-dark)) 88%, #000000 12%) 0%,
        color-mix(in srgb, var(--theme-button-bg, var(--brand-blue)) 88%, #000000 12%) 100%
    );
    color: #ffffff;
}

.site-header .dropdown.dropdown--mega-irc.dropdown--where-accordion {
    min-width: min(440px, calc(100vw - 1.5rem));
    max-width: min(440px, calc(100vw - 1.5rem));
}

.site-header .where-accordion {
    padding: 0.15rem 0;
}

.site-header .where-accordion__overview,
.site-header .where-accordion__province {
    display: block;
    padding: 0.72rem 1rem;
    font-size: 0.98rem;
}

.site-header .where-accordion__block {
    border-bottom: 1px solid var(--mega-tray-divider);
}

.site-header .where-accordion__block:last-child {
    border-bottom: 0;
}

.site-header .where-accordion__head,
.site-header .where-accordion__toggle,
.site-header .where-accordion__panel,
.site-header .where-accordion__cities {
    display: none;
}

@media (max-width: 1100px) {
    .site-header .nav-item__link {
        font-size: 0.9rem;
        padding: 0 0.72rem;
    }

    .site-header .nav-item + .nav-item .nav-item__link {
        border-left-color: rgba(0, 0, 0, 0.06);
    }
}

@media (max-width: 980px) {
    .site-header .utility-bar {
        padding: 0.28rem clamp(0.9rem, 4.8vw, 1.4rem);
    }

    .site-header .utility-nav {
        gap: 0.55rem;
    }

    .site-header .utility-bar .utility-nav__link + .utility-nav__link {
        margin-left: 0.3rem;
    }

    .site-header .utility-bar .utility-nav__link + .utility-nav__link::before {
        left: -0.4rem;
        height: 0.62rem;
    }

    .site-header .utility-bar .utility-nav__link {
        font-size: 0.72rem;
    }

    .site-header--scrolled .main-header,
    .site-header--scrolled .nav-item__link,
    .site-header--scrolled .header-actions .header-donate-btn {
        min-height: 3.35rem;
    }

    .site-header--scrolled .site-brand {
        min-height: 0;
    }

    .site-header .nav-item + .nav-item .nav-item__link {
        border-left: 0;
    }

    .header-actions .header-donate-btn {
        min-height: 3.75rem;
        padding: 0 1.1rem;
        min-width: 7.4rem;
    }

    .site-header .dropdown.dropdown--mega-irc.dropdown--where-accordion {
        min-width: min(340px, calc(100vw - 1rem));
        max-width: min(360px, calc(100vw - 1rem));
    }
}

/* Admin refresh */
.admin-body {
    background: radial-gradient(circle at top right, #dbeafe 0%, #eef2ff 32%, #f8fafc 100%);
}

.admin-sidebar {
    border-right: 1px solid rgba(255, 255, 255, 0.14);
}

.admin-nav a {
    border-radius: 10px;
    margin-bottom: 0.2rem;
    transition: background-color 0.15s ease, transform 0.15s ease;
}

.admin-nav a:hover {
    transform: translateX(3px);
    background: rgba(255, 255, 255, 0.1);
}

.admin-nav .is-active {
    background: rgba(255, 255, 255, 0.2);
}

.admin-content {
    padding: 1.6rem 1.8rem;
}

.admin-topbar {
    background: rgba(255, 255, 255, 0.9);
    border-radius: 16px;
    border: 1px solid rgba(148, 163, 184, 0.3);
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
}

.admin-panel {
    border: 1px solid rgba(148, 163, 184, 0.3);
    border-radius: 16px;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.06);
}

.admin-form input,
.admin-form select,
.admin-form textarea {
    border-radius: 12px;
}

.admin-table th {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #475569;
}

.admin-table tbody tr:hover {
    background: rgba(59, 130, 246, 0.06);
}

.permission-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 0.75rem;
}

.permission-card {
    border: 1px solid rgba(148, 163, 184, 0.3);
    border-radius: 12px;
    padding: 0.8rem;
    background: #ffffff;
}

.permission-card h3 {
    margin: 0 0 0.5rem;
    font-size: 0.9rem;
}

.permission-check {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin: 0.28rem 0;
    font-size: 0.86rem;
}

.admin-table__actions form {
    display: inline-block;
    margin: 0;
}

.btn-link-danger {
    border: 0;
    background: transparent;
    color: #b91c1c;
    font-weight: 600;
    cursor: pointer;
    padding: 0;
}

.btn-link-danger:hover {
    text-decoration: underline;
}

.login-body {
    background: linear-gradient(120deg, #020617 0%, #172554 40%, #0f766e 100%);
}

.login-shell {
    width: min(980px, 94vw);
    min-height: 70vh;
    display: grid;
    grid-template-columns: 1fr 1fr;
    border-radius: 22px;
    overflow: hidden;
    box-shadow: 0 28px 60px rgba(2, 6, 23, 0.35);
}

.login-card {
    background: #ffffff;
    padding: 2.3rem;
}

.login-kicker {
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #475569;
    font-size: 0.75rem;
    margin-bottom: 0.7rem;
}

.login-side {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.06));
    color: #f8fafc;
    padding: 2.3rem;
}

.login-side ul {
    margin: 1rem 0 0;
    padding-left: 1rem;
}

@media (max-width: 900px) {
    .login-shell {
        grid-template-columns: 1fr;
    }
}

/* Our Work — thematic portfolio (ow-) */
.ow-hero {
    position: relative;
    isolation: isolate;
    overflow: hidden;
    padding: clamp(2.75rem, 6vw, 4.25rem) 0 clamp(2.5rem, 5vw, 3.25rem);
    color: var(--text);
    background: #f4f8fc;
}

.ow-hero--has-bg .ow-hero__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    background: var(--ow-hero-bg) center 35% / cover no-repeat;
    transform: scale(1.06);
    filter: saturate(1.05);
}

.ow-hero__overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    background: linear-gradient(
        102deg,
        rgba(255, 255, 255, 0.97) 0%,
        rgba(255, 255, 255, 0.93) 32%,
        rgba(248, 251, 255, 0.82) 52%,
        rgba(244, 248, 252, 0.62) 72%,
        rgba(240, 246, 252, 0.38) 100%
    );
}

.ow-hero__mesh {
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    opacity: 0.7;
    background:
        radial-gradient(ellipse 48% 40% at 6% 18%, color-mix(in srgb, var(--accent) 16%, transparent), transparent 58%),
        radial-gradient(ellipse 42% 38% at 94% 82%, color-mix(in srgb, var(--logo-blue-deep) 12%, transparent), transparent 55%);
}

.ow-hero::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 3;
    height: 56px;
    pointer-events: none;
    background: linear-gradient(to bottom, transparent, var(--surface));
}

.ow-hero__grid {
    position: relative;
    z-index: 4;
    display: grid;
    grid-template-columns: minmax(0, 1.02fr) minmax(280px, 0.98fr);
    gap: clamp(1.75rem, 4vw, 3rem);
    align-items: center;
}

.ow-hero__panel {
    min-width: 0;
    padding: clamp(1.35rem, 3vw, 2rem);
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.78);
    border: 1px solid rgba(255, 255, 255, 0.95);
    box-shadow:
        0 28px 64px color-mix(in srgb, var(--surface-deep) 10%, transparent),
        0 1px 0 rgba(255, 255, 255, 0.9) inset;
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
}

.ow-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin: 0 0 0.75rem;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--accent);
}

.ow-hero__eyebrow-dot {
    width: 0.45rem;
    height: 0.45rem;
    border-radius: 999px;
    background: var(--accent);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 22%, transparent);
}

.ow-hero__title {
    margin: 0;
    font-family: "Libre Baskerville", Georgia, serif;
    font-size: clamp(2rem, 4.2vw, 2.85rem);
    font-weight: 700;
    line-height: 1.1;
    color: var(--surface-deep);
    text-wrap: balance;
}

.ow-hero__lead {
    margin: 1rem 0 0;
    max-width: 46ch;
    font-size: clamp(1.02rem, 2vw, 1.12rem);
    line-height: 1.65;
    color: var(--muted);
}

.ow-hero__stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.65rem;
    margin-top: 1.5rem;
}

.ow-hero__stat {
    position: relative;
    padding: 0.9rem 0.85rem;
    border-radius: 14px;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid color-mix(in srgb, var(--accent) 12%, var(--border));
    box-shadow: 0 8px 22px color-mix(in srgb, var(--surface-deep) 5%, transparent);
}

.ow-hero__stat::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--accent), color-mix(in srgb, var(--logo-blue-deep) 70%, var(--accent)));
}

.ow-hero__stat-value {
    display: block;
    font-size: clamp(1.1rem, 2.4vw, 1.4rem);
    font-weight: 800;
    line-height: 1.15;
    color: var(--accent-dark);
}

.ow-hero__stat-label {
    display: block;
    margin-top: 0.25rem;
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--muted);
}

.ow-hero__actions {
    margin-top: 1.35rem;
}

.ow-hero__cta {
    margin-top: 0;
    box-shadow: 0 12px 28px color-mix(in srgb, var(--accent) 28%, transparent);
}

.ow-hero__collage {
    position: relative;
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    grid-template-rows: repeat(6, 1fr);
    aspect-ratio: 4 / 5;
    max-height: min(520px, 74vh);
    min-height: 340px;
}

.ow-hero__badge {
    position: absolute;
    top: -0.35rem;
    right: 0.5rem;
    z-index: 6;
    padding: 0.55rem 0.9rem;
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    color: var(--surface-deep);
    background: rgba(255, 255, 255, 0.95);
    border: 1px solid color-mix(in srgb, var(--accent) 20%, var(--border));
    box-shadow: 0 12px 28px color-mix(in srgb, var(--surface-deep) 12%, transparent);
    backdrop-filter: blur(8px);
}

.ow-hero__badge strong {
    font-weight: 800;
    color: var(--accent-dark);
}

.ow-hero__collage-glow {
    position: absolute;
    inset: 6% -8% -12% 16%;
    z-index: 0;
    border-radius: 28px;
    background: linear-gradient(
        135deg,
        color-mix(in srgb, var(--accent-soft) 75%, transparent),
        color-mix(in srgb, var(--accent) 40%, transparent)
    );
    opacity: 0.65;
}

.ow-hero__shot {
    margin: 0;
    overflow: hidden;
    border-radius: 18px;
    border: 3px solid rgba(255, 255, 255, 0.98);
    box-shadow:
        0 22px 48px color-mix(in srgb, var(--surface-deep) 16%, transparent),
        0 6px 16px color-mix(in srgb, var(--surface-deep) 8%, transparent);
    transition: transform 0.35s var(--nav-ease), box-shadow 0.35s var(--nav-ease);
}

.ow-hero__shot:hover {
    transform: translateY(-4px) rotate(0deg);
    box-shadow: 0 28px 56px color-mix(in srgb, var(--surface-deep) 18%, transparent);
}

.ow-hero__shot img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s var(--nav-ease);
}

.ow-hero__shot:hover img {
    transform: scale(1.04);
}

.ow-hero__shot--field {
    grid-column: 3 / 7;
    grid-row: 1 / 7;
    z-index: 2;
}

.ow-hero__shot--food {
    grid-column: 1 / 4;
    grid-row: 1 / 4;
    z-index: 3;
    transform: rotate(-2.5deg);
}

.ow-hero__shot--agri {
    grid-column: 1 / 4;
    grid-row: 4 / 7;
    z-index: 3;
    transform: rotate(2deg);
}

.ow-hero__shot--field:hover {
    transform: translateY(-4px);
}

@media (max-width: 960px) {
    .ow-hero--has-bg .ow-hero__bg {
        background-position: center 30%;
    }

    .ow-hero__overlay {
        background: linear-gradient(
            180deg,
            rgba(255, 255, 255, 0.96) 0%,
            rgba(255, 255, 255, 0.92) 45%,
            rgba(248, 251, 255, 0.78) 100%
        );
    }

    .ow-hero__grid {
        grid-template-columns: 1fr;
    }

    .ow-hero__collage {
        max-height: 400px;
        margin-inline: auto;
        max-width: 440px;
    }

    .ow-hero__stats {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 560px) {
    .ow-hero__panel {
        padding: 1.25rem;
    }

    .ow-hero__stats {
        grid-template-columns: 1fr;
    }

    .ow-hero__collage {
        min-height: 300px;
        max-height: 360px;
    }

    .ow-hero__shot--food,
    .ow-hero__shot--agri {
        transform: none;
    }

    .ow-hero__badge {
        top: 0.25rem;
        right: 0.25rem;
        font-size: 0.68rem;
    }
}

.ow-toolbar-wrap {
    position: sticky;
    top: var(--header-offset, 0px);
    z-index: 8;
    padding: 0.85rem 0;
    background: color-mix(in srgb, var(--surface) 96%, var(--bg) 4%);
    border-bottom: 1px solid var(--border);
    box-shadow: 0 8px 22px color-mix(in srgb, var(--surface-deep) 5%, transparent);
}

.ow-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 1rem 1.75rem;
}

.ow-toolbar__intro {
    flex: 1 1 16rem;
    min-width: min(100%, 16rem);
    margin: 0;
    font-size: clamp(0.98rem, 1.8vw, 1.06rem);
    line-height: 1.6;
    color: var(--text);
}

.ow-toc {
    flex: 2 1 18rem;
    min-width: 0;
}

.ow-toc__label {
    display: block;
    margin: 0 0 0.45rem;
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--muted);
}

.ow-toc__list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem 0.5rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.ow-toc__link {
    display: inline-block;
    padding: 0.32rem 0.72rem;
    border-radius: 999px;
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-decoration: none;
    color: var(--brand-blue-dark);
    background: color-mix(in srgb, var(--brand-blue) 9%, var(--surface) 91%);
    border: 1px solid color-mix(in srgb, var(--logo-blue-deep) 18%, transparent);
    transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.ow-toc__link:hover {
    background: color-mix(in srgb, var(--accent) 12%, var(--surface) 88%);
    border-color: color-mix(in srgb, var(--accent) 35%, transparent);
    color: var(--accent-dark);
}

.ow-overview {
    padding: clamp(2rem, 4vw, 2.75rem) 0;
    background: var(--surface);
}

.ow-overview__head {
    max-width: 42rem;
    margin-bottom: 1.75rem;
}

.ow-overview__eyebrow {
    margin: 0 0 0.4rem;
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--accent);
}

.ow-overview__title {
    margin: 0;
    font-family: "Libre Baskerville", Georgia, serif;
    font-size: clamp(1.5rem, 3vw, 1.85rem);
    line-height: 1.2;
    color: var(--surface-deep);
}

.ow-overview__lead {
    margin: 0.75rem 0 0;
    font-size: 1.02rem;
    line-height: 1.65;
    color: var(--muted);
}

.ow-areas-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 260px), 1fr));
    gap: 0.85rem;
}

.ow-area-card {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 1rem 1.1rem;
    border-radius: 16px;
    text-decoration: none;
    color: inherit;
    background: var(--surface);
    border: 1px solid var(--border);
    box-shadow: 0 8px 24px color-mix(in srgb, var(--surface-deep) 4%, transparent);
    transition:
        transform 0.22s var(--nav-ease),
        box-shadow 0.22s var(--nav-ease),
        border-color 0.22s ease;
}

.ow-area-card:hover {
    transform: translateY(-3px);
    border-color: color-mix(in srgb, var(--accent) 35%, var(--border));
    box-shadow: 0 16px 36px color-mix(in srgb, var(--accent) 10%, transparent);
}

.ow-area-card__icon {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 12px;
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    color: #fff;
    background: linear-gradient(135deg, var(--accent), var(--accent-dark));
}

.ow-area-card__body {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    min-width: 0;
    flex: 1;
}

.ow-area-card__name {
    font-size: 0.95rem;
    font-weight: 700;
    line-height: 1.35;
    color: var(--surface-deep);
}

.ow-area-card__meta {
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--muted);
}

.ow-area-card__arrow {
    flex-shrink: 0;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--accent);
    opacity: 0.7;
    transition: transform 0.2s ease, opacity 0.2s ease;
}

.ow-area-card:hover .ow-area-card__arrow {
    transform: translateX(4px);
    opacity: 1;
}

.ow-section {
    scroll-margin-top: calc(var(--header-offset, 0px) + 5rem);
    padding: clamp(2rem, 4vw, 2.75rem) 0;
}

.ow-section--alt {
    background: var(--surface-alt);
}

.ow-section__head {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem 1.5rem;
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid color-mix(in srgb, var(--logo-blue-deep) 12%, transparent);
}

.ow-section__head-text {
    flex: 1 1 20rem;
    min-width: 0;
}

.ow-section__eyebrow {
    margin: 0 0 0.35rem;
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--accent);
}

.ow-section__title {
    margin: 0;
    font-family: "Libre Baskerville", Georgia, serif;
    font-size: clamp(1.35rem, 2.8vw, 1.65rem);
    line-height: 1.2;
    color: var(--surface-deep);
}

.ow-section__lead {
    margin: 0.65rem 0 0;
    max-width: 56ch;
    font-size: 0.98rem;
    line-height: 1.65;
    color: var(--muted);
}

.ow-section__badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    flex-shrink: 0;
}

.ow-section__badge {
    padding: 0.4rem 0.75rem;
    border-radius: 8px;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--muted);
    background: var(--surface);
    border: 1px solid var(--border);
}

.ow-section--alt .ow-section__badge {
    background: color-mix(in srgb, var(--surface-alt) 50%, var(--surface));
}

.ow-section__badge--budget {
    color: var(--accent-dark);
    background: color-mix(in srgb, var(--accent-soft) 45%, var(--surface));
    border-color: color-mix(in srgb, var(--accent) 22%, transparent);
}

.ow-cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 320px), 1fr));
    gap: 1.15rem;
}

.ow-card {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding: 1.25rem 1.3rem;
    border-radius: 16px;
    background: var(--surface);
    border: 1px solid var(--border);
    box-shadow: 0 10px 28px color-mix(in srgb, var(--surface-deep) 5%, transparent);
    transition:
        transform 0.22s var(--nav-ease),
        box-shadow 0.22s var(--nav-ease),
        border-color 0.22s ease;
}

.ow-section--alt .ow-card {
    background: var(--surface);
}

.ow-card:hover {
    transform: translateY(-4px);
    border-color: color-mix(in srgb, var(--accent) 28%, var(--border));
    box-shadow: 0 18px 40px color-mix(in srgb, var(--accent) 8%, transparent);
}

.ow-card__head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem 0.75rem;
}

.ow-card__num {
    display: inline-block;
    padding: 0.22rem 0.55rem;
    border-radius: 6px;
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--accent-dark);
    background: color-mix(in srgb, var(--accent-soft) 55%, var(--surface));
}

.ow-card__period {
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--muted);
}

.ow-card__title {
    margin: 0;
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.45;
    color: var(--surface-deep);
}

.ow-card__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.ow-card__tags li {
    padding: 0.2rem 0.5rem;
    border-radius: 999px;
    font-size: 0.68rem;
    font-weight: 600;
    color: var(--brand-blue-dark);
    background: color-mix(in srgb, var(--brand-blue) 10%, var(--surface) 90%);
    border: 1px solid color-mix(in srgb, var(--logo-blue-deep) 12%, transparent);
}

.ow-card__facts {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem 1rem;
    margin: 0;
    margin-top: auto;
    padding-top: 0.85rem;
    border-top: 1px solid color-mix(in srgb, var(--border) 85%, transparent);
}

.ow-card__fact {
    display: grid;
    gap: 0.15rem;
    min-width: 0;
}

.ow-card__fact--donor {
    grid-column: 1 / -1;
}

.ow-card__fact dt {
    margin: 0;
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--muted);
}

.ow-card__fact dd {
    margin: 0;
    font-size: 0.86rem;
    line-height: 1.4;
    color: var(--text);
}

.ow-empty,
.ow-empty-section .ow-empty {
    margin: 0;
    padding: 2rem;
    text-align: center;
    color: var(--muted);
    border-radius: 14px;
    border: 1px dashed var(--border);
    background: color-mix(in srgb, var(--surface-alt) 50%, var(--surface));
}

@media (max-width: 720px) {
    .ow-toolbar {
        flex-direction: column;
    }

    .ow-card__facts {
        grid-template-columns: 1fr;
    }

    .ow-section__head {
        flex-direction: column;
        align-items: flex-start;
    }
}
