/*
Theme Name: Pop IntelBox
Theme URI: https://popintelbox.com.br
Author: Pop IntelBox
Description: Tema institucional do Pop IntelBox com conteúdo dinâmico para notícias, publicações e pesquisas em andamento.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
Text Domain: pop-intelbox
*/

:root {
    --bg-900: #060d1f;
    --bg-800: #0f1b34;
    --surface: rgba(19, 39, 75, 0.78);
    --surface-soft: rgba(24, 46, 85, 0.62);
    --line: rgba(126, 156, 199, 0.32);
    --text-strong: #f2f7ff;
    --text-soft: #c6d7f3;
    --brand-blue: #5286c0;
    --brand-cyan: #49b5b7;
    --brand-orange: #efa11b;
    --brand-orange-soft: #f39f23;
    --radius-xl: 24px;
    --radius-lg: 16px;
    --radius-md: 12px;
    --shadow-soft: 0 18px 48px rgba(0, 0, 0, 0.22);
    --shadow-card: 0 14px 30px rgba(0, 0, 0, 0.2);
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    color: #083a5f;
    font-family: "Manrope", "Segoe UI", sans-serif;
    line-height: 1.6;
    background:
        radial-gradient(circle at 12% 8%, rgba(255, 255, 255, 0.35), transparent 34%),
        radial-gradient(circle at 86% 14%, rgba(255, 255, 255, 0.22), transparent 30%),
        linear-gradient(160deg, #4fb8bf 0%, #5bc2c8 45%, #4eb4bc 100%);
    min-height: 100vh;
}

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

a {
    color: inherit;
}

p {
    margin: 0;
}

.container {
    width: min(1120px, calc(100% - 2.4rem));
    margin-inline: auto;
}

.skip-link,
.screen-reader-text {
    position: absolute;
    top: -44px;
    left: 16px;
    background: var(--brand-orange);
    color: #111;
    padding: 0.55rem 0.85rem;
    border-radius: 10px;
    font-weight: 700;
    z-index: 1000;
    text-decoration: none;
}

.skip-link:focus,
.screen-reader-text:focus {
    top: 16px;
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 80;
    backdrop-filter: blur(8px);
    background:
        linear-gradient(120deg, rgba(73, 181, 183, 0.98), rgba(86, 188, 192, 0.96)),
        radial-gradient(circle at 20% 0, rgba(242, 251, 252, 0.25), transparent 42%);
    border-bottom: 1px solid rgba(14, 73, 102, 0.24);
}

.header-inner {
    min-height: 88px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.brand {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.42rem 0.62rem;
    border-radius: 14px;
    background: linear-gradient(145deg, rgba(242, 248, 255, 0.96), rgba(224, 237, 252, 0.9));
    border: 1px solid rgba(157, 178, 211, 0.56);
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.28);
}

.brand img {
    width: clamp(136px, 13vw, 186px);
    height: auto;
    filter: drop-shadow(0 1px 1px rgba(0, 0, 0, 0.22));
}

.brand .custom-logo-link {
    display: block;
    line-height: 0;
}

.brand .custom-logo {
    width: clamp(136px, 13vw, 186px);
    height: auto;
    filter: drop-shadow(0 1px 1px rgba(0, 0, 0, 0.22));
}

.main-nav .menu,
.main-nav ul {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    align-items: center;
    gap: 0.2rem;
    flex-wrap: wrap;
    justify-content: center;
}

.main-nav a {
    text-decoration: none;
    padding: 0.46rem 0.72rem;
    border-radius: 999px;
    color: #083a5f;
    font-size: 0.92rem;
    font-weight: 600;
    transition: color 0.25s ease, background-color 0.25s ease;
}

.main-nav a:hover,
.main-nav a:focus-visible {
    background: rgba(255, 255, 255, 0.22);
    color: var(--brand-orange);
}

.main-nav .current-menu-item > a,
.main-nav .current-menu-parent > a,
.main-nav .current-menu-ancestor > a,
.main-nav a.current,
.main-nav a[aria-current="page"] {
    background: rgba(255, 255, 255, 0.18);
    color: #072f4f;
    box-shadow: inset 0 0 0 1px rgba(12, 66, 93, 0.24);
}

.btn {
    text-decoration: none;
    border: 0;
    border-radius: 999px;
    padding: 0.72rem 1.12rem;
    font-weight: 700;
    font-family: inherit;
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

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

.btn-primary {
    background: linear-gradient(120deg, var(--brand-orange), var(--brand-orange-soft));
    color: #1c1406;
    box-shadow: 0 8px 18px rgba(239, 161, 27, 0.26);
}

.btn-ghost {
    color: var(--text-strong);
    border: 1px solid rgba(126, 156, 199, 0.44);
    background: rgba(18, 35, 67, 0.55);
}

.btn-header {
    white-space: nowrap;
    font-size: 0.9rem;
    color: #111;
    background: linear-gradient(130deg, var(--brand-cyan), #7fd4d6);
}

.menu-toggle {
    display: none;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 0.26rem;
    width: 48px;
    height: 44px;
    border: 1px solid rgba(18, 76, 105, 0.3);
    border-radius: 12px;
    background: rgba(16, 57, 88, 0.14);
    color: #07345a;
    cursor: pointer;
}

.menu-toggle__bar {
    width: 22px;
    height: 2px;
    border-radius: 999px;
    background: currentColor;
    transition: transform 0.2s ease, opacity 0.2s ease;
}

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

.menu-toggle.is-open .menu-toggle__bar:nth-child(1) {
    transform: translateY(6px) rotate(45deg);
}

.menu-toggle.is-open .menu-toggle__bar:nth-child(2) {
    opacity: 0;
}

.menu-toggle.is-open .menu-toggle__bar:nth-child(3) {
    transform: translateY(-6px) rotate(-45deg);
}

.hero {
    padding: clamp(3rem, 7vw, 5.1rem) 0 4rem;
}

.page-hero {
    padding: clamp(2.5rem, 6vw, 4rem) 0 1.4rem;
}

.page-hero-box {
    border-radius: var(--radius-xl);
    border: 1px solid var(--line);
    background:
        linear-gradient(145deg, rgba(15, 30, 58, 0.88), rgba(9, 20, 41, 0.92)),
        radial-gradient(circle at 86% 14%, rgba(239, 161, 27, 0.18), transparent 45%);
    box-shadow: var(--shadow-soft);
    padding: clamp(1.4rem, 3vw, 2rem);
}

.page-hero-box p:not(.kicker) {
    margin-top: 0.4rem;
    color: var(--text-soft);
    max-width: 72ch;
}

.hero-grid {
    display: grid;
    grid-template-columns: 1.2fr 0.9fr;
    gap: 1.2rem;
}

.hero-content {
    background: linear-gradient(145deg, rgba(15, 30, 58, 0.86), rgba(10, 21, 43, 0.9));
    border: 1px solid var(--line);
    border-radius: var(--radius-xl);
    padding: clamp(1.55rem, 3vw, 2.4rem);
    box-shadow: var(--shadow-soft);
}

.kicker {
    margin: 0;
    font-size: 0.82rem;
    letter-spacing: 0.13em;
    text-transform: uppercase;
    color: var(--brand-cyan);
    font-weight: 700;
}

h1,
h2,
h3,
h4 {
    font-family: "Sora", "Segoe UI", sans-serif;
    line-height: 1.2;
    margin-top: 0.52rem;
    margin-bottom: 0.88rem;
}

h1 {
    margin-top: 0.65rem;
    font-size: clamp(1.95rem, 4.8vw, 3.35rem);
    max-width: 16ch;
}

h2 {
    font-size: clamp(1.48rem, 3vw, 2.28rem);
    max-width: 22ch;
}

h3 {
    font-size: 1.15rem;
}

.hero-text {
    margin: 0 0 1.3rem;
    color: var(--text-soft);
    max-width: 60ch;
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
}

.highlight-card {
    padding: clamp(1.4rem, 2.6vw, 1.9rem);
    border-radius: var(--radius-xl);
    border: 1px solid rgba(73, 181, 183, 0.44);
    background:
        linear-gradient(160deg, rgba(16, 35, 64, 0.83), rgba(13, 28, 52, 0.9)),
        radial-gradient(circle at 80% 4%, rgba(73, 181, 183, 0.2), transparent 42%);
    box-shadow: var(--shadow-soft);
}

.highlight-card h2 {
    font-size: 1.55rem;
}

.highlight-card p {
    margin-top: 0;
    color: var(--text-soft);
}

.status-list {
    list-style: none;
    margin: 1.2rem 0;
    padding: 0;
    display: grid;
    gap: 0.7rem;
}

.status-list li {
    border: 1px solid rgba(126, 156, 199, 0.28);
    border-radius: var(--radius-md);
    padding: 0.72rem 0.85rem;
    background: rgba(15, 30, 58, 0.58);
    display: flex;
    justify-content: space-between;
    gap: 0.8rem;
    align-items: center;
}

.status-list span {
    color: var(--text-strong);
    font-size: 0.92rem;
}

.status-list strong {
    font-size: 0.82rem;
    color: #15202b;
    background: linear-gradient(130deg, #89c5db, #b4d7e9);
    border-radius: 999px;
    padding: 0.18rem 0.58rem;
    white-space: nowrap;
}

.text-link {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    color: var(--brand-orange);
    text-decoration: none;
    font-weight: 700;
}

.text-link::after {
    content: ">";
    font-size: 0.85rem;
}

.section {
    padding: clamp(2.8rem, 5.2vw, 4rem) 0;
}

.about p:not(.kicker) {
    max-width: 70ch;
    color: #1f5673;
}

.services .service-grid {
    margin-top: 1.45rem;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem;
}

.service-card,
.post-card {
    padding: 1.2rem 1.1rem;
    border-radius: var(--radius-lg);
    background:
        linear-gradient(165deg, rgba(20, 39, 72, 0.88), rgba(14, 27, 52, 0.9)),
        radial-gradient(circle at 90% 20%, rgba(239, 161, 27, 0.16), transparent 45%);
    border: 1px solid var(--line);
    box-shadow: var(--shadow-card);
}

.service-card:nth-child(2n),
.post-card:nth-child(2n) {
    background:
        linear-gradient(165deg, rgba(20, 39, 72, 0.88), rgba(14, 27, 52, 0.9)),
        radial-gradient(circle at 8% 14%, rgba(73, 181, 183, 0.15), transparent 46%);
}

.service-card p,
.post-card p {
    margin: 0;
    color: var(--text-soft);
}

.text-list {
    margin: 0.75rem 0 0;
    padding-left: 1rem;
    color: var(--text-soft);
}

.text-list li + li {
    margin-top: 0.3rem;
}

.service-card .text-link,
.progress-card .text-link {
    margin-top: 0.7rem;
}

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

.content-card {
    padding: 1.25rem 1.15rem;
    border-radius: var(--radius-lg);
    border: 1px solid var(--line);
    background: var(--surface);
    box-shadow: var(--shadow-card);
}

.content-card p:not(.kicker) {
    color: var(--text-soft);
}

.in-progress .section-intro {
    margin-top: 0;
    color: #1f5673;
}

.progress-grid,
.post-grid {
    margin-top: 1.2rem;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.9rem;
}

.progress-card {
    padding: 1.05rem 1rem;
    border: 1px solid rgba(73, 181, 183, 0.34);
    border-radius: var(--radius-lg);
    background:
        linear-gradient(165deg, rgba(12, 27, 52, 0.88), rgba(18, 35, 67, 0.86)),
        radial-gradient(circle at 8% 10%, rgba(73, 181, 183, 0.14), transparent 46%);
}

.progress-card p {
    margin: 0.6rem 0 0;
    color: var(--text-soft);
}

.progress-card .text-link,
.press-release-card .text-link {
    color: #8fd6f3;
}

.progress-card .text-link:hover,
.progress-card .text-link:focus-visible,
.press-release-card .text-link:hover,
.press-release-card .text-link:focus-visible {
    color: #eef9ff;
}

.posts-archive {
    padding-top: 0.8rem;
    padding-bottom: 4rem;
}

.post-meta {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    color: var(--text-soft);
    font-size: 0.85rem;
    margin-bottom: 0.55rem;
}

.post-type-label {
    display: inline-block;
    padding: 0.18rem 0.55rem;
    border-radius: 999px;
    background: rgba(73, 181, 183, 0.2);
    color: #9ce6e7;
    font-weight: 700;
}

.post-title-link {
    text-decoration: none;
}

.post-title-link:hover,
.post-title-link:focus-visible {
    color: var(--brand-cyan);
}

.post-excerpt {
    margin-top: 0.55rem;
    color: var(--text-soft);
}

.archive-empty {
    border: 1px dashed var(--line);
    border-radius: var(--radius-lg);
    padding: 1rem;
    background: rgba(11, 24, 47, 0.68);
}

.pagination {
    margin-top: 1.2rem;
}

.pagination .nav-links {
    display: flex;
    gap: 0.45rem;
    flex-wrap: wrap;
}

.pagination ul.page-numbers {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: 0.45rem;
    flex-wrap: wrap;
}

.pagination a,
.pagination span {
    border-radius: 999px;
    padding: 0.32rem 0.78rem;
    border: 1px solid var(--line);
    text-decoration: none;
}

.pagination .current {
    background: rgba(73, 181, 183, 0.25);
}

.single-wrap {
    padding: 1rem 0 4rem;
}

.single-card {
    border: 1px solid var(--line);
    border-radius: var(--radius-xl);
    background: var(--surface);
    box-shadow: var(--shadow-soft);
    padding: clamp(1.2rem, 2.4vw, 2rem);
}

.single-card .post-meta {
    margin-bottom: 0.9rem;
}

.single-content {
    color: var(--text-soft);
}

.single-content > * + * {
    margin-top: 1rem;
}

.single-content h2,
.single-content h3,
.single-content h4 {
    color: var(--text-strong);
}

.single-content a {
    color: var(--brand-cyan);
}

.single-content ul,
.single-content ol {
    padding-left: 1.2rem;
}

.back-link {
    margin-top: 1.2rem;
}

.contact {
    padding-bottom: clamp(3rem, 6vw, 4.4rem);
}

.contact-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

.contact p {
    color: #1d5675;
}

.contact-form {
    border-radius: var(--radius-xl);
    border: 1px solid var(--line);
    background: var(--surface-soft);
    box-shadow: var(--shadow-card);
    padding: 1.2rem;
    display: grid;
    gap: 0.58rem;
}

.contact-form label {
    font-size: 0.92rem;
    color: var(--text-strong);
    font-weight: 600;
}

.contact-form input,
.contact-form textarea {
    border: 1px solid rgba(126, 156, 199, 0.38);
    border-radius: 10px;
    background: rgba(12, 25, 47, 0.75);
    color: var(--text-strong);
    padding: 0.62rem 0.72rem;
    font: inherit;
}

.contact-form input::placeholder,
.contact-form textarea::placeholder {
    color: rgba(198, 215, 243, 0.74);
}

.contact-form textarea {
    resize: vertical;
    min-height: 110px;
}

.contact-form button {
    width: fit-content;
    margin-top: 0.3rem;
}

.site-footer {
    border-top: 1px solid var(--line);
    background: rgba(4, 10, 22, 0.86);
}

.footer-inner {
    min-height: 72px;
    display: flex;
    align-items: center;
    gap: 0.7rem;
}

.footer-inner img {
    width: 32px;
    height: 32px;
}

.footer-inner p {
    margin: 0;
    font-size: 0.92rem;
    color: rgba(198, 215, 243, 0.82);
}

.footer-credit {
    margin: 0 0 0 auto;
    font-size: 0.88rem;
    color: rgba(217, 238, 247, 0.92);
}

@media (min-width: 761px) {
    .site-header {
        background:
            linear-gradient(120deg, rgba(73, 181, 183, 0.98), rgba(86, 188, 192, 0.96)),
            radial-gradient(circle at 20% 0, rgba(242, 251, 252, 0.26), transparent 44%),
            radial-gradient(circle at 82% 0, rgba(82, 134, 192, 0.2), transparent 40%);
        border-bottom: 1px solid rgba(14, 73, 102, 0.26);
        backdrop-filter: blur(10px);
    }

    .header-inner {
        min-height: 78px;
        padding-top: 0.36rem;
        padding-bottom: 0.36rem;
        gap: 1.5rem;
    }

    .brand {
        padding: 0;
        border: 0;
        border-radius: 0;
        background: transparent;
        box-shadow: none;
    }

    .brand img,
    .brand .custom-logo {
        width: clamp(146px, 10.6vw, 176px);
        filter: drop-shadow(0 8px 14px rgba(5, 31, 53, 0.2));
    }

    .main-nav {
        margin-left: auto;
        flex: 0 1 auto;
        display: flex;
        align-items: center;
    }

    .main-nav .menu,
    .main-nav ul {
        justify-content: flex-end;
        gap: clamp(0.95rem, 1.4vw, 1.45rem);
        flex-wrap: nowrap;
    }

    .main-nav a {
        padding: 0;
        border-radius: 0;
        background: transparent;
        color: #083a5f;
        font-size: 0.81rem;
        font-weight: 700;
        line-height: 1.08;
        text-transform: uppercase;
        letter-spacing: 0.06em;
    }

    .main-nav a:hover,
    .main-nav a:focus-visible {
        background: transparent;
        color: var(--brand-orange);
    }

    .main-nav .current-menu-item > a,
    .main-nav .current-menu-parent > a,
    .main-nav .current-menu-ancestor > a,
    .main-nav a.current,
    .main-nav a[aria-current="page"] {
        background: transparent;
        box-shadow: none;
        color: #062c4b;
    }
}

.footer-credit a {
    color: #e8f8ff;
    font-weight: 700;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.footer-credit a:hover,
.footer-credit a:focus-visible {
    color: #ffffff;
}

.footer-link {
    margin-left: 0;
    color: #d2e9f7;
    text-decoration: none;
    font-weight: 700;
    border: 1px solid rgba(175, 212, 231, 0.36);
    border-radius: 999px;
    padding: 0.28rem 0.7rem;
    font-size: 0.85rem;
}

.footer-link:hover,
.footer-link:focus-visible {
    background: rgba(103, 170, 205, 0.18);
}

.footer-pref-btn {
    border: 1px solid rgba(175, 212, 231, 0.36);
    background: rgba(103, 170, 205, 0.1);
    color: #d6eaf7;
    border-radius: 999px;
    padding: 0.28rem 0.7rem;
    font-size: 0.85rem;
    font-weight: 700;
    cursor: pointer;
}

.footer-pref-btn:hover,
.footer-pref-btn:focus-visible {
    background: rgba(103, 170, 205, 0.2);
}

.legal-section {
    padding-top: 0.6rem;
    padding-bottom: 3.4rem;
}

.legal-card {
    border: 1px solid rgba(67, 114, 150, 0.45);
    border-radius: var(--radius-xl);
    background: linear-gradient(160deg, rgba(14, 40, 69, 0.95), rgba(18, 49, 82, 0.92));
    box-shadow: 0 16px 32px rgba(5, 29, 49, 0.24);
    padding: clamp(1.15rem, 2.6vw, 1.9rem);
}

.legal-card h2 {
    font-size: 1.15rem;
    margin-bottom: 0.45rem;
    color: #edf8ff;
}

.legal-card p {
    color: #cce2f3;
    margin-bottom: 1.15rem;
}

.legal-card p:last-child {
    margin-bottom: 0;
}

.legal-card a {
    color: #7fd0f1;
}

.privacy-popup {
    position: fixed;
    right: 1rem;
    bottom: 1rem;
    z-index: 120;
    width: min(410px, calc(100% - 2rem));
    border: 1px solid rgba(113, 171, 204, 0.52);
    border-radius: 16px;
    background: linear-gradient(155deg, rgba(14, 42, 72, 0.96), rgba(19, 52, 87, 0.94));
    box-shadow: 0 18px 36px rgba(4, 24, 42, 0.34);
    padding: 0.95rem;
    opacity: 0;
    transform: translateY(12px);
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.privacy-popup.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.privacy-popup__text {
    margin: 0;
    color: #ddedf9;
}

.privacy-popup__actions {
    margin-top: 0.7rem;
    display: flex;
    gap: 0.55rem;
    flex-wrap: wrap;
    align-items: center;
}

.privacy-popup__accept {
    padding: 0.56rem 0.86rem;
}

.privacy-popup__essential {
    border: 1px solid rgba(136, 184, 212, 0.5);
    background: rgba(122, 176, 208, 0.14);
    color: #d2e9f8;
    border-radius: 999px;
    padding: 0.5rem 0.82rem;
    font-weight: 700;
    font: inherit;
    cursor: pointer;
}

.privacy-popup__essential:hover,
.privacy-popup__essential:focus-visible {
    background: rgba(122, 176, 208, 0.25);
}

.privacy-popup__policy {
    color: #9bd8f3;
    font-weight: 700;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.form-consent {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    color: #d4e8f9;
    font-size: 0.9rem;
    line-height: 1.4;
    margin-top: 0.12rem;
}

.form-consent input {
    margin-top: 0.16rem;
    accent-color: #49b5b7;
}

.form-consent a {
    color: #8fd3f1;
    text-decoration: underline;
    text-underline-offset: 2px;
}


.news-categories {
    padding: 0.45rem 0 0.2rem;
}

.news-categories__links {
    display: flex;
    gap: 0.65rem;
    flex-wrap: wrap;
}

.news-categories__link {
    background: linear-gradient(130deg, rgba(17, 53, 84, 0.92), rgba(34, 78, 112, 0.9));
    border: 1px solid rgba(124, 182, 213, 0.5);
    color: #eef8ff;
    box-shadow: 0 10px 20px rgba(5, 22, 41, 0.2);
}

.news-categories__link:hover,
.news-categories__link:focus-visible {
    background: linear-gradient(130deg, rgba(14, 47, 75, 0.96), rgba(27, 71, 103, 0.93));
    color: #ffffff;
}

.posts-archive .section-intro {
    margin-top: 0;
    color: #134969;
}

.press-release-section .section-intro {
    margin-top: 0;
    color: #134969;
}

.press-release-card .kicker {
    color: #76c7e9;
}

.press-optin-section {
    padding-top: 0.4rem;
}

.press-optin-card {
    border: 1px solid rgba(73, 120, 162, 0.44);
    border-radius: var(--radius-xl);
    background:
        linear-gradient(160deg, rgba(14, 40, 69, 0.95), rgba(18, 50, 84, 0.92)),
        radial-gradient(circle at 92% 10%, rgba(73, 181, 183, 0.2), transparent 42%);
    box-shadow: 0 16px 32px rgba(5, 29, 49, 0.24);
    padding: clamp(1.15rem, 2.7vw, 1.9rem);
}

.press-optin-card .kicker {
    color: #82d0ef;
}

.press-optin-card h2 {
    color: #eef8ff;
    max-width: 26ch;
}

.press-optin-card p {
    color: #cde2f2;
    margin-top: 0;
}

.press-optin-form {
    margin-top: 1rem;
    display: grid;
    gap: 0.62rem;
}

.press-optin-form label {
    color: #e3f0fa;
    font-weight: 600;
}

.press-optin-form input[type="email"] {
    border: 1px solid rgba(129, 176, 210, 0.44);
    border-radius: 10px;
    background: rgba(11, 33, 57, 0.74);
    color: #eaf6ff;
    padding: 0.62rem 0.72rem;
    font: inherit;
}

.press-optin-form input[type="email"]::placeholder {
    color: rgba(219, 236, 247, 0.74);
}

.press-optin-choice {
    display: flex;
    gap: 0.7rem;
    flex-wrap: wrap;
}

.press-optin-choice label {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    background: rgba(106, 169, 202, 0.14);
    border: 1px solid rgba(136, 184, 212, 0.4);
    border-radius: 999px;
    padding: 0.36rem 0.72rem;
    color: #d5ebf8;
}

.press-optin-choice input {
    accent-color: #49b5b7;
}

@media (max-width: 1080px) {
    .header-inner {
        flex-wrap: nowrap;
        justify-content: space-between;
        padding: 0.75rem 0 0.9rem;
        min-height: auto;
    }
}

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

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

    .footer-inner {
        flex-wrap: wrap;
    }

    .footer-credit {
        margin-left: 0;
    }

    .footer-link {
        margin-left: 0;
    }
}

@media (max-width: 760px) {
    .menu-toggle {
        display: inline-flex;
    }

    .js-enabled .main-nav {
        display: none;
        width: 100%;
        overflow: visible;
        padding-bottom: 0;
        margin-top: 0.45rem;
    }

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

    .main-nav .menu,
    .main-nav ul {
        width: 100%;
        flex-wrap: nowrap;
        flex-direction: column;
        align-items: stretch;
        justify-content: flex-start;
        max-height: 62vh;
        overflow: auto;
    }

    .services .service-grid,
    .content-hub .split-grid,
    .progress-grid,
    .post-grid {
        grid-template-columns: 1fr;
    }

    h1 {
        max-width: 12ch;
    }

    .page-hero h1 {
        max-width: 14ch;
    }

    .brand {
        padding: 0.32rem 0.48rem;
        border-radius: 12px;
    }

    .header-inner {
        justify-content: space-between;
        align-items: center;
        gap: 0.65rem;
    }

    .btn-header {
        order: 3;
    }

    .main-nav {
        order: 4;
        flex-basis: 100%;
    }

    .privacy-popup {
        right: 0.75rem;
        left: 0.75rem;
        width: auto;
        bottom: 0.75rem;
    }

    .press-optin-choice {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (prefers-reduced-motion: no-preference) {
    .hero-content,
    .highlight-card,
    .service-card,
    .content-card,
    .progress-card,
    .contact-form,
    .post-card,
    .single-card {
        opacity: 0;
        transform: translateY(18px);
        animation: reveal-up 720ms ease forwards;
    }

    .highlight-card {
        animation-delay: 120ms;
    }

    .service-card:nth-child(1),
    .content-card:nth-child(1),
    .progress-card:nth-child(1),
    .post-card:nth-child(1) {
        animation-delay: 150ms;
    }

    .service-card:nth-child(2),
    .content-card:nth-child(2),
    .progress-card:nth-child(2),
    .post-card:nth-child(2) {
        animation-delay: 220ms;
    }

    .service-card:nth-child(3),
    .progress-card:nth-child(3),
    .post-card:nth-child(3) {
        animation-delay: 290ms;
    }

    .service-card:nth-child(4),
    .contact-form,
    .post-card:nth-child(4) {
        animation-delay: 350ms;
    }
}

@keyframes reveal-up {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Final contrast refinement across card components */
.highlight-card,
.content-card,
.service-card,
.post-card,
.progress-card,
.press-release-card,
.press-optin-card,
.legal-card,
.page-hero-box {
    color: #d5e8f8;
}

.highlight-card h2,
.highlight-card h3,
.content-card h2,
.content-card h3,
.service-card h2,
.service-card h3,
.post-card h2,
.post-card h3,
.progress-card h2,
.progress-card h3,
.press-release-card h2,
.press-release-card h3,
.press-optin-card h2,
.press-optin-card h3,
.legal-card h2,
.legal-card h3,
.page-hero-box h1,
.page-hero-box h2,
.page-hero-box h3 {
    color: #eef8ff;
}

.highlight-card p,
.content-card p,
.service-card p,
.post-card p,
.progress-card p,
.press-release-card p,
.press-optin-card p,
.legal-card p,
.page-hero-box p:not(.kicker),
.text-list,
.form-consent {
    color: #d0e5f5;
}

.kicker,
.highlight-card .kicker,
.content-card .kicker,
.service-card .kicker,
.progress-card .kicker,
.press-release-card .kicker,
.press-optin-card .kicker,
.legal-card .kicker,
.page-hero-box .kicker {
    color: #8fd6f3;
}

.text-link,
.progress-card .text-link,
.press-release-card .text-link,
.press-optin-card .text-link,
.legal-card a {
    color: #9edcf6;
}

.text-link:hover,
.text-link:focus-visible,
.progress-card .text-link:hover,
.progress-card .text-link:focus-visible,
.press-release-card .text-link:hover,
.press-release-card .text-link:focus-visible,
.press-optin-card .text-link:hover,
.press-optin-card .text-link:focus-visible,
.legal-card a:hover,
.legal-card a:focus-visible {
    color: #f2fbff;
}

/* BEGIN STATIC SITE-REFRESH SYNC */
/* Home redesign based on LOGO-2 identity */
.site-refresh {
    color: #073153;
    background:
        radial-gradient(circle at 12% 8%, rgba(255, 255, 255, 0.34), transparent 34%),
        radial-gradient(circle at 86% 14%, rgba(255, 255, 255, 0.21), transparent 30%),
        linear-gradient(160deg, #50b7bf 0%, #55bcc2 35%, #4eafb7 100%);
}

.site-refresh .skip-link {
    background: #123f67;
    color: #f4fbff;
}

.site-refresh .site-header-v2 {
    position: relative;
    border-bottom: 0;
    background: transparent;
    backdrop-filter: none;
}

.site-refresh .site-header-v2::after {
    display: none;
}

.site-refresh .site-header-v2 .header-inner {
    min-height: 146px;
    padding-top: 1rem;
    padding-bottom: 1.4rem;
    align-items: center;
    gap: 1.45rem;
}

.site-refresh .site-header-v2 .brand img {
    width: clamp(205px, 18vw, 262px);
    filter: drop-shadow(0 16px 24px rgba(4, 31, 54, 0.18));
}

.site-refresh .site-header-v2 .main-nav {
    flex: 1;
}

.site-refresh .site-header-v2 .main-nav ul {
    display: flex;
    justify-content: center;
    column-gap: 0.18rem;
    row-gap: 0.12rem;
    align-content: center;
    width: 100%;
    border-radius: 999px;
    padding: 0.24rem 0.34rem;
    background: linear-gradient(160deg, rgba(34, 124, 141, 0.34), rgba(47, 128, 145, 0.24));
    border: 1px solid rgba(18, 76, 105, 0.25);
    box-shadow: inset 0 1px 0 rgba(226, 245, 248, 0.34), 0 12px 28px rgba(7, 44, 71, 0.16);
}

.site-refresh .site-header-v2 .main-nav a {
    color: #07345a;
    font-weight: 800;
    padding: 0.38rem 0.95rem;
}

.site-refresh .site-header-v2 .main-nav a:hover,
.site-refresh .site-header-v2 .main-nav a:focus-visible {
    color: var(--brand-orange);
    background: rgba(255, 255, 255, 0.28);
}

.site-refresh .site-header-v2 .main-nav a.current,
.site-refresh .site-header-v2 .main-nav a[aria-current="page"] {
    color: #e9f6ff;
    background: linear-gradient(135deg, #163e67, #1f4e7a);
    box-shadow: inset 0 0 0 1px rgba(145, 190, 219, 0.32), 0 8px 14px rgba(12, 39, 66, 0.2);
}

.site-refresh .site-header-v2 .btn-header {
    background: linear-gradient(135deg, #184367, #1e5581);
    color: #f4fbff;
    box-shadow: 0 18px 26px rgba(7, 39, 62, 0.22);
}

.site-refresh .hero {
    padding-top: 0.6rem;
    padding-bottom: 2.6rem;
}

.site-refresh .hero-grid {
    grid-template-columns: 1.2fr 0.88fr;
    gap: 1rem;
}

.site-refresh .hero-content {
    border: 1px solid rgba(76, 133, 176, 0.34);
    background:
        linear-gradient(150deg, rgba(16, 46, 79, 0.94), rgba(18, 52, 86, 0.92)),
        radial-gradient(circle at 86% 14%, rgba(239, 161, 27, 0.16), transparent 46%);
    box-shadow: 0 16px 32px rgba(8, 54, 84, 0.2);
}

.site-refresh .hero-content .kicker {
    color: #8fd6f3;
}

.site-refresh .hero-content h1,
.site-refresh .hero-content h2,
.site-refresh .hero-content h3 {
    color: #eef8ff;
}

.site-refresh .hero-content .hero-text,
.site-refresh .hero-content p:not(.kicker) {
    color: #d0e5f5;
}

.site-refresh .hero-content .btn-ghost {
    background: rgba(255, 255, 255, 0.08);
    color: #eaf7ff;
    border-color: rgba(147, 190, 218, 0.44);
}

.site-refresh .hero-content .btn-ghost:hover,
.site-refresh .hero-content .btn-ghost:focus-visible {
    background: rgba(255, 255, 255, 0.16);
    color: #f4fbff;
}

.site-refresh .kicker {
    color: #0a426d;
}

.site-refresh h1,
.site-refresh h2,
.site-refresh h3 {
    color: #062f51;
}

.site-refresh .hero-text,
.site-refresh .about p:not(.kicker),
.site-refresh .service-card p,
.site-refresh .content-card p:not(.kicker),
.site-refresh .highlight-card p,
.site-refresh .status-list span {
    color: #1d506d;
}

.site-refresh .page-hero-box {
    border: 1px solid rgba(76, 133, 176, 0.34);
    background:
        linear-gradient(150deg, rgba(16, 46, 79, 0.94), rgba(18, 52, 86, 0.92)),
        radial-gradient(circle at 86% 14%, rgba(239, 161, 27, 0.2), transparent 46%);
}

.site-refresh .page-hero-box .kicker {
    color: #7fd0f1;
}

.site-refresh .page-hero-box h1,
.site-refresh .page-hero-box h2,
.site-refresh .page-hero-box h3 {
    color: #eff8ff;
}

.site-refresh .page-hero-box p:not(.kicker) {
    color: #d2e7f8;
}

.site-refresh .legal-card h2 {
    color: #eff8ff;
}

.site-refresh .legal-card p {
    color: #d2e6f6;
}

.site-refresh .legal-card a {
    color: #9bd8f3;
}

.site-refresh .press-optin-card .kicker {
    color: #8fd6f3;
}

.site-refresh .press-optin-card h2 {
    color: #eef8ff;
}

.site-refresh .press-optin-card p {
    color: #d2e6f6;
}

.site-refresh .press-release-section .section-intro {
    color: #174d6e;
}

.site-refresh .btn-primary {
    background: linear-gradient(135deg, #163f68, #1f5a87);
    color: #eef8ff;
    box-shadow: 0 10px 18px rgba(11, 51, 80, 0.22);
}

.site-refresh .btn-ghost {
    background: rgba(255, 255, 255, 0.32);
    color: #0d3b63;
    border-color: rgba(11, 73, 103, 0.36);
}

.site-refresh .highlight-card,
.site-refresh .content-card,
.site-refresh .service-card {
    border: 1px solid rgba(17, 78, 107, 0.2);
    background: linear-gradient(160deg, rgba(244, 251, 252, 0.78), rgba(229, 246, 248, 0.66));
    box-shadow: 0 14px 24px rgba(8, 54, 84, 0.13);
}

.site-refresh .service-card h3,
.site-refresh .content-card h2,
.site-refresh .content-card h3,
.site-refresh .highlight-card h2,
.site-refresh .highlight-card h3 {
    color: #0a375b;
}

.site-refresh .text-list {
    color: #2e5e7c;
}

.site-refresh .text-list li::marker {
    color: #5f8fb0;
}

.site-refresh .status-list li {
    background: rgba(255, 255, 255, 0.4);
    border: 1px solid rgba(17, 78, 107, 0.2);
}

.site-refresh .status-list strong {
    color: #102c42;
    background: linear-gradient(135deg, #f2a621, #f4b243);
}

.site-refresh .text-link {
    color: #0a3f69;
}

.site-refresh .progress-card {
    border: 1px solid rgba(70, 120, 168, 0.42);
    background:
        linear-gradient(155deg, rgba(17, 47, 79, 0.95), rgba(18, 49, 82, 0.92)),
        radial-gradient(circle at 10% 10%, rgba(73, 181, 183, 0.16), transparent 42%);
}

.site-refresh .progress-card h3 {
    color: #e8f4ff;
}

.site-refresh .progress-card p {
    color: #c9deef;
}

.site-refresh .progress-card .text-link,
.site-refresh .press-release-card .text-link {
    color: #8fd6f3;
}

.site-refresh .progress-card .text-link:hover,
.site-refresh .progress-card .text-link:focus-visible,
.site-refresh .press-release-card .text-link:hover,
.site-refresh .press-release-card .text-link:focus-visible {
    color: #eef9ff;
}

.site-refresh .contact-form {
    border: 1px solid rgba(71, 119, 162, 0.42);
    background: linear-gradient(155deg, rgba(16, 44, 74, 0.92), rgba(19, 49, 82, 0.9));
}

.site-refresh .section {
    padding-top: 2.35rem;
    padding-bottom: 2.35rem;
}

.site-refresh .site-footer {
    background: rgba(10, 55, 84, 0.82);
    border-top-color: rgba(192, 227, 236, 0.28);
}

.site-refresh .footer-inner p {
    color: rgba(232, 247, 250, 0.92);
}

@media (min-width: 761px) {
    .site-refresh .site-header-v2 {
        position: sticky;
        top: 0;
        z-index: 90;
        background:
            linear-gradient(120deg, rgba(73, 181, 183, 0.98), rgba(86, 188, 192, 0.96)),
            radial-gradient(circle at 20% 0, rgba(242, 251, 252, 0.26), transparent 44%),
            radial-gradient(circle at 82% 0, rgba(82, 134, 192, 0.2), transparent 40%);
        border-bottom: 1px solid rgba(14, 73, 102, 0.26);
        backdrop-filter: blur(10px);
    }

    .site-refresh .site-header-v2::after {
        display: none;
    }

    .site-refresh .site-header-v2 .header-inner {
        min-height: 78px;
        padding-top: 0.36rem;
        padding-bottom: 0.36rem;
        gap: 1.5rem;
    }

    .site-refresh .site-header-v2 .brand img {
        width: clamp(146px, 10.6vw, 176px);
        filter: drop-shadow(0 8px 14px rgba(5, 31, 53, 0.2));
    }

    .site-refresh .site-header-v2 .main-nav {
        margin-left: auto;
        flex: 0 1 auto;
        display: flex;
        align-items: center;
    }

    .site-refresh .site-header-v2 .main-nav ul {
        width: auto;
        justify-content: flex-end;
        gap: clamp(0.95rem, 1.4vw, 1.45rem);
        background: transparent;
        border: 0;
        box-shadow: none;
        padding: 0;
    }

    .site-refresh .site-header-v2 .main-nav a {
        padding: 0;
        border-radius: 0;
        background: transparent;
        color: #083a5f;
        font-size: 0.81rem;
        font-weight: 700;
        line-height: 1.08;
        text-transform: uppercase;
        letter-spacing: 0.06em;
    }

    .site-refresh .site-header-v2 .main-nav a:hover,
    .site-refresh .site-header-v2 .main-nav a:focus-visible {
        background: transparent;
        color: var(--brand-orange);
    }

    .site-refresh .site-header-v2 .main-nav a.current,
    .site-refresh .site-header-v2 .main-nav a[aria-current="page"] {
        background: transparent;
        box-shadow: none;
        color: #062c4b;
    }
}

@media (max-width: 1080px) {
    .site-refresh .site-header-v2 .header-inner {
        min-height: auto;
        padding-top: 0.95rem;
        padding-bottom: 1.05rem;
    }

    .site-refresh .site-header-v2 .main-nav {
        width: auto;
        margin-left: auto;
    }
}

@media (max-width: 760px) {
    .site-refresh .site-header-v2 .header-inner {
        justify-content: space-between;
        align-items: center;
        gap: 0.65rem;
    }

    .site-refresh .menu-toggle {
        order: 2;
        background: rgba(11, 55, 83, 0.22);
        color: #083a5f;
    }

    .site-refresh .site-header-v2 .btn-header {
        order: 3;
    }

    .site-refresh .site-header-v2 .main-nav {
        order: 4;
        flex-basis: 100%;
    }

    .site-refresh .site-header-v2 .brand img {
        width: clamp(160px, 48vw, 208px);
    }

    .site-refresh .site-header-v2 .main-nav ul {
        justify-content: flex-start;
        width: 100%;
        flex-wrap: nowrap;
    }

    .site-refresh .site-header-v2 .main-nav a {
        display: block;
        text-align: center;
    }
}

/* Final contrast refinement across all card types (site-refresh pages) */
.site-refresh .highlight-card,
.site-refresh .content-card,
.site-refresh .service-card {
    color: #184a67;
}

.site-refresh .highlight-card h2,
.site-refresh .highlight-card h3,
.site-refresh .content-card h2,
.site-refresh .content-card h3,
.site-refresh .service-card h2,
.site-refresh .service-card h3 {
    color: #0b3559;
}

.site-refresh .highlight-card p,
.site-refresh .content-card p,
.site-refresh .service-card p,
.site-refresh .text-list {
    color: #235875;
}

.site-refresh .highlight-card .kicker,
.site-refresh .content-card .kicker,
.site-refresh .service-card .kicker {
    color: #1f6b8e;
}

.site-refresh .highlight-card .text-link,
.site-refresh .content-card .text-link,
.site-refresh .service-card .text-link {
    color: #0b4b74;
}

.site-refresh .highlight-card .text-link:hover,
.site-refresh .highlight-card .text-link:focus-visible,
.site-refresh .content-card .text-link:hover,
.site-refresh .content-card .text-link:focus-visible,
.site-refresh .service-card .text-link:hover,
.site-refresh .service-card .text-link:focus-visible {
    color: #072f51;
}

.site-refresh .progress-card,
.site-refresh .press-release-card,
.site-refresh .press-optin-card,
.site-refresh .legal-card,
.site-refresh .page-hero-box {
    color: #d6e9f8;
}

.site-refresh .progress-card h2,
.site-refresh .progress-card h3,
.site-refresh .press-release-card h2,
.site-refresh .press-release-card h3,
.site-refresh .press-optin-card h2,
.site-refresh .press-optin-card h3,
.site-refresh .legal-card h2,
.site-refresh .legal-card h3,
.site-refresh .page-hero-box h1,
.site-refresh .page-hero-box h2,
.site-refresh .page-hero-box h3 {
    color: #eef8ff;
}

.site-refresh .progress-card p,
.site-refresh .press-release-card p,
.site-refresh .press-optin-card p,
.site-refresh .legal-card p,
.site-refresh .page-hero-box p:not(.kicker),
.site-refresh .form-consent {
    color: #d0e5f5;
}

.site-refresh .progress-card .kicker,
.site-refresh .press-release-card .kicker,
.site-refresh .press-optin-card .kicker,
.site-refresh .legal-card .kicker,
.site-refresh .page-hero-box .kicker {
    color: #8fd6f3;
}

.site-refresh .progress-card .text-link,
.site-refresh .press-release-card .text-link,
.site-refresh .press-optin-card .text-link,
.site-refresh .legal-card .text-link,
.site-refresh .legal-card a {
    color: #9edcf6;
}

.site-refresh .progress-card .text-link:hover,
.site-refresh .progress-card .text-link:focus-visible,
.site-refresh .press-release-card .text-link:hover,
.site-refresh .press-release-card .text-link:focus-visible,
.site-refresh .press-optin-card .text-link:hover,
.site-refresh .press-optin-card .text-link:focus-visible,
.site-refresh .legal-card a:hover,
.site-refresh .legal-card a:focus-visible {
    color: #f2fbff;
}

.site-refresh .post-card {
    color: #d6e9f8;
}

.site-refresh .post-card h2,
.site-refresh .post-card h3,
.site-refresh .post-card .post-title-link {
    color: #eef8ff;
}

.site-refresh .post-card .post-title-link:hover,
.site-refresh .post-card .post-title-link:focus-visible {
    color: #8fd6f3;
}

.site-refresh .post-card p,
.site-refresh .post-card .post-excerpt,
.site-refresh .post-card .post-meta,
.site-refresh .post-card .post-meta time {
    color: #d0e5f5;
}

.site-refresh .post-card .post-type-label {
    color: #8fd6f3;
    background: rgba(143, 214, 243, 0.2);
}

.site-refresh .post-card .text-link {
    color: #9edcf6;
}

.site-refresh .post-card .text-link:hover,
.site-refresh .post-card .text-link:focus-visible {
    color: #f2fbff;
}

.site-refresh .archive-empty p {
    color: #d0e5f5;
}
/* END STATIC SITE-REFRESH SYNC */

/* BRAND REFINEMENT V2: Unified visual system */
.site-refresh {
    --pib-bg-1: #53bac2;
    --pib-bg-2: #5ac2c8;
    --pib-bg-3: #4fb4bc;
    --pib-surface-light-1: #d5e9ee;
    --pib-surface-light-2: #cde4ea;
    --pib-surface-dark-1: #10395f;
    --pib-surface-dark-2: #16436d;
    --pib-blue-900: #0b3a63;
    --pib-blue-800: #123f67;
    --pib-blue-700: #1d527f;
    --pib-text-body: #2a5f7f;
    --pib-text-inverse: #eaf6ff;
    --pib-text-inverse-soft: #cfe4f5;
    --pib-line-light: rgba(122, 166, 189, 0.46);
    --pib-line-dark: rgba(122, 164, 193, 0.42);
    --pib-orange: #f2ad28;
    --pib-orange-soft: #f5bb48;
    --pib-orange-deep: #d69417;
    background:
        radial-gradient(circle at 12% 8%, rgba(255, 255, 255, 0.32), transparent 34%),
        radial-gradient(circle at 86% 14%, rgba(255, 255, 255, 0.2), transparent 30%),
        linear-gradient(160deg, var(--pib-bg-1) 0%, var(--pib-bg-2) 35%, var(--pib-bg-3) 100%);
    color: var(--pib-blue-900);
}

.site-refresh h1,
.site-refresh h2,
.site-refresh h3 {
    color: var(--pib-blue-900);
}

.site-refresh .kicker {
    color: var(--pib-blue-900);
}

.site-refresh .section {
    padding-top: clamp(2.3rem, 5vw, 3.7rem);
    padding-bottom: clamp(2.3rem, 5vw, 3.7rem);
}

.site-refresh .site-header-v2 {
    background:
        linear-gradient(120deg, rgba(83, 186, 194, 0.96), rgba(94, 197, 202, 0.94)),
        radial-gradient(circle at 20% 0, rgba(242, 251, 252, 0.24), transparent 44%);
    border-bottom: 1px solid rgba(14, 73, 102, 0.22);
}

.site-refresh .site-header-v2 .brand {
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.site-refresh .site-header-v2 .main-nav a {
    color: var(--pib-blue-900);
    font-weight: 700;
}

.site-refresh .site-header-v2 .main-nav a:hover,
.site-refresh .site-header-v2 .main-nav a:focus-visible {
    color: var(--pib-orange);
    background: rgba(255, 255, 255, 0.16);
}

.site-refresh .site-header-v2 .main-nav a.current,
.site-refresh .site-header-v2 .main-nav a[aria-current="page"] {
    color: var(--pib-text-inverse);
    background: linear-gradient(135deg, var(--pib-blue-800), var(--pib-blue-700));
    box-shadow: inset 0 0 0 1px rgba(150, 193, 220, 0.3);
}

.site-refresh .hero {
    padding-top: clamp(0.55rem, 1.4vw, 1rem);
    padding-bottom: clamp(2rem, 3.2vw, 3rem);
}

.site-refresh .hero-grid {
    grid-template-columns: 1.2fr 0.88fr;
    gap: 1rem;
}

.site-refresh .hero-content,
.site-refresh .highlight-card {
    border: 1px solid var(--pib-line-light);
    background:
        linear-gradient(155deg, rgba(213, 233, 238, 0.96), rgba(205, 228, 234, 0.94)),
        radial-gradient(circle at 86% 8%, rgba(255, 255, 255, 0.32), transparent 46%);
    box-shadow: 0 16px 28px rgba(7, 51, 79, 0.14);
    color: var(--pib-blue-900);
}

.site-refresh .hero-content .hero-text,
.site-refresh .hero-content p:not(.kicker),
.site-refresh .highlight-card p,
.site-refresh .highlight-card .section-intro,
.site-refresh .status-list span {
    color: var(--pib-text-body);
}

.site-refresh .status-list li {
    background: rgba(232, 244, 247, 0.88);
    border: 1px solid rgba(140, 179, 197, 0.52);
}

.site-refresh .status-list strong,
.site-refresh .post-card .post-type-label {
    color: #102f4a;
    background: linear-gradient(135deg, var(--pib-orange), var(--pib-orange-soft));
    box-shadow: inset 0 -1px 0 rgba(159, 103, 4, 0.2);
}

.site-refresh .btn-primary {
    background: linear-gradient(135deg, var(--pib-blue-800), #255b8c);
    color: var(--pib-text-inverse);
    box-shadow: 0 10px 18px rgba(13, 57, 89, 0.24);
}

.site-refresh .btn-primary:hover,
.site-refresh .btn-primary:focus-visible {
    background: linear-gradient(135deg, #103a61, #1e517f);
}

.site-refresh .btn-ghost {
    background: rgba(232, 245, 248, 0.7);
    color: var(--pib-blue-900);
    border-color: rgba(133, 174, 194, 0.82);
}

.site-refresh .btn-ghost:hover,
.site-refresh .btn-ghost:focus-visible {
    background: rgba(241, 250, 252, 0.9);
    color: #082f52;
}

.site-refresh .service-card,
.site-refresh .content-card {
    background: linear-gradient(160deg, rgba(236, 248, 250, 0.84), rgba(224, 242, 246, 0.76));
    border-color: rgba(122, 165, 187, 0.38);
}

.site-refresh .home-section {
    padding-top: clamp(3rem, 6vw, 4.6rem);
    padding-bottom: clamp(3rem, 6vw, 4.6rem);
}

.site-refresh .service-icon {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 0.72rem;
    color: var(--pib-blue-800);
    background: linear-gradient(160deg, rgba(228, 243, 248, 0.92), rgba(213, 233, 240, 0.9));
    border: 1px solid rgba(136, 175, 194, 0.64);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}

.site-refresh .service-icon svg {
    width: 24px;
    height: 24px;
    stroke: currentColor;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
    fill: none;
}

.site-refresh .service-card p,
.site-refresh .content-card p,
.site-refresh .text-list,
.site-refresh .about p:not(.kicker),
.site-refresh .in-progress .section-intro,
.site-refresh .press-release-section .section-intro {
    color: var(--pib-text-body);
}

.site-refresh .service-card .text-link,
.site-refresh .content-card .text-link,
.site-refresh .highlight-card .text-link,
.site-refresh .about .text-link {
    color: var(--pib-blue-800);
}

.site-refresh .service-card .text-link:hover,
.site-refresh .service-card .text-link:focus-visible,
.site-refresh .content-card .text-link:hover,
.site-refresh .content-card .text-link:focus-visible,
.site-refresh .highlight-card .text-link:hover,
.site-refresh .highlight-card .text-link:focus-visible,
.site-refresh .about .text-link:hover,
.site-refresh .about .text-link:focus-visible {
    color: var(--pib-orange-deep);
}

.site-refresh .page-hero-box,
.site-refresh .post-card,
.site-refresh .progress-card,
.site-refresh .press-release-card,
.site-refresh .press-optin-card,
.site-refresh .legal-card,
.site-refresh .contact-form,
.site-refresh .single-card {
    background:
        linear-gradient(155deg, rgba(16, 57, 95, 0.94), rgba(22, 67, 109, 0.92)),
        radial-gradient(circle at 10% 8%, rgba(73, 181, 183, 0.15), transparent 44%);
    border-color: var(--pib-line-dark);
    color: var(--pib-text-inverse-soft);
}

.site-refresh .page-hero-box .kicker,
.site-refresh .progress-card .kicker,
.site-refresh .press-release-card .kicker,
.site-refresh .press-optin-card .kicker,
.site-refresh .legal-card .kicker {
    color: #8fd6f3;
}

.site-refresh .page-hero-box h1,
.site-refresh .page-hero-box h2,
.site-refresh .page-hero-box h3,
.site-refresh .post-card h2,
.site-refresh .post-card h3,
.site-refresh .post-card .post-title-link,
.site-refresh .progress-card h2,
.site-refresh .progress-card h3,
.site-refresh .press-release-card h2,
.site-refresh .press-release-card h3,
.site-refresh .press-optin-card h2,
.site-refresh .press-optin-card h3,
.site-refresh .legal-card h2,
.site-refresh .legal-card h3,
.site-refresh .single-card h1,
.site-refresh .single-card h2,
.site-refresh .single-card h3 {
    color: var(--pib-text-inverse);
}

.site-refresh .page-hero-box p:not(.kicker),
.site-refresh .post-card p,
.site-refresh .post-card .post-meta,
.site-refresh .post-card .post-excerpt,
.site-refresh .progress-card p,
.site-refresh .press-release-card p,
.site-refresh .press-optin-card p,
.site-refresh .legal-card p,
.site-refresh .single-content,
.site-refresh .archive-empty p,
.site-refresh .form-consent {
    color: var(--pib-text-inverse-soft);
}

.site-refresh .post-card .post-title-link:hover,
.site-refresh .post-card .post-title-link:focus-visible {
    color: #8fd6f3;
}

.site-refresh .post-card .text-link,
.site-refresh .progress-card .text-link,
.site-refresh .press-release-card .text-link,
.site-refresh .press-optin-card .text-link,
.site-refresh .legal-card a,
.site-refresh .single-card .text-link {
    color: #9edcf6;
}

.site-refresh .post-card .text-link:hover,
.site-refresh .post-card .text-link:focus-visible,
.site-refresh .progress-card .text-link:hover,
.site-refresh .progress-card .text-link:focus-visible,
.site-refresh .press-release-card .text-link:hover,
.site-refresh .press-release-card .text-link:focus-visible,
.site-refresh .press-optin-card .text-link:hover,
.site-refresh .press-optin-card .text-link:focus-visible,
.site-refresh .legal-card a:hover,
.site-refresh .legal-card a:focus-visible,
.site-refresh .single-card .text-link:hover,
.site-refresh .single-card .text-link:focus-visible {
    color: var(--pib-orange);
}

.site-refresh .contact-form label,
.site-refresh .press-optin-form label {
    color: var(--pib-text-inverse);
}

.site-refresh .contact-form input,
.site-refresh .contact-form textarea,
.site-refresh .press-optin-form input[type="email"] {
    background: rgba(10, 33, 57, 0.66);
    border-color: rgba(129, 166, 192, 0.48);
    color: var(--pib-text-inverse);
}

.site-refresh .contact-form input::placeholder,
.site-refresh .contact-form textarea::placeholder,
.site-refresh .press-optin-form input[type="email"]::placeholder {
    color: rgba(201, 224, 240, 0.7);
}

.site-refresh .news-categories__link.btn-ghost {
    background: rgba(236, 248, 250, 0.72);
    border-color: rgba(131, 172, 194, 0.68);
    color: var(--pib-blue-900);
}

.site-refresh .news-categories__link.btn-ghost:hover,
.site-refresh .news-categories__link.btn-ghost:focus-visible {
    background: rgba(245, 252, 253, 0.92);
    color: var(--pib-orange-deep);
}

.site-refresh .pagination .current {
    background: rgba(143, 214, 243, 0.25);
    color: var(--pib-text-inverse);
}

.site-refresh .site-footer {
    background: rgba(9, 48, 74, 0.9);
    border-top-color: rgba(192, 227, 236, 0.26);
}

.site-refresh .footer-inner p,
.site-refresh .footer-credit a,
.site-refresh .footer-link,
.site-refresh .footer-pref-btn {
    color: rgba(234, 247, 250, 0.94);
}

.site-refresh .footer-credit a:hover,
.site-refresh .footer-credit a:focus-visible,
.site-refresh .footer-link:hover,
.site-refresh .footer-link:focus-visible,
.site-refresh .footer-pref-btn:hover,
.site-refresh .footer-pref-btn:focus-visible {
    color: var(--pib-orange);
}

@media (prefers-reduced-motion: no-preference) {
    .site-refresh .service-card {
        transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
    }

    .site-refresh .service-card:hover {
        transform: translateY(-2px);
        border-color: rgba(110, 156, 180, 0.56);
        box-shadow: 0 16px 28px rgba(8, 54, 84, 0.17);
    }

    .site-refresh .service-icon {
        transition: transform 240ms ease, box-shadow 240ms ease;
    }

    .site-refresh .service-card:hover .service-icon {
        transform: translateY(-1px) scale(1.03);
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7), 0 8px 14px rgba(13, 57, 89, 0.14);
    }

    .site-refresh .status-list li {
        opacity: 0;
        transform: translateY(8px);
        animation: pib-data-rise 520ms ease forwards;
    }

    .site-refresh .status-list li:nth-child(1) { animation-delay: 80ms; }
    .site-refresh .status-list li:nth-child(2) { animation-delay: 140ms; }
    .site-refresh .status-list li:nth-child(3) { animation-delay: 200ms; }

    .site-refresh .status-list strong {
        animation: pib-badge-breathe 2.8s ease-in-out infinite;
    }
}

@media (prefers-reduced-motion: reduce) {
    .site-refresh .service-card,
    .site-refresh .service-icon,
    .site-refresh .status-list li,
    .site-refresh .status-list strong {
        animation: none !important;
        transition: none !important;
        transform: none !important;
    }
}

@media (max-width: 980px) {
    .site-refresh .hero-grid {
        grid-template-columns: 1fr;
    }

    .site-refresh .home-section {
        padding-top: clamp(2.4rem, 5vw, 3.2rem);
        padding-bottom: clamp(2.4rem, 5vw, 3.2rem);
    }
}

@media (max-width: 760px) {
    .site-refresh .site-header-v2 .brand img {
        width: clamp(162px, 49vw, 210px);
    }

    .site-refresh .site-header-v2 .main-nav ul {
        background: rgba(10, 53, 80, 0.18);
        border: 1px solid rgba(18, 76, 105, 0.24);
        box-shadow: inset 0 1px 0 rgba(230, 247, 250, 0.3);
    }

    .site-refresh .site-header-v2 .main-nav a {
        padding: 0.42rem 0.72rem;
        font-size: 0.9rem;
        text-transform: none;
        letter-spacing: 0.01em;
    }

    .site-refresh .home-section {
        padding-top: 2.2rem;
        padding-bottom: 2.2rem;
    }
}

@keyframes pib-data-rise {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes pib-badge-breathe {
    0%, 100% {
        filter: saturate(1);
        transform: translateY(0);
    }
    50% {
        filter: saturate(1.08);
        transform: translateY(-1px);
    }
}

/* SURGICAL REFINEMENT V3: palette, hierarchy, spacing and contrast */
.site-refresh {
    --pib-accent: #f2ad28;
    --pib-accent-2: #f6bf4e;
    --pib-accent-deep: #d79416;
}

.site-refresh p,
.site-refresh li {
    line-height: 1.72;
}

.site-refresh .site-header-v2 .header-inner {
    min-height: 90px;
    padding-top: 0.52rem;
    padding-bottom: 0.52rem;
}

.site-refresh .site-header-v2 .brand-logo {
    width: clamp(158px, 11.2vw, 194px);
    height: auto;
}

.site-refresh .footer-icon {
    width: 26px;
    height: 26px;
    object-fit: contain;
    background: transparent;
    display: block;
}

.site-refresh .site-header-v2 .main-nav a {
    font-size: clamp(0.95rem, 1.03vw, 1.05rem);
    font-weight: 700;
    letter-spacing: 0.012em;
    text-transform: uppercase;
}

.site-refresh .site-header-v2 .main-nav a.current,
.site-refresh .site-header-v2 .main-nav a[aria-current="page"] {
    background: transparent;
    box-shadow: inset 0 -2px 0 rgba(10, 55, 91, 0.56);
    color: #083b61;
}

.site-refresh .hero-content,
.site-refresh .highlight-card {
    background:
        linear-gradient(155deg, rgba(223, 239, 244, 0.98), rgba(210, 232, 239, 0.96)),
        radial-gradient(circle at 85% 10%, rgba(255, 255, 255, 0.36), transparent 46%);
    border-color: rgba(124, 166, 187, 0.46);
}

.site-refresh .hero-content h1,
.site-refresh .hero-content h2,
.site-refresh .hero-content h3 {
    color: #0b3a63;
}

.site-refresh .hero-content h1 {
    font-size: clamp(3rem, 5.3vw, 5rem);
    font-weight: 800;
    line-height: 1.05;
    max-width: 11ch;
    margin-bottom: 1.05rem;
}

.site-refresh .hero-content .kicker {
    color: #124e79;
}

.site-refresh .hero-content .hero-text,
.site-refresh .hero-content p:not(.kicker) {
    color: #275d7d;
    font-size: clamp(1rem, 1.24vw, 1.26rem);
    max-width: 52ch;
}

.site-refresh .btn-primary {
    background: linear-gradient(135deg, var(--pib-accent), var(--pib-accent-2));
    color: #122538;
    box-shadow: 0 12px 24px rgba(199, 135, 15, 0.3);
}

.site-refresh .btn-primary:hover,
.site-refresh .btn-primary:focus-visible {
    background: linear-gradient(135deg, var(--pib-accent-deep), var(--pib-accent));
    color: #101f30;
}

.site-refresh .btn-ghost {
    background: rgba(235, 247, 251, 0.82);
    border-color: rgba(118, 162, 188, 0.82);
    color: #12456f;
}

.site-refresh .btn-ghost:hover,
.site-refresh .btn-ghost:focus-visible {
    background: rgba(248, 252, 254, 0.96);
    border-color: rgba(89, 143, 175, 0.82);
    color: #0d3a5f;
}

.site-refresh .hero-actions {
    gap: 0.8rem;
}

.site-refresh .highlight-card h2 {
    color: #0d3f69;
    font-size: clamp(2rem, 3vw, 2.9rem);
    margin-bottom: 0.8rem;
}

.site-refresh .highlight-card p {
    color: #275d7d;
}

.site-refresh .highlight-card .text-link,
.site-refresh .about .text-link,
.site-refresh .service-card .text-link,
.site-refresh .content-card .text-link {
    color: #0f4d78;
}

.site-refresh .highlight-card .text-link:hover,
.site-refresh .highlight-card .text-link:focus-visible,
.site-refresh .about .text-link:hover,
.site-refresh .about .text-link:focus-visible,
.site-refresh .service-card .text-link:hover,
.site-refresh .service-card .text-link:focus-visible,
.site-refresh .content-card .text-link:hover,
.site-refresh .content-card .text-link:focus-visible {
    color: var(--pib-accent-deep);
}

.site-refresh .status-list li {
    background: rgba(234, 245, 248, 0.95);
    border-color: rgba(152, 188, 206, 0.66);
}

.site-refresh .status-list span {
    color: #1d4f71;
    font-size: clamp(1rem, 1.05vw, 1.18rem);
}

.site-refresh .status-list strong {
    background: linear-gradient(135deg, var(--pib-accent), var(--pib-accent-2));
    color: #1a2d40;
}

.site-refresh .home-section {
    padding-top: clamp(4.1rem, 7.2vw, 6.4rem);
    padding-bottom: clamp(4.1rem, 7.2vw, 6.4rem);
}

.site-refresh .services .service-grid,
.site-refresh .content-hub .split-grid,
.site-refresh .progress-grid,
.site-refresh .post-grid {
    gap: clamp(1.2rem, 2.1vw, 1.85rem);
    margin-top: clamp(1.45rem, 2.3vw, 2rem);
}

.site-refresh .service-card,
.site-refresh .content-card,
.site-refresh .post-card,
.site-refresh .progress-card,
.site-refresh .press-release-card {
    padding: clamp(1.28rem, 2vw, 1.72rem);
}

.site-refresh .service-card h3,
.site-refresh .content-card h2,
.site-refresh .post-card h2,
.site-refresh .post-card h3,
.site-refresh .progress-card h3,
.site-refresh .press-release-card h3 {
    margin-bottom: 0.72rem;
}

.site-refresh .service-card p,
.site-refresh .content-card p,
.site-refresh .post-card p,
.site-refresh .post-card .post-excerpt,
.site-refresh .progress-card p,
.site-refresh .press-release-card p,
.site-refresh .about p:not(.kicker) {
    font-size: clamp(1rem, 1.04vw, 1.14rem);
}

.site-refresh .page-hero-box h1,
.site-refresh .page-hero-box h2,
.site-refresh .page-hero-box h3,
.site-refresh .post-card h2,
.site-refresh .post-card h3,
.site-refresh .post-card .post-title-link,
.site-refresh .progress-card h2,
.site-refresh .progress-card h3,
.site-refresh .press-release-card h2,
.site-refresh .press-release-card h3,
.site-refresh .press-optin-card h2,
.site-refresh .press-optin-card h3,
.site-refresh .legal-card h2,
.site-refresh .legal-card h3 {
    color: #eff8ff;
}

.site-refresh .site-footer {
    background: rgba(9, 48, 74, 0.92);
}

.site-refresh .footer-inner {
    min-height: 78px;
    gap: 0.84rem;
}

@media (max-width: 980px) {
    .site-refresh .site-header-v2 .main-nav a {
        font-size: 0.91rem;
    }

    .site-refresh .hero-content h1 {
        font-size: clamp(2.45rem, 7.2vw, 3.45rem);
        max-width: 13ch;
    }
}
