﻿:root {
    --copp-ink: #252525;
    --copp-ink-rgb: 37, 37, 37;
    --copp-ink-soft: #2b2b2b;
    --copp-ink-soft-rgb: 43, 43, 43;
    --copp-dark: #111111;
    --copp-dark-rgb: 17, 17, 17;
    --copp-muted: #626262;
    --copp-muted-rgb: 98, 98, 98;
    --copp-soft: #f1f2f3;
    --copp-soft-rgb: 241, 242, 243;
    --copp-pale: #e4e4e4;
    --copp-pale-rgb: 228, 228, 228;
    --copp-line: #dddddd;
    --copp-line-rgb: 221, 221, 221;
    --copp-container-sm: 648px;
    --copp-container-md: 864px;
    --copp-container-lg: 1152px;
    --copp-container-xl: 1368px;
    --copp-container-content: calc(100vw - 30px);
    --copp-hero-inner-max: 1584px;
}

.dropdown-item.active,
.dropdown-item:active {
    background-color: var(--copp-red) !important;
    color: #ffffff !important;
}

.btn-primary {
    background-color: var(--copp-red) !important;
    border-color: var(--copp-red) !important;
    color: #ffffff !important;
}

.btn-primary:hover,
.btn-primary:focus {
    background-color: var(--copp-red) !important;
    border-color: var(--copp-red) !important;
    color: #ffffff !important;
}

.btn-outline-primary {
    color: var(--copp-red) !important;
    border-color: var(--copp-red) !important;
}

.btn-outline-primary:hover,
.btn-outline-primary:focus {
    background-color: var(--copp-red) !important;
    border-color: var(--copp-red) !important;
    color: #ffffff !important;
}

.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
    background-color: var(--copp-red) !important;
    color: #ffffff !important;
}

.page-link.active,
.page-item.active .page-link {
    background-color: var(--copp-red) !important;
    border-color: var(--copp-red) !important;
    color: #ffffff !important;
}

.bg-primary {
    background-color: var(--copp-red) !important;
}

.badge-primary {
    background-color: var(--copp-red) !important;
    color: #ffffff !important;
}

.list-group-item.active {
    background-color: var(--copp-red) !important;
    border-color: var(--copp-red) !important;
    color: #ffffff !important;
}

a:hover,
a:focus {
    color: var(--copp-red);
}

a:not([href]):hover,
a:not([href]):focus {
    color: inherit;
}

.copp-footer-column a:hover,
.copp-footer-column a:focus {
    color: #ffffff;
}

:root {
    --copp-container-sm: 648px;
    --copp-container-md: 864px;
    --copp-container-lg: 1152px;
    --copp-container-xl: 1368px;
    --copp-container-content: calc(100vw - 30px);
    --copp-hero-inner-max: 1584px;
    --copp-search-offset: 104px;
    --copp-font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    --copp-font-heading: 'Montserrat', 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;

    --copp-fs-hero: clamp(42px, 5vw, 72px);
    --copp-fs-hero-sub: clamp(34px, 4vw, 60px);
    --copp-fs-section: 28px;
    --copp-fs-card-title: 16px;
    --copp-fs-body: 15px;
    --copp-fs-body-sm: 14px;
    --copp-fs-eyebrow: 12px;
    --copp-fs-badge: 11px;
    --copp-fs-label: 13px;
    --copp-fs-btn: 15px;

    --copp-fw-heading: 800;
    --copp-fw-heading-bold: 900;
    --copp-fw-eyebrow: 800;
    --copp-fw-body: 400;
    --copp-fw-medium: 500;
    --copp-fw-semibold: 600;
    --copp-fw-bold: 700;
    --copp-fw-black: 900;

    --copp-lh-hero: 0.95;
    --copp-lh-section: 1.05;
    --copp-lh-heading: 1.2;
    --copp-lh-card-title: 1.3;
    --copp-lh-body: 1.55;
    --copp-lh-eyebrow: 1;
    --copp-lh-btn: 1;

    --copp-ls-eyebrow: 0.08em;
    --copp-ls-section: 0.02em;
    --copp-ls-label: 0.04em;
}

body {
    color: var(--copp-ink);
    font-family: var(--copp-font-body);
    letter-spacing: 0;
    overflow-x: hidden;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

h1, h2, h3, h4, h5, h6,
.copp-overview__title,
.copp-pathfinder__title,
.copp-showcase__title,
.copp-news-hero__title,
.copp-programs-archive__copy h1,
.copp-program-article__copy h1,
.copp-stat-card__value,
.copp-program-tile__body h2,
.copp-program-tile__body h3,
.copp-events-calendar__month-head strong,
.copp-doc-card__title {
    font-family: var(--copp-font-heading);
}

body.copp-search-open {
    overflow: hidden;
}

html {
    overflow-x: hidden;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

html::-webkit-scrollbar,
body::-webkit-scrollbar {
    display: none;
    height: 0;
    width: 0;
}

.icms-cookiealert {
    background: transparent;
    bottom: 20px;
    left: 0;
    margin: 0;
    opacity: 0;
    padding: 0 18px;
    pointer-events: none;
    right: 0;
    transform: translateY(calc(100% + 20px));
    transition: opacity 320ms ease, transform 320ms ease;
    z-index: 1060;
}

.icms-cookiealert.show {
    opacity: 1;
    transform: translateY(0);
}

.icms-cookiealert > .container {
    max-width: var(--copp-container-content);
    padding-left: 0;
    padding-right: 0;
}

.icms-cookiealert__inner {
    align-items: center;
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.12);
    border-radius: 0;
    box-shadow: 0 20px 48px rgba(0, 0, 0, 0.16);
    color: var(--copp-ink);
    display: flex;
    gap: 24px;
    padding: 18px 22px;
    pointer-events: auto;
}

.icms-cookiealert__text {
    color: var(--copp-ink);
    flex: 1 1 auto;
    font-size: 15px;
    line-height: 1.55;
}

.icms-cookiealert__text > *:last-child {
    margin-bottom: 0;
}

.icms-cookiealert__link {
    color: var(--copp-red);
    display: inline;
    font-size: inherit;
    font-weight: 700;
    text-decoration: none;
}

.icms-cookiealert__link:hover,
.icms-cookiealert__link:focus {
    color: var(--copp-red-dark);
    outline: none;
    text-decoration: underline;
}

.icms-cookiealert__button {
    align-items: center;
    background: var(--copp-red);
    border: 2px solid var(--copp-red);
    border-radius: 0;
    color: #ffffff;
    cursor: pointer;
    display: inline-flex;
    flex: 0 0 auto;
    font-size: 15px;
    font-weight: 800;
    height: 48px;
    justify-content: center;
    min-width: 88px;
    padding: 0 24px;
    transition: background-color 180ms ease, border-color 180ms ease, color 180ms ease;
}

.icms-cookiealert__button:hover,
.icms-cookiealert__button:focus {
    background: var(--copp-red-dark);
    border-color: var(--copp-red-dark);
    color: #ffffff;
    outline: none;
}

#scroll-top {
    align-items: center;
    background: var(--copp-red);
    border: 0;
    border-radius: 50%;
    bottom: 28px;
    box-shadow: 0 18px 40px rgba(var(--copp-ink-rgb), 0.22);
    color: #ffffff;
    display: inline-flex;
    height: 56px;
    justify-content: center;
    opacity: 0;
    padding: 0;
    right: 28px;
    transform: translateY(18px) scale(0.92);
    transition: background-color 180ms ease, box-shadow 180ms ease, opacity 220ms ease, transform 220ms ease;
    visibility: hidden;
    width: 56px;
}

#scroll-top:hover,
#scroll-top:focus {
    background: var(--copp-red-dark);
    box-shadow: 0 22px 42px rgba(var(--copp-ink-rgb), 0.26);
    color: #ffffff;
    outline: none;
    text-decoration: none;
    transform: translateY(-2px);
}

#scroll-top .icms-svg-icon {
    height: 18px;
    width: 18px;
}

.copp-inline-arrow {
    align-items: center;
    display: inline-flex;
    flex: 0 0 auto;
    justify-content: center;
    line-height: 1;
}

.copp-inline-arrow .icms-svg-icon {
    height: 0.95em;
    width: 0.95em;
}

.copp-inline-arrow--sep {
    margin: 0 0.45rem;
    opacity: 0.8;
}

#scroll-top.position-fixed {
    opacity: 1;
    transform: translateY(0) scale(1);
    visibility: visible;
}

.copp-scroll-square {
    --copp-scroll-square-left: 0px;
    --copp-scroll-square-top: 132px;
    --copp-scroll-square-x: 0px;
    --copp-scroll-square-rot: 0deg;
    --copp-scroll-square-progress: 0;
    background: transparent;
    bottom: 0;
    left: 0;
    pointer-events: none;
    position: fixed;
    top: 0;
    width: clamp(96px, 10vw, 132px);
    z-index: 12;
}

.copp-scroll-square__roller {
    background: transparent;
    border: 3px solid var(--copp-dark);
    border-radius: 0;
    box-shadow: none;
    cursor: grab;
    height: clamp(60px, 6vw, 82px);
    left: calc(var(--copp-scroll-square-left) + var(--copp-scroll-square-x));
    pointer-events: auto;
    position: absolute;
    touch-action: none;
    top: var(--copp-scroll-square-top);
    transform: rotate(var(--copp-scroll-square-rot));
    transform-origin: 50% 50%;
    user-select: none;
    width: clamp(60px, 6vw, 82px);
}

.copp-scroll-square.is-dragging .copp-scroll-square__roller {
    cursor: grabbing;
}

.copp-scroll-square__artifact {
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    inset: 0;
    opacity: 0;
    pointer-events: none;
    position: absolute;
    transition: opacity 220ms linear;
    will-change: opacity;
}

.copp-scroll-square__artifact.is-active {
    opacity: 1;
}

@media (max-width: 767.98px) {
    #scroll-top {
        bottom: 18px;
        height: 48px;
        right: 18px;
        width: 48px;
    }
}

@media (max-width: 991.98px) {
    .copp-scroll-square {
        display: none;
    }
}

@media (min-width: 576px) {
    :root {
        --copp-container-content: calc(var(--copp-container-sm) - 30px);
    }

    .container,
    .container-sm {
        max-width: var(--copp-container-sm);
    }
}

@media (min-width: 768px) {
    :root {
        --copp-container-content: calc(var(--copp-container-md) - 30px);
    }

    .container,
    .container-sm,
    .container-md {
        max-width: var(--copp-container-md);
    }
}

@media (min-width: 992px) {
    :root {
        --copp-container-content: calc(var(--copp-container-lg) - 30px);
    }

    .container,
    .container-sm,
    .container-md,
    .container-lg {
        max-width: var(--copp-container-lg);
    }
}

@media (min-width: 1200px) {
    :root {
        --copp-container-content: calc(var(--copp-container-xl) - 30px);
    }

    .container,
    .container-sm,
    .container-md,
    .container-lg,
    .container-xl {
        max-width: var(--copp-container-xl);
    }
}

.icms-header__middle {
    background: #ffffff;
    color: var(--copp-ink);
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.08);
    position: relative;
    z-index: 20;
}

.icms-header__middle > .container {
    align-items: center !important;
    min-height: 104px;
    gap: 20px;
}

.icms-header__middle .navbar {
    align-items: center;
    color: var(--copp-ink);
    display: flex;
    min-width: 0;
    height: 100%;
}

.icms-header__middle .navbar-expand-lg {
    flex: 1 1 auto;
    justify-content: flex-end;
    min-width: 0;
    height: 100%;
}

.icms-header__middle .navbar-dark {
    flex: 0 0 auto;
    justify-content: flex-end;
    margin-left: 8px;
    height: 100%;
}

.icms-header__middle .navbar-collapse {
    align-items: center;
    min-width: 0;
    height: 100%;
}

.icms-header__middle .navbar-expand-lg .navbar-collapse {
    flex: 1 1 auto;
    justify-content: center;
    margin-left: 0 !important;
    height: 100%;
}

.icms-header__middle .navbar-brand {
    margin-right: 26px !important;
}

.icms-header__middle .navbar-brand img.d-none {
    display: block !important;
    width: 184px;
}

.icms-header__middle .navbar-brand img.d-sm-none {
    width: auto;
    height: 58px;
}

.copp-header__logo-svg {
    display: inline-flex;
    align-items: center;
    line-height: 0;
}

.copp-header__logo-svg svg {
    display: block;
    max-width: 100%;
    height: auto;
}

.copp-header__logo-svg--sm svg {
    height: 58px;
    width: auto;
}

.copp-header__logo-svg--lg svg {
    width: 184px;
    height: auto;
}

.icms-header__middle .ml-auto.d-flex {
    align-items: center;
    flex: 1 1 auto;
    flex-wrap: nowrap;
    gap: 0;
    justify-content: flex-start;
    margin-left: 0 !important;
    min-width: 0;
}

.icms-header__middle .container.d-flex {
    align-items: center;
    min-height: 72px;
}

.icms-header__middle .icms-navbar-brand__show_on_hide {
    display: none;
}

.icms-header__middle .navbar {
    align-items: center;
    color: var(--copp-ink);
    display: flex;
    min-width: 0;
}

.icms-header__middle .navbar-expand-lg {
    flex: 1 1 auto;
    justify-content: flex-end;
    min-width: 0;
}

.icms-header__middle .navbar-dark {
    flex: 0 0 auto;
    justify-content: flex-end;
    margin-left: 8px;
}

.icms-header__middle .navbar-collapse {
    align-items: center;
    min-width: 0;
}

.icms-header__middle .navbar-expand-lg .navbar-collapse {
    flex: 1 1 auto;
    justify-content: center;
    margin-left: 0 !important;
}

.icms-header__middle .navbar-light .navbar-nav .nav-link,
.icms-header__middle .navbar-dark .navbar-nav .nav-link {
    color: var(--copp-ink);
}

.icms-header__middle .menu-main {
    align-items: center !important;
    flex: 1 1 auto;
    gap: 16px;
    justify-content: center !important;
    width: auto !important;
    height: 100%;
}

.icms-header__middle .menu-main .nav-link {
    align-items: center;
    color: var(--copp-ink) !important;
    display: inline-flex;
    font-size: 14px;
    font-weight: 700;
    height: 72px;
    justify-content: center;
    letter-spacing: 0.05em;
    line-height: 1.2;
    padding: 0 !important;
    text-transform: uppercase;
}

.icms-header__middle .menu-main .nav-link:hover,
.icms-header__middle .menu-main .nav-link.active,
.icms-header__middle .menu-main .dropdown.show > .nav-link {
    color: var(--copp-red) !important;
    text-decoration: none;
}

.icms-header__middle .menu-main .dropdown:not(.is-active) > .nav-link {
    color: var(--copp-ink) !important;
}

.icms-header__middle .menu-main .dropdown:not(.is-active) > .nav-link:hover,
.icms-header__middle .menu-main .dropdown:not(.is-active).show > .nav-link {
    color: var(--copp-red) !important;
}

.icms-header__middle .menu-main .dropdown-menu {
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    border-radius: 0;
    box-shadow: 0 18px 42px rgba(var(--copp-ink-rgb), 0.14);
    margin-top: 10px;
    min-width: 260px;
    padding: 8px;
}

.icms-header__middle .menu-main .dropdown-item {
    align-items: center;
    border: 1px solid transparent;
    border-radius: 0;
    color: var(--copp-ink);
    display: flex;
    font-size: 14px;
    font-weight: 700;
    gap: 10px;
    line-height: 1.25;
    min-height: auto;
    padding: 10px 14px;
    transition: background-color 0.2s ease, border-color 0.2s ease;
}

.icms-header__middle .menu-main .dropdown-item:hover,
.icms-header__middle .menu-main .dropdown-item:focus {
    background-color: rgba(var(--copp-red-rgb), 0.06);
    border-color: var(--copp-red);
    color: var(--copp-red);
    text-decoration: none;
}

.icms-header__middle .menu-main .dropdown-divider {
    border-top-color: rgba(var(--copp-ink-rgb), 0.1);
    display: block;
    margin: 6px 4px;
}

.icms-header__middle .menu-main .copp-menu-project-link {
    max-width: 300px;
    white-space: normal !important;
}

.copp-menu-project-link__icon {
    align-items: center;
    background: var(--copp-red);
    border-radius: 0;
    color: #ffffff;
    display: inline-flex;
    flex: 0 0 28px;
    height: 28px;
    justify-content: center;
    width: 28px;
}

.copp-menu-project-link__icon svg {
    height: 12px;
    width: 12px;
}

.copp-menu-project-link__text {
    min-width: 0;
}

.icms-header__middle .menu-main .dropdown-submenu {
    position: relative;
}

.icms-header__middle .menu-main .dropdown-submenu > .dropdown-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    font-weight: 700;
    color: var(--copp-ink);
}

.icms-header__middle .menu-main .dropdown-submenu > .dropdown-item::after {
    content: '';
    border-left: 5px solid var(--copp-ink);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    display: inline-block;
    margin-left: auto;
    opacity: 0.5;
}

.icms-header__middle .menu-main .dropdown-submenu:hover > .dropdown-item::after {
    opacity: 1;
}

.icms-header__middle .menu-main .dropdown-submenu .copp-menu-projects-submenu {
    display: none;
    left: 100%;
    top: 0;
    margin-top: -8px;
    min-width: 280px;
    padding: 8px;
    position: absolute;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.1);
    box-shadow: 0 8px 24px rgba(0,0,0,0.15);
}

.icms-header__middle .menu-main .dropdown-submenu:hover > .copp-menu-projects-submenu {
    display: block;
}

.icms-header__middle .menu-main .copp-menu-project-group-link {
    cursor: default;
}

.icms-header__middle .menu-main .copp-menu-opportunities__menu {
    min-width: 390px;
    padding: 10px;
}

.icms-header__middle .menu-main .copp-menu-opportunity-link {
    gap: 4px;
    margin: 3px 0;
    max-width: 370px;
    white-space: normal !important;
}

.copp-menu-opportunity-link__title {
    color: var(--copp-ink);
    font-size: 14px;
    font-weight: 900;
    line-height: 1.15;
}

.copp-menu-opportunity-link__desc {
    color: rgba(var(--copp-ink-rgb), 0.62);
    font-size: 12px;
    font-weight: 700;
    line-height: 1.35;
}

.icms-header__middle .menu-main .copp-menu-opportunity-link:hover .copp-menu-opportunity-link__title,
.icms-header__middle .menu-main .copp-menu-opportunity-link:focus .copp-menu-opportunity-link__title {
    color: var(--copp-red);
}

.icms-header__middle .menu-main .copp-menu-opportunity-link.active .copp-menu-opportunity-link__title {
    color: #ffffff;
}

.icms-header__middle .menu-main .copp-menu-about__menu {
    min-width: 390px;
    padding: 10px;
}

.icms-header__middle .menu-main .copp-menu-about-link {
    gap: 4px;
    margin: 3px 0;
    max-width: 370px;
    white-space: normal !important;
}

.icms-header__middle .menu-main .copp-menu-about-link:hover,
.icms-header__middle .menu-main .copp-menu-about-link:focus {
    background-color: rgba(var(--copp-red-rgb), 0.06);
    border-color: var(--copp-red);
}

.copp-menu-about-link__title {
    color: var(--copp-ink);
    font-size: 14px;
    font-weight: 900;
    line-height: 1.15;
}

.copp-menu-about-link__desc {
    color: rgba(var(--copp-ink-rgb), 0.62);
    font-size: 12px;
    font-weight: 700;
    line-height: 1.35;
}

.icms-header__middle .menu-main .copp-menu-about-link:hover .copp-menu-about-link__title,
.icms-header__middle .menu-main .copp-menu-about-link:focus .copp-menu-about-link__title {
    color: var(--copp-red);
}

.icms-header__middle .menu-main .copp-menu-about-link.active .copp-menu-about-link__title {
    color: #ffffff;
}

.icms-header__middle .menu-main .copp-menu-opportunities__menu > li:not(:last-child),
.icms-header__middle .menu-main .copp-menu-about__menu > li:not(:last-child) {
    margin-bottom: 4px;
}

@media (min-width: 992px) {
    .icms-header__middle .menu-main .nav-item.dropdown:hover > .dropdown-menu,
    .icms-header__middle .menu-main .nav-item.dropdown:focus-within > .dropdown-menu {
        display: block;
    }
}

@media (max-width: 991px) {
    .icms-header__middle .menu-main .dropdown-menu {
        border: 0;
        box-shadow: none;
        margin-top: 0;
        min-width: 0;
        padding: 4px 0 6px 10px;
    }

    .icms-header__middle .menu-main .copp-menu-opportunities__menu {
        min-width: 0;
        padding-left: 8px;
    }

    .icms-header__middle .menu-main .copp-menu-opportunity-link {
        max-width: none;
    }

    .icms-header__middle .menu-main .copp-menu-about__menu {
        min-width: 0;
        padding-left: 8px;
    }

    .icms-header__middle .menu-main .copp-menu-about-link {
        max-width: none;
    }

}

.icms-header__middle .form-inline {
    align-items: center;
    display: flex;
    flex: 0 0 auto;
    margin-left: 18px !important;
}

.icms-header__middle .form-inline .input-group {
    align-items: center;
    height: 40px;
    width: 40px;
}

.icms-header__middle .form-inline .form-control {
    border: 0;
    height: 1px;
    opacity: 0;
    padding: 0;
    pointer-events: none;
    position: absolute;
    width: 1px;
}

.icms-header__middle .form-inline .input-group-append {
    margin-left: 0;
}

.icms-header__middle .form-inline .btn {
    align-items: center;
    background: transparent;
    border: 0;
    color: var(--copp-ink);
    display: flex;
    height: 40px;
    justify-content: center;
    padding: 0;
    width: 40px;
}

.icms-header__middle .form-inline .btn:hover,
.icms-header__middle .form-inline .btn:focus {
    color: var(--copp-red);
    box-shadow: none;
}

.icms-header__middle .form-inline .icms-svg-icon {
    font-size: 20px;
}

.icms-header__middle .copp-search-panel__backdrop {
    background: rgba(var(--copp-dark-rgb), 0.22);
    inset: var(--copp-search-offset) 0 0;
    opacity: 0;
    pointer-events: none;
    position: fixed;
    transition: opacity 220ms ease;
    z-index: 28;
}

.icms-header__middle .copp-search-panel {
    left: 0;
    opacity: 0;
    pointer-events: none;
    position: absolute;
    right: 0;
    top: calc(100% - 1px);
    transform: translateY(-12px);
    transition: opacity 220ms ease, transform 220ms ease;
    z-index: 29;
}

.icms-header__middle [data-copp-search-root].is-search-open .copp-search-panel__backdrop {
    opacity: 1;
    pointer-events: auto;
}

.icms-header__middle [data-copp-search-root].is-search-open .copp-search-panel {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

.copp-search-panel > .container {
    max-width: var(--copp-container-content);
    padding-left: 0;
    padding-right: 0;
}

.copp-search-panel__inner {
    background: rgba(255, 255, 255, 0.98);
    border: 1px solid rgba(var(--copp-ink-rgb), 0.1);
    border-radius: 0;
    box-shadow: 0 28px 56px rgba(0, 0, 0, 0.16);
    padding: 28px 32px 30px;
}

.copp-search-panel__head {
    align-items: center;
    display: flex;
    gap: 24px;
    justify-content: space-between;
    margin-bottom: 22px;
}

.copp-search-panel__heading h2 {
    color: var(--copp-ink);
    font-size: 30px;
    font-weight: 900;
    line-height: 1.05;
    margin: 6px 0 0;
    text-transform: uppercase;
}

.copp-search-panel__eyebrow {
    color: var(--copp-red);
    display: inline-block;
    font-size: var(--copp-fs-eyebrow);
    font-weight: var(--copp-fw-eyebrow);
    letter-spacing: var(--copp-ls-eyebrow);
    text-transform: uppercase;
}

.copp-search-panel__close {
    align-items: center;
    background: var(--copp-soft);
    border: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    border-radius: 0;
    color: var(--copp-ink);
    cursor: pointer;
    display: inline-flex;
    flex: 0 0 auto;
    height: 48px;
    justify-content: center;
    padding: 0;
    transition: background-color 180ms ease, border-color 180ms ease, color 180ms ease;
    width: 48px;
}

.copp-search-panel__close:hover,
.copp-search-panel__close:focus {
    background: #ffffff;
    border-color: rgba(var(--copp-red-rgb), 0.22);
    color: var(--copp-red);
    outline: none;
}

.copp-search-panel__close svg {
    height: 18px;
    width: 18px;
}

.copp-search-panel__form {
    display: grid;
    gap: 20px;
}

.copp-search-panel__query-row {
    align-items: end;
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(0, 1fr) auto;
}

.copp-search-panel__query,
.copp-search-panel__field {
    display: grid;
    gap: 10px;
    margin: 0;
}

.copp-search-panel__field-label {
    color: var(--copp-muted);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.copp-search-panel__input,
.copp-search-panel__select {
    appearance: none;
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.12);
    border-radius: 0;
    color: var(--copp-ink);
    font-size: 16px;
    font-weight: 600;
    height: 56px;
    min-width: 0;
    padding: 0 18px;
    transition: border-color 180ms ease, box-shadow 180ms ease;
    width: 100%;
}

.copp-search-panel__input:focus,
.copp-search-panel__select:focus {
    border-color: rgba(var(--copp-red-rgb), 0.45);
    box-shadow: 0 0 0 4px rgba(var(--copp-red-rgb), 0.08);
    outline: none;
}

.copp-search-panel__select {
    background-image: linear-gradient(45deg, transparent 50%, var(--copp-ink) 50%), linear-gradient(135deg, var(--copp-ink) 50%, transparent 50%);
    background-position: calc(100% - 21px) calc(50% - 4px), calc(100% - 15px) calc(50% - 4px);
    background-repeat: no-repeat;
    background-size: 6px 6px, 6px 6px;
    padding-right: 42px;
}

.copp-search-panel__filters {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.copp-search-panel__actions {
    align-items: center;
    display: flex;
    gap: 14px;
}

.copp-search-panel__reset {
    color: var(--copp-muted);
    font-size: 14px;
    font-weight: 700;
    text-decoration: none;
    white-space: nowrap;
}

.copp-search-panel__reset:hover,
.copp-search-panel__reset:focus {
    color: var(--copp-red);
    outline: none;
    text-decoration: none;
}

.copp-search-panel__submit {
    align-items: center;
    background: var(--copp-red);
    border: 2px solid var(--copp-red);
    border-radius: 0;
    color: #ffffff;
    cursor: pointer;
    display: inline-flex;
    gap: 10px;
    height: 56px;
    justify-content: center;
    min-width: 164px;
    padding: 0 24px;
    transition: background-color 180ms ease, border-color 180ms ease;
}

.copp-search-panel__submit:hover,
.copp-search-panel__submit:focus {
    background: var(--copp-red-dark);
    border-color: var(--copp-red-dark);
    color: #ffffff;
    outline: none;
}

.copp-search-panel__submit .icms-svg-icon {
    height: 16px;
    width: 16px;
}

.icms-header__middle .menu-header {
    align-items: center !important;
    justify-content: flex-end;
    flex: 0 0 auto;
    gap: 12px;
    margin-left: 0;
}

.icms-header__middle .menu-main .nav-item,
.icms-header__middle .menu-header .nav-item {
    align-items: center;
    display: flex;
}

.icms-header__middle .menu-main > .nav-item {
    flex: 0 1 auto;
    justify-content: center;
    white-space: nowrap;
}

.icms-header__middle .menu-header .nav-link {
    align-items: center;
    border: 2px solid var(--copp-ink);
    color: var(--copp-ink) !important;
    display: inline-flex;
    font-size: 13px;
    font-weight: 700;
    height: 38px;
    justify-content: center;
    min-width: 0;
    padding: 0 16px !important;
    text-decoration: none;
    white-space: nowrap;
}

.icms-header__middle .menu-header .nav-link svg {
    display: none;
}

.icms-header__middle .menu-header .nav-link:hover,
.icms-header__middle .menu-header .nav-link:focus {
    border-color: var(--copp-red);
    color: var(--copp-red) !important;
}

.icms-header__middle .menu-notices,
.icms-header__middle .notices-counter {
    display: none !important;
}

.icms-header__middle .icms-user-menu {
    align-items: center;
    background: transparent;
    border-radius: 0;
    display: flex;
    margin-left: 4px;
    max-width: 220px;
}

.icms-header__middle .icms-user-menu__summary {
    background: transparent;
    border: none;
    border-radius: 0;
    color: var(--copp-ink);
    cursor: pointer;
    gap: 8px;
    height: 40px;
    min-width: 0;
    padding: 0 8px !important;
    transition: opacity 0.15s;
}

.icms-header__middle .icms-user-menu__summary:hover,
.icms-header__middle .icms-user-menu.show .icms-user-menu__summary {
    opacity: 0.7;
}

.icms-header__middle .icms-user-menu__summary .icms-user-avatar > *,
.icms-header__middle .icms-user-menu__summary .icms-profile-avatar__default.avatar__mini {
    border: none;
    border-radius: 50%;
    min-height: 28px;
    min-width: 28px;
}

.icms-header__middle .icms-user-menu__summary .icms-profile-avatar__default.avatar__mini svg {
    color: var(--copp-ink);
}

.icms-header__middle .icms-user-menu__nickname {
    color: var(--copp-ink) !important;
    display: flex;
    font-size: 0.82rem;
    font-weight: 700;
    min-width: 0;
}

.icms-header__middle .icms-user-menu__nickname span {
    display: block !important;
    max-width: 120px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.icms-header__middle .icms-user-menu__nickname .dropdown-toggle::after {
    border-top-color: rgba(var(--copp-ink-rgb), 0.3);
    margin-left: 6px;
}

.icms-header__middle .icms-user-menu__items {
    background: var(--copp-dark);
    border: none;
    border-radius: 0;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
    left: auto !important;
    margin-top: 0;
    min-width: 260px;
    padding: 0;
    right: 0 !important;
}

.icms-header__middle .icms-user-menu__items .nav-item {
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.icms-header__middle .icms-user-menu__items .nav-item:last-child {
    border-bottom: none;
}

.icms-header__middle .icms-user-menu__items .nav-link {
    color: rgba(255, 255, 255, 0.85) !important;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.01em;
    padding: 12px 18px;
    transition: background 0.15s, color 0.15s;
}

.icms-header__middle .icms-user-menu__items .nav-link:hover,
.icms-header__middle .icms-user-menu__items .nav-link:focus {
    background: rgba(var(--copp-red-rgb), 0.12);
    color: #ffffff !important;
}

.icms-header__middle .icms-user-menu__items .nav-link .icms-svg-icon {
    color: rgba(255, 255, 255, 0.4);
}

.icms-header__middle .icms-user-menu__items .nav-link:hover .icms-svg-icon {
    color: var(--copp-red);
}

.icms-header__middle .icms-user-menu__items .nav-item.cpanel .nav-link {
    color: var(--copp-red) !important;
}

.icms-header__middle .icms-user-menu__items .nav-item.cpanel .nav-link:hover {
    background: var(--copp-red);
    color: #ffffff !important;
}

.icms-header__middle .icms-user-menu__items .nav-item.logout .nav-link {
    color: rgba(255, 255, 255, 0.5) !important;
}

.icms-header__middle .icms-user-menu__items .nav-item.logout .nav-link:hover {
    color: #ffffff !important;
}

.icms-header__middle .icms-user-menu__items .dropdown-menu {
    background: var(--copp-dark);
    border: none;
    border-radius: 0;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
    margin-top: 0;
    padding: 0;
}

.icms-header__middle .icms-user-menu__items .dropdown-menu .dropdown-item {
    color: rgba(255, 255, 255, 0.75) !important;
    font-size: 13px;
    font-weight: 600;
    padding: 10px 18px 10px 28px;
    transition: background 0.15s, color 0.15s;
}

.icms-header__middle .icms-user-menu__items .dropdown-menu .dropdown-item:hover,
.icms-header__middle .icms-user-menu__items .dropdown-menu .dropdown-item:focus {
    background: rgba(var(--copp-red-rgb), 0.12);
    color: #ffffff !important;
}

.icms-header__middle .icms-user-menu__items .dropdown-toggle::after {
    border-top-color: rgba(255, 255, 255, 0.4);
}

.icms-header__middle #menu-item-id-header-35 {
    background: var(--copp-red);
    border-color: var(--copp-red);
    color: #ffffff !important;
    min-width: 118px;
}

.icms-header__middle #menu-item-id-header-35:hover,
.icms-header__middle #menu-item-id-header-35:focus {
    background: var(--copp-red-dark);
    border-color: var(--copp-red-dark);
    color: #ffffff !important;
}

.icms-header__bottom {
    background: var(--copp-soft);
    border-bottom: 0 !important;
}

.icms-header__bottom > .container {
    max-width: none;
    padding-left: 0;
    padding-right: 0;
}

.copp-hero {
    background: var(--copp-soft);
    min-height: 445px;
    overflow: visible;
    position: relative;
    z-index: 3;
}

.copp-hero__slides {
    overflow: hidden;
}

.copp-hero__track {
    display: flex;
    transform: translate3d(0, 0, 0);
}

.copp-hero__slide {
    flex: 0 0 100%;
    min-width: 100%;
    overflow: visible;
    pointer-events: none;
    position: relative;
    visibility: visible;
}

.copp-hero__slide.is-active {
    pointer-events: auto;
}

.copp-hero__inner {
    align-items: center;
    display: grid;
    gap: 58px;
    grid-template-columns: minmax(440px, 0.92fr) minmax(500px, 1fr);
    height: 100%;
    margin: 0 auto;
    max-width: var(--copp-hero-inner-max);
    min-height: 445px;
    overflow: visible;
    padding: 48px 108px 52px;
}

.copp-hero__copy {
    align-self: stretch;
    display: grid;
    grid-template-rows: auto auto minmax(10px, 0.6fr) auto minmax(10px, 0.6fr);
    min-height: 100%;
    padding-bottom: 34px;
    position: relative;
    z-index: 2;
}

.copp-hero__copy h1 {
    color: var(--copp-ink);
    font-size: 56px;
    font-weight: 900;
    line-height: 1.08;
    margin: 0 0 32px;
    max-width: 560px;
    text-transform: uppercase;
}

.copp-hero__copy h1 span {
    color: var(--copp-red);
}

.copp-hero__copy p {
    color: var(--copp-ink);
    font-size: 20px;
    line-height: 1.5;
    margin: 0 0 20px;
    max-width: 570px;
}

.copp-hero__actions {
    display: grid;
    gap: 22px;
    grid-row: 4;
    grid-template-columns: repeat(2, minmax(0, 248px));
    max-width: 518px;
}

.copp-hero__btn {
    align-items: center;
    border: 2px solid var(--copp-red);
    display: inline-flex;
    font-size: var(--copp-fs-btn);
    font-weight: 800;
    height: 54px;
    justify-content: center;
    min-width: 0;
    padding: 0 26px;
    text-decoration: none;
    white-space: nowrap;
    width: 100%;
}

@media (min-width: 1200px) {
    .copp-hero__copy h1 {
        min-height: 124px;
    }

    .copp-hero__copy p {
        min-height: 92px;
    }
}

@media (min-width: 992px) and (max-width: 1199.98px) {
    .copp-hero__copy h1 {
        min-height: 132px;
    }

    .copp-hero__copy p {
        min-height: 118px;
    }
}

.copp-hero__btn:hover,
.copp-hero__btn:focus {
    text-decoration: none;
}

.copp-hero__btn--primary {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-hero__btn--primary:hover,
.copp-hero__btn--primary:focus {
    background: var(--copp-red-dark);
    border-color: var(--copp-red-dark);
    color: #ffffff;
}

.copp-hero__btn--outline {
    background: transparent;
    color: var(--copp-red);
}

.copp-hero__btn--outline:hover,
.copp-hero__btn--outline:focus {
    background: #ffffff;
    color: var(--copp-red-dark);
}

.copp-hero__visual {
    align-self: stretch;
    min-height: 350px;
    overflow: visible;
    position: relative;
}

.copp-visual {
    height: 100%;
    min-height: 350px;
    overflow: visible;
    position: relative;
}

.copp-hero__people {
    align-items: flex-end;
    bottom: -54px;
    display: flex;
    height: calc(100% + 52px);
    justify-content: flex-end;
    pointer-events: none;
    position: absolute;
    right: -28px;
    transform: translateY(62px);
    width: min(108%, 724px);
    z-index: 1;
}

.copp-hero__people img {
    display: block;
    height: auto;
    max-height: none;
    max-width: none;
    mix-blend-mode: darken;
    width: 100%;
}

.copp-visual__arc {
    background: var(--copp-red);
    border-radius: 0;
    bottom: -60px;
    height: 235px;
    left: 78px;
    opacity: 0.95;
    position: absolute;
    width: 472px;
    z-index: 1;
}

.copp-visual__line {
    background: rgba(var(--copp-ink-rgb), 0.2);
    height: 2px;
    position: absolute;
    right: 34px;
    top: 252px;
    width: 132px;
    z-index: 2;
}

.copp-visual__block {
    align-items: center;
    display: flex;
    justify-content: center;
    position: absolute;
    transform: translate3d(0, 0, 0);
    transform-style: preserve-3d;
    transition: transform 220ms ease-out;
    will-change: transform;
    z-index: 6;
}

.copp-visual__block svg {
    height: 42px;
    width: 42px;
}

.copp-visual__block--red {
    background: var(--copp-red);
    color: #ffffff;
    height: 82px;
    right: 112px;
    top: 14px;
    width: 82px;
}

.copp-visual__block--black {
    background: var(--copp-dark);
    color: #ffffff;
    height: 80px;
    left: 30px;
    top: 94px;
    width: 80px;
}

.copp-visual__block--chart {
    background: var(--copp-dark);
    color: #ffffff;
    height: 78px;
    right: 58px;
    top: 210px;
    width: 78px;
}

.copp-visual__tile {
    position: absolute;
    transform: translate3d(0, 0, 0);
    transform-style: preserve-3d;
    transition: transform 220ms ease-out;
    will-change: transform;
    z-index: 5;
}

.copp-visual__tile--one {
    background: var(--copp-red);
    height: 42px;
    left: 112px;
    top: 16px;
    width: 42px;
}

.copp-visual__tile--two {
    background: var(--copp-line);
    height: 42px;
    left: 154px;
    top: 16px;
    width: 42px;
}

.copp-visual__tile--three {
    background: var(--copp-soft);
    box-shadow: inset 0 0 0 1px var(--copp-line);
    height: 72px;
    left: 176px;
    top: 98px;
    width: 72px;
}

.copp-visual__tile--four {
    background: var(--copp-red);
    height: 42px;
    right: 250px;
    top: 66px;
    width: 42px;
}

.copp-visual__tile--five {
    background: var(--copp-line);
    height: 54px;
    right: 88px;
    top: 134px;
    width: 54px;
}

.copp-visual__tile--six {
    background: var(--copp-dark);
    height: 92px;
    right: 76px;
    bottom: 24px;
    width: 50px;
}

.copp-hero .copp-visual__arc,
.copp-hero .copp-visual__line {
    display: none;
}

.copp-hero .copp-visual__tile--one {
    background: rgba(var(--copp-red-rgb), 0.96);
    height: 46px;
    left: 102px;
    top: 16px;
    width: 46px;
}

.copp-hero .copp-visual__tile--two {
    background: rgba(220, 220, 220, 0.92);
    height: 42px;
    left: 150px;
    top: 18px;
    width: 42px;
}

.copp-hero .copp-visual__tile--three {
    background: rgba(255, 255, 255, 0.84);
    box-shadow: inset 0 0 0 1px rgba(225, 225, 225, 0.78);
    height: 58px;
    left: 128px;
    top: 118px;
    width: 58px;
}

.copp-hero .copp-visual__tile--four {
    background: rgba(var(--copp-dark-rgb), 0.92);
    height: 24px;
    right: 272px;
    top: 72px;
    width: 24px;
}

.copp-hero .copp-visual__tile--five {
    background: rgba(var(--copp-red-rgb), 0.96);
    height: 34px;
    right: 98px;
    top: 126px;
    width: 34px;
}

.copp-hero .copp-visual__tile--six {
    background: rgba(255, 255, 255, 0.9);
    bottom: 20px;
    box-shadow: inset 0 0 0 1px rgba(225, 225, 225, 0.72);
    height: 42px;
    right: 74px;
    width: 42px;
}

.copp-person {
    bottom: 0;
    position: absolute;
    z-index: 4;
}

.copp-person--left {
    height: 322px;
    left: 202px;
    width: 168px;
}

.copp-person--right {
    height: 294px;
    right: 168px;
    width: 154px;
}

.copp-person__head {
    background: var(--copp-line);
    border: 3px solid var(--copp-ink-soft);
    border-radius: 0;
    height: 74px;
    left: 48px;
    position: absolute;
    top: 0;
    width: 74px;
}

.copp-person__hair {
    background: var(--copp-dark);
    border-radius: 0;
    height: 46px;
    left: 38px;
    position: absolute;
    top: -5px;
    width: 88px;
}

.copp-person--right .copp-person__hair {
    border-radius: 0;
    height: 112px;
    left: 26px;
    top: -8px;
    width: 104px;
}

.copp-person__body {
    background: var(--copp-ink);
    border-radius: 0;
    bottom: 0;
    height: 248px;
    left: 16px;
    position: absolute;
    width: 136px;
}

.copp-person--right .copp-person__body {
    background: var(--copp-pale);
    border: 3px solid var(--copp-ink-soft);
    height: 218px;
    left: 16px;
    width: 128px;
}

.copp-person__hood {
    border: 3px solid rgba(255, 255, 255, 0.55);
    border-top: 0;
    border-radius: 0;
    height: 76px;
    left: 30px;
    position: absolute;
    top: 82px;
    width: 78px;
}

.copp-person__doc {
    background: var(--copp-pale);
    border: 3px solid var(--copp-ink-soft);
    bottom: 58px;
    height: 98px;
    position: absolute;
    transform: rotate(-14deg);
    width: 84px;
}

.copp-person--left .copp-person__doc {
    right: -12px;
}

.copp-person--right .copp-person__doc {
    background: var(--copp-ink-soft);
    border-color: var(--copp-ink);
    bottom: 60px;
    right: -18px;
    transform: rotate(5deg);
}

.copp-hero__arrow {
    align-items: center;
    background: rgba(var(--copp-ink-rgb), 0.18);
    border: 0;
    border-radius: 0;
    color: #ffffff;
    display: flex;
    height: 54px;
    justify-content: center;
    padding: 0;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 54px;
    z-index: 7;
}

.copp-hero__arrow:hover,
.copp-hero__arrow:focus {
    background: rgba(var(--copp-ink-rgb), 0.72);
    box-shadow: none;
}

.copp-hero__arrow svg {
    height: 24px;
    width: 24px;
}

.copp-hero__arrow--prev {
    left: 42px;
}

.copp-hero__arrow--next {
    right: 42px;
}

.copp-hero__dots {
    bottom: 42px;
    display: flex;
    gap: 10px;
    left: 50%;
    margin-left: -552px;
    position: absolute;
    z-index: 8;
    align-items: center;
}

.copp-hero__pill {
    position: absolute;
    height: 12px;
    width: 12px;
    background: var(--copp-red);
    border-radius: 50%;
    transition: left 400ms cubic-bezier(0.4, 0, 0.2, 1);
    pointer-events: none;
    z-index: 1;
}

.copp-hero__dot {
    background: rgba(255, 255, 255, 0.5);
    border: 0;
    border-radius: 50%;
    height: 12px;
    padding: 0;
    width: 12px;
    position: relative;
    z-index: 2;
    cursor: pointer;
    transition: background 300ms ease;
}

.copp-hero__dot:hover {
    background: rgba(255, 255, 255, 0.8);
}

.copp-hero__dot.is-active {
    background: transparent;
}

.icms-frontpage > .container:first-of-type {
    padding-top: 0;
}

.icms-frontpage > .container > .row.no-gutters > [class*="col-"]:last-child {
    margin-bottom: 0 !important;
}

body:not(.icms-frontpage) header + .container {
    padding-top: 18px;
}

body:not(.icms-frontpage) .copp-breadcrumbs {
    margin-bottom: 16px;
    padding: 14px 0 10px;
}

body:not(.icms-frontpage) .copp-breadcrumbs__list {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    list-style: none;
    margin: 0;
    padding: 0;
}

body:not(.icms-frontpage) .copp-breadcrumbs__item {
    align-items: center;
    display: inline-flex;
    margin-left: -2px;
    max-width: 100%;
    position: relative;
}

body:not(.icms-frontpage) .copp-breadcrumbs__item:first-child .copp-breadcrumbs__link {
    border-radius: 4px 0 0 4px;
}

body:not(.icms-frontpage) .copp-breadcrumbs__item:last-child .copp-breadcrumbs__link {
    border-radius: 0 4px 4px 0;
}

body:not(.icms-frontpage) .copp-breadcrumbs__item.is-current {
    z-index: 2;
}

body:not(.icms-frontpage) .copp-breadcrumbs__link {
    background-color: #fff;
    border: 2px solid var(--copp-pale);
    color: var(--copp-muted);
    display: inline-flex;
    justify-content: center;
    align-items: center;
    text-decoration: none;
    font-size: 12px;
    font-weight: 700;
    height: 2.5em;
    padding-left: 1.25em;
    padding-right: 1.25em;
    border-radius: 0;
    transform: skewX(-30deg);
    position: relative;
    transition: color 0.15s ease, border-color 0.15s ease, background-color 0.15s ease, z-index 0s;
    white-space: nowrap;
    line-height: 1;
}

body:not(.icms-frontpage) .copp-breadcrumbs__link > span,
body:not(.icms-frontpage) .copp-breadcrumbs__link > meta {
    transform: skewX(30deg);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

body:not(.icms-frontpage) .copp-breadcrumbs__link--home {
    background-color: #fff;
    border-color: var(--copp-pale);
    color: var(--copp-red);
    z-index: 1;
}

body:not(.icms-frontpage) .copp-breadcrumbs__link--home:hover,
body:not(.icms-frontpage) .copp-breadcrumbs__link--home:focus {
    background-color: var(--copp-red);
    border-color: var(--copp-red);
    color: #fff;
    z-index: 3;
}

body:not(.icms-frontpage) .copp-breadcrumbs__icon {
    display: inline-block;
    height: 1.15em;
    width: 1.15em;
    margin-right: 0.35em;
    flex-shrink: 0;
}

body:not(.icms-frontpage) .copp-breadcrumbs__link:not(.copp-breadcrumbs__link--home):not(.copp-breadcrumbs__link--active):not(.copp-breadcrumbs__link--disabled):hover,
body:not(.icms-frontpage) .copp-breadcrumbs__link:not(.copp-breadcrumbs__link--home):not(.copp-breadcrumbs__link--active):not(.copp-breadcrumbs__link--disabled):focus {
    color: var(--copp-red);
    border-color: var(--copp-red);
    z-index: 3;
    outline: 0;
}

body:not(.icms-frontpage) .copp-breadcrumbs__link--disabled {
    cursor: default;
}

body:not(.icms-frontpage) .copp-breadcrumbs__link--active {
    background-color: var(--copp-red);
    border-color: var(--copp-red);
    color: #fff;
    z-index: 2;
}

body:not(.icms-frontpage) .copp-breadcrumbs__link span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 100%;
}

body:not(.icms-frontpage) .copp-breadcrumbs__item.is-current {
    min-width: 0;
}

@media (max-width: 767px) {
    body:not(.icms-frontpage) .copp-breadcrumbs__link {
        font-size: 11px;
        height: 2.2em;
        padding-left: 0.9em;
        padding-right: 0.9em;
    }
}

body:not(.icms-frontpage) .copp-breadcrumbs__list {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    list-style: none;
    margin: 0;
    padding: 0;
}

body:not(.icms-frontpage) .copp-breadcrumbs__item {
    align-items: center;
    display: inline-flex;
    max-width: 100%;
}



body:not(.icms-frontpage) main > article > h1 {
    color: var(--copp-ink);
    font-size: 44px;
    font-weight: 900;
    letter-spacing: 0;
    line-height: 1.06;
    margin: 8px 0 0;
    max-width: 960px;
}

body:not(.icms-frontpage) .content_item.pages_item {
    margin-top: 24px !important;
}

body:not(.icms-frontpage) .content_item.pages_item .ft_html .value {
    color: var(--copp-ink);
    font-size: 18px;
    line-height: 1.7;
}

body:not(.icms-frontpage) .content_item.pages_item .ft_html h2,
body:not(.icms-frontpage) .content_item.pages_item .ft_html h3 {
    color: var(--copp-ink);
    font-weight: 900;
    letter-spacing: 0;
    line-height: 1.08;
    margin: 42px 0 18px;
}

body:not(.icms-frontpage) .content_item.pages_item .ft_html h2 {
    font-size: 30px;
}

body:not(.icms-frontpage) .content_item.pages_item .ft_html h3 {
    font-size: 24px;
}

body:not(.icms-frontpage) .content_item.pages_item .ft_html p,
body:not(.icms-frontpage) .content_item.pages_item .ft_html ul,
body:not(.icms-frontpage) .content_item.pages_item .ft_html ol {
    margin-bottom: 22px;
}

body:not(.icms-frontpage) .content_item.pages_item .ft_html ul,
body:not(.icms-frontpage) .content_item.pages_item .ft_html ol {
    padding-left: 1.5rem;
}

body:not(.icms-frontpage) .content_item.pages_item .ft_html li + li {
    margin-top: 10px;
}

body:not(.icms-frontpage) .content_item.pages_item .ft_html a {
    color: var(--copp-red);
    text-decoration-color: currentColor;
    text-decoration-thickness: 1px;
    text-underline-offset: 0.16em;
}

.copp-legal-document {
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    border-left: 6px solid var(--copp-red);
    border-radius: 0;
    box-shadow: 10px 10px 0 rgba(var(--copp-ink-rgb), 0.06);
    margin-bottom: 36px;
    padding: clamp(24px, 4vw, 42px);
}

.copp-legal-document__date {
    color: var(--copp-red);
    font-size: 14px;
    font-weight: 900;
    letter-spacing: 0;
    line-height: 1.3;
    margin: 0 0 14px !important;
    text-transform: uppercase;
}

.copp-legal-document__lead {
    color: var(--copp-ink);
    font-size: 20px;
    font-weight: 700;
    line-height: 1.5;
}

.copp-legal-document h2:first-of-type {
    margin-top: 0 !important;
}

.copp-legal-document ul {
    background: var(--copp-soft);
    border-radius: 0;
    padding: 18px 22px 18px 42px !important;
}

.copp-legal-document li::marker {
    color: var(--copp-red);
}

body:not(.icms-frontpage) .content_item.pages_item .ft_html > *:last-child,
body:not(.icms-frontpage) .content_item.pages_item .ft_html .value > *:last-child {
    margin-bottom: 0;
}

@media (max-width: 991.98px) {
    body:not(.icms-frontpage) main > article > h1 {
        font-size: 36px;
    }

    body:not(.icms-frontpage) .content_item.pages_item .ft_html .value {
        font-size: 17px;
    }

    body:not(.icms-frontpage) .content_item.pages_item .ft_html h2 {
        font-size: 26px;
    }
}

@media (max-width: 575.98px) {
    body:not(.icms-frontpage) header + .container {
        padding-top: 14px;
    }

    body:not(.icms-frontpage) main > article > h1 {
        font-size: 30px;
    }

    body:not(.icms-frontpage) .content_item.pages_item {
        margin-top: 18px !important;
    }

    body:not(.icms-frontpage) .content_item.pages_item .ft_html .value {
        font-size: 16px;
        line-height: 1.65;
    }

    body:not(.icms-frontpage) .content_item.pages_item .ft_html h2 {
        font-size: 24px;
        margin: 34px 0 16px;
    }

    body:not(.icms-frontpage) .content_item.pages_item .ft_html h3 {
        font-size: 21px;
        margin: 30px 0 14px;
    }
}

.copp-auth {
    align-items: stretch;
    display: grid;
    gap: 24px;
    grid-template-columns: minmax(320px, 0.9fr) minmax(0, 1.12fr);
    margin: 18px 0 56px;
}

.copp-auth--compact {
    grid-template-columns: minmax(0, 1fr);
    margin: 0 auto;
    max-width: 680px;
}

.copp-auth--compact .copp-auth__panel {
    padding: 28px 28px 30px;
}

.copp-auth--compact .copp-auth__panel-head {
    margin-bottom: 24px;
}

.copp-auth--compact .copp-auth__panel-head h1 {
    font-size: 32px;
}

.copp-auth__intro {
    background: linear-gradient(155deg, var(--copp-red) 0%, var(--copp-red-dark) 100%);
    border-radius: 0;
    color: #ffffff;
    display: flex;
    flex-direction: column;
    min-height: 100%;
    overflow: hidden;
    padding: 32px 32px 34px;
    position: relative;
}

.copp-auth__intro::before,
.copp-auth__intro::after {
    content: "";
    pointer-events: none;
    position: absolute;
}

.copp-auth__intro::before {
    background: rgba(255, 255, 255, 0.1);
    height: 168px;
    right: -48px;
    top: -32px;
    transform: rotate(14deg);
    width: 168px;
}

.copp-auth__intro::after {
    background: rgba(var(--copp-ink-rgb), 0.12);
    border: 1px solid rgba(255, 255, 255, 0.18);
    bottom: -44px;
    height: 180px;
    right: 56px;
    transform: rotate(12deg);
    width: 180px;
}

.copp-auth__brand {
    align-items: center;
    color: #ffffff;
    display: inline-flex;
    gap: 14px;
    margin-bottom: 36px;
    position: relative;
    text-decoration: none;
    z-index: 1;
}

.copp-auth__brand:hover,
.copp-auth__brand:focus {
    color: #ffffff;
    text-decoration: none;
}

.copp-auth__brand-mark {
    align-items: center;
    background: #ffffff;
    border-radius: 0;
    box-shadow: 0 18px 32px rgba(0, 0, 0, 0.12);
    display: inline-flex;
    flex: 0 0 74px;
    height: 74px;
    justify-content: center;
    padding: 10px;
    width: 74px;
}

.copp-auth__brand-mark img {
    height: auto;
    max-width: 100%;
}

.copp-auth__brand-name {
    display: block;
    font-size: 15px;
    font-weight: 800;
    line-height: 1.3;
    max-width: 132px;
}

.copp-auth__eyebrow,
.copp-auth__panel-kicker {
    font-size: var(--copp-fs-eyebrow);
    font-weight: var(--copp-fw-eyebrow);
    letter-spacing: var(--copp-ls-eyebrow);
    line-height: var(--copp-lh-eyebrow);
    text-transform: uppercase;
}

.copp-auth__intro-title {
    color: #ffffff;
    font-size: 34px;
    font-weight: 900;
    line-height: 1.08;
    margin: 14px 0 16px;
    max-width: 480px;
    position: relative;
    z-index: 1;
}

.copp-auth__intro-text {
    color: rgba(255, 255, 255, 0.92);
    font-size: 16px;
    line-height: 1.65;
    margin: 0 0 24px;
    max-width: 480px;
    position: relative;
    z-index: 1;
}

.copp-auth__intro-list {
    display: grid;
    gap: 14px;
    list-style: none;
    margin: 0;
    max-width: 480px;
    padding: 0;
    position: relative;
    z-index: 1;
}

.copp-auth__intro-list li {
    align-items: flex-start;
    color: #ffffff;
    display: flex;
    font-size: 15px;
    font-weight: 600;
    gap: 12px;
    line-height: 1.5;
}

.copp-auth__intro-list li::before {
    background: #ffffff;
    border-radius: 0;
    content: "";
    flex: 0 0 6px;
    height: 6px;
    margin-top: 0.48rem;
}

.copp-auth__intro-link {
    align-items: center;
    align-self: flex-start;
    border: 2px solid rgba(255, 255, 255, 0.76);
    border-radius: 0;
    color: #ffffff;
    display: inline-flex;
    font-size: 15px;
    font-weight: 800;
    height: 52px;
    justify-content: center;
    margin-top: 28px;
    min-width: 190px;
    padding: 0 24px;
    position: relative;
    text-decoration: none;
    transition: background-color 0.2s ease, border-color 0.2s ease;
    z-index: 1;
}

.copp-auth__intro-link:hover,
.copp-auth__intro-link:focus {
    background: rgba(255, 255, 255, 0.12);
    border-color: #ffffff;
    color: #ffffff;
    text-decoration: none;
}

.copp-auth__panel {
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    border-radius: 0;
    box-shadow: 0 24px 60px rgba(var(--copp-ink-rgb), 0.08);
    padding: 34px 36px 36px;
}

.copp-auth__panel-head {
    margin-bottom: 28px;
}

.copp-auth__panel-kicker {
    color: var(--copp-red);
}

.copp-auth__panel-head h1 {
    color: var(--copp-ink);
    font-size: 44px;
    font-weight: 900;
    line-height: 1.06;
    margin: 10px 0 12px;
}

.copp-auth__panel-head p {
    color: var(--copp-muted);
    font-size: 16px;
    line-height: 1.65;
    margin: 0;
    max-width: 540px;
}

.copp-auth__panel-body--split {
    display: grid;
    gap: 0;
    grid-template-columns: minmax(0, 1fr) 58px minmax(240px, 0.78fr);
}

.copp-auth__form,
.copp-auth__providers {
    min-width: 0;
}

.copp-auth__providers {
    padding-left: 32px;
}

.copp-auth__providers h3 {
    color: var(--copp-ink);
    font-size: 18px;
    font-weight: 800;
    line-height: 1.25;
    margin: 0 0 16px;
}

.copp-auth__providers > * + * {
    margin-top: 12px;
}

.copp-auth__providers a,
.copp-auth__providers .btn {
    align-items: center;
    background: #ffffff;
    border: 1px solid var(--copp-pale);
    border-radius: 0;
    color: var(--copp-ink);
    display: flex;
    font-weight: 700;
    justify-content: center;
    min-height: 52px;
    padding: 0 16px;
    text-decoration: none;
    width: 100%;
}

.copp-auth__providers a:hover,
.copp-auth__providers a:focus,
.copp-auth__providers .btn:hover,
.copp-auth__providers .btn:focus {
    border-color: var(--copp-red);
    box-shadow: none;
    color: var(--copp-red);
    text-decoration: none;
}

.copp-auth .center_cell {
    align-items: center;
    border-left: 1px solid var(--copp-pale);
    border-right: 1px solid var(--copp-pale);
    color: var(--copp-muted);
    display: flex;
    font-size: 12px;
    font-weight: 800;
    justify-content: center;
    letter-spacing: 0.12em;
    line-height: 1.2;
    text-transform: uppercase;
}

.copp-auth form {
    margin: 0;
}

.copp-auth .form-tabs,
.copp-auth .icms-form-body {
    margin: 0;
}

.copp-auth fieldset,
.copp-auth .without-tabs fieldset {
    background: #ffffff;
    border: 1px solid var(--copp-pale);
    border-radius: 0;
    margin-bottom: 18px;
    padding: 20px 22px 4px;
}

.copp-auth fieldset:last-child,
.copp-auth .without-tabs fieldset:last-child {
    margin-bottom: 0;
}

.copp-auth legend {
    color: var(--copp-ink);
    font-size: 18px;
    font-weight: 800;
    line-height: 1.3;
    margin: 0 0 20px;
    padding: 0;
    width: auto;
}

.copp-auth .form-group {
    margin-bottom: 18px;
}

.copp-auth label {
    color: var(--copp-ink);
    font-size: 14px;
    font-weight: 700;
    margin-bottom: 8px;
}

.copp-auth .form-control {
    background: var(--copp-soft);
    border: 1.5px solid var(--copp-line);
    border-radius: 0;
    box-shadow: none;
    color: var(--copp-ink);
    min-height: 54px;
    padding: 14px 16px;
}

.copp-auth textarea.form-control {
    min-height: 140px;
}

.copp-auth .form-control:focus {
    background: #ffffff;
    border-color: var(--copp-red);
    box-shadow: 0 0 0 3px rgba(var(--copp-red-rgb), 0.08);
}

.copp-auth .custom-control-label {
    color: var(--copp-ink);
    font-size: 14px;
    font-weight: 600;
    line-height: 1.55;
}

.copp-auth .custom-control-label::before {
    border-color: var(--copp-line);
}

.copp-auth .custom-control-label span {
    display: inline;
}

.copp-auth .custom-control-input:focus ~ .custom-control-label::before {
    box-shadow: 0 0 0 3px rgba(var(--copp-red-rgb), 0.08);
}

.copp-auth .custom-control-input:checked ~ .custom-control-label::before {
    background-color: var(--copp-red);
    border-color: var(--copp-red);
}

.copp-auth .custom-control-label a {
    color: var(--copp-red);
    font-weight: 700;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.copp-auth .custom-control-label a:hover,
.copp-auth .custom-control-label a:focus {
    color: var(--copp-red-dark);
}

.copp-auth .icms-forms-hint,
.copp-auth .hint,
.copp-auth .form-text {
    color: var(--copp-muted) !important;
    font-size: 13px;
    line-height: 1.5;
}

.copp-auth .auth_restore_link,
.copp-auth__panel-footer a {
    color: var(--copp-red);
    font-weight: 800;
}

.copp-auth .auth_restore_link:hover,
.copp-auth .auth_restore_link:focus,
.copp-auth__panel-footer a:hover,
.copp-auth__panel-footer a:focus {
    color: var(--copp-red-dark);
}

.copp-auth .buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 26px !important;
}

.copp-auth .buttons .btn,
.copp-auth .buttons .button {
    align-items: center;
    border-radius: 0;
    box-shadow: none;
    display: inline-flex;
    font-size: 15px;
    font-weight: 800;
    justify-content: center;
    min-height: 54px;
    min-width: 198px;
    padding: 0 24px;
}

.copp-auth .buttons .button-submit,
.copp-auth .buttons .btn-primary {
    background: var(--copp-red);
    border: 2px solid var(--copp-red);
    color: #ffffff;
}

.copp-auth .buttons .button-submit:hover,
.copp-auth .buttons .button-submit:focus,
.copp-auth .buttons .btn-primary:hover,
.copp-auth .buttons .btn-primary:focus {
    background: var(--copp-red-dark);
    border-color: var(--copp-red-dark);
    color: #ffffff;
}

.copp-auth .buttons .button-cancel,
.copp-auth .buttons .btn-secondary {
    background: #ffffff;
    border: 2px solid rgba(var(--copp-ink-rgb), 0.18);
    color: var(--copp-ink);
}

.copp-auth .buttons .button-cancel:hover,
.copp-auth .buttons .button-cancel:focus,
.copp-auth .buttons .btn-secondary:hover,
.copp-auth .buttons .btn-secondary:focus {
    border-color: var(--copp-red);
    color: var(--copp-red);
}

.copp-auth__panel-footer {
    align-items: center;
    color: var(--copp-muted);
    display: flex;
    flex-wrap: wrap;
    gap: 8px 12px;
    margin-top: 20px;
}

.copp-auth .alert {
    border-radius: 0;
    font-size: 15px;
    line-height: 1.55;
    margin-bottom: 0;
    padding: 16px 18px;
}

.copp-auth #reg_resubmit_timer {
    color: var(--copp-muted);
    margin-top: 14px;
}

@media (max-width: 1199.98px) {
    .copp-auth {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-auth__panel-body--split {
        gap: 24px;
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-auth .center_cell {
        border-left: 0;
        border-right: 0;
        border-top: 1px solid var(--copp-pale);
        border-bottom: 1px solid var(--copp-pale);
        padding: 10px 0;
    }

    .copp-auth__providers {
        padding-left: 0;
    }
}

@media (max-width: 767.98px) {
    .copp-auth {
        margin: 12px 0 40px;
    }

    .copp-auth__intro,
    .copp-auth__panel {
        padding: 24px 22px;
    }

    .copp-auth__brand {
        gap: 12px;
        margin-bottom: 24px;
    }

    .copp-auth__brand-mark {
        flex-basis: 62px;
        height: 62px;
        width: 62px;
    }

    .copp-auth__intro-title {
        font-size: 28px;
    }

    .copp-auth__panel-head h1 {
        font-size: 30px;
    }

    .copp-auth fieldset,
    .copp-auth .without-tabs fieldset {
        padding: 18px 18px 2px;
    }

    .copp-auth .buttons {
         flex-direction: column;
     }
 }

.form-group .icms-forms-hint {
     clear: both;
     display: block;
     position: relative;
}

.form-group .icms-forms-hint .hint {
     line-height: 1.5;
}

.icms-content-documents .icms-body-toolbox h1 {
    color: var(--copp-ink);
    font-family: var(--copp-font-heading);
    font-size: 22px;
    font-weight: 800;
    margin: 0;
    text-transform: uppercase;
}

.icms-content-documents .category_description {
    color: rgba(var(--copp-ink-rgb), 0.55);
    font-size: 0.8125rem;
    line-height: 1.5;
    margin-bottom: 20px;
}

.icms-content-documents .icms-content-subcats { display: none; }

.copp-docs-page {
    display: grid;
    gap: 24px;
}

.copp-docs-page__section {
    display: grid;
    gap: 4px;
}

.copp-docs-page__head {
    align-items: center;
    border-bottom: 1px solid rgba(var(--copp-red-rgb), 0.25);
    display: flex;
    gap: 8px;
    margin-bottom: 4px;
    padding-bottom: 6px;
}

.copp-docs-page__head i {
    color: var(--copp-red);
    font-size: 13px;
}

.copp-docs-page__head h2 {
    color: var(--copp-ink);
    font-family: var(--copp-font-heading);
    font-size: 14px;
    font-weight: 800;
    letter-spacing: 0.04em;
    margin: 0;
    text-transform: uppercase;
}

.copp-docs-page__empty {
    color: #999;
    font-size: 14px;
    padding: 12px 0;
    font-style: italic;
}

.icms-content-documents .category_description {
    color: rgba(var(--copp-ink-rgb), 0.6);
    font-size: var(--copp-fs-body);
    line-height: var(--copp-lh-body);
    margin-bottom: 24px;
}

.icms-content-documents .icms-content-subcats {
    display: none;
}

.copp-docs-grid {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.copp-docs-grid__item {
    align-items: center;
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.07);
    border-radius: 0;
    display: flex;
    gap: 12px;
    padding: 12px 16px;
    transition: border-color 160ms ease, box-shadow 160ms ease;
}

.copp-docs-grid__item:hover {
    border-color: rgba(var(--copp-red-rgb), 0.22);
    box-shadow: 0 2px 8px rgba(var(--copp-ink-rgb), 0.06);
}

.copp-docs-grid__icon {
    align-items: center;
    background: rgba(var(--copp-red-rgb), 0.06);
    border-radius: 0;
    color: var(--copp-red);
    display: inline-flex;
    flex: 0 0 36px;
    font-size: 17px;
    height: 36px;
    justify-content: center;
    width: 36px;
}

.copp-docs-grid__info {
    flex: 1 1 auto;
    min-width: 0;
}

.copp-docs-grid__title {
    font-size: 0.9375rem;
    font-weight: 600;
    line-height: 1.35;
    margin: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.copp-docs-grid__title a {
    color: var(--copp-ink);
    text-decoration: none;
}

.copp-docs-grid__title a:hover {
    color: var(--copp-red);
}

.copp-docs-grid__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 2px;
}

.copp-docs-grid__type,
.copp-docs-grid__number,
.copp-docs-grid__date {
    color: rgba(var(--copp-ink-rgb), 0.5);
    font-size: 0.75rem;
}

.copp-docs-grid__type::after,
.copp-docs-grid__number::after {
    content: '·';
    margin-left: 6px;
}

.copp-docs-grid__status {
    border-radius: 0;
    font-size: 0.6875rem;
    font-weight: 700;
    line-height: 1;
    padding: 2px 7px;
}

.copp-docs-grid__status--active {
    background: rgba(51, 189, 102, 0.1);
    color: #22a559;
}

.copp-docs-grid__status--expired {
    background: rgba(var(--copp-muted-rgb), 0.12);
    color: var(--copp-muted);
}

.copp-docs-grid__status--draft {
    background: rgba(56, 103, 214, 0.1);
    color: #3867d6;
}

.copp-docs-grid__actions {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    gap: 6px;
}

.copp-docs-grid__btn {
    align-items: center;
    border-radius: 0;
    color: #fff;
    display: inline-flex;
    font-size: 0.75rem;
    font-weight: 700;
    gap: 5px;
    padding: 6px 12px;
    text-decoration: none;
    transition: background 160ms ease;
    white-space: nowrap;
}

.copp-docs-grid__btn--view {
    background: var(--copp-blue, #3867d6);
}

.copp-docs-grid__btn--view:hover {
    background: var(--copp-blue-dark, #2a4fa0);
    color: #fff;
}

.copp-docs-grid__btn--download {
    background: var(--copp-red);
}

.copp-docs-grid__btn--download:hover {
    background: var(--copp-red-dark);
    color: #fff;
}

.copp-docs-grid__ext {
    font-size: 0.6875rem;
}

.copp-docs-grid__size {
    color: rgba(255, 255, 255, 0.65);
    font-weight: 400;
}

@media (min-width: 768px) {
    .copp-docs-page {
    display: grid;
    gap: 32px;
}

.copp-docs-page__section {
    display: grid;
    gap: 14px;
}

.copp-docs-page__head {
    align-items: center;
    border-bottom: 2px solid var(--copp-red);
    display: flex;
    gap: 10px;
    padding-bottom: 10px;
}

.copp-docs-page__head i {
    color: var(--copp-red);
    font-size: 18px;
}

.copp-docs-page__head h2 {
    color: var(--copp-ink);
    font-family: var(--copp-font-heading);
    font-size: 18px;
    font-weight: 800;
    margin: 0;
    text-transform: uppercase;
}

@media (min-width: 992px) {
    .copp-docs-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 10px;
    }
}

@media (max-width: 767.98px) {
    .copp-docs-grid__item {
        flex-wrap: wrap;
        gap: 8px;
        padding: 10px 14px;
    }

    .copp-docs-grid__icon {
        flex: 0 0 32px;
        font-size: 15px;
        height: 32px;
        width: 32px;
    }

    .copp-docs-grid__actions {
        flex: 0 0 auto;
        margin-left: auto;
    }

    .copp-docs-grid__btn {
        padding: 5px 10px;
        font-size: 0.6875rem;
    }
}

.copp-gallery-hero {
    background: var(--copp-soft);
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding: 40px max(15px, calc((100vw - 1140px) / 2 + 15px)) 36px;
    position: relative;
}

.copp-gallery-hero::after {
    background: rgba(var(--copp-dark-rgb), 0.06);
    bottom: 0;
    content: "";
    height: 1px;
    left: 0;
    position: absolute;
    right: 0;
}

.copp-gallery-hero__inner {
    align-items: center;
    display: grid;
    gap: 40px;
    grid-template-columns: minmax(0, 1fr) minmax(0, 340px);
    margin: 0 auto;
    max-width: 1140px;
}

.copp-gallery-hero__copy {
    position: relative;
    z-index: 2;
}

.copp-gallery-hero__eyebrow {
    color: rgba(var(--copp-ink-rgb), 0.5);
    display: inline-flex;
    font-size: var(--copp-fs-eyebrow);
    font-weight: var(--copp-fw-eyebrow);
    letter-spacing: var(--copp-ls-eyebrow);
    margin-bottom: 14px;
    text-transform: uppercase;
}

.copp-gallery-hero__title {
    color: var(--copp-ink);
    font-family: var(--copp-font-heading);
    font-size: clamp(46px, 4.5vw, 72px);
    font-weight: 900;
    line-height: var(--copp-lh-hero);
    margin: 0;
    text-transform: uppercase;
}

.copp-gallery-hero__subtitle {
    color: var(--copp-ink);
    font-size: clamp(18px, 1.8vw, 26px);
    font-weight: 800;
    line-height: 1.2;
    margin: 20px 0 0;
    text-transform: uppercase;
}

.copp-gallery-hero__media {
    min-height: 280px;
    position: relative;
}

.copp-gallery-hero__frame {
    border-radius: 0;
    display: grid;
    gap: 6px;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr;
    height: 280px;
    overflow: hidden;
    padding: 6px;
    position: relative;
}

.copp-gallery-hero__tile {
    border-radius: 0;
}

.copp-gallery-hero__tile--red {
    background: var(--copp-red);
}

.copp-gallery-hero__tile--dark {
    background: var(--copp-ink);
}

.copp-gallery-hero__tile--light {
    background: var(--copp-pale);
}

.copp-gallery-hero__tile--sm {
    grid-column: span 1;
}

.copp-gallery-hero__icon {
    color: rgba(255, 255, 255, 0.9);
    font-size: 40px;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 3;
}

.copp-gallery-page {
    display: grid;
    gap: 28px;
    max-width: var(--copp-container-content);
    margin: 0 auto;
    padding: 36px 0 60px;
}

.copp-gallery-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.copp-gallery-filters__btn {
    background: var(--copp-soft);
    border: 1px solid transparent;
    border-radius: 0;
    color: var(--copp-ink);
    cursor: pointer;
    font-family: var(--copp-font-heading);
    font-size: 0.85rem;
    font-weight: 700;
    padding: 8px 18px;
    text-transform: uppercase;
    transition: background 0.15s, border-color 0.15s, color 0.15s;
}

.copp-gallery-filters__btn:hover {
    background: var(--copp-pale);
}

.copp-gallery-filters__btn.is-active {
    background: var(--copp-red);
    border-color: var(--copp-red);
    color: #ffffff;
}

.copp-gallery-content {
    display: grid;
    gap: 36px;
}

.copp-gallery-category__title {
    color: var(--copp-ink);
    font-family: var(--copp-font-heading);
    font-size: 1.4rem;
    font-weight: 800;
    margin: 0 0 18px;
    padding-bottom: 10px;
    position: relative;
    text-transform: uppercase;
}

.copp-gallery-category__title::after {
    background: var(--copp-red);
    bottom: 0;
    content: "";
    height: 3px;
    left: 0;
    position: absolute;
    width: 40px;
}

.copp-gallery-albums-grid {
    display: grid;
    gap: 20px;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
}

.copp-album-card {
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.06);
    border-radius: 0;
    cursor: pointer;
    overflow: hidden;
    transition: box-shadow 0.2s, transform 0.15s;
}

.copp-album-card:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
    transform: translateY(-2px);
}

.copp-album-card__cover {
    aspect-ratio: 4 / 3;
    overflow: hidden;
    position: relative;
}

.copp-album-card__cover img {
    display: block;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s;
    width: 100%;
}

.copp-album-card:hover .copp-album-card__cover img {
    transform: scale(1.04);
}

.copp-album-card__count {
    background: rgba(0, 0, 0, 0.6);
    border-radius: 0;
    bottom: 8px;
    color: #fff;
    font-family: var(--copp-font-heading);
    font-size: 0.75rem;
    font-weight: 700;
    padding: 3px 8px;
    position: absolute;
    right: 8px;
}

.copp-album-card__count i {
    margin-left: 3px;
}

.copp-album-card__noimg {
    align-items: center;
    background: var(--copp-soft);
    color: rgba(var(--copp-ink-rgb), 0.15);
    display: flex;
    height: 100%;
    justify-content: center;
}

.copp-album-card__noimg i {
    font-size: 36px;
}

.copp-album-card__body {
    padding: 12px 14px 14px;
}

.copp-album-card__title {
    color: var(--copp-ink);
    font-family: var(--copp-font-heading);
    font-size: var(--copp-fs-card-title);
    font-weight: var(--copp-fw-bold);
    line-height: var(--copp-lh-card-title);
    margin: 0 0 4px;
}

.copp-album-card__cat {
    color: rgba(var(--copp-ink-rgb), 0.45);
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
}

.copp-album-detail__head {
    align-items: center;
    display: flex;
    gap: 16px;
    margin-bottom: 24px;
}

.copp-album-detail__back {
    align-items: center;
    background: none;
    border: 1px solid rgba(0, 0, 0, 0.12);
    border-radius: 0;
    color: var(--copp-ink);
    cursor: pointer;
    display: inline-flex;
    font-family: var(--copp-font-heading);
    font-size: 0.82rem;
    font-weight: 700;
    gap: 6px;
    padding: 7px 14px;
    transition: background 0.15s, border-color 0.15s;
}

.copp-album-detail__back:hover {
    background: var(--copp-soft);
    border-color: rgba(0, 0, 0, 0.2);
}

.copp-album-detail__title {
    color: var(--copp-ink);
    font-family: var(--copp-font-heading);
    font-size: 1.3rem;
    font-weight: 800;
    margin: 0;
    text-transform: uppercase;
}

.copp-album-detail__count {
    color: rgba(var(--copp-ink-rgb), 0.5);
    font-size: 0.82rem;
    font-weight: 600;
    margin-left: auto;
}

.copp-album-detail__grid {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
}

.copp-album-detail__item {
    border-radius: 0;
    overflow: hidden;
    position: relative;
}

.copp-album-detail__item a {
    cursor: zoom-in;
    display: block;
}

.copp-album-detail__item img {
    aspect-ratio: 1 / 1;
    display: block;
    object-fit: cover;
    transition: transform 0.3s;
    width: 100%;
}

.copp-album-detail__item:hover img {
    transform: scale(1.04);
}

.copp-album-detail__caption {
    background: rgba(0, 0, 0, 0.55);
    bottom: 0;
    color: #fff;
    font-size: 0.75rem;
    left: 0;
    padding: 4px 8px;
    position: absolute;
    right: 0;
}

.copp-album-detail__noimg {
    align-items: center;
    aspect-ratio: 1 / 1;
    background: var(--copp-soft);
    color: rgba(var(--copp-ink-rgb), 0.12);
    display: flex;
    justify-content: center;
}

.copp-album-detail__noimg i {
    font-size: 28px;
}

.copp-gallery-empty {
    align-items: center;
    background: rgba(var(--copp-ink-rgb), 0.03);
    border: 2px dashed rgba(var(--copp-ink-rgb), 0.1);
    border-radius: 0;
    color: rgba(var(--copp-ink-rgb), 0.35);
    display: flex;
    flex-direction: column;
    gap: 10px;
    justify-content: center;
    min-height: 200px;
    padding: 40px 20px;
    text-align: center;
}

.copp-gallery-empty i {
    color: var(--copp-red);
    font-size: 36px;
    opacity: 0.4;
}

.copp-gallery-empty p {
    font-size: 0.9rem;
    margin: 0;
}

.copp-gallery-lightbox {
    cursor: zoom-in;
    display: block;
    position: relative;
}

@media (max-width: 1200px) {
    .copp-gallery-albums-grid { grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); }
    .copp-album-detail__grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); }
}

@media (max-width: 768px) {
    .copp-gallery-hero__inner { grid-template-columns: 1fr; }
    .copp-gallery-hero__media { display: none; }
    .copp-gallery-filters { gap: 6px; }
    .copp-gallery-filters__btn { font-size: 0.78rem; padding: 6px 14px; }
    .copp-gallery-albums-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 14px; }
    .copp-album-detail__grid { grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); }
    .copp-album-detail__head { flex-wrap: wrap; gap: 10px; }
    .copp-album-detail__title { font-size: 1.1rem; }
}

@media (max-width: 480px) {
    .copp-gallery-albums-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
    .copp-album-detail__grid { grid-template-columns: repeat(3, 1fr); gap: 6px; }
}

.copp-awards-gallery {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 20px;
}

.copp-awards-gallery__grid {
    display: contents;
}

.copp-awards-gallery__placeholder {
    align-items: center;
    background: rgba(var(--copp-ink-rgb), 0.03);
    border: 2px dashed rgba(var(--copp-ink-rgb), 0.12);
    border-radius: 0;
    color: rgba(var(--copp-ink-rgb), 0.35);
    display: flex;
    flex-direction: column;
    gap: 10px;
    grid-column: 1 / -1;
    justify-content: center;
    min-height: 180px;
    padding: 32px 20px;
    text-align: center;
}

.copp-awards-gallery__placeholder i {
    font-size: 32px;
    color: var(--copp-red);
    opacity: 0.4;
}

.copp-awards-gallery__placeholder p {
    font-size: 0.875rem;
    margin: 0;
}

.copp-awards-card {
    background: #ffffff;
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.copp-awards-card__image {
    cursor: zoom-in;
    display: block;
    position: relative;
    aspect-ratio: 3 / 4;
    background: var(--copp-soft);
    overflow: hidden;
}

.copp-awards-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.copp-awards-card__image:hover img {
    transform: scale(1.03);
}

.copp-awards-card__image::after {
    align-items: center;
    background: rgba(0, 0, 0, 0.35);
    border-radius: 0;
    color: #fff;
    content: "\f00e";
    font-family: "Font Awesome 6 Free";
    font-size: 16px;
    font-weight: 900;
    height: 36px;
    justify-content: center;
    left: 50%;
    opacity: 0;
    pointer-events: none;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    transition: opacity 0.2s;
    width: 36px;
    z-index: 2;
}

.copp-awards-card__image:hover::after {
    opacity: 1;
}

.copp-awards-card__image--empty {
    align-items: center;
    color: rgba(var(--copp-ink-rgb), 0.2);
    cursor: default;
    justify-content: center;
}

.copp-awards-card__image--empty::after {
    display: none;
}

.copp-awards-card__image--empty i {
    font-size: 48px;
}

.copp-awards-card__body {
    padding: 14px 16px 18px;
}

.copp-awards-card__title {
    color: var(--copp-ink);
    font-family: var(--copp-font-heading);
    font-size: var(--copp-fs-card-title);
    font-weight: var(--copp-fw-bold);
    line-height: var(--copp-lh-card-title);
    margin: 0 0 6px;
}

.copp-awards-card__meta {
    color: rgba(var(--copp-ink-rgb), 0.55);
    font-size: 0.8rem;
    margin: 0 0 8px;
    display: flex;
    gap: 8px;
}

.copp-awards-card__meta span + span::before {
    content: "·";
    margin-right: 8px;
}

.copp-awards-card__desc {
    color: rgba(var(--copp-ink-rgb), 0.7);
    font-size: 0.85rem;
    line-height: 1.4;
    margin: 0;
}

.copp-awards-lightbox {
    cursor: zoom-in;
    display: block;
    position: relative;
}

.copp-overview {
    background: #ffffff;
    isolation: isolate;
    padding: 46px 0 22px;
    position: relative;
    z-index: 4;
}

body.icms-frontpage header + .container {
    position: relative;
    z-index: 8;
}

body.icms-frontpage header + .container::before {
    background: #ffffff;
    content: '';
    height: 220px;
    left: 50%;
    pointer-events: none;
    position: absolute;
    top: 0;
    transform: translateX(-50%);
    width: 100vw;
    z-index: -1;
}

.copp-overview__layout {
    align-items: start;
    display: grid;
    gap: 28px;
    grid-template-columns: minmax(260px, 1.08fr) minmax(0, 2.25fr);
}

.copp-overview__intro {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 14px 0 10px;
}

.copp-overview__title {
    color: var(--copp-ink);
    display: inline-block;
    font-size: 28px;
    font-weight: var(--copp-fw-heading-bold);
    letter-spacing: var(--copp-ls-section);
    line-height: 1.05;
    margin: 0 0 18px;
    position: relative;
    text-transform: uppercase;
}

.copp-overview__tabs {
    align-items: center;
    display: flex;
    gap: 10px;
    margin: 0 0 26px;
}

.copp-overview__tab {
    background: rgba(var(--copp-red-rgb), 0.15);
    border: 0;
    border-radius: 0;
    cursor: pointer;
    height: 4px;
    padding: 0;
    transition: background-color 220ms ease, transform 220ms ease;
    width: 34px;
}

.copp-overview__tab.is-active {
    background: var(--copp-red);
}

.copp-overview__tab:hover,
.copp-overview__tab:focus {
    background: rgba(var(--copp-red-rgb), 0.4);
    outline: none;
    transform: scaleX(1.05);
}

.copp-overview__tab.is-active:hover,
.copp-overview__tab.is-active:focus {
    background: var(--copp-red);
}

.copp-overview__text-slider {
    align-items: start;
    display: grid;
    margin: 0 0 30px;
    max-width: 330px;
}

.copp-overview__text-slider > * {
    grid-area: 1 / 1;
}

.copp-overview__text {
    color: var(--copp-ink-soft);
    font-size: var(--copp-fs-body);
    line-height: var(--copp-lh-body);
    margin: 0;
    opacity: 0;
    pointer-events: none;
    transform: translateY(12px);
    transition: opacity 360ms ease, transform 360ms ease;
}

.copp-overview__text.is-active {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
    .copp-overview__tab,
    .copp-overview__text {
        transition: none;
    }
}

.copp-overview__link {
    align-items: center;
    border: 2px solid var(--copp-red);
    color: var(--copp-red);
    display: inline-flex;
    font-size: 16px;
    font-weight: 800;
    gap: 18px;
    height: 56px;
    justify-content: center;
    max-width: 214px;
    padding: 0 22px;
    text-decoration: none;
}

.copp-overview__link:hover,
.copp-overview__link:focus {
    background: rgba(var(--copp-red-rgb), 0.04);
    color: var(--copp-red-dark);
    text-decoration: none;
}

.copp-overview__link svg {
    flex: 0 0 auto;
    height: 20px;
    width: 20px;
}

.copp-overview__stats {
    align-self: start;
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    grid-auto-rows: 1fr;
}

.copp-stat-card {
    border-radius: 0;
    display: flex;
    flex-direction: column;
    min-height: 258px;
    padding: 26px 22px 24px;
}

.copp-overview__stats .copp-stat-card {
    gap: 12px;
    justify-content: flex-end;
    min-height: 164px;
    padding: 24px 22px 20px;
}

.copp-stat-card--empty {
    background: var(--copp-soft);
    min-height: 164px;
}

.copp-stat-card__icon {
    align-items: center;
    display: inline-flex;
    height: 38px;
    justify-content: center;
    margin-bottom: 34px;
    width: 38px;
}

.copp-overview__stats .copp-stat-card__icon {
    margin-bottom: 12px;
}

.copp-stat-card__icon svg {
    height: 38px;
    width: 38px;
}

.copp-stat-card__value {
    font-size: 34px;
    font-weight: 900;
    line-height: 1;
    margin-bottom: 18px;
}

.copp-overview__stats .copp-stat-card__value {
    font-size: 36px;
    margin-bottom: 6px;
}

.copp-stat-card__label {
    font-size: 15px;
    font-weight: 500;
    line-height: 1.35;
    margin-top: auto;
}

.copp-overview__stats .copp-stat-card__label {
    font-size: 14px;
    line-height: 1.35;
    margin-top: 0;
}

.copp-overview__popular {
    border-top: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    display: grid;
    gap: 16px;
    margin-top: 20px;
    padding-top: 18px;
}

.copp-overview__popular-head {
    align-items: baseline;
    display: flex;
    flex-wrap: wrap;
    gap: 10px 18px;
    justify-content: space-between;
}

.copp-overview__popular-head h3 {
    color: var(--copp-ink);
    font-size: 18px;
    font-weight: 900;
    line-height: 1.15;
    margin: 0;
}

.copp-overview__popular-head a {
    color: var(--copp-red);
    font-size: 14px;
    font-weight: 800;
    text-decoration: none;
}

.copp-overview__popular-head a:hover,
.copp-overview__popular-head a:focus {
    color: var(--copp-red-dark);
    text-decoration: none;
}

.copp-overview__popular-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.copp-overview__popular-card {
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    border-radius: 0;
    display: grid;
    gap: 10px;
    min-width: 0;
    padding: 14px 14px 13px;
}

.copp-overview__popular-meta {
    align-items: center;
    display: flex;
    gap: 8px;
    justify-content: space-between;
    min-width: 0;
}

.copp-overview__popular-category,
.copp-overview__popular-reason {
    border-radius: 0;
    display: inline-flex;
    font-size: 11px;
    font-weight: 800;
    line-height: 1;
    max-width: 100%;
    padding: 7px 10px;
    white-space: nowrap;
}

.copp-overview__popular-category {
    background: #f4f4f5;
    color: var(--copp-ink);
    overflow: hidden;
    text-overflow: ellipsis;
}

.copp-overview__popular-reason {
    background: rgba(var(--copp-red-rgb), 0.03);
    color: var(--copp-red);
    flex: 0 0 auto;
}

.copp-overview__popular-card h4 {
    margin: 0;
}

.copp-overview__popular-card h4 a {
    color: var(--copp-ink);
    display: -webkit-box;
    font-size: 16px;
    font-weight: 900;
    line-height: 1.28;
    overflow: hidden;
    text-decoration: none;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.copp-overview__popular-card h4 a:hover,
.copp-overview__popular-card h4 a:focus {
    color: var(--copp-red);
    text-decoration: none;
}

.copp-overview__popular-facts {
    color: rgba(var(--copp-ink-rgb), 0.72);
    display: flex;
    flex-wrap: wrap;
    font-size: 13px;
    font-weight: 700;
    gap: 8px 14px;
    line-height: 1.35;
}

.copp-overview__popular-facts span {
    position: relative;
}

.copp-overview__popular-facts span + span::before {
    color: rgba(var(--copp-ink-rgb), 0.28);
    content: '•';
    left: -9px;
    position: absolute;
}

.copp-stat-card--light {
    background: var(--copp-pale);
    color: var(--copp-dark);
}

.copp-stat-card--coral {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-stat-card--red {
    background: var(--copp-red-dark);
    color: #ffffff;
}

.copp-stat-card--dark {
    background: var(--copp-ink);
    color: #ffffff;
}

.copp-pathfinder {
    background: #ffffff;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    overflow: hidden;
    padding: 0;
    position: relative;
    width: 100vw;
}

.copp-pathfinder__shell {
    display: grid;
    grid-template-columns: minmax(320px, 0.78fr) minmax(0, 1.22fr);
    margin: 0 auto;
    max-width: var(--copp-container-content);
    min-height: 430px;
}

.copp-pathfinder__intro,
.copp-pathfinder__quiz {
    min-width: 0;
    position: relative;
}

.copp-pathfinder__intro::before,
.copp-pathfinder__quiz::after {
    bottom: 0;
    content: "";
    pointer-events: none;
    position: absolute;
    top: 0;
    width: 100vw;
}

.copp-pathfinder__intro::before {
    background: var(--copp-red);
    right: 100%;
}

.copp-pathfinder__quiz::after {
    background: var(--copp-ink);
    left: 100%;
}

.copp-pathfinder__intro {
    background: var(--copp-red);
    color: #ffffff;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 42px 44px 36px;
    transform: translateX(-100%);
    transition: transform 0.8s cubic-bezier(0.65, 0, 0.35, 1);
}

.copp-pathfinder__stage {
    transform: translateX(100%);
    transition: transform 0.8s cubic-bezier(0.65, 0, 0.35, 1);
}

.copp-pathfinder.is-smashed .copp-pathfinder__intro {
    transform: translateX(0);
}

.copp-pathfinder.is-smashed .copp-pathfinder__stage {
    transform: translateX(0);
}

.copp-pathfinder__title {
    color: #ffffff;
    font-size: 28px;
    font-weight: var(--copp-fw-heading-bold);
    letter-spacing: var(--copp-ls-section);
    line-height: 1.05;
    margin: 0 0 18px;
    text-transform: uppercase;
}

.copp-pathfinder__lead {
    color: rgba(255, 255, 255, 0.9);
    font-size: 18px;
    line-height: 1.45;
    margin: 0;
    max-width: 360px;
}

.copp-pathfinder__start {
    align-items: center;
    align-self: flex-start;
    background: transparent;
    border: 2px solid rgba(255, 255, 255, 0.55);
    border-radius: 0;
    color: #ffffff;
    cursor: pointer;
    display: inline-flex;
    font-size: 18px;
    font-weight: 800;
    gap: 18px;
    height: 54px;
    justify-content: center;
    margin-top: 28px;
    min-width: 184px;
    padding: 0 24px;
}

.copp-pathfinder__start:hover,
.copp-pathfinder__start:focus {
    background: rgba(255, 255, 255, 0.08);
    color: #ffffff;
    outline: none;
    text-decoration: none;
}

.copp-pathfinder__start svg {
    height: 20px;
    width: 20px;
}

.copp-pathfinder__social {
    display: grid;
    gap: 20px;
    justify-items: start;
}

.copp-pathfinder__social-row {
    align-items: center;
    display: flex;
    gap: 16px;
}

.copp-pathfinder__avatars {
    display: flex;
    padding-left: 6px;
}

.copp-pathfinder__avatars--small .copp-pathfinder__avatar {
    height: 44px;
    width: 44px;
}

.copp-pathfinder__avatar {
    align-items: center;
    border: 3px solid var(--copp-red);
    border-radius: 50%;
    color: var(--copp-ink);
    display: inline-flex;
    font-size: 16px;
    font-weight: 800;
    height: 52px;
    justify-content: center;
    margin-left: -6px;
    overflow: hidden;
    width: 52px;
}

.copp-pathfinder__avatar img {
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.copp-pathfinder__avatar--light {
    background: #f3eadf;
}

.copp-pathfinder__avatar--sand {
    background: #e7d2bb;
}

.copp-pathfinder__avatar--rose {
    background: rgba(var(--copp-red-rgb), 0.2);
}

.copp-pathfinder__avatar--warm {
    background: #d8b08a;
}

.copp-pathfinder__social-copy {
    color: #ffffff;
    font-size: 17px;
    font-weight: 700;
    line-height: 1.3;
}

.copp-pathfinder__quiz {
    background: var(--copp-ink);
    color: #ffffff;
    display: flex;
    flex-direction: column;
    gap: 28px;
    padding: 30px 36px 38px;
}

.copp-pathfinder__progress {
    display: grid;
    gap: 12px;
}

.copp-pathfinder__progress-top {
    align-items: center;
    display: flex;
    gap: 14px;
    justify-content: space-between;
}

.copp-pathfinder__progress-copy {
    color: var(--copp-red);
    font-size: 16px;
    font-weight: 800;
    line-height: 1.2;
}

.copp-pathfinder__progress-copy--muted {
    color: rgba(255, 255, 255, 0.45);
    font-size: 14px;
    font-weight: 600;
}

.copp-pathfinder__progress-bar {
    background: rgba(255, 255, 255, 0.1);
    border-radius: 0;
    height: 6px;
    overflow: hidden;
}

.copp-pathfinder__progress-bar span {
    background: var(--copp-red);
    border-radius: 0;
    display: block;
    height: 100%;
    transition: width 260ms ease;
    width: 33.33%;
}

.copp-pathfinder__question {
    color: #ffffff;
    font-size: 28px;
    font-weight: 800;
    line-height: 1.15;
    margin: 0;
    max-width: 760px;
}

.copp-pathfinder__choices {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.copp-pathfinder__choice {
    align-items: flex-start;
    background: var(--copp-ink);
    border: 2px solid transparent;
    border-radius: 0;
    color: #ffffff;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    gap: 22px;
    min-height: 132px;
    padding: 18px 18px 20px;
    text-align: left;
    transition: border-color 180ms ease, background-color 180ms ease, transform 180ms ease;
}

.copp-pathfinder__choice:hover,
.copp-pathfinder__choice:focus {
    background: var(--copp-ink);
    border-color: rgba(var(--copp-red-rgb), 0.55);
    outline: none;
    transform: translateY(-2px);
}

.copp-pathfinder__choice.is-active {
    background: var(--copp-ink);
    border-color: var(--copp-red);
}

.copp-pathfinder__choice-icon {
    color: #ffffff;
    display: inline-flex;
    height: 34px;
    width: 34px;
}

.copp-pathfinder__choice-icon svg {
    height: 34px;
    width: 34px;
}

.copp-pathfinder__choice-label {
    color: #ffffff;
    font-size: 17px;
    font-weight: 700;
    line-height: 1.35;
}

.copp-pathfinder__actions {
    align-items: center;
    display: flex;
    justify-content: space-between;
    margin-top: auto;
}

.copp-pathfinder__nav {
    align-items: center;
    border-radius: 0;
    cursor: pointer;
    display: inline-flex;
    font-size: 18px;
    font-weight: 800;
    gap: 18px;
    height: 48px;
    justify-content: center;
    min-width: 176px;
    padding: 0 22px;
}

.copp-pathfinder__nav svg {
    height: 18px;
    width: 18px;
}

.copp-pathfinder__nav--ghost {
    background: transparent;
    border: 2px solid rgba(255, 255, 255, 0.26);
    color: #ffffff;
}

.copp-pathfinder__nav--ghost:hover,
.copp-pathfinder__nav--ghost:focus {
    border-color: rgba(255, 255, 255, 0.42);
    color: #ffffff;
    outline: none;
}

.copp-pathfinder__nav--ghost:disabled {
    opacity: 0.45;
}

.copp-pathfinder__nav--primary {
    background: var(--copp-red);
    border: 0;
    color: #ffffff;
}

.copp-pathfinder__nav--primary:hover,
.copp-pathfinder__nav--primary:focus {
    background: var(--copp-red-dark);
    color: #ffffff;
    outline: none;
}

.copp-pathfinder.is-result-mode .copp-pathfinder__choices {
    display: block;
}

.copp-pathfinder__result {
    display: grid;
    gap: 12px;
}

.copp-pathfinder__result-summary {
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 0;
    display: grid;
    gap: 8px;
    padding: 12px 16px;
}

.copp-pathfinder__result-summary--muted {
    background: rgba(255, 255, 255, 0.04);
}

.copp-pathfinder__result-badge {
    align-items: center;
    background: rgba(var(--copp-red-rgb), 0.16);
    border: 1px solid rgba(var(--copp-red-rgb), 0.36);
    border-radius: 0;
    color: #ffffff;
    display: inline-flex;
    font-size: var(--copp-fs-badge);
    font-weight: var(--copp-fw-bold);
    justify-self: start;
    letter-spacing: var(--copp-ls-label);
    line-height: 1;
    min-height: 24px;
    padding: 0 10px;
    text-transform: uppercase;
}

.copp-pathfinder__result-text {
    color: rgba(255, 255, 255, 0.86);
    font-size: 14px;
    line-height: 1.5;
    margin: 0;
}

.copp-pathfinder__result-facts {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.copp-pathfinder__result-fact {
    background: var(--copp-ink);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 0;
    display: grid;
    gap: 4px;
    min-height: 68px;
    padding: 10px 14px;
}

.copp-pathfinder__result-fact span {
    color: rgba(255, 255, 255, 0.48);
    font-size: 11px;
    font-weight: 700;
    line-height: 1.2;
    text-transform: uppercase;
}

.copp-pathfinder__result-fact strong {
    color: #ffffff;
    font-size: 15px;
    font-weight: 800;
    line-height: 1.3;
}

.copp-pathfinder__result-heading {
    color: #ffffff;
    font-size: 15px;
    font-weight: 800;
    line-height: 1.25;
    margin: 0 0 4px;
}

.copp-pathfinder__result-subtitle {
    color: rgba(255, 255, 255, 0.58);
    font-size: 13px;
    line-height: 1.45;
    margin: 0 0 10px;
}

.copp-pathfinder__result-program-grid {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.copp-pathfinder__result-program-card {
    background: var(--copp-ink);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 0;
    color: #ffffff;
    display: grid;
    gap: 6px;
    min-height: 80px;
    padding: 12px 14px;
    text-decoration: none;
}

.copp-pathfinder__result-program-card strong {
    color: #ffffff;
    font-size: 14px;
    font-weight: 800;
    line-height: 1.35;
}

.copp-pathfinder__result-program-card span {
    color: rgba(255, 255, 255, 0.58);
    font-size: 12px;
    line-height: 1.4;
}

.copp-pathfinder__result-program-card:hover,
.copp-pathfinder__result-program-card:focus {
    border-color: rgba(var(--copp-red-rgb), 0.55);
    color: #ffffff;
    text-decoration: none;
    transform: translateY(-2px);
}

.copp-pathfinder__result-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.copp-pathfinder__result-link {
    align-items: center;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 0;
    color: #ffffff;
    display: inline-flex;
    font-size: 13px;
    font-weight: 700;
    justify-content: center;
    min-height: 36px;
    padding: 0 14px;
    text-decoration: none;
}

.copp-pathfinder__result-link--primary {
    background: var(--copp-red);
    border-color: var(--copp-red);
}

.copp-pathfinder__result-link:hover,
.copp-pathfinder__result-link:focus {
    border-color: rgba(255, 255, 255, 0.48);
    color: #ffffff;
    text-decoration: none;
}

.copp-pathfinder__result-link--primary:hover,
.copp-pathfinder__result-link--primary:focus {
    background: var(--copp-red-dark);
    border-color: var(--copp-red-dark);
}

.copp-pathfinder__status {
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 0;
    color: #ffffff;
    font-size: 15px;
    font-weight: 700;
    line-height: 1.5;
    padding: 16px 18px;
}

.copp-pathfinder__choices > .copp-pathfinder__status {
    grid-column: 1 / -1;
}

.copp-pathfinder__status--error {
    border-color: rgba(var(--copp-red-rgb), 0.44);
    color: rgba(255, 255, 255, 0.92);
}

.copp-pathfinder__status--loading {
    border-color: rgba(255, 255, 255, 0.2);
    color: rgba(255, 255, 255, 0.8);
}

@media (max-width: 991.98px) {
    .copp-pathfinder__result-facts,
    .copp-pathfinder__result-program-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .copp-pathfinder__result-facts,
    .copp-pathfinder__result-program-grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-pathfinder__result-actions {
        flex-direction: column;
    }

    .copp-pathfinder__result-link {
        width: 100%;
    }
}

.copp-showcase {
    background: #ffffff;
    padding: 34px 0 50px;
}

.copp-showcase__shell {
    display: grid;
    gap: 38px;
}

.copp-showcase__section {
    display: grid;
    gap: 20px;
}

.copp-showcase__head {
    align-items: end;
    display: flex;
    gap: 20px;
    justify-content: space-between;
}

.copp-showcase__title {
    color: var(--copp-ink);
    font-size: 28px;
    font-weight: var(--copp-fw-heading-bold);
    letter-spacing: var(--copp-ls-section);
    line-height: 1.05;
    margin: 0 0 14px;
    text-transform: uppercase;
}

.copp-showcase__bars {
    align-items: center;
    display: flex;
    gap: 10px;
}

.copp-showcase__bars > * {
    background: rgba(var(--copp-red-rgb), 0.15);
    border: 0;
    border-radius: 0;
    cursor: pointer;
    display: block;
    height: 4px;
    padding: 0;
    transition: background-color 220ms ease, transform 220ms ease;
    width: 34px;
}

.copp-showcase__bars > *:hover,
.copp-showcase__bars > *:focus {
    background: rgba(var(--copp-red-rgb), 0.4);
    outline: none;
    transform: scaleX(1.05);
}

.copp-showcase__bars .is-active {
    background: var(--copp-red);
}

.copp-showcase__bars .is-active:hover,
.copp-showcase__bars .is-active:focus {
    background: var(--copp-red);
}

.copp-showcase__link {
    align-items: center;
    color: var(--copp-red);
    display: inline-flex;
    font-size: 18px;
    font-weight: 800;
    gap: 14px;
    text-decoration: none;
}

.copp-showcase__link:hover,
.copp-showcase__link:focus {
    color: var(--copp-red-dark);
    text-decoration: none;
}

.copp-showcase__link svg {
    height: 18px;
    width: 18px;
}

.copp-programs {
    position: relative;
}

.copp-programs__viewport {
    overflow: hidden;
}

.copp-programs__track {
    display: flex;
    gap: 16px;
    transition: transform 260ms ease;
}

.copp-program-card {
    border-radius: 0;
    color: inherit;
    display: flex;
    flex-direction: column;
    flex: 0 0 calc((100% - 48px) / 4);
    max-width: calc((100% - 48px) / 4);
    min-height: 170px;
    min-width: 0;
    padding: 24px 24px 18px;
    position: relative;
    text-decoration: none;
}

.copp-program-card:hover,
.copp-program-card:focus {
    color: inherit;
    text-decoration: none;
}

.copp-program-card__icon {
    display: inline-flex;
    height: 34px;
    margin-bottom: 24px;
    width: 34px;
}

.copp-program-card__icon svg {
    height: 34px;
    width: 34px;
}

.copp-program-card__icon i {
    display: block;
    font-size: 30px;
    line-height: 1;
}

.copp-program-card__title {
    font-size: var(--copp-fs-card-title);
    font-weight: var(--copp-fw-bold);
    line-height: var(--copp-lh-card-title);
    max-width: 190px;
}

.copp-program-card__arrow {
    align-items: center;
    border: 2px solid rgba(255, 255, 255, 0.45);
    border-radius: 0;
    bottom: 16px;
    display: inline-flex;
    height: 40px;
    justify-content: center;
    position: absolute;
    right: 16px;
    width: 40px;
}

.copp-program-card__arrow svg {
    height: 18px;
    width: 18px;
}

.copp-program-card--light {
    background: var(--copp-pale);
    color: var(--copp-ink);
}

.copp-program-card--light .copp-program-card__arrow {
    border-color: rgba(var(--copp-ink-rgb), 0.45);
}

.copp-program-card--coral {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-program-card--red {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-program-card--deep {
    background: var(--copp-red-deep);
    color: #ffffff;
}

.copp-program-card--dark {
    background: var(--copp-ink);
    color: #ffffff;
}

.copp-programs__prev,
.copp-programs__next {
    align-items: center;
    background: rgba(var(--copp-ink-rgb), 0.82);
    border: 0;
    border-radius: 0;
    color: #ffffff;
    cursor: pointer;
    display: inline-flex;
    height: 54px;
    justify-content: center;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 54px;
    z-index: 2;
}

.copp-programs__prev {
    left: -10px;
}

.copp-programs__next {
    right: -10px;
}

.copp-programs__prev svg {
    transform: rotate(180deg);
}

.copp-programs__prev:hover,
.copp-programs__prev:focus,
.copp-programs__next:hover,
.copp-programs__next:focus {
    background: var(--copp-ink);
    outline: none;
}

.copp-programs__prev:disabled,
.copp-programs__next:disabled {
    cursor: default;
    opacity: 0.42;
}

.copp-programs__prev:disabled:hover,
.copp-programs__prev:disabled:focus,
.copp-programs__next:disabled:hover,
.copp-programs__next:disabled:focus {
    background: rgba(var(--copp-ink-rgb), 0.82);
}

.copp-programs__prev[hidden],
.copp-programs__next[hidden] {
    display: none !important;
}

.copp-programs__prev svg,
.copp-programs__next svg {
    height: 22px;
    width: 22px;
}

.copp-programs-page-hero__stats {
    color: rgba(var(--copp-ink-rgb), 0.78);
    display: flex;
    flex-wrap: wrap;
    gap: 12px 18px;
    margin-top: 22px;
}

.copp-programs-page-hero__stats span {
    align-items: baseline;
    display: inline-flex;
    gap: 6px;
}

.copp-programs-page-hero__stats strong {
    color: var(--copp-red);
    font-size: 22px;
    font-weight: 900;
    line-height: 1;
}

.copp-programs-page {
    display: grid;
    gap: 40px;
}

.copp-programs-page__stats {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.copp-programs-page__stats .copp-stat-card {
    gap: 12px;
    min-height: 0;
    padding: 20px 18px 18px;
}

.copp-programs-page__stats .copp-stat-card__icon {
    height: 30px;
    margin-bottom: 0;
    width: 30px;
}

.copp-programs-page__stats .copp-stat-card__value {
    font-size: 32px;
    margin-bottom: 0;
}

.copp-programs-page__stats .copp-stat-card__label {
    line-height: 1.25;
    margin-top: 0;
}

.copp-programs-page__categories {
    margin-bottom: 0;
}

.copp-programs-page__category-count {
    bottom: 18px;
    color: inherit;
    font-size: 13px;
    font-weight: 700;
    left: 24px;
    opacity: 0.78;
    position: absolute;
}

.copp-program-grid {
    --copp-grid-columns: 3;
    align-items: stretch;
    display: grid;
    gap: 20px;
    grid-template-columns: repeat(var(--copp-grid-columns), minmax(0, 1fr));
}

.copp-opportunity-page {
    display: grid;
    gap: 40px;
}

.copp-opportunity-intro {
    display: grid;
    gap: 18px;
}

.copp-opportunity-page > .copp-opportunity-intro {
    display: none;
}

.copp-opportunity-page .copp-school-help__process {
    --copp-about-process-gap: 16px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    align-items: stretch;
    gap: var(--copp-about-process-gap);
    padding-top: 0;
    width: 100%;
}

.copp-opportunity-page .copp-school-help__step {
    align-content: start;
    align-items: start;
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    border-radius: 0;
    box-shadow: 0 18px 36px rgba(var(--copp-dark-rgb), 0.06);
    gap: 18px;
    justify-items: start;
    min-height: 100%;
    padding: 24px 22px 22px;
    text-align: left;
}

.copp-opportunity-page .copp-about-process__body {
    display: grid;
    gap: 10px;
    justify-items: start;
    text-align: left;
    width: 100%;
}

.copp-opportunity-page .copp-about-process__step-index {
    align-items: center;
    align-self: start;
    background: rgba(var(--copp-red-rgb), 0.08);
    border-radius: 0;
    color: var(--copp-red);
    display: inline-flex;
    font-size: 12px;
    font-weight: 800;
    height: 30px;
    justify-content: center;
    line-height: 1;
    width: 30px;
}

.copp-opportunity-page .copp-about-process__icon {
    margin: 0;
}

.copp-opportunity-page .copp-about-process__connector {
    display: none;
}

.copp-opportunity-page .copp-about-process__body h3 {
    color: var(--copp-ink);
    font-size: 18px;
    font-weight: 800;
    line-height: 1.28;
    margin: 0;
    max-width: none;
}

.copp-opportunity-page .copp-about-process__body p {
    color: var(--copp-muted);
    font-size: 14px;
    line-height: 1.5;
    margin: 0;
    max-width: none;
}

@media (max-width: 1199px) {
    .copp-opportunity-hero .copp-news-hero__inner {
        grid-template-columns: minmax(0, 1fr) minmax(260px, 0.88fr);
        min-height: 300px;
    }

    .copp-opportunity-page .copp-school-help__process {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .copp-opportunity-hero {
        padding-top: 18px;
        padding-bottom: 20px;
    }

    .copp-opportunity-hero .copp-news-hero__inner {
        gap: 18px;
        min-height: 0;
    }

    .copp-opportunity-hero .copp-news-hero__media,
    .copp-opportunity-hero .copp-students-hero__scene {
        min-height: 220px;
    }

    .copp-opportunity-hero__subtitle,
    .copp-opportunity-hero__lead-copy {
        max-width: none;
    }

    .copp-opportunity-page .copp-school-help__process {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-opportunity-page .copp-school-help__step {
        padding: 20px 18px 18px;
    }
}

.copp-opportunity-hero .copp-partners-hero__subtitle,
.copp-opportunity-hero .copp-news-hero__lead {
    display: none;
}

.copp-opportunity-hero {
    padding-top: 18px;
    padding-bottom: 22px;
}

.copp-opportunity-hero .copp-news-hero__inner {
    align-items: center;
    gap: 28px;
    grid-template-columns: minmax(0, 390px) minmax(320px, 1fr);
    min-height: 332px;
}

.copp-opportunity-hero .copp-news-hero__copy {
    align-content: start;
    display: grid;
    gap: 16px;
}

.copp-opportunity-hero .copp-news-hero__title {
    font-size: clamp(40px, 4.3vw, 60px);
    line-height: var(--copp-lh-hero);
}

.copp-opportunity-hero__subtitle {
    color: var(--copp-ink);
    font-size: 18px;
    font-weight: 800;
    line-height: 1.35;
    margin: 0;
    max-width: 360px;
}

.copp-opportunity-hero__lead-copy {
    color: #424242;
    font-size: 15px;
    line-height: 1.55;
    margin: 0;
    max-width: 360px;
}

.copp-opportunity-hero .copp-news-hero__actions {
    margin-top: 6px;
}

.copp-opportunity-hero .copp-news-btn--outline,
.copp-opportunity-hero .copp-programs-page-hero__stats {
    display: none;
}

.copp-opportunity-hero .copp-news-hero__media,
.copp-opportunity-hero .copp-students-hero__scene {
    min-height: 300px;
}

.copp-opportunity-hero .copp-students-hero__people img {
    max-height: 292px;
    object-fit: contain;
    object-position: center bottom;
}

.copp-opportunity-intro__body {
    color: #474747;
    display: grid;
    gap: 14px;
    max-width: 980px;
}

.copp-opportunity-intro__body > * {
    margin-bottom: 0;
}

.copp-opportunity-focus {
    align-items: stretch;
    display: grid;
    gap: 16px;
    grid-auto-rows: 1fr;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.copp-opportunity-focus .copp-students-opportunity {
    height: 100%;
    min-height: 220px;
}

.copp-opportunity-focus .copp-students-opportunity p {
    margin-bottom: 0;
}

.copp-program-tile {
    background: #ffffff;
    border: 1px solid rgba(35, 35, 35, 0.08);
    border-radius: 0;
    box-shadow: 0 18px 34px rgba(20, 20, 20, 0.05);
    display: flex;
    flex-direction: column;
    height: 100%;
    min-width: 0;
    overflow: hidden;
}

.copp-program-tile__image {
    aspect-ratio: 1.56;
    display: block;
    overflow: hidden;
    position: relative;
}

.copp-program-tile__image img {
    display: block;
    height: 100%;
    object-fit: cover;
    transition: transform 260ms ease;
    width: 100%;
}

.copp-program-tile:hover .copp-program-tile__image img,
.copp-program-tile:focus-within .copp-program-tile__image img {
    transform: scale(1.03);
}

.copp-program-tile__badge {
    align-items: center;
    border-radius: 0;
    color: #ffffff;
    display: inline-flex;
    font-size: var(--copp-fs-badge);
    font-weight: var(--copp-fw-bold);
    gap: 8px;
    left: 18px;
    line-height: 1;
    max-width: calc(100% - 36px);
    padding: 10px 14px;
    position: absolute;
    top: 18px;
    letter-spacing: var(--copp-ls-label);
    text-transform: uppercase;
}

.copp-program-tile__badge--light {
    background: rgba(35, 35, 35, 0.82);
}

.copp-program-tile__badge--coral {
    background: var(--copp-red);
}

.copp-program-tile__badge--red {
    background: var(--copp-red);
}

.copp-program-tile__badge--deep {
    background: var(--copp-red-deep);
}

.copp-program-tile__badge--dark {
    background: var(--copp-ink);
}

.copp-program-tile__body {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    gap: 14px;
    padding: 22px 22px 24px;
}

.copp-program-tile__state {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.copp-program-tile__state span {
    border-radius: 0;
    color: #3f3f3f;
    font-size: 12px;
    font-weight: 800;
    line-height: 1;
    padding: 9px 12px;
}

.copp-program-tile__state .is-open {
    background: rgba(24, 160, 88, 0.12);
    color: #17824b;
}

.copp-program-tile__state .is-closed {
    background: rgba(35, 35, 35, 0.08);
    color: #565656;
}

.copp-program-tile__state span:not(.is-open):not(.is-closed) {
    background: rgba(var(--copp-red-rgb), 0.1);
    color: var(--copp-red);
}

.copp-program-tile__body h2,
.copp-program-tile__body h3 {
    font-size: 22px;
    font-weight: 900;
    line-height: 1.22;
    margin: 0;
    min-height: calc(1.22em * 2);
}

.copp-program-tile__body h2 a,
.copp-program-tile__body h3 a {
    color: var(--copp-ink);
    text-decoration: none;
}

.copp-program-tile__body h2 a:hover,
.copp-program-tile__body h2 a:focus,
.copp-program-tile__body h3 a:hover,
.copp-program-tile__body h3 a:focus {
    color: var(--copp-red);
    text-decoration: none;
}

.copp-program-tile__body p {
    color: #5f5f5f;
    font-size: 15px;
    line-height: 1.55;
    margin: 0;
    min-height: calc(1.55em * 4);
}

.copp-program-tile__facts {
    display: grid;
    gap: 10px 12px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin: 0;
}

.copp-program-tile__facts div {
    background: var(--copp-soft);
    border-radius: 0;
    min-width: 0;
    padding: 12px 14px;
}

.copp-program-tile__facts dt {
    color: #7a7a7a;
    font-size: 12px;
    font-weight: 700;
    line-height: 1.2;
    margin: 0 0 6px;
}

.copp-program-tile__facts dd {
    color: var(--copp-ink);
    font-size: 14px;
    font-weight: 800;
    line-height: 1.35;
    margin: 0;
}

.copp-program-tile__link {
    align-items: center;
    color: var(--copp-red);
    display: inline-flex;
    font-size: 15px;
    font-weight: 800;
    gap: 10px;
    margin-top: auto;
    text-decoration: none;
}

.copp-program-tile__link:hover,
.copp-program-tile__link:focus {
    color: var(--copp-red-dark);
    text-decoration: none;
}

.copp-program-tile__link svg {
    height: 16px;
    width: 16px;
}

.copp-programs-archive {
    display: grid;
    gap: 28px;
}

.copp-programs-archive__hero {
    align-items: center;
    background: linear-gradient(135deg, #ffffff 0%, #f4f4f4 100%);
    border: 1px solid rgba(35, 35, 35, 0.06);
    border-radius: 0;
    display: grid;
    gap: 24px;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.84fr);
    overflow: hidden;
    padding: 36px 40px;
}

.copp-programs-archive__eyebrow {
    color: var(--copp-red);
    display: inline-block;
    font-size: var(--copp-fs-eyebrow);
    font-weight: var(--copp-fw-eyebrow);
    letter-spacing: var(--copp-ls-eyebrow);
    margin-bottom: 12px;
    text-transform: uppercase;
}

.copp-programs-archive__copy h1 {
    font-size: 48px;
    font-weight: 900;
    line-height: 0.98;
    margin: 0 0 16px;
    text-transform: uppercase;
}

.copp-programs-archive__copy p {
    color: #595959;
    font-size: 17px;
    line-height: 1.55;
    margin: 0;
    max-width: 720px;
}

.copp-programs-archive__meta {
    color: #515151;
    display: flex;
    flex-wrap: wrap;
    gap: 10px 12px;
    margin-top: 20px;
}

.copp-programs-archive__meta span {
    background: rgba(35, 35, 35, 0.05);
    border-radius: 0;
    font-size: 13px;
    font-weight: 800;
    line-height: 1;
    padding: 10px 14px;
}

.copp-programs-archive__art {
    align-self: stretch;
    min-height: 280px;
    position: relative;
}

.copp-programs-archive__art img {
    bottom: 0;
    display: block;
    height: 100%;
    object-fit: contain;
    object-position: right bottom;
    position: absolute;
    right: 0;
    width: 100%;
}

.copp-programs-archive__filters {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.copp-program-chip {
    align-items: center;
    background: var(--copp-soft);
    border-radius: 0;
    color: #313131;
    display: inline-flex;
    font-size: 14px;
    font-weight: 700;
    gap: 10px;
    line-height: 1;
    max-width: 100%;
    padding: 12px 16px;
    text-decoration: none;
}

.copp-program-chip b {
    background: rgba(35, 35, 35, 0.08);
    border-radius: 0;
    color: inherit;
    font-size: 12px;
    font-weight: 900;
    min-width: 28px;
    padding: 6px 8px;
    text-align: center;
}

.copp-program-chip:hover,
.copp-program-chip:focus,
.copp-program-chip.is-active {
    background: var(--copp-red);
    color: #ffffff;
    text-decoration: none;
}

.copp-program-chip:hover b,
.copp-program-chip:focus b,
.copp-program-chip.is-active b {
    background: rgba(255, 255, 255, 0.18);
}

.copp-programs-filters {
    background: var(--copp-pale);
    border: 1px solid var(--copp-pale);
    border-radius: 0;
    padding: 18px 20px;
    margin-bottom: 24px;
}

.copp-programs-filters__form {
    align-items: end;
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(220px, 1.25fr) repeat(4, minmax(0, 1fr)) auto;
}

.copp-programs-filters__field {
    display: grid;
    gap: 8px;
}

.copp-programs-filters__field > span {
    color: var(--copp-muted);
    font-size: 14px;
    font-weight: 700;
    line-height: 1.2;
}

.copp-programs-filters__field select,
.copp-programs-filters__field input {
    appearance: none;
    background: #ffffff;
    border: 1px solid transparent;
    border-radius: 0;
    box-shadow: none;
    color: var(--copp-ink);
    font-size: 16px;
    font-weight: 700;
    height: 52px;
    line-height: 52px;
    outline: none;
    padding: 0 18px;
    width: 100%;
}

.copp-programs-filters__field select {
    background-image:
        linear-gradient(45deg, transparent 50%, var(--copp-red) 50%),
        linear-gradient(135deg, var(--copp-red) 50%, transparent 50%);
    background-position:
        calc(100% - 20px) calc(50% - 3px),
        calc(100% - 14px) calc(50% - 3px);
    background-repeat: no-repeat;
    background-size: 6px 6px, 6px 6px;
    padding-right: 40px;
}

.copp-programs-filters__field--search {
    min-width: 0;
}

.copp-programs-filters__actions {
    display: flex;
    gap: 12px;
    justify-content: flex-end;
}

.copp-programs-filters__actions .copp-news-btn {
    align-items: center;
    display: inline-flex;
    justify-content: center;
    min-height: 52px;
    min-width: 154px;
}

@media (max-width: 991px) {
    .copp-programs-filters__form {
        grid-template-columns: 1fr 1fr;
    }
    .copp-programs-filters__field--search {
        grid-column: 1 / -1;
    }
    .copp-programs-filters__actions {
        grid-column: 1 / -1;
    }
}

@media (max-width: 767px) {
    .copp-programs-filters__form {
        grid-template-columns: 1fr;
    }
}

.copp-news-pagination__current {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    background: var(--copp-red);
    color: #ffffff;
    font-weight: 900;
    font-size: 14px;
}

.copp-news-pagination a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    background: var(--copp-soft);
    color: var(--copp-ink);
    font-weight: 700;
    font-size: 14px;
    text-decoration: none;
    transition: background 0.15s ease, color 0.15s ease;
}

.copp-news-pagination a:hover {
    background: rgba(var(--copp-red-rgb), 0.08);
    color: var(--copp-red);
}

.copp-program-article {
    display: grid;
    gap: 28px;
}

.copp-program-article__hero {
    align-items: stretch;
    background: linear-gradient(135deg, #ffffff 0%, var(--copp-soft) 100%);
    border: 1px solid rgba(35, 35, 35, 0.06);
    border-radius: 0;
    display: grid;
    gap: 24px;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.88fr);
    overflow: hidden;
    padding: 36px;
}

.copp-program-article__eyebrow {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 16px;
}

.copp-program-article__eyebrow span,
.copp-program-article__eyebrow b {
    border-radius: 0;
    font-size: var(--copp-fs-eyebrow);
    font-weight: var(--copp-fw-eyebrow);
    letter-spacing: var(--copp-ls-eyebrow);
    line-height: var(--copp-lh-eyebrow);
    padding: 10px 14px;
    text-transform: uppercase;
}

.copp-program-article__eyebrow span {
    background: rgba(35, 35, 35, 0.08);
    color: #3f3f3f;
}

.copp-program-article__eyebrow b {
    background: rgba(var(--copp-red-rgb), 0.12);
    color: var(--copp-red);
}

.copp-program-article__copy h1 {
    font-size: 46px;
    font-weight: 900;
    line-height: 1;
    margin: 0 0 16px;
    text-transform: uppercase;
}

.copp-program-article__lead {
    color: #585858;
    font-size: 18px;
    line-height: 1.55;
    margin: 0 0 20px;
    max-width: 760px;
}

.copp-program-article__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.copp-program-article__meta span {
    background: #ffffff;
    border: 1px solid rgba(35, 35, 35, 0.08);
    border-radius: 0;
    color: var(--copp-ink);
    font-size: 13px;
    font-weight: 800;
    line-height: 1;
    padding: 11px 14px;
}

.copp-program-article__media img {
    border-radius: 0;
    display: block;
    height: auto;
    max-height: 400px;
    object-fit: cover;
    width: 100%;
}

.copp-program-article__layout {
    align-items: start;
    display: grid;
    gap: 24px;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 340px);
}

.copp-program-article__content {
    background: #ffffff;
    border: 1px solid rgba(35, 35, 35, 0.06);
    border-radius: 0;
    display: grid;
    gap: 24px;
    padding: 28px 30px;
}

.copp-program-article__content p,
.copp-program-article__content li {
    font-size: 16px;
    line-height: 1.72;
}

.copp-program-article__content > :last-child {
    margin-bottom: 0;
}

.copp-program-article__content-footer {
    border-top: 1px solid rgba(35, 35, 35, 0.08);
    display: grid;
    gap: 18px;
    padding-top: 4px;
}

.copp-program-article__content-footer .copp-news-article__tags {
    margin: 0;
}

.copp-program-article__aside {
    background: var(--copp-ink);
    border-radius: 0;
    color: #ffffff;
    display: grid;
    gap: 14px;
    padding: 22px;
    position: sticky;
    top: 100px;
}

.copp-program-article__fact {
    background: rgba(255, 255, 255, 0.06);
    border-radius: 0;
    display: grid;
    gap: 6px;
    padding: 14px 16px;
}

.copp-program-article__fact span {
    color: rgba(255, 255, 255, 0.66);
    font-size: 12px;
    font-weight: 700;
    line-height: 1.2;
}

.copp-program-article__fact strong {
    color: #ffffff;
    font-size: 18px;
    font-weight: 900;
    line-height: 1.25;
}

.copp-enrollment-box {
    display: flex;
    flex-direction: column;
    gap: 14px;
    margin-top: 8px;
    padding: 18px;
    border: 1px solid rgba(35, 35, 35, 0.1);
    border-radius: 0;
    background: linear-gradient(180deg, #ffffff 0%, var(--copp-soft) 100%);
}

.copp-enrollment-box__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}

.copp-enrollment-box__head > span {
    color: rgba(35, 35, 35, 0.58);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0.04em;
    line-height: 1;
    text-transform: uppercase;
}

.copp-enrollment-box__status {
    align-items: center;
    background: rgba(35, 35, 35, 0.06);
    border-radius: 0;
    color: var(--copp-ink);
    display: inline-flex;
    font-size: 12px;
    font-weight: 900;
    line-height: 1;
    min-height: 30px;
    padding: 0 12px;
    white-space: nowrap;
}

.copp-enrollment-box__status--active {
    background: rgba(var(--copp-red-rgb), 0.12);
    color: var(--copp-red);
}

.copp-enrollment-box__status--muted {
    background: rgba(35, 35, 35, 0.08);
    color: rgba(35, 35, 35, 0.62);
}

.copp-enrollment-box__message {
    margin: 0;
    color: rgba(35, 35, 35, 0.74);
    font-size: 14px;
    font-weight: 700;
    line-height: 1.6;
}

.copp-enrollment-box__list {
    display: grid;
    gap: 8px;
    margin: 0;
    padding-left: 18px;
}

.copp-enrollment-box__list li {
    color: rgba(35, 35, 35, 0.72);
    font-size: 14px;
    line-height: 1.55;
}

.copp-enrollment-box__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.copp-enrollment-box__meta span {
    align-items: center;
    background: rgba(35, 35, 35, 0.04);
    border-radius: 0;
    color: var(--copp-ink);
    display: inline-flex;
    font-size: 12px;
    font-weight: 800;
    line-height: 1;
    min-height: 30px;
    padding: 0 12px;
}

.copp-enrollment-box__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.copp-enrollment-box__form {
    display: flex;
}

.copp-enrollment-box__actions .copp-news-btn,
.copp-enrollment-box__form .copp-news-btn {
    min-height: 46px;
}

.copp-program-article__footer {
    display: flex;
    justify-content: flex-start;
}

.copp-programs-empty {
    background: var(--copp-soft);
    border-radius: 0;
    padding: 28px 24px;
}

@media (max-width: 1199px) {
    .copp-program-grid {
        --copp-grid-columns: 2;
    }

    .copp-programs-page__stats,
    .copp-opportunity-focus {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .copp-programs-archive__hero,
    .copp-program-article__hero,
    .copp-program-article__layout {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-programs-archive__art {
        min-height: 220px;
    }

    .copp-program-article__aside {
        position: static;
    }

    .copp-enrollment-box__head {
        align-items: flex-start;
        flex-direction: column;
    }
}

@media (max-width: 991px) {
    .copp-program-tile__facts {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .copp-programs-archive__copy h1,
    .copp-program-article__copy h1 {
        font-size: 38px;
    }
}

@media (max-width: 767px) {
    .copp-program-grid {
        --copp-grid-columns: 1;
    }

    .copp-programs-page__stats,
    .copp-opportunity-focus,
    .copp-program-tile__facts {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-opportunity-focus .copp-students-opportunity,
    .copp-program-tile__body h2,
    .copp-program-tile__body h3,
    .copp-program-tile__body p {
        min-height: 0;
    }

    .copp-programs-page,
    .copp-programs-archive {
        gap: 26px;
    }

    .copp-programs-archive__hero,
    .copp-program-article__hero,
    .copp-program-article__content {
        padding: 24px 20px;
    }

    .copp-programs-archive__copy h1,
    .copp-program-article__copy h1 {
        font-size: 30px;
    }

    .copp-program-article__lead,
    .copp-programs-archive__copy p {
        font-size: 16px;
    }

    .copp-enrollment-box__actions,
    .copp-enrollment-box__form {
        display: flex;
        flex-direction: column;
    }

    .copp-enrollment-box__actions .copp-news-btn,
    .copp-enrollment-box__form .copp-news-btn {
        width: 100%;
    }
}

.copp-showcase__section--events {
    overflow: hidden;
}

.copp-events {
    display: grid;
    gap: 16px;
    grid-auto-columns: minmax(0, 100%);
    grid-auto-flow: column;
    transition: transform 260ms ease;
}

.copp-event-card {
    background: var(--copp-soft);
    border-radius: 0;
    color: var(--copp-ink);
    display: grid;
    gap: 12px;
    grid-template-columns: minmax(0, 1fr);
    min-height: 0;
    padding: 18px;
    text-decoration: none;
}

.copp-event-card:hover,
.copp-event-card:focus {
    color: var(--copp-ink);
    text-decoration: none;
}

.copp-event-card__head {
    display: grid;
    gap: 16px;
    grid-template-columns: 68px minmax(0, 1fr);
    min-width: 0;
}

.copp-event-card__date {
    align-items: center;
    align-self: start;
    background: var(--copp-red);
    border-radius: 0;
    color: #ffffff;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 72px;
    height: 72px;
    padding: 8px 6px;
}

.copp-event-card__date strong {
    font-size: 26px;
    font-weight: 900;
    line-height: 1;
}

.copp-event-card__date span {
    font-size: 15px;
    font-weight: 800;
    line-height: 1.1;
}

.copp-event-card__body {
    display: grid;
    gap: 10px;
    grid-template-rows: minmax(72px, auto) auto auto;
    min-width: 0;
}

.copp-event-card__title {
    align-self: stretch;
    color: var(--copp-ink);
    font-size: var(--copp-fs-card-title);
    font-weight: var(--copp-fw-bold);
    line-height: var(--copp-lh-card-title);
    margin: 0;
    min-height: 72px;
    height: 72px;
    max-height: 72px;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.copp-event-card__description {
    color: #6b6b6b;
    font-size: var(--copp-fs-body);
    line-height: var(--copp-lh-body);
    margin: 0;
    width: 100%;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.copp-event-card__meta,
.copp-event-card__location {
    align-items: flex-start;
    color: #5c5c5c;
    display: flex;
    font-size: 14px;
    font-weight: 600;
    gap: 10px;
    justify-content: flex-start;
    line-height: 1.3;
    text-align: left;
    width: 100%;
    min-width: 0;
}

.copp-event-card__meta span,
.copp-event-card__location span {
    min-width: 0;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.copp-event-card__meta svg,
.copp-event-card__location svg {
    color: var(--copp-red);
    flex: 0 0 auto;
    height: 18px;
    width: 18px;
}

.copp-partners,
.copp-profile-cta {
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    width: 100vw;
}

.copp-news-widget {
    padding: 40px 0;
}

.copp-news-widget__head {
    align-items: center;
    display: flex;
    gap: 20px;
    justify-content: space-between;
    margin-bottom: 24px;
}

.copp-news-widget__title-wrap {
    display: grid;
    gap: 8px;
}

.copp-news-widget__title {
    color: var(--copp-ink, var(--copp-ink));
    font-family: var(--copp-font-heading);
    font-size: clamp(22px, 2.2vw, 32px);
    font-weight: var(--copp-fw-heading-bold);
    letter-spacing: var(--copp-ls-section);
    line-height: 1;
    margin: 0;
    text-transform: uppercase;
}

.copp-news-widget__link {
    align-items: center;
    color: var(--copp-ink, var(--copp-ink));
    display: inline-flex;
    font-family: var(--copp-font-heading);
    font-size: 0.82rem;
    font-weight: 700;
    gap: 6px;
    text-decoration: none;
    text-transform: uppercase;
    transition: color 0.15s;
    white-space: nowrap;
}

.copp-news-widget__link:hover {
    color: var(--copp-red);
}

.copp-news-widget__link i {
    font-size: 0.72rem;
    transition: transform 0.2s;
}

.copp-news-widget__link:hover i {
    transform: translateX(3px);
}

.copp-news-widget__grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(3, 1fr);
}

.copp-news-card {
    background: #ffffff;
    border-radius: 0;
    overflow: hidden;
    transition: box-shadow 0.2s, transform 0.15s;
}

.copp-news-card:hover {
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.06);
    transform: translateY(-1px);
}

.copp-news-card__image {
    display: block;
    overflow: hidden;
}

.copp-news-card__image img {
    aspect-ratio: 16 / 10;
    display: block;
    object-fit: cover;
    transition: transform 0.3s;
    width: 100%;
}

.copp-news-card:hover .copp-news-card__image img {
    transform: scale(1.04);
}

.copp-news-card__placeholder {
    align-items: center;
    aspect-ratio: 16 / 10;
    color: rgba(255, 255, 255, 0.35);
    display: flex;
    justify-content: center;
    text-decoration: none;
    transition: filter 0.2s;
}

.copp-news-card__placeholder:hover {
    filter: brightness(1.1);
}

.copp-news-card__placeholder i {
    font-size: 28px;
}

.copp-news-card__body {
    padding: 12px 14px 14px;
}

.copp-news-card__date {
    color: rgba(35, 35, 35, 0.45);
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
}

.copp-news-card__title {
    color: var(--copp-ink, var(--copp-ink));
    font-family: var(--copp-font-heading);
    font-size: var(--copp-fs-card-title);
    font-weight: var(--copp-fw-bold);
    line-height: var(--copp-lh-card-title);
    margin: 4px 0 6px;
}

.copp-news-card__title a {
    color: inherit;
    text-decoration: none;
}

.copp-news-card__title a:hover {
    color: var(--copp-red);
}

.copp-news-card__desc {
    color: rgba(35, 35, 35, 0.55);
    font-size: 0.78rem;
    line-height: 1.45;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.copp-news-widget__empty {
    align-items: center;
    background: rgba(37, 37, 37, 0.03);
    border: 2px dashed rgba(37, 37, 37, 0.1);
    border-radius: 0;
    color: rgba(37, 37, 37, 0.35);
    display: flex;
    flex-direction: column;
    gap: 10px;
    justify-content: center;
    min-height: 160px;
    text-align: center;
}

.copp-news-widget__empty i {
    color: var(--copp-red);
    font-size: 28px;
    opacity: 0.4;
}

.copp-news-widget__empty p {
    font-size: 0.85rem;
    margin: 0;
}

@media (max-width: 992px) {
    .copp-news-widget__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
    .copp-news-widget__grid { grid-template-columns: 1fr; }
    .copp-news-widget__head { flex-direction: column; align-items: flex-start; gap: 12px; }
}

@keyframes copp-marquee-left {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

@keyframes copp-marquee-right {
    0% { transform: translateX(-50%); }
    100% { transform: translateX(0); }
}

.copp-marquee {
    background: var(--copp-ink);
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    overflow: hidden;
    padding: 0;
    width: 100vw;
}

.copp-marquee__track {
    overflow: hidden;
    white-space: nowrap;
}

.copp-marquee__track--left {
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.copp-marquee__strip {
    display: inline-flex;
    animation: copp-marquee-left 40s linear infinite;
    will-change: transform;
}

.copp-marquee__strip--reverse {
    animation: copp-marquee-right 45s linear infinite;
}

.copp-marquee__item {
    align-items: center;
    color: rgba(255, 255, 255, 0.35);
    display: inline-flex;
    font-family: var(--copp-font-heading);
    font-size: 15px;
    font-weight: 700;
    gap: 10px;
    padding: 14px 28px;
    text-transform: uppercase;
    white-space: nowrap;
}

.copp-marquee__item--stat {
    color: rgba(255, 255, 255, 0.7);
}

.copp-marquee__value {
    color: var(--copp-red);
    font-size: 20px;
    font-weight: 900;
    letter-spacing: -0.02em;
    line-height: 1;
}

.copp-marquee__label {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.06em;
    line-height: 1.2;
    max-width: 120px;
    white-space: normal;
}

.copp-marquee__item:not(.copp-marquee__item--stat)::after {
    content: '◆';
    color: rgba(var(--copp-red-rgb), 0.35);
    font-size: 8px;
    margin-left: 20px;
}

.copp-marquee__item--stat::after {
    content: '';
    border-left: 1px solid rgba(255, 255, 255, 0.1);
    height: 32px;
    margin-left: 20px;
}

.copp-marquee:hover .copp-marquee__strip,
.copp-marquee:hover .copp-marquee__strip--reverse {
    animation-play-state: paused;
}

@media (max-width: 768px) {
    .copp-marquee__item { font-size: 13px; padding: 10px 20px; gap: 8px; }
    .copp-marquee__value { font-size: 17px; }
    .copp-marquee__label { font-size: 10px; max-width: 90px; }
}

@media (max-width: 480px) {
    .copp-marquee__item { font-size: 12px; padding: 8px 16px; gap: 6px; }
    .copp-marquee__value { font-size: 15px; }
}

.copp-programs-widget {
    padding: 40px 0;
}

.copp-programs-widget__head {
    align-items: center;
    display: flex;
    gap: 20px;
    justify-content: space-between;
    margin-bottom: 20px;
}

.copp-programs-widget__title-wrap {
    display: grid;
    gap: 8px;
}

.copp-programs-widget__title {
    color: var(--copp-ink, var(--copp-ink));
    font-family: var(--copp-font-heading);
    font-size: clamp(22px, 2.2vw, 32px);
    font-weight: var(--copp-fw-heading-bold);
    letter-spacing: var(--copp-ls-section);
    line-height: 1;
    margin: 0;
    text-transform: uppercase;
}

.copp-programs-widget__link {
    align-items: center;
    color: var(--copp-ink, var(--copp-ink));
    display: inline-flex;
    font-family: var(--copp-font-heading);
    font-size: 0.82rem;
    font-weight: 700;
    gap: 6px;
    text-decoration: none;
    text-transform: uppercase;
    transition: color 0.15s;
    white-space: nowrap;
}

.copp-programs-widget__link:hover {
    color: var(--copp-red);
}

.copp-programs-widget__link i {
    font-size: 0.72rem;
    transition: transform 0.2s;
}

.copp-programs-widget__link:hover i {
    transform: translateX(3px);
}

.copp-programs-widget__filters {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 24px;
}

.copp-programs-widget__filter {
    background: var(--copp-soft);
    border: 0;
    border-radius: 0;
    color: #555;
    cursor: pointer;
    font-family: var(--copp-font-heading);
    font-size: 0.78rem;
    font-weight: 600;
    padding: 8px 16px;
    transition: background 0.15s, color 0.15s;
    white-space: nowrap;
}

.copp-programs-widget__filter:hover {
    background: #e0e0e0;
}

.copp-programs-widget__filter.is-active {
    background: var(--copp-ink, var(--copp-ink));
    color: #ffffff;
}

.copp-programs-widget__grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(4, 1fr);
}

.copp-prog-card,
.copp-event-card,
.copp-news-card,
.copp-program-tile,
.copp-events-card,
.copp-awards-card,
.copp-album-card,
.copp-knowledge-card,
.copp-projects-card,
.copp-team-card {
    position: relative;
    overflow: hidden;
}

.copp-reveal-quad {
    position: absolute;
    width: 50%;
    height: 50%;
    z-index: 5;
    pointer-events: none;
    transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.copp-reveal-quad--tl { top: 0; left: 0; }
.copp-reveal-quad--tr { top: 0; left: 50%; }
.copp-reveal-quad--bl { top: 50%; left: 0; }
.copp-reveal-quad--br { top: 50%; left: 50%; }

.copp-reveal-quad--tl.is-revealed { transform: translate(-100%, -100%); }
.copp-reveal-quad--tr.is-revealed { transform: translate(100%, -100%); }
.copp-reveal-quad--bl.is-revealed { transform: translate(-100%, 100%); }
.copp-reveal-quad--br.is-revealed { transform: translate(100%, 100%); }

.copp-prog-card .copp-reveal-quad,
.copp-program-tile .copp-reveal-quad { background: var(--copp-red); }

.copp-event-card .copp-reveal-quad,
.copp-events-card .copp-reveal-quad { background: var(--copp-ink); }

.copp-news-card .copp-reveal-quad { background: var(--copp-red-deep); }

.copp-awards-card .copp-reveal-quad { background: var(--copp-red-dark); }

.copp-album-card .copp-reveal-quad { background: var(--copp-ink-soft); }

.copp-knowledge-card .copp-reveal-quad { background: var(--copp-red-deep); }

.copp-projects-card .copp-reveal-quad { background: var(--copp-ink-soft); }

.copp-team-card .copp-reveal-quad { background: var(--copp-ink); }

.copp-prog-card {
    background: #ffffff;
    border-radius: 0;
    overflow: hidden;
    transition: box-shadow 0.2s, transform 0.15s;
}

.copp-prog-card:hover {
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
    transform: translateY(-1px);
}

.copp-prog-card__top {
    position: relative;
}

.copp-prog-card__image {
    display: block;
    overflow: hidden;
}

.copp-prog-card__image img {
    aspect-ratio: 16 / 10;
    display: block;
    object-fit: cover;
    transition: transform 0.3s;
    width: 100%;
}

.copp-prog-card:hover .copp-prog-card__image img {
    transform: scale(1.04);
}

.copp-prog-card__placeholder {
    align-items: center;
    aspect-ratio: 16 / 10;
    color: rgba(255, 255, 255, 0.35);
    display: flex;
    justify-content: center;
    text-decoration: none;
}

.copp-prog-card__placeholder:hover {
    color: rgba(255, 255, 255, 0.55);
}

.copp-prog-card__placeholder i {
    font-size: 32px;
}

.copp-prog-card__body {
    padding: 14px 16px 16px;
}

.copp-prog-card__title {
    font-family: var(--copp-font-heading);
    font-size: var(--copp-fs-card-title);
    font-weight: var(--copp-fw-bold);
    line-height: var(--copp-lh-card-title);
    margin: 0 0 10px;
}

.copp-prog-card__title a {
    color: var(--copp-ink, var(--copp-ink));
    text-decoration: none;
    transition: color 0.15s;
}

.copp-prog-card__title a:hover {
    color: var(--copp-red);
}

.copp-prog-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 14px;
    margin-bottom: 10px;
}

.copp-prog-card__meta-item {
    align-items: center;
    color: #888;
    display: inline-flex;
    font-size: 0.72rem;
    gap: 4px;
}

.copp-prog-card__meta-item i {
    font-size: 0.68rem;
}

.copp-prog-card__badges {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.copp-prog-badge {
    border-radius: 0;
    font-size: var(--copp-fs-badge);
    font-weight: var(--copp-fw-bold);
    letter-spacing: var(--copp-ls-label);
    padding: 3px 8px;
    text-transform: uppercase;
}

.copp-prog-badge--free {
    background: #e8f5e9;
    color: #2e7d32;
}

.copp-prog-badge--open {
    background: #e3f2fd;
    color: #1565c0;
}

.copp-prog-badge--ovz {
    background: #fff3e0;
    color: #e65100;
}

.copp-programs-widget__empty {
    align-items: center;
    background: rgba(37, 37, 37, 0.03);
    border: 2px dashed rgba(37, 37, 37, 0.1);
    border-radius: 0;
    color: rgba(37, 37, 37, 0.35);
    display: flex;
    flex-direction: column;
    gap: 10px;
    justify-content: center;
    min-height: 160px;
    text-align: center;
}

.copp-programs-widget__empty i {
    color: var(--copp-red);
    font-size: 28px;
    opacity: 0.4;
}

.copp-programs-widget__empty p {
    font-size: 0.85rem;
    margin: 0;
}

@media (max-width: 1100px) {
    .copp-programs-widget__grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
    .copp-programs-widget__grid { grid-template-columns: repeat(2, 1fr); }
    .copp-programs-widget__filters { gap: 6px; }
    .copp-programs-widget__filter { font-size: 0.72rem; padding: 6px 12px; }
}

@media (max-width: 480px) {
    .copp-programs-widget__grid { grid-template-columns: 1fr; }
    .copp-programs-widget__head { flex-direction: column; align-items: flex-start; gap: 12px; }
}

.copp-partners {
    background: var(--copp-ink);
    color: #ffffff;
    padding: 34px 0 30px;
}

.copp-partners__shell,
.copp-profile-cta__shell {
    margin: 0 auto;
    max-width: calc(var(--copp-container-xl) + 30px);
    padding-left: 15px;
    padding-right: 15px;
}

.copp-partners__head {
    align-items: center;
    display: flex;
    gap: 20px;
    justify-content: space-between;
    margin-bottom: 24px;
}

.copp-partners__title {
    color: #ffffff;
    font-size: 28px;
    font-weight: var(--copp-fw-heading-bold);
    letter-spacing: var(--copp-ls-section);
    line-height: 1.05;
    margin: 0 0 12px;
    text-transform: uppercase;
}

.copp-partners__accent {
    background: var(--copp-red);
    border-radius: 0;
    display: block;
    height: 4px;
    width: 54px;
}

.copp-partners__viewport {
    overflow: hidden;
}

.copp-partners__track {
    display: flex;
    gap: 18px;
    transition: transform 260ms ease;
}

.copp-partner {
    align-items: center;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 0;
    color: rgba(255, 255, 255, 0.9);
    display: flex;
    flex: 0 0 calc((100% - 90px) / 6);
    justify-content: center;
    max-width: calc((100% - 90px) / 6);
    min-height: 88px;
    min-width: 0;
    padding: 16px 20px;
    text-decoration: none;
    overflow: hidden;
}

.copp-partner:hover,
.copp-partner:focus {
    border-color: rgba(255, 255, 255, 0.2);
    color: #ffffff;
    text-decoration: none;
}

.copp-partner__name {
    font-size: 22px;
    font-weight: 900;
    letter-spacing: 0;
    line-height: 1;
    text-transform: uppercase;
    white-space: nowrap;
}

.copp-partner--has-logo {
    padding: 0;
}

.copp-partner__logo {
    display: block;
    height: 100%;
    max-width: none;
    object-fit: cover;
    width: 100%;
}

.copp-partners__nav {
    align-items: center;
    display: inline-flex;
    gap: 10px;
}

.copp-partners__prev,
.copp-partners__next {
    align-items: center;
    background: rgba(255, 255, 255, 0.12);
    border: 0;
    border-radius: 0;
    color: #ffffff;
    cursor: pointer;
    display: inline-flex;
    flex: 0 0 auto;
    height: 48px;
    justify-content: center;
    width: 48px;
}

.copp-partners__prev svg {
    transform: rotate(180deg);
}

.copp-partners__prev:hover,
.copp-partners__prev:focus,
.copp-partners__next:hover,
.copp-partners__next:focus {
    background: rgba(255, 255, 255, 0.2);
    outline: none;
}

.copp-partners__prev:disabled,
.copp-partners__next:disabled {
    cursor: default;
    opacity: 0.42;
}

.copp-partners__prev:disabled:hover,
.copp-partners__prev:disabled:focus,
.copp-partners__next:disabled:hover,
.copp-partners__next:disabled:focus {
    background: rgba(255, 255, 255, 0.12);
}

.copp-partners__prev[hidden],
.copp-partners__next[hidden] {
    display: none !important;
}

.copp-partners__prev svg,
.copp-partners__next svg {
    height: 20px;
    width: 20px;
}

.copp-profile-cta {
    background: var(--copp-red);
    overflow: hidden;
}

.copp-profile-cta__shell {
    align-items: center;
    display: grid;
    gap: 24px;
    grid-template-columns: minmax(0, 0.92fr) minmax(360px, 1fr);
    min-height: 246px;
    padding-top: 0;
    padding-bottom: 0;
}

.copp-profile-cta__copy {
    color: #ffffff;
    padding: 44px 0;
}

.copp-profile-cta__title {
    color: #ffffff;
    font-size: 32px;
    font-weight: 900;
    line-height: 1.08;
    margin: 0 0 18px;
    text-transform: uppercase;
}

.copp-profile-cta__lead {
    color: rgba(255, 255, 255, 0.92);
    font-size: 17px;
    line-height: 1.5;
    margin: 0 0 28px;
    max-width: 420px;
}

.copp-profile-cta__button {
    align-items: center;
    border: 2px solid rgba(255, 255, 255, 0.66);
    border-radius: 0;
    color: #ffffff;
    display: inline-flex;
    font-size: 17px;
    font-weight: 800;
    height: 52px;
    justify-content: center;
    min-width: 190px;
    padding: 0 24px;
    text-decoration: none;
}

.copp-profile-cta__button:hover,
.copp-profile-cta__button:focus {
    background: rgba(255, 255, 255, 0.08);
    color: #ffffff;
    text-decoration: none;
}

.copp-profile-cta__visual {
    align-self: stretch;
    position: relative;
}

.copp-profile-cta__art {
    height: 100%;
    min-height: 246px;
    position: relative;
}

.copp-profile-cta__tile {
    background: rgba(255, 255, 255, 0.18);
    pointer-events: none;
    position: absolute;
    transition: transform 260ms ease;
    will-change: transform;
    z-index: 1;
}

.copp-profile-cta__tile::after {
    background: rgba(37, 37, 37, 0.28);
    content: "";
    inset: 0;
    position: absolute;
}

.copp-profile-cta__tile--one {
    height: 54px;
    left: 96px;
    top: 54px;
    width: 54px;
}

.copp-profile-cta__tile--two {
    height: 68px;
    left: 154px;
    top: 32px;
    width: 68px;
}

.copp-profile-cta__tile--three {
    height: 44px;
    right: 132px;
    top: 66px;
    width: 44px;
}

.copp-profile-cta__tile--four {
    height: 52px;
    right: 68px;
    top: 94px;
    width: 52px;
}

.copp-profile-cta__icon {
    align-items: center;
    background: #ffffff;
    border-radius: 0;
    color: var(--copp-red);
    display: inline-flex;
    height: 46px;
    justify-content: center;
    pointer-events: none;
    position: absolute;
    z-index: 4;
    width: 46px;
}

.copp-profile-cta__icon svg {
    height: 20px;
    width: 20px;
}

.copp-profile-cta__icon--arrow {
    left: 280px;
    top: 28px;
}

.copp-profile-cta__icon--plus {
    right: 12px;
    top: 86px;
}

.copp-profile-cta__person {
    bottom: 0;
    display: block;
    height: 262px;
    object-fit: contain;
    object-position: bottom center;
    pointer-events: none;
    position: absolute;
    right: 86px;
    width: auto;
    z-index: 3;
}

.icms-footer__middle {
    background: var(--copp-ink);
    background-image: none;
    color: #ffffff;
}

.icms-footer__middle > .container {
    border-bottom: 0 !important;
}

.icms-footer__middle .row {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
    padding-top: 0 !important;
}

.icms-footer__middle [class*="col-"] {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    margin-bottom: 0 !important;
    padding-bottom: 24px;
    padding-top: 24px;
}

.icms-footer__middle [class*="col-"] > * {
    width: 100%;
}

.icms-footer__middle .icms-widget__transparent {
    height: 100%;
}

.icms-footer__middle .copp-footer-legal-slot {
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    flex: 0 0 100%;
    max-width: 100%;
    padding-bottom: 20px;
    padding-top: 28px;
}

.icms-footer__middle .copp-footer-legal-slot > * {
    width: 100%;
}

.icms-footer__middle .copp-footer-legal-slot .icms-widget__transparent {
    height: auto;
}

.icms-footer__bottom {
    background: var(--copp-ink);
    border-top: 0 !important;
    color: rgba(255, 255, 255, 0.72);
    display: block;
}

.icms-footer__bottom > .container {
    border-top: 0 !important;
    padding-bottom: 24px !important;
    padding-top: 0 !important;
}

.icms-footer__bottom .row {
    align-items: center;
    flex-direction: column;
    gap: 16px;
    justify-content: center;
    margin: 0;
}

.icms-footer__bottom [class*="col-"] {
    display: flex;
    flex: 0 0 100%;
    justify-content: center;
    margin: 0;
    max-width: 100%;
    padding: 0;
    width: 100%;
}

.icms-footer__bottom .icms-widget__transparent,
.icms-footer__bottom [class*="col-"] > * {
    width: 100%;
}

.copp-footer-brand {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.copp-footer-brand__logo {
    display: inline-flex;
    max-width: 220px;
}

.copp-footer-brand__logo img,
.copp-footer-brand__logo svg {
    display: block;
    width: 100%;
    height: auto;
}

.copp-footer-brand__copy {
    color: rgba(255, 255, 255, 0.72);
    font-size: 14px;
    font-weight: 600;
    line-height: 1.3;
}

.copp-footer-main {
    display: grid;
    gap: 20px;
    grid-template-columns: auto repeat(5, minmax(0, 1fr));
    align-items: start;
}

.copp-footer-brand-col {
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding-right: 8px;
    border-right: 1px solid rgba(255,255,255,0.08);
}

.copp-footer-column {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.copp-footer-column h3 {
    color: #ffffff;
    font-size: 15px;
    font-weight: 800;
    line-height: 1.1;
    margin: 0 0 4px;
    white-space: nowrap;
}

.copp-footer-column a {
    color: rgba(255, 255, 255, 0.82);
    font-size: 14px;
    font-weight: 600;
    line-height: 1.35;
    text-decoration: none;
}

.copp-footer-column a:hover,
.copp-footer-column a:focus {
    color: #ffffff;
    text-decoration: underline;
}

.copp-footer-social {
    display: grid;
    gap: 12px;
    margin-top: 10px;
}

.copp-footer-social--standalone {
    margin-top: 18px;
}

.icms-footer__bottom .copp-footer-social--standalone {
    margin-top: 0;
}

.copp-footer-contacts {
    display: grid;
    gap: 8px;
}

.copp-footer-contact {
    align-items: center;
    color: rgba(255, 255, 255, 0.88);
    display: grid;
    gap: 10px;
    grid-template-columns: 36px minmax(0, 1fr);
    text-decoration: none;
}

.copp-footer-column .copp-footer-contact:hover,
.copp-footer-column .copp-footer-contact:focus {
    color: #ffffff;
    text-decoration: none;
}

.copp-footer-contact__icon {
    align-items: center;
    background: #ffffff;
    border-radius: 50%;
    color: var(--copp-ink);
    display: inline-flex;
    height: 36px;
    justify-content: center;
    width: 36px;
}

.copp-footer-contact__icon img {
    display: block;
    max-height: 20px;
    max-width: 20px;
}

.copp-footer-contact__icon svg {
    display: block;
    height: 16px;
    width: 16px;
}

.copp-footer-contact__body {
    display: grid;
    gap: 1px;
    min-width: 0;
}

.copp-footer-contact__label {
    color: inherit;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.3;
}

.copp-footer-contact__meta {
    color: rgba(255, 255, 255, 0.62);
    font-size: 12px;
    font-weight: 600;
    line-height: 1.3;
}

.copp-footer-social__title {
    color: #ffffff;
    font-size: 15px;
    font-weight: 800;
    line-height: 1.3;
}

.copp-footer-social__items {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-start;
}

.copp-footer-social--titleless {
    gap: 0;
}

.copp-footer-social__item {
    align-items: center;
    background: transparent;
    border: 0;
    border-radius: 0;
    color: rgba(255, 255, 255, 0.78);
    display: inline-flex;
    font-size: 13px;
    font-weight: 900;
    height: auto;
    justify-content: center;
    line-height: 1;
    overflow: visible;
    padding: 2px;
    text-transform: uppercase;
    text-decoration: none;
    width: auto;
    transition: color 0.2s ease, opacity 0.2s ease, transform 0.2s ease;
}

.copp-footer-social__item,
.copp-footer-social__item:hover,
.copp-footer-social__item:focus,
.copp-footer-social__item:active,
.copp-footer-social__item:visited {
    text-decoration: none !important;
}

.copp-footer-column .copp-footer-social__item:hover,
.copp-footer-column .copp-footer-social__item:focus {
    color: #ffffff;
    text-decoration: none;
    transform: translateY(-1px);
}

.copp-footer-social__item img {
    display: block;
    max-height: 32px;
    max-width: 32px;
}

.copp-footer-social__brand-mask {
    display: block;
    flex: 0 0 auto;
}

.copp-footer-social__item i,
.copp-footer-social__item svg {
    display: block;
    font-size: 26px;
    line-height: 1;
    width: 1em;
    height: 1em;
}

.copp-footer-social__item--max i {
    font-size: 22px;
}

.copp-footer-social__item--max {
    color: transparent;
}

.copp-footer-social__max-icon {
    display: block;
    width: 28px;
    height: 28px;
    background: linear-gradient(135deg, #40c4ff 0%, #3f5fff 45%, #9737ff 100%);
    -webkit-mask-image: url("/templates/modern/images/max-brand-icon.png");
    -webkit-mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-image: url("/templates/modern/images/max-brand-icon.png");
    mask-size: contain;
    mask-repeat: no-repeat;
    mask-position: center;
    transition: opacity 0.2s;
}

.copp-footer-social__item--max:hover .copp-footer-social__max-icon,
.copp-footer-social__item--max:focus .copp-footer-social__max-icon {
    opacity: 0.85;
}

.copp-footer-social__item--vk svg,
.copp-footer-social__item--telegram svg {
    width: 30px;
    height: 30px;
}

.copp-footer-social__item--max svg {
    width: 28px;
    height: 28px;
}

.copp-footer-social__item--max {
    color: transparent;
}

.copp-footer-social__item--max svg path {
    fill: url(#copp-max-gradient);
}

.copp-footer-social__item--max:hover,
.copp-footer-social__item--max:focus {
    color: transparent;
}

.copp-footer-social__wordmark {
    display: block;
    font-size: 13px;
    font-weight: 900;
    letter-spacing: 0.08em;
    line-height: 1;
}

.copp-footer-social__wordmark--compact {
    font-size: 10px;
}

.copp-footer-social__item--vk {
    color: #0077ff;
}

.copp-footer-social__item--telegram {
    color: #229ed9;
}

.copp-footer-social__item--youtube {
    color: var(--copp-red);
}

.copp-footer-social__item--ok {
    color: #f58220;
}

.copp-footer-social__item--whatsapp {
    color: #25d366;
}

.copp-footer-social__item--vk:hover,
.copp-footer-social__item--vk:focus {
    color: #3f92ff;
}

.copp-footer-social__item--telegram:hover,
.copp-footer-social__item--telegram:focus {
    color: #4fb5e6;
}

.copp-footer-social__item--youtube:hover,
.copp-footer-social__item--youtube:focus {
    color: var(--copp-red);
}

.copp-footer-social__item--ok:hover,
.copp-footer-social__item--ok:focus {
    color: #ff9a3d;
}

.copp-footer-social__item--whatsapp:hover,
.copp-footer-social__item--whatsapp:focus {
    color: #4ce083;
}

.copp-footer-social__item--dzen:hover,
.copp-footer-social__item--dzen:focus {
    color: #ffffff;
}

.copp-footer-social__item--site:hover,
.copp-footer-social__item--site:focus,
.copp-footer-social__item--email:hover,
.copp-footer-social__item--email:focus,
.copp-footer-social__item--custom:hover,
.copp-footer-social__item--custom:focus {
    color: var(--copp-red);
}

.copp-footer-social__item--max:hover,
.copp-footer-social__item--max:focus {
    color: #ffffff;
}

.copp-footer-social__item--max:hover .copp-footer-social__brand-mask--max,
.copp-footer-social__item--max:focus .copp-footer-social__brand-mask--max {
    background: linear-gradient(135deg, #5ed0ff 0%, #5b7bff 45%, #a95bff 100%);
}

.icms-footer__bottom .copp-footer-social {
    justify-items: center;
    text-align: center;
}

.icms-footer__bottom .copp-footer-social__items {
    gap: 12px;
    justify-content: center;
}

.icms-footer__bottom .copp-footer-social__item {
    color: #ffffff;
    transition: color 0.2s ease, opacity 0.2s ease, transform 0.2s ease;
}

.icms-footer__bottom .copp-footer-social__item--vk {
    color: #0077ff;
}

.icms-footer__bottom .copp-footer-social__item--telegram {
    color: #229ed9;
}

.icms-footer__bottom .copp-footer-social__item--youtube {
    color: var(--copp-red);
}

.icms-footer__bottom .copp-footer-social__item--ok {
    color: #f58220;
}

.icms-footer__bottom .copp-footer-social__item--whatsapp {
    color: #25d366;
}

.icms-footer__bottom .copp-footer-social__item:hover,
.icms-footer__bottom .copp-footer-social__item:focus {
    color: #ffffff;
    text-decoration: none;
    transform: translateY(-1px);
}

.icms-footer__bottom .copp-footer-social__item--max:hover,
.icms-footer__bottom .copp-footer-social__item--max:focus {
    color: #ffffff;
}

.icms-footer__bottom .copp-footer-social__item--max:hover .copp-footer-social__brand-mask--max,
.icms-footer__bottom .copp-footer-social__item--max:focus .copp-footer-social__brand-mask--max {
    background: linear-gradient(135deg, #5ed0ff 0%, #5b7bff 45%, #a95bff 100%);
}

.icms-footer__bottom .copp-footer-social__item--vk:hover,
.icms-footer__bottom .copp-footer-social__item--vk:focus {
    color: #3f92ff;
}

.icms-footer__bottom .copp-footer-social__item--telegram:hover,
.icms-footer__bottom .copp-footer-social__item--telegram:focus {
    color: #4fb5e6;
}

.icms-footer__bottom .copp-footer-social__item--youtube:hover,
.icms-footer__bottom .copp-footer-social__item--youtube:focus {
    color: var(--copp-red);
}

.icms-footer__bottom .copp-footer-social__item--ok:hover,
.icms-footer__bottom .copp-footer-social__item--ok:focus {
    color: #ff9a3d;
}

.icms-footer__bottom .copp-footer-social__item--whatsapp:hover,
.icms-footer__bottom .copp-footer-social__item--whatsapp:focus {
    color: #4ce083;
}

.icms-footer__bottom .copp-footer-social__item--dzen:hover,
.icms-footer__bottom .copp-footer-social__item--dzen:focus {
    color: #ffffff;
}

.icms-footer__bottom .copp-footer-social__item--site:hover,
.icms-footer__bottom .copp-footer-social__item--site:focus,
.icms-footer__bottom .copp-footer-social__item--email:hover,
.icms-footer__bottom .copp-footer-social__item--email:focus,
.icms-footer__bottom .copp-footer-social__item--custom:hover,
.icms-footer__bottom .copp-footer-social__item--custom:focus {
    color: var(--copp-red);
}

.copp-footer-legal {
    align-items: center;
    color: rgba(255, 255, 255, 0.72);
    display: flex;
    flex-wrap: wrap;
    gap: 14px 28px;
    justify-content: space-between;
    line-height: 1.4;
    text-align: left;
    width: 100%;
}

.copp-footer-legal__group {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px 24px;
    min-width: 0;
}

.copp-footer-legal__group--right {
    justify-content: flex-end;
    margin-left: auto;
    text-align: right;
}

.copp-footer-legal__age-rating {
    display: inline-flex;
    align-items: center;
    margin-left: 12px;
}

.copp-footer-legal__age-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border: 2px solid currentColor;
    font-size: 13px;
    font-weight: 800;
    line-height: 1;
    text-align: center;
}

.copp-footer-legal__item,
.copp-footer-legal__link {
    color: inherit;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
}

.copp-footer-legal__link:hover,
.copp-footer-legal__link:focus {
    color: #ffffff;
    text-decoration: underline;
}

@media (max-width: 1199.98px) {
    .copp-partner {
        flex-basis: calc((100% - 36px) / 3);
        max-width: calc((100% - 36px) / 3);
    }

    .copp-profile-cta__shell {
        grid-template-columns: minmax(0, 0.9fr) minmax(300px, 0.95fr);
    }

    .copp-profile-cta__person {
        height: 250px;
        right: 46px;
    }
}

@media (max-width: 991.98px) {
    .copp-partner {
        flex-basis: calc((100% - 36px) / 3);
        max-width: calc((100% - 36px) / 3);
    }

    .copp-profile-cta__shell {
        gap: 0;
        grid-template-columns: 1fr;
    }

    .copp-profile-cta__copy {
        padding-bottom: 20px;
    }

    .copp-profile-cta__visual {
        min-height: 210px;
    }

    .copp-profile-cta__person {
        height: 236px;
        right: 22px;
    }

    .copp-footer-main {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    body:not(.icms-frontpage) .copp-breadcrumbs {
        margin-bottom: 10px;
    }

    body:not(.icms-frontpage) .copp-breadcrumbs__list {
        gap: 0;
    }



    body:not(.icms-frontpage) .copp-breadcrumbs__link,
    body:not(.icms-frontpage) .copp-breadcrumbs__current {
        font-size: 11px;
    }

    body:not(.icms-frontpage) .copp-breadcrumbs__link {
        padding: 4px 10px;
    }

    body:not(.icms-frontpage) .copp-breadcrumbs__link--home {
        padding: 4px 7px;
    }

    .copp-partners {
        padding-bottom: 26px;
        padding-top: 28px;
    }

    .copp-partners__title,
    .copp-profile-cta__title {
        font-size: 26px;
    }

    .copp-partner__name {
        font-size: 18px;
    }

    .copp-profile-cta__copy {
        padding-top: 34px;
    }

    .copp-profile-cta__lead {
        font-size: 16px;
    }

    .icms-footer__middle [class*="col-"] {
        padding-bottom: 22px;
        padding-top: 22px;
    }

    .icms-footer__middle .copp-footer-legal-slot {
        padding-bottom: 8px;
        padding-top: 18px;
    }

    .icms-footer__bottom > .container {
        padding-bottom: 20px !important;
    }
}

@media (max-width: 575.98px) {
    .copp-partner {
        flex-basis: calc((100% - 18px) / 2);
        max-width: calc((100% - 18px) / 2);
    }

    .copp-partners__head {
        margin-bottom: 18px;
    }

    .copp-partners__title,
    .copp-profile-cta__title {
        font-size: 22px;
    }

    .copp-profile-cta__button {
        min-width: 100%;
    }

    .copp-profile-cta__person {
        height: 220px;
        right: 6px;
    }

    .copp-profile-cta__icon--arrow {
        left: auto;
        right: 96px;
    }

    .copp-footer-social__items {
        flex-wrap: wrap;
    }

    .copp-footer-legal {
        gap: 10px 14px;
    }

    .copp-footer-legal__group {
        gap: 6px 14px;
    }

    .copp-footer-legal__item,
    .copp-footer-legal__link {
        font-size: 13px;
    }
}

@media (max-width: 767.98px) {
    .copp-footer-legal {
        justify-content: center;
        text-align: center;
    }

    .copp-footer-legal__group {
        justify-content: center;
        width: 100%;
    }

    .copp-footer-legal__group--right {
        margin-left: 0;
        text-align: center;
    }
}

@media (max-width: 1360px) and (min-width: 992px) {
    .icms-header__middle > .container {
        gap: 14px;
    }

    .icms-header__middle .navbar-brand {
        margin-right: 18px !important;
    }

    .icms-header__middle .navbar-brand img.d-none {
        width: 170px;
    }

    .icms-header__middle .menu-main {
        gap: 12px;
    }

    .icms-header__middle .menu-main .nav-link {
        font-size: 12.5px;
    }

    .icms-header__middle .form-inline {
        margin-left: 10px !important;
    }

    .icms-header__middle .icms-user-menu {
        margin-left: 0;
        max-width: none;
    }

    .icms-header__middle .icms-user-menu__nickname {
        display: none !important;
    }

    .icms-header__middle .icms-user-menu__nickname span {
        display: none !important;
    }

    .icms-header__middle .icms-user-menu__summary {
        gap: 0;
        justify-content: center;
        padding-left: 10px !important;
        padding-right: 10px !important;
        width: 54px;
    }
}

@media (max-width: 1199.98px) {
    :root {
        --copp-search-offset: 96px;
    }

    .icms-header__middle > .container {
        min-height: 96px;
    }

    .icms-header__middle .navbar-brand {
        margin-right: 16px !important;
    }

    .icms-header__middle .navbar-brand img.d-none {
        width: 170px;
    }

    .icms-header__middle .menu-main {
        gap: 12px;
    }

    .copp-search-panel__filters {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .copp-hero__inner {
        grid-template-columns: minmax(380px, 0.9fr) minmax(390px, 1fr);
        padding-left: 76px;
        padding-right: 76px;
    }

    .copp-hero__copy h1 {
        font-size: 46px;
    }

    .copp-hero__copy p {
        font-size: 18px;
    }

    .copp-hero__people {
        right: -12px;
        transform: translateY(56px);
        width: min(104%, 612px);
    }

    .copp-person--left {
        left: 138px;
    }

    .copp-person--right {
        right: 82px;
    }

    .copp-hero__dots {
        left: 76px;
        margin-left: 0;
    }

    .copp-overview__layout {
        grid-template-columns: minmax(240px, 0.9fr) minmax(0, 2.1fr);
    }

    .copp-pathfinder__shell {
        grid-template-columns: minmax(280px, 0.8fr) minmax(0, 1.2fr);
    }

    .copp-pathfinder__intro {
        padding: 36px 32px 30px;
    }

    .copp-pathfinder__quiz {
        padding: 28px 30px 32px;
    }

    .copp-pathfinder__question {
        font-size: 25px;
    }

    .copp-pathfinder__choices {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .copp-showcase__title {
        font-size: 26px;
    }

    .copp-program-card {
        flex-basis: calc((100% - 32px) / 3);
        max-width: calc((100% - 32px) / 3);
    }

    .copp-events {
        grid-auto-columns: minmax(0, 100%);
    }

    .copp-stat-card {
        min-height: 228px;
        padding-left: 18px;
        padding-right: 18px;
    }

    .copp-overview__stats .copp-stat-card {
        min-height: 188px;
        padding: 18px 16px 16px;
    }

    .copp-stat-card__value {
        font-size: 31px;
    }

    .copp-overview__stats .copp-stat-card__value {
        font-size: 28px;
    }

    .icms-header__middle .icms-user-menu {
        max-width: 212px;
    }

    .icms-header__middle .icms-user-menu__nickname span {
        max-width: 126px;
    }
}

@media (max-width: 991.98px) {
    :root {
        --copp-search-offset: 88px;
    }

    .icms-header__middle > .container {
        align-items: flex-start !important;
        flex-wrap: wrap !important;
        min-height: 0;
        padding-bottom: 16px;
        padding-top: 16px;
    }

    .icms-header__middle .navbar-brand {
        margin-right: 0 !important;
    }

    .icms-header__middle .ml-auto.d-flex {
        flex: 0 0 100%;
        flex-wrap: wrap;
        justify-content: space-between;
        margin-left: 0 !important;
        row-gap: 10px;
    }

    .icms-header__middle .navbar-expand-lg {
        flex: 1 1 auto;
        order: 1;
    }

    .icms-header__middle .navbar-toggler {
        border-color: var(--copp-line);
        margin-left: auto;
    }

    .icms-header__middle .navbar-collapse {
        background: #ffffff;
        flex-basis: 100%;
        padding-top: 14px;
    }

    .icms-header__middle .menu-main {
        align-items: flex-start;
        gap: 0;
    }

    .icms-header__middle .menu-main .nav-link {
        padding: 10px 0 !important;
    }

    .icms-header__middle .form-inline {
        margin-left: 0 !important;
        margin-top: 8px !important;
    }

    .icms-header__middle .copp-search-panel__backdrop {
        inset: 0;
    }

    .icms-header__middle .copp-search-panel {
        bottom: 0;
        overflow-y: auto;
        position: fixed;
        top: var(--copp-search-offset);
        transform: translateY(-8px);
    }

    .copp-search-panel > .container {
        max-width: none;
        padding-left: 0;
        padding-right: 0;
    }

    .copp-search-panel__inner {
        border-radius: 0;
        min-height: calc(100vh - var(--copp-search-offset));
        padding: 24px 18px 28px;
    }

    .copp-search-panel__query-row {
        grid-template-columns: 1fr;
    }

    .copp-search-panel__actions {
        justify-content: space-between;
    }

    .icms-header__middle .navbar:not(.navbar-expand-lg) {
        order: 2;
    }

    .icms-header__middle .icms-user-menu {
        margin-left: auto;
        max-width: none;
    }

    .copp-hero__inner {
        grid-template-columns: 1fr;
        min-height: 0;
        padding: 44px 60px 72px;
    }

    .copp-hero__copy h1 {
        font-size: 42px;
    }

    .copp-hero__copy {
        display: block;
        min-height: 0;
        padding-bottom: 0;
    }

    .copp-hero__visual {
        min-height: 270px;
    }

    .copp-visual {
        margin: 0 auto;
        max-width: 560px;
        min-height: 270px;
    }

    .copp-hero__people {
        bottom: -72px;
        height: calc(100% + 72px);
        right: -4px;
        transform: translateY(78px);
        width: min(100%, 516px);
    }

    .copp-person {
        transform: scale(0.78);
        transform-origin: bottom center;
    }

    .copp-person--left {
        left: 185px;
    }

    .copp-person--right {
        right: 88px;
    }

    .copp-hero__arrow {
        height: 46px;
        width: 46px;
    }

    .copp-hero__arrow--prev {
        left: 18px;
    }

    .copp-hero__arrow--next {
        right: 18px;
    }

    .copp-hero__dots {
        bottom: 30px;
        left: 60px;
    }

    .copp-overview {
        padding-top: 34px;
    }

    .copp-overview__layout {
        grid-template-columns: 1fr;
        gap: 22px;
    }

    .copp-overview__intro {
        padding: 0;
    }

    .copp-overview__text-slider {
        max-width: 100%;
    }

    .copp-overview__stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .copp-overview__popular-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .copp-pathfinder__shell {
        grid-template-columns: 1fr;
    }

    .copp-pathfinder__intro {
        gap: 28px;
        padding: 34px 30px 30px;
    }

    .copp-pathfinder__lead {
        max-width: 100%;
    }

    .copp-pathfinder__social {
        gap: 16px;
    }

    .copp-pathfinder__quiz {
        gap: 22px;
        padding: 28px 30px 30px;
    }

    .copp-pathfinder__question {
        font-size: 24px;
    }

    .copp-pathfinder__choice {
        min-height: 116px;
    }

    .copp-showcase {
        padding-top: 28px;
    }

    .copp-showcase__head {
        align-items: flex-start;
        flex-direction: column;
    }

    .copp-program-card {
        flex-basis: calc((100% - 16px) / 2);
        max-width: calc((100% - 16px) / 2);
    }
}

@media (max-width: 767.98px) {
    :root {
        --copp-search-offset: 76px;
    }

    .icms-cookiealert {
        bottom: 12px;
        padding-left: 12px;
        padding-right: 12px;
        transform: translateY(calc(100% + 12px));
    }

    .icms-cookiealert__inner {
        align-items: stretch;
        flex-direction: column;
        gap: 14px;
        padding: 16px;
    }

    .icms-cookiealert__text {
        font-size: 14px;
        line-height: 1.5;
    }

    .icms-cookiealert__button {
        width: 100%;
    }

    .copp-search-panel__head {
        align-items: flex-start;
    }

    .copp-search-panel__heading h2 {
        font-size: 24px;
    }

    .copp-search-panel__filters {
        grid-template-columns: 1fr;
    }

    .copp-search-panel__actions {
        flex-direction: column-reverse;
        width: 100%;
    }

    .copp-search-panel__submit {
        min-width: 100%;
    }

    .icms-header__middle > .container {
        gap: 12px;
    }

    .icms-header__middle .navbar-brand img.d-none {
        display: none !important;
    }

    .icms-header__middle .navbar-brand img.d-sm-none {
        display: block !important;
        height: 48px;
        width: auto;
    }

    .icms-header__middle .ml-auto.d-flex {
        align-items: center !important;
        justify-content: flex-end;
    }

    .icms-header__middle .navbar-expand-lg {
        flex: 0 1 auto;
        justify-content: flex-end;
    }

    .icms-header__middle .navbar-toggler {
        padding: 0.25rem 0.7rem;
    }

    .icms-header__middle .menu-header {
        gap: 6px;
    }

    .icms-header__middle .icms-user-menu__nickname span {
        display: none !important;
    }

    .icms-header__middle .icms-user-menu__summary {
        padding-left: 8px !important;
        padding-right: 8px !important;
    }

    .icms-header__middle .menu-header .nav-link {
        height: 36px;
        min-width: 0;
        padding: 0 10px !important;
        font-size: 12px;
    }

    .icms-header__middle #menu-item-id-header-35 {
        min-width: 0;
    }

    .icms-header__middle .menu-main .nav-item .nav-item-text {
        font-size: 12px;
    }

    .copp-hero {
        min-height: 0;
    }

    .copp-hero__inner {
        padding: 36px 24px 76px;
    }

    .copp-hero__copy h1 {
        font-size: 34px;
        line-height: 1.12;
        margin-bottom: 24px;
    }

    .copp-hero__copy {
        display: block;
        min-height: 0;
        padding-bottom: 0;
    }

    .copp-hero__copy p {
        font-size: 17px;
        margin-bottom: 26px;
    }

    .copp-hero__actions {
        gap: 12px;
        grid-template-columns: 1fr;
        max-width: none;
    }

    .copp-hero__btn {
        width: 100%;
    }

    .copp-hero__visual {
        display: none;
    }

    .copp-hero__arrow {
        display: none;
    }

    .copp-hero__dots {
        bottom: 30px;
        left: 24px;
    }

    .copp-overview {
        padding: 28px 0 12px;
    }

    .copp-overview__title {
        font-size: 24px;
        margin-bottom: 26px;
    }

    .copp-overview__tabs {
        margin-bottom: 20px;
    }

    .copp-overview__text {
        font-size: 15px;
        margin-bottom: 22px;
    }

    .copp-overview__link {
        max-width: 100%;
        width: 100%;
    }

    .copp-overview__stats {
        grid-template-columns: 1fr;
    }

    .copp-overview__popular-grid {
        grid-template-columns: 1fr;
    }

    .copp-overview__popular-meta {
        align-items: flex-start;
        flex-direction: column;
    }

    .copp-overview__popular-reason {
        flex: 0 1 auto;
    }

    .copp-stat-card {
        min-height: 0;
        padding: 22px 18px;
    }

    .copp-overview__stats .copp-stat-card {
        padding: 18px 16px;
    }

    .copp-stat-card__icon {
        margin-bottom: 22px;
    }

    .copp-overview__stats .copp-stat-card__icon {
        margin-bottom: 16px;
    }

    .copp-stat-card__value {
        font-size: 30px;
        margin-bottom: 12px;
    }

    .copp-overview__stats .copp-stat-card__value {
        font-size: 27px;
        margin-bottom: 10px;
    }

    .copp-pathfinder__intro {
        padding: 28px 22px 24px;
    }

    .copp-pathfinder__title {
        font-size: 24px;
    }

    .copp-pathfinder__lead {
        font-size: 16px;
    }

    .copp-pathfinder__start {
        align-self: stretch;
        justify-content: space-between;
        width: 100%;
    }

    .copp-pathfinder__social-row {
        align-items: flex-start;
        flex-direction: column;
    }

    .copp-pathfinder__quiz {
        padding: 24px 22px;
    }

    .copp-pathfinder__progress-top {
        align-items: flex-start;
        flex-direction: column;
    }

    .copp-pathfinder__question {
        font-size: 22px;
    }

    .copp-pathfinder__choices {
        grid-template-columns: 1fr;
    }

    .copp-pathfinder__actions {
        flex-direction: column-reverse;
        gap: 12px;
    }

    .copp-pathfinder__nav {
        width: 100%;
    }

    .copp-showcase {
        padding: 24px 0 34px;
    }

    .copp-showcase__title {
        font-size: 24px;
    }

    .copp-showcase__link {
        font-size: 16px;
    }

    .copp-program-card {
        flex-basis: 88%;
        max-width: 88%;
    }

    .copp-programs__prev,
    .copp-programs__next {
        height: 46px;
        width: 46px;
    }

    .copp-program-card {
        min-height: 160px;
        padding: 20px 20px 16px;
    }

    .copp-events {
        grid-auto-columns: minmax(0, 100%);
    }

    .copp-event-card {
        gap: 14px;
        padding: 18px;
    }

    .copp-event-card__head {
        gap: 14px;
        grid-template-columns: 62px minmax(0, 1fr);
    }

    .copp-event-card__title {
        font-size: 17px;
    }
}

/* News page */
.copp-section-accent {
    display: inline-flex;
    align-items: stretch;
    gap: 0;
    margin-top: 12px;
    width: 102px;
    height: 3px;
    overflow: hidden;
    border-radius: 0;
}

.copp-section-accent span {
    display: block;
    width: 34px;
    height: 100%;
    flex: 0 0 34px;
    border-radius: 0;
    background: var(--copp-red);
}

.copp-section-accent span.is-active {
    background: var(--copp-red);
}

.copp-news-hero {
    --copp-hero-container-max: 1140px;
    --copp-hero-container-gutter: 15px;
    position: relative;
    overflow: visible;
    background: var(--copp-soft);
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding: 28px max(var(--copp-hero-container-gutter), calc((100vw - var(--copp-hero-container-max)) / 2 + var(--copp-hero-container-gutter))) 34px;
}

.copp-news-hero::after {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 1px;
    background: rgba(34, 34, 34, 0.08);
}

.copp-news-hero__inner {
    display: grid;
    grid-template-columns: minmax(0, 420px) minmax(0, 1fr);
    align-items: center;
    gap: 42px;
    min-height: 412px;
    overflow: visible;
}

.copp-news-breadcrumbs {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 24px;
    color: #686868;
    font-size: 14px;
    line-height: 1.4;
}

.copp-news-breadcrumbs a {
    color: #4a4a4a;
    text-decoration: none;
}

.copp-news-breadcrumbs a:hover {
    color: var(--copp-red);
}

.copp-news-hero__title {
    margin: 0;
    color: var(--copp-ink);
    font-size: clamp(48px, 5vw, 74px);
    font-weight: 800;
    line-height: var(--copp-lh-hero);
    letter-spacing: 0;
    text-transform: uppercase;
}

.copp-news-hero__lead {
    max-width: 380px;
    margin: 24px 0 0;
    color: #383838;
    font-size: 21px;
    line-height: 1.55;
}

.copp-news-hero__actions {
    margin-top: 30px;
}

.copp-news-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    min-height: 52px;
    padding: 12px 24px;
    border: 1px solid var(--copp-red);
    border-radius: 0;
    font-size: 16px;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;
    transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.copp-news-btn:hover {
    transform: translateY(-1px);
    text-decoration: none;
}

.copp-news-btn--primary {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-news-btn--primary:hover {
    background: var(--copp-red);
    border-color: var(--copp-red);
    color: #ffffff;
}

.copp-news-btn--outline {
    background: transparent;
    color: var(--copp-red);
}

.copp-news-btn--outline:hover {
    background: rgba(239, 43, 45, 0.08);
    color: var(--copp-red);
}

.copp-news-btn--outline-light {
    background: transparent;
    border-color: rgba(255,255,255,0.4);
    color: #ffffff;
}

.copp-news-btn--outline-light:hover {
    background: rgba(255,255,255,0.08);
    border-color: rgba(255,255,255,0.7);
    color: #ffffff;
}

.copp-news-btn--light {
    background: #ffffff;
    border-color: #ffffff;
    color: var(--copp-red);
}

.copp-news-btn--light:hover {
    background: #f7f7f7;
    border-color: #f7f7f7;
    color: var(--copp-red);
}

.copp-news-btn--wide {
    width: 100%;
}

.copp-news-hero__media {
    overflow: visible;
    position: relative;
    min-height: 372px;
}

.copp-news-hero__media img {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 372px;
    object-fit: cover;
    object-position: center;
    position: relative;
    z-index: 1;
}

.copp-news-hero__tile {
    background: var(--tile-color, rgba(242, 242, 242, 0.92));
    display: block;
    height: var(--tile-size, 20px);
    left: var(--tile-left, auto);
    top: var(--tile-top, auto);
    position: absolute;
    right: var(--tile-right, auto);
    bottom: var(--tile-bottom, auto);
    transform: translate3d(0, 0, 0);
    transform-style: preserve-3d;
    transition: transform 220ms ease-out;
    will-change: transform;
    width: var(--tile-size, 20px);
    z-index: var(--tile-z, 3);
}

.copp-news-hero__badge {
    position: absolute;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    border-radius: 0;
    background: var(--copp-red);
    color: #ffffff;
    box-shadow: 0 18px 30px rgba(31, 31, 31, 0.18);
    transform: translate3d(0, 0, 0);
    transform-style: preserve-3d;
    transition: transform 220ms ease-out;
    will-change: transform;
    z-index: var(--badge-z, 8);
    --parallax-depth: var(--badge-depth, 1.08);
}

.copp-news-hero__badge svg {
    width: 24px;
    height: 24px;
}

.copp-news-hero__badge--top {
    top: 18px;
    right: 24px;
    --badge-z: 8;
    --badge-depth: 1.02;
}

.copp-news-hero__badge--left {
    top: 112px;
    left: -16px;
    background: var(--copp-ink);
    --badge-z: 5;
    --badge-depth: 0.66;
}

.copp-news-hero__badge--right {
    right: -12px;
    top: 200px;
    background: var(--copp-ink);
    --badge-z: 7;
    --badge-depth: 0.9;
}

.copp-news-hero__badge--bottom {
    right: 38px;
    bottom: 24px;
    --badge-z: 9;
    --badge-depth: 1.16;
}

.copp-about-hero {
    padding-bottom: 26px;
}

.copp-about-hero .copp-news-hero__inner {
    grid-template-columns: minmax(0, 470px) minmax(0, 1fr);
    gap: 34px;
    min-height: 454px;
}

.copp-about-hero .copp-news-hero__title {
    font-size: clamp(58px, 5vw, 82px);
    line-height: var(--copp-lh-hero);
}

.copp-about-hero__subtitle {
    margin: 22px 0 0;
    color: var(--copp-ink);
    font-size: clamp(23px, 2.1vw, 31px);
    font-weight: 800;
    line-height: 1.18;
    text-transform: uppercase;
}

.copp-about-hero .copp-news-hero__lead {
    max-width: 440px;
    margin-top: 28px;
    font-size: 18px;
    line-height: 1.66;
}

.copp-about-hero .copp-news-hero__media {
    min-height: 412px;
}

.copp-about-hero .copp-news-hero__media img {
    min-height: 412px;
}

.copp-about-hero__badge-arrow svg {
    transform: rotate(-45deg);
}

.copp-about-page-content {
    margin-top: 30px;
    margin-bottom: 0 !important;
    padding-bottom: 60px;
}

.copp-partners-page-content {
    margin-top: 30px;
    margin-bottom: 0 !important;
    padding-bottom: 0;
}

.copp-partners-content {
    display: grid;
    gap: 40px;
}

.copp-partners-hero .copp-news-hero__inner {
    gap: 42px;
    grid-template-columns: minmax(0, 430px) minmax(0, 1fr);
    min-height: 408px;
}

.copp-partners-hero .copp-news-hero__copy {
    min-width: 0;
    position: relative;
    z-index: 2;
}

.copp-partners-hero .copp-news-hero__title {
    margin-bottom: 24px;
    max-width: 430px;
    font-size: clamp(46px, 4.8vw, 72px);
    line-height: var(--copp-lh-hero);
}

.copp-partners-hero__subtitle {
    margin: 0 0 18px;
    color: var(--copp-ink);
    font-size: 28px;
    font-weight: 800;
    line-height: 1.28;
    max-width: 420px;
}

.copp-partners-hero .copp-news-hero__lead {
    max-width: 410px;
}

.copp-partners-hero__media {
    min-height: 384px;
}

.copp-partners-hero__media img {
    min-height: 384px;
    object-fit: cover;
    object-position: center;
}

.copp-partners-hero__badge--left {
    background: var(--copp-ink);
    color: #ffffff;
    left: 12px;
    top: 118px;
}

.copp-partners-hero__badge--top {
    right: 46px;
    top: 18px;
}

.copp-partners-hero__badge--right {
    background: var(--copp-ink);
    color: #ffffff;
    right: 10px;
    top: 192px;
}

.copp-partners-hero__badge--bottom {
    bottom: 20px;
    right: 40px;
}

.copp-partners-help-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.copp-partners-offers {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.copp-partners-offer {
    display: grid;
    gap: 14px;
    align-content: start;
}

.copp-partners-offer__icon {
    width: 42px;
    height: 42px;
    justify-content: flex-start;
    color: var(--copp-ink);
}

.copp-partners-offer__icon i {
    font-size: 26px;
    line-height: 1;
}

.copp-partners-offer__copy {
    display: grid;
    gap: 8px;
}

.copp-partners-offer__copy h3 {
    margin: 0;
    color: var(--copp-ink);
    font-size: 18px;
    font-weight: 800;
    line-height: 1.3;
}

.copp-partners-offer__copy p {
    margin: 0;
    color: #6d6d6d;
    font-size: 14px;
    line-height: 1.55;
}

.copp-partners-process {
    margin-top: 6px;
}

.copp-partners-process__step {
    min-height: 188px;
}

.copp-partners-process__index {
    opacity: 0.14;
}

.copp-partners-page-widget {
    display: grid;
}

.copp-partners-page-widget .copp-partners {
    margin: 0;
    width: 100%;
    background: transparent;
    color: var(--copp-ink);
    padding: 0;
}

.copp-partners-page-widget .copp-partners__shell {
    max-width: none;
    padding-left: 0;
    padding-right: 0;
}

.copp-partners-page-widget .copp-partners__head {
    margin-bottom: 20px;
}

.copp-partners-page-widget .copp-partners__title {
    color: var(--copp-ink);
}

.copp-partners-page-widget .copp-partners__next {
    background: #2c2c2c;
}

.copp-partners-page-widget .copp-partner {
    background: #ffffff;
    border-color: rgba(37, 37, 37, 0.1);
    color: #7b7b7b;
}

.copp-partners-page-widget .copp-partner:hover,
.copp-partners-page-widget .copp-partner:focus {
    border-color: rgba(37, 37, 37, 0.18);
    color: var(--copp-ink);
}

.copp-partners-cta {
    position: relative;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    background: linear-gradient(90deg, var(--copp-red) 0%, var(--copp-red) 45%, var(--copp-red) 100%);
    overflow: hidden;
}

.copp-partners-cta__inner {
    width: min(100%, var(--copp-container-content));
    margin: 0 auto;
    min-height: 260px;
    padding: 0 15px;
    display: grid;
    gap: 28px;
    grid-template-columns: minmax(0, 390px) minmax(320px, 1fr);
    align-items: center;
}

.copp-partners-cta__copy {
    display: grid;
    gap: 18px;
    color: #ffffff;
    align-content: center;
    padding: 34px 0;
    position: relative;
    z-index: 2;
}

.copp-partners-cta__copy h2 {
    margin: 0;
    max-width: 360px;
    font-size: clamp(30px, 3vw, 44px);
    font-weight: 900;
    line-height: 1.02;
}

.copp-partners-cta__copy p {
    margin: 0;
    max-width: 320px;
    font-size: 17px;
    line-height: 1.6;
}

.copp-partners-cta__visual {
    position: relative;
    min-height: 260px;
    overflow: visible;
}

.copp-partners-cta__visual > img {
    position: absolute;
    right: 42px;
    bottom: 0;
    width: min(100%, 390px);
    max-width: none;
    height: auto;
    max-height: 100%;
    object-fit: cover;
    filter: grayscale(1);
    z-index: 2;
}

.copp-partners-cta__badge {
    z-index: 6;
}

.copp-partners-cta__badge--arrow {
    background: var(--copp-ink);
    color: #ffffff;
    left: 12%;
    top: 46%;
}

.copp-partners-cta__badge--briefcase {
    right: 10%;
    top: 34%;
}

.copp-school-page-content {
    margin-top: 30px;
    margin-bottom: -1rem !important;
}

.copp-opportunity-page-content {
    margin-top: 30px;
    margin-bottom: -1rem !important;
}

.copp-school-page-content .field.ft_html.f_content {
    margin-bottom: 0;
}

.copp-opportunity-page-content .field.ft_html.f_content {
    margin-bottom: 0;
}

.copp-school-page-content .field.ft_html.f_content > .value > *:last-child {
    margin-bottom: 0;
}

.copp-opportunity-page-content .field.ft_html.f_content > .value > *:last-child {
    margin-bottom: 0;
}

.copp-contacts-page-content {
    margin-top: 30px;
    margin-bottom: -1rem !important;
}

.copp-contacts-page-content .field.ft_html.f_content,
.copp-contacts-page-content .field.ft_html.f_content > .value > *:last-child {
    margin-bottom: 0;
}

.copp-contacts-content {
    display: grid;
    gap: 40px;
}

.copp-contacts-hero .copp-news-hero__inner {
    gap: 42px;
    grid-template-columns: minmax(0, 400px) minmax(0, 1fr);
    min-height: 396px;
}

.copp-contacts-hero .copp-news-hero__copy {
    min-width: 0;
}

.copp-contacts-hero .copp-news-hero__title {
    margin-bottom: 26px;
}

.copp-contacts-hero__subtitle {
    margin: 0 0 24px;
    color: var(--copp-ink);
    font-size: 20px;
    font-weight: 800;
    line-height: 1.45;
    max-width: 360px;
}

.copp-contacts-hero .copp-news-hero__lead {
    max-width: 320px;
}

.copp-contacts-hero__media {
    min-height: 396px;
}

.copp-contacts-hero__media img {
    height: 100%;
    object-fit: cover;
    object-position: center center;
    width: 100%;
}

.copp-contacts-hero__badge {
    z-index: 8;
}

.copp-contacts-hero__badge--map {
    background: var(--copp-ink);
    color: #ffffff;
    left: 20px;
    top: 110px;
}

.copp-contacts-hero__badge--phone {
    right: 48px;
    top: 22px;
}

.copp-contacts-hero__badge--mail {
    background: var(--copp-ink);
    color: #ffffff;
    right: 10px;
    top: 178px;
}

.copp-contacts-hero__badge--chat {
    bottom: 24px;
    right: 56px;
}

.copp-contacts-cards {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.copp-contact-card {
    min-height: 198px;
    padding: 24px 22px 20px;
    border-radius: 0;
    display: grid;
    gap: 14px;
    grid-template-rows: auto auto 1fr auto;
    color: inherit;
    text-decoration: none;
}

.copp-contact-card:hover,
.copp-contact-card:focus {
    color: inherit;
    text-decoration: none;
}

.copp-contact-card--light {
    background: var(--copp-pale);
    color: var(--copp-ink);
}

.copp-contact-card--coral {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-contact-card--deep {
    background: var(--copp-red-deep);
    color: #ffffff;
}

.copp-contact-card--dark {
    background: var(--copp-ink);
    color: #ffffff;
}

.copp-contact-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
}

.copp-contact-card__icon svg {
    width: 26px;
    height: 26px;
}

.copp-contact-card h2 {
    margin: 0;
    font-size: 18px;
    font-weight: 800;
    line-height: 1.1;
}

.copp-contact-card p,
.copp-contact-card small {
    margin: 0;
    color: inherit;
    font-size: 16px;
    line-height: 1.45;
}

.copp-contact-card small {
    font-size: 14px;
    opacity: 0.9;
}

.copp-contact-card__button,
.copp-contact-card__arrow {
    align-items: center;
    display: inline-flex;
    justify-content: center;
    text-decoration: none;
}

.copp-contact-card__button {
    min-height: 42px;
    padding: 0 16px;
    border: 1px solid rgba(35, 35, 35, 0.22);
    border-radius: 0;
    gap: 10px;
    color: var(--copp-ink);
    justify-self: start;
    background: rgba(255, 255, 255, 0.66);
}

.copp-contact-card__button:hover,
.copp-contact-card__button:focus {
    color: var(--copp-red);
    text-decoration: none;
}

.copp-contact-card__button svg,
.copp-contact-card__arrow svg {
    width: 14px;
    height: 14px;
}

.copp-contact-card__arrow {
    width: 40px;
    height: 40px;
    border: 1px solid currentColor;
    border-radius: 0;
    justify-self: end;
}

.copp-contacts-layout {
    display: grid;
    gap: 28px;
    grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
    align-items: start;
}

.copp-contacts-layout__column {
    display: grid;
    gap: 18px;
}

.copp-contacts-map-shell {
    display: grid;
    gap: 16px;
}

.copp-contacts-map {
    min-height: 360px;
    border-radius: 0;
    overflow: hidden;
    background: var(--copp-pale);
    box-shadow: 0 20px 48px rgba(20, 20, 20, 0.08);
    position: relative;
    cursor: grab;
    touch-action: none;
    user-select: none;
}

.copp-contacts-map.is-dragging {
    cursor: grabbing;
}

.copp-contacts-map__tiles,
.copp-contacts-map__overlay {
    position: absolute;
    inset: 0;
}

.copp-contacts-map__tiles {
    overflow: hidden;
    background:
        radial-gradient(circle at center, rgba(255, 255, 255, 0.24), rgba(255, 255, 255, 0) 58%),
        var(--copp-pale);
}

.copp-contacts-map__tiles img {
    position: absolute;
    width: 256px;
    height: 256px;
    user-select: none;
    -webkit-user-drag: none;
}

.copp-contacts-map__overlay {
    width: 100%;
    height: 100%;
    pointer-events: none;
}

.copp-contacts-map__controls {
    position: absolute;
    right: 14px;
    top: 14px;
    z-index: 5;
    display: grid;
    gap: 8px;
}

.copp-contacts-map__control {
    width: 40px;
    height: 40px;
    border: 0;
    border-radius: 0;
    background: rgba(255, 255, 255, 0.96);
    color: var(--copp-ink);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 12px 24px rgba(20, 20, 20, 0.12);
    cursor: pointer;
}

.copp-contacts-map__control:hover,
.copp-contacts-map__control:focus {
    background: #ffffff;
    color: var(--copp-red);
    outline: none;
}

.copp-contacts-map__control svg {
    width: 14px;
    height: 14px;
}

.copp-contacts-map__route {
    fill: none;
    stroke: var(--copp-red);
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 4;
    filter: drop-shadow(0 4px 10px rgba(var(--copp-red-rgb), 0.22));
}

.copp-contacts-map__route--fallback {
    stroke-dasharray: 6 8;
    opacity: 0.82;
}

.copp-contacts-map__marker {
    filter: drop-shadow(0 8px 16px rgba(20, 20, 20, 0.18));
}

.copp-contacts-map__marker--destination circle:first-child {
    fill: #ffffff;
    stroke: var(--copp-red);
    stroke-width: 3;
}

.copp-contacts-map__marker--destination circle:last-child {
    fill: var(--copp-red);
}

.copp-contacts-map__marker--user circle:first-child {
    fill: rgba(31, 31, 31, 0.14);
}

.copp-contacts-map__marker--user circle:last-child {
    fill: var(--copp-ink);
    stroke: #ffffff;
    stroke-width: 2;
}

.copp-contacts-map__panel {
    display: grid;
    gap: 14px;
    padding: 18px 20px;
    border-radius: 0;
    background: var(--copp-soft);
}

.copp-contacts-map__status {
    margin: 0;
    color: #535353;
    font-size: 15px;
    line-height: 1.55;
}

.copp-contacts-map__metrics {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.copp-contacts-map__metrics span,
.copp-contacts-route__meta span {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 0 12px;
    border-radius: 0;
    background: rgba(var(--copp-red-rgb), 0.08);
    color: var(--copp-red-deep);
    font-size: 13px;
    font-weight: 700;
    line-height: 1;
}

.copp-contacts-map__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.copp-contacts-map__actions .copp-news-btn {
    min-height: 48px;
}

.copp-contacts-map__center {
    min-height: 22px;
    color: var(--copp-ink);
    font-size: 14px;
    font-weight: 600;
    line-height: 1.55;
}

.copp-contacts-map__hint {
    margin: 2px 0 0;
    color: #7c7c7c;
    font-size: 13px;
    line-height: 1.55;
}

.copp-contacts-route {
    appearance: none;
    border: 0;
    width: 100%;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 16px;
    align-items: center;
    min-height: 132px;
    padding: 22px 22px 20px;
    background: var(--copp-soft);
    border-radius: 0;
    color: inherit;
    text-align: left;
    cursor: pointer;
}

.copp-contacts-route:hover,
.copp-contacts-route:focus {
    color: inherit;
    text-decoration: none;
}

.copp-contacts-route__icon,
.copp-contacts-route__arrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.copp-contacts-route__icon {
    width: 34px;
    height: 34px;
}

.copp-contacts-route__icon svg {
    width: 26px;
    height: 26px;
    color: var(--copp-ink);
}

.copp-contacts-route__copy h3 {
    margin: 0 0 8px;
    font-size: 18px;
    font-weight: 800;
    line-height: 1.2;
    color: var(--copp-ink);
}

.copp-contacts-route__copy p {
    margin: 0;
    color: #626262;
    font-size: 15px;
    line-height: 1.55;
}

.copp-contacts-route__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 14px;
}

.copp-contacts-route__arrow {
    width: 40px;
    height: 40px;
    border: 1px solid rgba(35, 35, 35, 0.22);
    border-radius: 0;
    color: var(--copp-ink);
}

.copp-contacts-route__arrow svg {
    width: 14px;
    height: 14px;
}

.copp-contacts-form__lead {
    margin: -4px 0 0;
    color: #5f5f5f;
    font-size: 15px;
    line-height: 1.55;
    max-width: 430px;
}

.copp-contacts-form {
    display: grid;
    gap: 12px;
}

.copp-contacts-form__field {
    position: relative;
    display: block;
}

.copp-contacts-form__field input,
.copp-contacts-form__field textarea {
    width: 100%;
    border: 1px solid var(--copp-pale);
    background: var(--copp-soft);
    color: var(--copp-ink);
    border-radius: 0;
    box-shadow: none;
    outline: none;
    font-size: 15px;
    line-height: 1.4;
    padding: 0 46px 0 16px;
}

.copp-contacts-form__field input {
    height: 52px;
}

.copp-contacts-form__field textarea {
    min-height: 152px;
    padding-top: 16px;
    padding-bottom: 16px;
    resize: vertical;
}

.copp-contacts-form__field input:focus,
.copp-contacts-form__field textarea:focus {
    border-color: rgba(var(--copp-red-rgb), 0.28);
    background: #ffffff;
}

.copp-contacts-form__field > span {
    position: absolute;
    top: 50%;
    right: 16px;
    transform: translateY(-50%);
    color: #8b8b8b;
    pointer-events: none;
}

.copp-contacts-form__field--textarea > span {
    top: 18px;
    transform: none;
}

.copp-contacts-form__field > span svg {
    width: 16px;
    height: 16px;
}

.copp-contacts-form__submit {
    min-height: 52px;
    justify-self: start;
}

.copp-contacts-form__notice {
    padding: 14px 16px;
    border-radius: 0;
    font-size: 14px;
    line-height: 1.5;
}

.copp-contacts-form__notice--success {
    background: rgba(18, 140, 63, 0.09);
    color: #15723b;
}

.copp-contacts-form__notice--error {
    background: rgba(var(--copp-red-rgb), 0.08);
    color: var(--copp-red-deep);
}

.copp-contacts-form__policy {
    margin: 4px 0 0;
    color: #8a8a8a;
    font-size: 13px;
    line-height: 1.5;
}

.copp-contacts-form__policy a {
    color: inherit;
    text-decoration: none;
}

.copp-contacts-form__policy a:hover,
.copp-contacts-form__policy a:focus {
    color: var(--copp-red);
    text-decoration: none;
}

.copp-contacts-faq {
    display: grid;
    gap: 22px;
    grid-template-columns: minmax(0, 1.45fr) minmax(280px, 0.72fr);
    align-items: start;
}

.copp-contacts-faq__main,
.copp-contacts-faq__aside {
    display: grid;
    gap: 18px;
}

.copp-contacts-faq__list {
    display: grid;
    gap: 12px;
}

.copp-contacts-faq__item {
    border-radius: 0;
    background: var(--copp-soft);
    overflow: hidden;
}

.copp-contacts-faq__item summary {
    list-style: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    min-height: 62px;
    padding: 0 22px;
    cursor: pointer;
    font-size: 18px;
    font-weight: 800;
    line-height: 1.3;
    color: var(--copp-ink);
}

.copp-contacts-faq__item summary::-webkit-details-marker {
    display: none;
}

.copp-contacts-faq__arrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    transition: transform 0.24s ease;
}

.copp-contacts-faq__item[open] .copp-contacts-faq__arrow {
    transform: rotate(90deg);
}

.copp-contacts-faq__answer {
    padding: 0 22px 18px;
}

.copp-contacts-faq__answer p {
    margin: 0;
    color: #626262;
    font-size: 15px;
    line-height: 1.65;
}

.copp-contacts-faq__aside {
    min-height: 100%;
    padding: 26px 24px 24px;
    border-radius: 0;
    background: var(--copp-pale);
    align-content: start;
}

.copp-contacts-faq__aside-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    color: var(--copp-ink);
}

.copp-contacts-faq__aside-icon svg {
    width: 28px;
    height: 28px;
}

.copp-contacts-faq__aside h3 {
    margin: 0;
    font-size: 28px;
    font-weight: 800;
    line-height: 1.1;
    color: var(--copp-ink);
}

.copp-contacts-faq__aside p {
    margin: 0;
    color: #5f5f5f;
    font-size: 15px;
    line-height: 1.65;
}

.copp-contacts-cta {
    position: relative;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    background: linear-gradient(90deg, var(--copp-red) 0%, var(--copp-red) 45%, var(--copp-red) 100%);
    overflow: hidden;
}

.copp-contacts-cta__inner {
    width: min(100%, var(--copp-container-content));
    margin: 0 auto;
    min-height: 268px;
    padding: 0 15px;
    display: grid;
    gap: 28px;
    grid-template-columns: minmax(0, 420px) minmax(320px, 1fr);
    align-items: center;
}

.copp-contacts-cta__copy {
    display: grid;
    gap: 18px;
    color: #ffffff;
    align-content: center;
    padding: 34px 0;
    position: relative;
    z-index: 2;
}

.copp-contacts-cta__copy h2 {
    margin: 0;
    max-width: 420px;
    font-size: clamp(32px, 3.2vw, 46px);
    font-weight: 900;
    line-height: 1.02;
    text-transform: uppercase;
}

.copp-contacts-cta__copy p {
    margin: 0;
    max-width: 350px;
    font-size: 17px;
    line-height: 1.6;
}

.copp-contacts-cta__visual {
    position: relative;
    min-height: 268px;
    overflow: visible;
}

.copp-contacts-cta__visual > img {
    position: absolute;
    right: 22px;
    bottom: 0;
    width: min(100%, 430px);
    max-width: none;
    height: auto;
    max-height: 100%;
    object-fit: cover;
    filter: grayscale(1);
    z-index: 2;
}

.copp-contacts-cta__badge {
    z-index: 6;
}

.copp-contacts-cta__badge--arrow {
    background: var(--copp-ink);
    color: #ffffff;
    left: 10%;
    top: 48%;
}

.copp-contacts-cta__badge--phone {
    right: 12%;
    top: 42%;
}

.copp-contacts-cta__badge--mail {
    background: var(--copp-ink);
    color: #ffffff;
    right: 5%;
    top: 16%;
}

@media (min-width: 768px) {
    .copp-contacts-page-content {
        margin-bottom: -1.5rem !important;
    }
}

.copp-school-content {
    display: grid;
    gap: 40px;
}

.copp-school-hero .copp-news-hero__inner {
    gap: 42px;
    grid-template-columns: minmax(0, 470px) minmax(0, 1fr);
    min-height: 396px;
}

.copp-school-hero .copp-news-hero__copy {
    min-width: 0;
    position: relative;
    z-index: 2;
}

.copp-school-hero .copp-news-hero__title {
    margin-bottom: 20px;
    font-size: clamp(42px, 4.4vw, 68px);
    line-height: var(--copp-lh-hero);
    max-width: 440px;
}

.copp-school-hero__subtitle {
    color: var(--copp-ink);
    font-size: 28px;
    font-weight: 800;
    line-height: 1.28;
    margin: 0 0 16px;
    max-width: 420px;
}

.copp-school-hero .copp-news-hero__lead {
    max-width: 420px;
}

.copp-school-hero__media {
    min-height: 380px;
    justify-self: end;
    width: min(100%, 560px);
}

.copp-school-hero__scene {
    min-height: 380px;
}

.copp-school-hero__media .copp-visual__block--black {
    left: 48px;
    top: 92px;
}

.copp-school-hero__media .copp-visual__block--red {
    right: 82px;
    top: 12px;
}

.copp-school-hero__media .copp-visual__block--chart {
    right: 18px;
    top: 208px;
}

.copp-school-hero__media .copp-person--left {
    left: 206px;
}

.copp-school-hero__media .copp-person--right {
    right: 126px;
}

.copp-school-section {
    display: grid;
    gap: 18px;
}

.copp-school-section__head {
    align-items: end;
    display: flex;
    gap: 20px;
    justify-content: space-between;
}

.copp-school-section__heading {
    display: grid;
    gap: 10px;
}

.copp-school-section__head h2 {
    color: var(--copp-ink);
    font-size: 28px;
    font-weight: 900;
    line-height: 1.05;
    margin: 0;
    text-transform: uppercase;
}

.copp-school-directions .copp-showcase__head {
    align-items: end;
}

.copp-school-directions .copp-showcase__title {
    margin-bottom: 0;
}

.copp-school-directions .copp-showcase__bars {
    margin-top: 0;
}

.copp-school-tests {
    --copp-grid-columns: 5;
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(var(--copp-grid-columns), minmax(0, 1fr));
}

.copp-school-test {
    background: var(--copp-soft);
    border-radius: 0;
    color: inherit;
    cursor: pointer;
    display: grid;
    gap: 14px;
    min-height: 236px;
    padding: 24px 20px 18px;
    text-decoration: none;
}

.copp-school-test:hover,
.copp-school-test:focus {
    color: inherit;
    text-decoration: none;
}

.copp-school-test__icon,
.copp-school-test__cta-icon {
    align-items: center;
    color: var(--copp-ink);
    display: inline-flex;
    height: 40px;
    justify-content: center;
    width: 40px;
}

.copp-school-test__icon i,
.copp-school-test__cta-icon i {
    display: block;
    font-size: 30px;
    line-height: 1;
}

.copp-school-test h3 {
    color: var(--copp-ink);
    font-size: 22px;
    font-weight: 800;
    line-height: 1.24;
    margin: 0;
}

.copp-school-test p {
    color: #6c6c6c;
    font-size: 15px;
    line-height: 1.45;
    margin: 0;
}

.copp-school-test__meta {
    align-items: center;
    color: #636363;
    display: inline-flex;
    font-size: 14px;
    font-weight: 600;
    gap: 8px;
    margin-top: auto;
}

.copp-school-test__meta svg {
    color: var(--copp-red);
    height: 16px;
    width: 16px;
}

.copp-school-test--cta {
    align-content: space-between;
    background: #ededed;
    position: relative;
}

.copp-school-test__cta-icon {
    color: rgba(var(--copp-red-rgb), 0.32);
    justify-self: end;
}

.copp-school-test__cta-copy {
    display: grid;
    gap: 12px;
}

.copp-school-test--cta .copp-news-btn {
    align-self: end;
    justify-self: start;
    min-width: 118px;
    padding-left: 20px;
    padding-right: 20px;
}

.copp-school-events {
    --copp-grid-columns: 4;
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(var(--copp-grid-columns), minmax(0, 1fr));
}

.copp-school-events .copp-event-card {
    height: 100%;
    min-height: 0;
}

.copp-school-help__process {
    --copp-about-process-gap: 24px;
    --copp-about-process-track-offset: calc(50% + 8px);
    --copp-about-process-track-width: calc(100% + var(--copp-about-process-gap) - 16px);
    --copp-about-process-pulse-width: 24px;
    gap: var(--copp-about-process-gap);
    padding-top: 6px;
}

.copp-school-help__step {
    align-items: start;
    display: grid;
    gap: 16px;
    justify-items: start;
    padding-top: 0;
    position: relative;
}

.copp-school-help__index {
    color: rgba(35, 35, 35, 0.08);
    font-size: 76px;
    font-weight: 900;
    left: 0;
    line-height: 0.9;
    position: absolute;
    top: -18px;
    z-index: 0;
}

.copp-school-help__step .copp-about-process__icon {
    align-items: center;
    background: #ffffff;
    border: 1px solid rgba(35, 35, 35, 0.14);
    border-radius: 0;
    color: var(--copp-ink);
    display: inline-flex;
    height: 64px;
    justify-content: center;
    position: relative;
    width: 64px;
    z-index: 1;
}

.copp-school-help__step .copp-about-process__icon i {
    font-size: 26px;
    line-height: 1;
}

.copp-school-help__copy {
    display: grid;
    gap: 10px;
    position: relative;
    z-index: 1;
}

.copp-school-help__copy h3 {
    color: var(--copp-ink);
    font-size: 16px;
    font-weight: 800;
    line-height: 1.3;
    margin: 0;
    max-width: 186px;
}

.copp-school-help__copy p {
    color: #676767;
    font-size: 14px;
    line-height: 1.45;
    margin: 0;
    max-width: 186px;
}

.copp-school-help__step .copp-about-process__connector {
    top: 31px;
}

.copp-school-help__step .copp-about-process__connector-line {
    background: linear-gradient(90deg, rgba(var(--copp-red-rgb), 0.28) 0 50%, transparent 50% 100%);
    background-size: 8px 1px;
    background-repeat: repeat-x;
    border-radius: 0;
    height: 1px;
    top: 1px;
}

.copp-school-help__step.is-active .copp-about-process__icon {
    box-shadow: 0 12px 24px rgba(var(--copp-red-rgb), 0.18);
}

.copp-school-cta {
    background: linear-gradient(135deg, var(--copp-red) 0%, var(--copp-red) 100%);
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    margin-bottom: -1px;
    overflow: hidden;
    position: relative;
    width: 100vw;
}

.copp-school-cta__inner {
    align-items: center;
    display: grid;
    gap: clamp(28px, 4vw, 64px);
    grid-template-columns: minmax(320px, 420px) minmax(0, 1fr);
    margin: 0 auto;
    max-width: var(--copp-container-content);
    min-height: 184px;
    width: calc(100% - 30px);
}

.copp-school-cta__copy {
    color: #ffffff;
    padding: 28px 0;
}

.copp-school-cta__copy h2 {
    color: #ffffff;
    font-size: 24px;
    font-weight: 900;
    line-height: 1.12;
    margin: 0;
    max-width: 320px;
}

.copp-school-cta__copy p {
    color: rgba(255, 255, 255, 0.92);
    font-size: 15px;
    line-height: 1.45;
    margin: 14px 0 0;
    max-width: 290px;
}

.copp-school-cta__copy .copp-news-btn {
    margin-top: 18px;
    min-width: 132px;
}

.copp-school-cta__copy .copp-news-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 18px;
}

.copp-school-cta__copy .copp-news-hero__actions .copp-news-btn {
    margin-top: 0;
}

.copp-school-cta__copy .copp-news-btn--primary {
    background: #ffffff;
    border-color: #ffffff;
    color: var(--copp-red);
}

.copp-school-cta__copy .copp-news-btn--primary:hover {
    background: rgba(255, 255, 255, 0.92);
    border-color: rgba(255, 255, 255, 0.92);
    color: var(--copp-red-dark);
}

.copp-school-cta__copy .copp-news-btn--outline {
    background: transparent;
    border-color: rgba(255, 255, 255, 0.88);
    color: #ffffff;
}

.copp-school-cta__copy .copp-news-btn--outline:hover {
    background: rgba(255, 255, 255, 0.12);
    border-color: #ffffff;
    color: #ffffff;
}

.copp-school-cta__visual {
    min-height: 184px;
    position: relative;
}

.copp-school-cta__scene {
    margin-left: auto;
    max-width: none;
    min-height: 184px;
    width: 100%;
}

.copp-school-cta__scene .copp-visual__arc,
.copp-school-cta__scene .copp-visual__line {
    display: none;
}

.copp-school-cta__scene .copp-visual__tile--one {
    background: rgba(255, 255, 255, 0.94);
    height: 42px;
    left: 28px;
    top: 26px;
    width: 42px;
}

.copp-school-cta__scene .copp-visual__tile--two {
    background: rgba(255, 255, 255, 0.88);
    height: 30px;
    left: 80px;
    top: 22px;
    width: 30px;
}

.copp-school-cta__scene .copp-visual__tile--three {
    background: rgba(35, 35, 35, 0.92);
    box-shadow: none;
    height: 46px;
    left: 128px;
    top: 30px;
    width: 46px;
}

.copp-school-cta__scene .copp-visual__tile--four {
    background: rgba(255, 255, 255, 0.9);
    height: 54px;
    right: 76px;
    top: 18px;
    width: 54px;
}

.copp-school-cta__scene .copp-visual__tile--five {
    background: rgba(35, 35, 35, 0.92);
    box-shadow: none;
    height: 34px;
    right: 38px;
    top: 42px;
    width: 34px;
}

.copp-school-cta__scene .copp-visual__tile--six {
    background: rgba(255, 255, 255, 0.94);
    bottom: 18px;
    height: 38px;
    right: 110px;
    width: 38px;
}

.copp-school-cta__scene .copp-visual__block--black {
    background: var(--copp-ink);
    left: 56px;
    top: 66px;
}

.copp-school-cta__scene .copp-visual__block--black svg {
    transform: rotate(-45deg);
}

.copp-school-cta__scene .copp-visual__block--red {
    right: 58px;
    top: 66px;
}

.copp-school-cta__scene .copp-person--left {
    left: 204px;
    top: 6px;
    transform: scale(0.9);
    transform-origin: center bottom;
}

.copp-events-page-content {
    margin-bottom: 0 !important;
}

.copp-events-page-content .field.ft_html.f_content {
    margin-bottom: 0;
}

.copp-events-page-content .field.ft_html.f_content > .value > *:last-child {
    margin-bottom: 0;
}

.copp-events-page {
    display: grid;
    gap: 40px;
}

.copp-events-hero .copp-news-hero__inner {
    gap: 42px;
    grid-template-columns: minmax(0, 470px) minmax(0, 1fr);
    min-height: 396px;
}

.copp-events-hero .copp-news-hero__copy {
    min-width: 0;
    position: relative;
    z-index: 2;
}

.copp-events-hero .copp-news-hero__title {
    margin-bottom: 20px;
    font-size: clamp(44px, 4.2vw, 68px);
    line-height: var(--copp-lh-hero);
    max-width: 440px;
}

.copp-events-hero__subtitle {
    color: var(--copp-ink);
    font-size: 24px;
    font-weight: 800;
    line-height: 1.45;
    margin: 0;
    max-width: 420px;
}

.copp-events-hero .copp-news-hero__actions {
    margin-top: 28px;
}

.copp-events-hero__media {
    min-height: 380px;
    justify-self: end;
    width: min(100%, 560px);
}

.copp-events-hero__media img {
    min-height: 380px;
    object-position: center center;
}

.copp-events-hero__badge {
    z-index: 8;
}

.copp-events-hero__badge--left {
    background: var(--copp-ink);
    color: #ffffff;
    left: 44px;
    top: 88px;
}

.copp-events-hero__badge--top {
    right: 64px;
    top: 12px;
}

.copp-events-hero__badge--right {
    background: var(--copp-ink);
    color: #ffffff;
    right: 18px;
    top: 204px;
}

.copp-events-filters {
    background: var(--copp-pale);
    border: 1px solid var(--copp-pale);
    border-radius: 0;
    padding: 18px 20px;
}

.copp-events-filters__form {
    align-items: end;
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(220px, 1.25fr) repeat(4, minmax(0, 1fr)) auto;
}

.copp-events-filters__field {
    display: grid;
    gap: 8px;
}

.copp-events-filters__field > span {
    color: var(--copp-muted);
    font-size: 14px;
    font-weight: 700;
    line-height: 1.2;
}

.copp-events-filters__field select,
.copp-events-filters__field input {
    appearance: none;
    background: #ffffff;
    border: 1px solid transparent;
    border-radius: 0;
    box-shadow: none;
    color: var(--copp-ink);
    font-size: 16px;
    font-weight: 700;
    height: 52px;
    line-height: 52px;
    outline: none;
    padding: 0 18px;
    width: 100%;
}

.copp-events-filters__field select {
    background-image:
        linear-gradient(45deg, transparent 50%, var(--copp-red) 50%),
        linear-gradient(135deg, var(--copp-red) 50%, transparent 50%);
    background-position:
        calc(100% - 20px) calc(50% - 3px),
        calc(100% - 14px) calc(50% - 3px);
    background-repeat: no-repeat;
    background-size: 6px 6px, 6px 6px;
    padding-right: 40px;
}

.copp-events-filters__field input[type="date"] {
    padding-right: 16px;
}

.copp-events-filters__field--search {
    min-width: 0;
}

.copp-events-filters__actions {
    display: flex;
    gap: 12px;
    justify-content: flex-end;
}

.copp-events-filters__actions .copp-news-btn {
    align-items: center;
    display: inline-flex;
    justify-content: center;
    min-height: 52px;
    min-width: 154px;
}

.copp-events-section {
    display: grid;
    gap: 18px;
}

.copp-events-summary {
    --copp-grid-columns: 4;
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(var(--copp-grid-columns), minmax(0, 1fr));
}

.copp-events-summary__card {
    border-radius: 0;
    display: grid;
    gap: 10px;
    min-height: 122px;
    padding: 22px 20px;
}

.copp-events-summary__card strong {
    color: inherit;
    display: block;
    font-size: clamp(30px, 3vw, 42px);
    font-weight: 900;
    letter-spacing: 0;
    line-height: 0.95;
}

.copp-events-summary__card span {
    color: inherit;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.35;
    max-width: 220px;
}

.copp-events-summary__card--light {
    background: var(--copp-pale);
    color: var(--copp-ink);
}

.copp-events-summary__card--accent {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-events-summary__card--deep {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-events-summary__card--dark {
    background: var(--copp-ink);
    color: #ffffff;
}

.copp-events-cards {
    --copp-grid-columns: 4;
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(var(--copp-grid-columns), minmax(0, 1fr));
}

.copp-events-card {
    background: var(--copp-soft);
    border-radius: 0;
    color: inherit;
    display: grid;
    grid-template-rows: auto 1fr;
    min-height: 410px;
    overflow: hidden;
    text-decoration: none;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.copp-events-card:hover,
.copp-events-card:focus {
    box-shadow: 0 18px 38px rgba(var(--copp-ink-rgb), 0.12);
    color: inherit;
    text-decoration: none;
    transform: translateY(-2px);
}

.copp-events-card__media {
    aspect-ratio: 1.26 / 1;
    overflow: hidden;
    position: relative;
}

.copp-events-card__media img {
    filter: grayscale(1);
    height: 100%;
    object-fit: cover;
    transition: transform 0.24s ease;
    width: 100%;
}

.copp-events-card:hover .copp-events-card__media img,
.copp-events-card:focus .copp-events-card__media img {
    transform: scale(1.03);
}

.copp-events-card__date {
    align-items: center;
    background: var(--copp-red);
    border-radius: 0;
    color: #ffffff;
    display: grid;
    justify-items: center;
    left: 14px;
    min-height: 66px;
    padding: 8px 10px;
    position: absolute;
    top: 14px;
    width: 58px;
}

.copp-events-card__date strong {
    display: block;
    font-size: 26px;
    font-weight: 900;
    line-height: 0.95;
}

.copp-events-card__date span {
    display: block;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0;
    line-height: 1;
    text-transform: uppercase;
}

.copp-events-card__chip {
    background: rgba(255, 255, 255, 0.96);
    border-radius: 0;
    color: var(--copp-muted);
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
    padding: 7px 10px;
    position: absolute;
    right: 14px;
    top: 14px;
}

.copp-events-card__body {
    display: grid;
    gap: 14px;
    grid-template-rows: auto auto 1fr auto;
    padding: 16px 18px 18px;
}

.copp-events-card__meta {
    color: var(--copp-muted);
    display: grid;
    gap: 6px;
}

.copp-events-card__meta span {
    align-items: center;
    display: inline-flex;
    gap: 8px;
}

.copp-events-card__meta svg {
    color: var(--copp-red);
    flex-shrink: 0;
    height: 14px;
    width: 14px;
}

.copp-events-card__meta b {
    font-size: 14px;
    font-weight: 600;
    line-height: 1.35;
}

.copp-events-card__body h3 {
    color: var(--copp-ink);
    font-size: 22px;
    font-weight: 900;
    line-height: 1.2;
    margin: 0;
}

.copp-events-card__body p {
    color: var(--copp-muted);
    font-size: 15px;
    line-height: 1.5;
    margin: 0;
}

.copp-events-card__attendance {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.copp-events-card__attendance span {
    align-items: center;
    background: rgba(var(--copp-red-rgb), 0.08);
    border-radius: 0;
    color: var(--copp-red-deep);
    display: inline-flex;
    font-size: 12px;
    font-weight: 800;
    line-height: 1;
    min-height: 30px;
    padding: 0 12px;
}

.copp-events-card__arrow {
    align-items: center;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.22);
    border-radius: 0;
    color: var(--copp-ink);
    display: inline-flex;
    height: 40px;
    justify-content: center;
    justify-self: end;
    width: 40px;
}

.copp-events-card__arrow svg {
    height: 14px;
    width: 14px;
}

.copp-projects-page {
    display: grid;
    gap: 40px;
}

.copp-projects-hero__media img {
    object-position: center center;
}

.copp-projects-hero__tabs {
    display: flex;
    gap: 8px;
    margin-top: 20px;
    flex-wrap: wrap;
}

.copp-projects-hero__tab {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 18px;
    background: rgba(255,255,255,0.12);
    border: 2px solid rgba(255,255,255,0.3);
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    transition: background 0.2s, border-color 0.2s;
}

.copp-projects-hero__tab svg {
    width: 16px;
    height: 16px;
}

.copp-projects-hero__tab b {
    background: rgba(255,255,255,0.2);
    padding: 2px 8px;
    font-size: 12px;
    font-weight: 900;
}

.copp-projects-hero__tab:hover {
    background: rgba(255,255,255,0.2);
    border-color: rgba(255,255,255,0.5);
}

.copp-projects-hero__tab.is-active {
    background: #fff;
    color: var(--copp-ink, #1a1a2e);
    border-color: #fff;
}

.copp-projects-hero__tab.is-active b {
    background: rgba(0,0,0,0.08);
}

.copp-projects-content--hidden {
    display: none;
}

.copp-projects-empty-note {
    color: #888;
    font-size: 15px;
    padding: 24px 0;
}

.copp-projects-section {
    padding-bottom: 8px;
}

.copp-projects-section__lead {
    color: var(--copp-muted);
    font-size: 16px;
    font-weight: 600;
    line-height: 1.5;
    margin: 0;
    max-width: 420px;
}

.copp-projects-cards {
    --copp-grid-columns: 3;
    grid-template-columns: repeat(var(--copp-grid-columns), minmax(0, 1fr));
}

.copp-projects-card {
    min-height: 430px;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.copp-projects-card:hover,
.copp-projects-card:focus {
    box-shadow: 0 18px 38px rgba(var(--copp-ink-rgb), 0.12);
    transform: translateY(-2px);
}

.copp-projects-card__media img {
    transition: transform 0.24s ease;
}

.copp-projects-card:hover .copp-projects-card__media img,
.copp-projects-card:focus .copp-projects-card__media img {
    transform: scale(1.03);
}

.copp-projects-card__mark {
    align-items: center;
    background: var(--copp-red);
    border-radius: 0;
    color: #ffffff;
    display: inline-flex;
    height: 58px;
    justify-content: center;
    left: 14px;
    position: absolute;
    top: 14px;
    width: 58px;
}

.copp-projects-card__mark svg {
    height: 22px;
    width: 22px;
}

.copp-projects-card__badge {
    max-width: calc(100% - 96px);
}

.copp-projects-card__level {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    padding: 3px 10px;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.copp-projects-card__level--regional {
    background: rgba(var(--copp-accent-rgb, 0,120,120), 0.15);
    color: rgb(var(--copp-accent-rgb, 0,120,120));
}

.copp-projects-card__level--federal {
    background: rgba(var(--copp-red-rgb, 200,16,46), 0.15);
    color: var(--copp-red, #c8102e);
}

.copp-project-article__meta .copp-projects-card__level {
    font-size: 13px;
    padding: 4px 12px;
}

.copp-projects-card__body {
    grid-template-rows: auto auto auto 1fr auto;
}

.copp-projects-card__meta:empty {
    display: none;
}

.copp-projects-card__type {
    color: var(--copp-red);
    font-size: 13px;
    font-weight: 800;
    line-height: 1.2;
    text-transform: uppercase;
}

.copp-projects-empty {
    padding: 28px;
}

.copp-projects-empty h3 {
    color: var(--copp-ink);
    font-size: 24px;
    font-weight: 900;
    line-height: 1.2;
    margin: 0 0 8px;
}

.copp-projects-empty p {
    color: var(--copp-muted);
    font-size: 16px;
    line-height: 1.5;
    margin: 0;
}

.copp-project-article {
    display: grid;
    gap: 34px;
}

.copp-project-article__hero {
    align-items: stretch;
    background: var(--copp-soft);
    border-radius: 0;
    display: grid;
    gap: 26px;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 500px);
    overflow: hidden;
}

.copp-project-article__copy {
    align-content: center;
    display: grid;
    gap: 18px;
    min-width: 0;
    padding: 42px;
}

.copp-project-article__eyebrow {
    align-items: center;
    color: var(--copp-red);
    display: inline-flex;
    font-size: var(--copp-fs-eyebrow);
    font-weight: var(--copp-fw-eyebrow);
    gap: 10px;
    letter-spacing: var(--copp-ls-eyebrow);
    line-height: var(--copp-lh-eyebrow);
    text-transform: uppercase;
}

.copp-project-article__eyebrow svg {
    height: 16px;
    width: 16px;
}

.copp-project-article__copy h1 {
    color: var(--copp-ink);
    font-size: clamp(36px, 4vw, 58px);
    font-weight: 900;
    line-height: 1;
    margin: 0;
    max-width: 720px;
}

.copp-project-article__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.copp-project-article__meta span {
    background: #ffffff;
    border-radius: 0;
    color: var(--copp-muted);
    font-size: 14px;
    font-weight: 800;
    line-height: 1;
    padding: 9px 12px;
}

.copp-project-article__media {
    min-height: 360px;
    overflow: hidden;
}

.copp-project-article__media img {
    filter: grayscale(1);
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.copp-project-article__content {
    max-width: 880px;
}

.copp-project-article__footer {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.copp-equipment-article {
    display: grid;
    gap: 34px;
    position: relative;
    z-index: 20;
}

.copp-equipment-article__hero {
    align-items: stretch;
    background: var(--copp-soft);
    border-radius: 0;
    display: grid;
    gap: 26px;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 500px);
    overflow: hidden;
}

.copp-equipment-article__copy {
    align-content: center;
    display: grid;
    gap: 18px;
    min-width: 0;
    padding: 42px;
}

.copp-equipment-article__copy h1 {
    color: var(--copp-ink);
    font-size: clamp(36px, 4vw, 58px);
    font-weight: 900;
    line-height: 1;
    margin: 0;
    max-width: 760px;
    text-transform: uppercase;
}

.copp-equipment-article__copy p {
    color: var(--copp-ink);
    font-size: 18px;
    line-height: 1.55;
    margin: 0;
    max-width: 660px;
}

.copp-equipment-article__media {
    min-height: 360px;
    overflow: hidden;
}

.copp-equipment-article__media img {
    filter: grayscale(1) contrast(1.12);
    height: 100%;
    object-fit: cover;
    object-position: right center;
    width: 100%;
}

.copp-equipment-article__layout {
    align-items: start;
    display: grid;
    gap: 28px;
    grid-template-columns: minmax(0, 1fr);
}

.copp-equipment-article__content {
    max-width: none;
}

.copp-equipment-article__aside {
    background: var(--copp-ink);
    border-radius: 0;
    color: #ffffff;
    display: grid;
    gap: 16px;
    overflow: hidden;
    padding: 18px;
    position: sticky;
    top: 96px;
}

.copp-equipment-article__aside > span {
    background: var(--copp-red);
    color: #ffffff;
    font-size: 12px;
    font-weight: 900;
    justify-self: start;
    line-height: 1;
    padding: 10px 12px;
    text-transform: uppercase;
}

.copp-equipment-article__aside img {
    aspect-ratio: 16 / 10;
    display: block;
    filter: grayscale(1) contrast(1.12);
    object-fit: cover;
    object-position: right center;
    width: 100%;
}

.copp-equipment-article__aside h2 {
    color: #ffffff;
    font-size: 24px;
    font-weight: 900;
    line-height: 1.12;
    margin: 0;
    text-transform: uppercase;
}

.copp-equipment-article__aside p {
    color: rgba(255, 255, 255, 0.82);
    font-size: 15px;
    line-height: 1.5;
    margin: 0;
}

.copp-equipment-article__aside-link {
    align-items: center;
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 0;
    color: #ffffff;
    display: inline-flex;
    font-size: 12px;
    font-weight: 900;
    justify-content: center;
    min-height: 38px;
    padding: 0 12px;
    text-transform: uppercase;
}

.copp-equipment-article__aside-link:hover,
.copp-equipment-article__aside-link:focus {
    background: #ffffff;
    color: var(--copp-red);
    text-decoration: none;
}

.copp-equipment-article__details {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: 30px;
}

.copp-equipment-article__detail-card {
    background: var(--copp-soft);
    border: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    border-left: 5px solid var(--copp-red);
    border-radius: 0;
    display: grid;
    gap: 16px;
    padding: 22px;
}

.copp-equipment-article__detail-card > span {
    align-items: center;
    color: var(--copp-ink);
    display: inline-flex;
    font-size: 18px;
    font-weight: 900;
    gap: 10px;
    line-height: 1.2;
    text-transform: uppercase;
}

.copp-equipment-article__detail-card > span i {
    color: var(--copp-red);
}

.copp-equipment-article__detail-card ul {
    display: grid;
    gap: 10px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.copp-equipment-article__detail-card li {
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    border-radius: 0;
    color: #454545;
    display: grid;
    gap: 4px;
    line-height: 1.45;
    padding: 13px 14px;
}

.copp-equipment-article__detail-card strong,
.copp-equipment-article__detail-card a {
    color: var(--copp-ink);
    font-weight: 900;
}

.copp-equipment-article__detail-card a:hover,
.copp-equipment-article__detail-card a:focus {
    color: var(--copp-red);
}

.copp-equipment-article__detail-card em {
    color: var(--copp-muted);
    font-size: 14px;
    font-style: normal;
}

.copp-equipment-article__photos {
    display: grid;
    gap: 16px;
    margin-top: 32px;
}

.copp-equipment-article__photos h2 {
    color: var(--copp-ink);
    font-size: 26px;
    font-weight: 900;
    line-height: 1.1;
    margin: 0;
    text-transform: uppercase;
}

.copp-equipment-article__photos-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.copp-equipment-article__photos-grid img {
    aspect-ratio: 4 / 3;
    border-radius: 0;
    display: block;
    filter: grayscale(1) contrast(1.08);
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.copp-events-calendar__layout {
    display: grid;
    gap: 24px;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: start;
}

.copp-events-calendar__month {
    max-width: 420px;
}

.copp-events-calendar__month,
.copp-events-calendar__items,
.copp-events-empty {
    background: var(--copp-soft);
    border-radius: 0;
}

.copp-events-calendar__month {
    display: grid;
    gap: 16px;
    padding: 18px;
}

.copp-events-calendar__month-head {
    align-items: center;
    display: grid;
    gap: 10px;
    grid-template-columns: 36px minmax(0, 1fr) 36px;
}

.copp-events-calendar__month-head strong {
    color: var(--copp-ink);
    font-size: 18px;
    font-weight: 800;
    line-height: 1.2;
    text-align: center;
}

.copp-events-calendar__month-nav {
    align-items: center;
    color: var(--copp-muted);
    display: inline-flex;
    height: 36px;
    justify-content: center;
    text-decoration: none;
    width: 36px;
}

.copp-events-calendar__month-nav:hover,
.copp-events-calendar__month-nav:focus {
    color: var(--copp-red);
    text-decoration: none;
}

.copp-events-calendar__month-nav svg {
    height: 14px;
    width: 14px;
}

.copp-events-calendar__weekdays,
.copp-events-calendar__grid {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(7, minmax(0, 1fr));
}

.copp-events-calendar__weekdays span {
    color: var(--copp-muted);
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
    text-align: center;
}

.copp-events-calendar__cell {
    align-items: center;
    border-radius: 0;
    color: var(--copp-muted);
    display: inline-flex;
    font-size: 14px;
    font-weight: 700;
    aspect-ratio: 1 / 1;
    justify-content: center;
    position: relative;
}

.copp-events-calendar__cell.is-empty {
    opacity: 0;
}

.copp-events-calendar__cell.has-event {
    color: var(--copp-ink);
}

.copp-events-calendar__cell.has-event::after {
    background: var(--copp-red);
    border-radius: 0;
    bottom: 0;
    content: "";
    height: 4px;
    left: 0;
    position: absolute;
    width: 100%;
}

.copp-events-calendar__cell.is-selected {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-events-calendar__cell.is-selected::after {
    background: #ffffff;
    height: 4px;
}

.copp-events-calendar__items {
    overflow: hidden;
}

.copp-events-calendar__item {
    align-items: center;
    border-bottom: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    display: grid;
    gap: 16px;
    grid-template-columns: 68px 60px minmax(0, 1fr) auto 40px;
    padding: 16px 18px;
}

.copp-events-calendar__item:last-child {
    border-bottom: none;
}

.copp-events-calendar__item-date {
    align-items: center;
    color: var(--copp-red);
    display: grid;
    gap: 2px;
    justify-items: start;
}

.copp-events-calendar__item-date strong {
    color: var(--copp-ink);
    font-size: 24px;
    font-weight: 900;
    line-height: 1;
}

.copp-events-calendar__item-date span {
    color: var(--copp-muted);
    font-size: 12px;
    font-weight: 800;
    line-height: 1;
    text-transform: uppercase;
}

.copp-events-calendar__item-time {
    color: var(--copp-muted);
    font-size: 16px;
    font-weight: 700;
    line-height: 1.2;
}

.copp-events-calendar__item-copy h3 {
    color: var(--copp-ink);
    font-size: 18px;
    font-weight: 800;
    line-height: 1.3;
    margin: 0;
}

.copp-events-calendar__item-copy p {
    color: var(--copp-muted);
    font-size: 14px;
    line-height: 1.45;
    margin: 4px 0 0;
}

.copp-events-calendar__item-format {
    background: rgba(var(--copp-ink-rgb), 0.08);
    border-radius: 0;
    color: var(--copp-muted);
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
    padding: 7px 10px;
    white-space: nowrap;
}

.copp-events-calendar__item-link {
    align-items: center;
    color: var(--copp-ink);
    display: inline-flex;
    height: 40px;
    justify-content: center;
    text-decoration: none;
    width: 40px;
}

.copp-events-calendar__item-link:hover,
.copp-events-calendar__item-link:focus {
    color: var(--copp-red);
    text-decoration: none;
}

.copp-events-calendar__item-link svg {
    height: 14px;
    width: 14px;
}

.copp-events-calendar__meta {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
    flex-wrap: wrap;
}

.copp-events-calendar__legend,
.copp-events-calendar__stats {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.copp-events-calendar__legend-item,
.copp-events-calendar__stat {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 40px;
    padding: 0 14px;
    border-radius: 0;
    background: var(--copp-soft);
    color: var(--copp-ink);
}

.copp-events-calendar__legend-item {
    --calendar-accent: var(--copp-ink);
    --calendar-bg: var(--copp-soft);
    --calendar-fg: var(--copp-ink);
    background: var(--calendar-bg);
    color: var(--calendar-fg);
    font-size: 13px;
    font-weight: 700;
    line-height: 1;
}

.copp-events-calendar__legend-item b {
    font-size: 13px;
    font-weight: 800;
}

.copp-events-calendar__legend-item > span:last-child {
    opacity: 0.75;
}

.copp-events-calendar__legend-swatch {
    width: 10px;
    height: 10px;
    border-radius: 0;
    background: var(--calendar-accent);
    flex-shrink: 0;
}

.copp-events-calendar__legend-item i {
    font-size: 14px;
}

.copp-events-calendar__legend-item--light,
.copp-events-calendar__marker--light,
.copp-events-calendar-preview__card--light,
.copp-events-calendar-tooltip[data-theme="light"] {
    --calendar-accent: var(--copp-muted);
    --calendar-bg: var(--copp-soft);
    --calendar-fg: var(--copp-ink);
}

.copp-events-calendar__legend-item--coral,
.copp-events-calendar__marker--coral,
.copp-events-calendar-preview__card--coral,
.copp-events-calendar-tooltip[data-theme="coral"] {
    --calendar-accent: var(--copp-red);
    --calendar-bg: rgba(var(--copp-red-rgb), 0.13);
    --calendar-fg: var(--copp-ink);
}

.copp-events-calendar__legend-item--red,
.copp-events-calendar__marker--red,
.copp-events-calendar-preview__card--red,
.copp-events-calendar-tooltip[data-theme="red"] {
    --calendar-accent: var(--copp-red);
    --calendar-bg: rgba(var(--copp-red-rgb), 0.12);
    --calendar-fg: var(--copp-ink);
}

.copp-events-calendar__legend-item--deep,
.copp-events-calendar__marker--deep,
.copp-events-calendar-preview__card--deep,
.copp-events-calendar-tooltip[data-theme="deep"] {
    --calendar-accent: var(--copp-red-deep);
    --calendar-bg: rgba(var(--copp-red-rgb), 0.12);
    --calendar-fg: var(--copp-ink);
}

.copp-events-calendar__legend-item--dark,
.copp-events-calendar__marker--dark,
.copp-events-calendar-preview__card--dark,
.copp-events-calendar-tooltip[data-theme="dark"] {
    --calendar-accent: var(--copp-ink);
    --calendar-bg: rgba(var(--copp-ink-rgb), 0.08);
    --calendar-fg: var(--copp-ink);
}

.copp-events-calendar__stat {
    gap: 10px;
}

.copp-events-calendar__stat strong {
    font-size: 18px;
    font-weight: 900;
    line-height: 1;
}

.copp-events-calendar__stat span {
    color: var(--copp-muted);
    font-size: 13px;
    font-weight: 700;
    line-height: 1;
}

.copp-events-calendar__board,
.copp-events-calendar-preview {
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    border-radius: 0;
}

.copp-events-calendar__board {
    overflow: hidden;
}

.copp-events-calendar__month-head--board {
    padding: 20px 20px 18px;
}

.copp-events-calendar__weekdays--board {
    gap: 0;
    border-top: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    border-bottom: 1px solid rgba(var(--copp-ink-rgb), 0.08);
}

.copp-events-calendar__weekdays--board span {
    padding: 12px 0;
    font-size: 13px;
    font-weight: 800;
    color: var(--copp-muted);
}

.copp-events-calendar__grid--board {
    gap: 0;
}

.copp-events-calendar__day {
    aspect-ratio: 1 / 1;
    min-height: 0;
    padding: 8px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    border-right: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    border-bottom: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    background: #ffffff;
    color: inherit;
    text-decoration: none;
    position: relative;
    transition: box-shadow 0.18s ease, background-color 0.18s ease;
}

.copp-events-calendar__day:nth-child(7n) {
    border-right: none;
}

.copp-events-calendar__day.is-empty {
    background: var(--copp-soft);
}

.copp-events-calendar__day:hover,
.copp-events-calendar__day:focus,
.copp-events-calendar__day.is-previewed {
    text-decoration: none;
    color: inherit;
    box-shadow: inset 0 0 0 2px rgba(var(--copp-red-rgb), 0.9);
    z-index: 2;
}

.copp-events-calendar__day.is-selected {
    background: rgba(var(--copp-red-rgb), 0.04);
}

.copp-events-calendar__day-number {
    font-size: 15px;
    font-weight: 900;
    line-height: 1;
}

.copp-events-calendar__markers {
    display: grid;
    gap: 3px;
    align-content: start;
    overflow: hidden;
}

.copp-events-calendar__marker {
    --calendar-accent: var(--copp-ink);
    --calendar-bg: rgba(var(--copp-ink-rgb), 0.08);
    --calendar-fg: var(--copp-ink);
    display: grid;
    gap: 1px;
    padding: 3px 6px;
    border-left: 3px solid var(--calendar-accent);
    border-radius: 0;
    background: var(--calendar-bg);
    color: var(--calendar-fg);
}

.copp-events-calendar__marker-time {
    font-size: 9px;
    font-weight: 800;
    line-height: 1;
    opacity: 0.76;
    text-transform: uppercase;
}

.copp-events-calendar__marker-title {
    font-size: 10px;
    font-weight: 700;
    line-height: 1.25;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.copp-events-calendar__more {
    color: var(--copp-red);
    font-size: 12px;
    font-weight: 800;
    line-height: 1;
    margin-top: 2px;
}

.copp-events-calendar__day-empty {
    margin-top: auto;
    color: var(--copp-muted);
    font-size: 12px;
    line-height: 1.3;
}

.copp-events-calendar-preview {
    padding: 20px;
    display: grid;
    gap: 16px;
    align-self: start;
    position: sticky;
    top: 112px;
}

.copp-events-calendar-preview__head {
    display: grid;
    gap: 6px;
}

.copp-events-calendar-preview__head p {
    margin: 0;
    color: var(--copp-muted);
    font-size: 12px;
    font-weight: 800;
    line-height: 1;
    text-transform: uppercase;
}

.copp-events-calendar-preview__head h3 {
    margin: 0;
    font-size: 26px;
    font-weight: 900;
    line-height: 1.15;
    color: var(--copp-ink);
}

.copp-events-calendar-preview__head span {
    color: var(--copp-muted);
    font-size: 14px;
    font-weight: 700;
    line-height: 1.3;
}

.copp-events-calendar-preview__list {
    display: grid;
    gap: 12px;
}

.copp-events-calendar-preview__card {
    --calendar-accent: var(--copp-ink);
    --calendar-bg: rgba(var(--copp-ink-rgb), 0.08);
    --calendar-fg: var(--copp-ink);
    display: grid;
    gap: 10px;
    padding: 14px;
    border-radius: 0;
    border-left: 4px solid var(--calendar-accent);
    background: var(--calendar-bg);
    color: var(--calendar-fg);
    text-decoration: none;
}

.copp-events-calendar-preview__card:hover,
.copp-events-calendar-preview__card:focus {
    color: var(--calendar-fg);
    text-decoration: none;
}

.copp-events-calendar-preview__card-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.copp-events-calendar-preview__card-type,
.copp-events-calendar-preview__card-time,
.copp-events-calendar-preview__card-format {
    font-size: 12px;
    font-weight: 800;
    line-height: 1.2;
}

.copp-events-calendar-preview__card strong {
    color: var(--copp-ink);
    font-size: 18px;
    font-weight: 900;
    line-height: 1.25;
}

.copp-events-calendar-preview__card p {
    margin: 0;
    color: var(--copp-muted);
    font-size: 14px;
    line-height: 1.45;
}

.copp-events-calendar-preview__empty {
    color: var(--copp-muted);
    font-size: 14px;
    line-height: 1.5;
}

.copp-events-calendar-tooltip {
    --calendar-accent: var(--copp-ink);
    --calendar-bg: #ffffff;
    position: fixed;
    z-index: 1200;
    width: min(320px, calc(100vw - 32px));
    padding: 14px 15px;
    border-radius: 0;
    border-top: 4px solid var(--calendar-accent);
    background: #ffffff;
    box-shadow: 0 18px 44px rgba(12, 13, 18, 0.18);
    pointer-events: none;
    display: grid;
    gap: 6px;
}

.copp-events-calendar-tooltip__type {
    color: var(--calendar-accent);
    font-size: 12px;
    font-weight: 800;
    line-height: 1.1;
    text-transform: uppercase;
}

.copp-events-calendar-tooltip strong {
    color: var(--copp-ink);
    font-size: 16px;
    font-weight: 900;
    line-height: 1.3;
}

.copp-events-calendar-tooltip__time,
.copp-events-calendar-tooltip__meta {
    color: var(--copp-muted);
    font-size: 13px;
    line-height: 1.4;
}

.copp-events-empty {
    color: var(--copp-muted);
    font-size: 16px;
    line-height: 1.5;
    padding: 28px 24px;
}

.copp-events-page--calendar {
    gap: 34px;
}

.copp-events-section__lead {
    margin: -6px 0 0;
    color: var(--copp-muted);
    font-size: 15px;
    line-height: 1.6;
    max-width: 720px;
}

.copp-events-calendar__layout--expanded {
    grid-template-columns: auto minmax(340px, 400px);
    align-items: start;
}

.copp-events-calendar__layout--expanded .copp-events-calendar__board {
    width: 100%;
    max-width: 560px;
}

.copp-events-calendar__layout--expanded .copp-events-calendar__grid--board {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
}

.copp-events-calendar__layout--expanded .copp-events-calendar__day {
    aspect-ratio: 1 / 1;
    min-height: 0;
}

.copp-events-cards--detail {
    --copp-grid-columns: 3;
    grid-template-columns: repeat(var(--copp-grid-columns), minmax(0, 1fr));
}

.copp-events-types__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

.copp-events-type-tile {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 10px;
    padding: 14px 16px;
    text-decoration: none;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.copp-events-type-tile--light {
    background: var(--copp-pale);
    color: var(--copp-ink);
}

.copp-events-type-tile--coral {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-events-type-tile--red {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-events-type-tile--deep {
    background: var(--copp-red-deep);
    color: #ffffff;
}

.copp-events-type-tile--dark {
    background: var(--copp-ink);
    color: #ffffff;
}

.copp-events-type-tile:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(var(--copp-ink-rgb), 0.1);
    text-decoration: none;
    color: inherit;
}

.copp-events-type-tile__icon {
    font-size: 16px;
    line-height: 1;
    opacity: 0.9;
}

.copp-events-type-tile__title {
    font-size: 14px;
    font-weight: var(--copp-fw-bold);
    text-transform: uppercase;
    letter-spacing: var(--copp-ls-label);
    line-height: 1.2;
}

.copp-events-type-tile__count {
    font-size: 18px;
    font-weight: var(--copp-fw-black);
    opacity: 0.85;
}

@media (max-width: 991px) {
    .copp-events-types__grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .copp-events-types__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

.copp-events-type-card {
    min-height: 156px;
    border-radius: 0;
    padding: 22px 18px 18px;
    display: grid;
    grid-template-rows: auto auto 1fr auto;
    gap: 12px;
    color: inherit;
    text-decoration: none;
}

.copp-events-type-card:hover,
.copp-events-type-card:focus {
    color: inherit;
    text-decoration: none;
}

.copp-events-type-card--light {
    background: var(--copp-pale);
    color: var(--copp-ink);
}

.copp-events-type-card--coral {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-events-type-card--red {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-events-type-card--deep {
    background: var(--copp-red-deep);
    color: #ffffff;
}

.copp-events-type-card--dark {
    background: var(--copp-ink);
    color: #ffffff;
}

.copp-events-type-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    font-size: 22px;
    line-height: 1;
}

.copp-events-type-card h3 {
    margin: 0;
    font-size: 26px;
    font-weight: 900;
    line-height: 1.14;
}

.copp-events-type-card p {
    margin: 0;
    color: inherit;
    opacity: 0.88;
    font-size: 14px;
    line-height: 1.35;
}

.copp-events-type-card__arrow {
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    justify-self: end;
    border: 1px solid currentColor;
    border-radius: 0;
    display: inline-flex;
}

.copp-events-type-card__arrow svg {
    width: 14px;
    height: 14px;
}

.copp-events-cta {
    margin-top: 8px;
}

.copp-events-cta .copp-news-cta__copy h2 {
    max-width: 420px;
}

.copp-events-cta .copp-news-cta__copy p {
    max-width: 420px;
}

.copp-about-page-content .field.ft_html.f_content {
    margin-bottom: 0;
}

.copp-about-page-content .field.ft_html.f_content > .value > *:last-child {
    margin-bottom: 0;
}

.copp-about-content {
    display: grid;
    gap: 42px;
}

.copp-about-page-intro {
    color: rgba(var(--copp-ink-rgb), 0.82);
    display: grid;
    gap: 12px;
    line-height: 1.7;
    max-width: 900px;
}

.copp-about-page-intro > * {
    margin: 0;
}

.copp-about-page-intro h2,
.copp-about-page-intro h3 {
    color: var(--copp-ink);
    font-size: clamp(26px, 2.6vw, 34px);
    font-weight: 900;
    line-height: 1.12;
    margin-top: 10px;
}

.copp-about-page-intro h3 {
    font-size: clamp(22px, 2.2vw, 28px);
}

.copp-about-page-intro ul,
.copp-about-page-intro ol {
    display: grid;
    gap: 10px;
    margin: 0;
    padding-left: 22px;
}

.copp-about-page-intro li {
    color: inherit;
}

.copp-about-page-intro strong {
    color: var(--copp-ink);
}

.copp-about-subpage-hero .copp-news-hero__copy {
    max-width: 680px;
    position: relative;
    z-index: 2;
}

.copp-about-subpage-hero .copp-news-hero__title {
    font-size: clamp(34px, 3.8vw, 60px);
    line-height: var(--copp-lh-hero);
    max-width: 520px;
}

.copp-about-subpage-hero__eyebrow {
    color: rgba(var(--copp-ink-rgb), 0.56);
    display: inline-flex;
    font-size: var(--copp-fs-eyebrow);
    font-weight: var(--copp-fw-eyebrow);
    letter-spacing: var(--copp-ls-eyebrow);
    margin-bottom: 16px;
    text-transform: uppercase;
}

.copp-about-subpage-hero__subtitle {
    font-size: clamp(24px, 2.2vw, 30px);
    line-height: 1.2;
    max-width: 620px;
    text-transform: none;
}

.copp-about-subpage-hero__lead {
    max-width: 620px;
}

.copp-about-subpage-hero__badge-main {
    font-size: 22px;
}

.copp-about-documents-grid {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.copp-about-document-card {
    background:
        linear-gradient(145deg, rgba(var(--copp-ink-rgb), 0.03) 0, rgba(var(--copp-ink-rgb), 0) 50%),
        #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    border-radius: 0;
    box-shadow: 0 18px 42px rgba(var(--copp-ink-rgb), 0.08);
    color: inherit;
    display: grid;
    gap: 12px;
    min-height: 100%;
    padding: 22px;
    text-decoration: none;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.copp-about-document-card:hover {
    border-color: rgba(var(--copp-red-rgb), 0.28);
    box-shadow: 0 24px 48px rgba(var(--copp-ink-rgb), 0.12);
    transform: translateY(-2px);
}

.copp-about-document-card__badge {
    align-items: center;
    background: rgba(var(--copp-red-rgb), 0.1);
    border-radius: 0;
    color: var(--copp-red);
    display: inline-flex;
    font-size: var(--copp-fs-badge);
    font-weight: var(--copp-fw-bold);
    letter-spacing: var(--copp-ls-label);
    line-height: 1;
    padding: 8px 12px;
    text-transform: uppercase;
    width: fit-content;
}

.copp-about-document-card strong {
    color: var(--copp-ink);
    font-size: 22px;
    font-weight: 900;
    line-height: 1.15;
}

.copp-about-document-card p {
    color: rgba(var(--copp-ink-rgb), 0.74);
    line-height: 1.6;
    margin: 0;
}

.copp-about-document-card__link {
    align-items: center;
    color: var(--copp-red);
    display: inline-flex;
    gap: 10px;
    font-weight: 800;
    margin-top: auto;
}

.copp-about-feature-grid {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.copp-about-feature-grid--compact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.copp-vacancies {
    display: grid;
    gap: 20px;
}

.copp-vacancies__search {
    background: var(--copp-soft);
    padding: 20px;
}

.copp-vacancies__form {
    display: flex;
    gap: 10px;
}

.copp-vacancies__input-wrap {
    align-items: center;
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.12);
    display: flex;
    flex: 1;
    gap: 10px;
    padding: 0 14px;
}

.copp-vacancies__input-wrap i {
    color: var(--copp-muted);
    font-size: 14px;
}

.copp-vacancies__input {
    background: none;
    border: none;
    color: var(--copp-ink);
    font-size: 14px;
    height: 44px;
    outline: none;
    width: 100%;
}

.copp-vacancies__input::placeholder {
    color: var(--copp-muted);
}

.copp-vacancies__btn {
    background: var(--copp-red);
    border: none;
    color: #ffffff;
    cursor: pointer;
    font-size: var(--copp-fs-btn);
    font-weight: 900;
    height: 44px;
    padding: 0 24px;
    text-transform: uppercase;
    transition: background 0.15s;
}

.copp-vacancies__btn:hover {
    background: var(--copp-red);
}

.copp-vacancies__meta {
    color: var(--copp-muted);
    font-size: 12px;
    margin-top: 10px;
}

.copp-vacancies__grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(2, 1fr);
    min-height: 200px;
}

.copp-vacancies__loading {
    align-items: center;
    display: flex;
    gap: 10px;
    grid-column: 1 / -1;
    justify-content: center;
    padding: 60px 0;
    color: var(--copp-muted);
    font-size: 14px;
}

.copp-vac-card {
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    display: grid;
    gap: 8px;
    padding: 18px;
    position: relative;
    overflow: hidden;
    transition: border-color 0.15s, box-shadow 0.15s;
}

.copp-vac-card:hover {
    border-color: rgba(var(--copp-red-rgb), 0.2);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.06);
}

.copp-vac-card__title {
    color: var(--copp-ink);
    font-size: var(--copp-fs-card-title);
    font-weight: var(--copp-fw-bold);
    line-height: var(--copp-lh-card-title);
    margin: 0;
}

.copp-vac-card__employer {
    color: var(--copp-red);
    font-size: 13px;
    font-weight: 700;
    margin: 0;
}

.copp-vac-card__details {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.copp-vac-card__tag {
    background: var(--copp-soft);
    color: var(--copp-muted);
    font-size: var(--copp-fs-badge);
    font-weight: var(--copp-fw-bold);
    letter-spacing: var(--copp-ls-label);
    padding: 3px 8px;
    text-transform: uppercase;
}

.copp-vac-card__tag--salary {
    background: rgba(var(--copp-red-rgb), 0.08);
    color: var(--copp-red);
}

.copp-vac-card__link {
    align-items: center;
    color: var(--copp-red);
    display: inline-flex;
    font-size: 12px;
    font-weight: 900;
    gap: 6px;
    text-decoration: none;
    text-transform: uppercase;
}

.copp-vac-card__link:hover {
    text-decoration: underline;
}

.copp-vac-card__link svg {
    height: 12px;
    width: 12px;
}

.copp-vacancies__pagination {
    align-items: center;
    display: flex;
    gap: 8px;
    justify-content: center;
}

.copp-vacancies__page-btn {
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.1);
    cursor: pointer;
    font-size: 13px;
    font-weight: 700;
    height: 38px;
    padding: 0 14px;
    transition: background 0.15s, border-color 0.15s;
}

.copp-vacancies__page-btn:hover {
    border-color: var(--copp-red);
    color: var(--copp-red);
}

.copp-vacancies__page-btn:disabled {
    cursor: default;
    opacity: 0.4;
}

.copp-vacancies__page-btn--active {
    background: var(--copp-red);
    border-color: var(--copp-red);
    color: #ffffff;
}

.copp-vacancies__source {
    color: var(--copp-muted);
    font-size: 12px;
    text-align: center;
}

.copp-vacancies__source a {
    color: var(--copp-red);
    font-weight: 700;
    text-decoration: none;
}

.copp-vacancies__source a:hover {
    text-decoration: underline;
}

.copp-vacancies__empty {
    color: var(--copp-muted);
    font-size: 14px;
    grid-column: 1 / -1;
    padding: 40px 0;
    text-align: center;
}

@media (max-width: 767px) {
    .copp-vacancies__grid {
        grid-template-columns: 1fr;
    }

    .copp-vacancies__form {
        flex-direction: column;
    }
}

.copp-vacancies__tabs {
    display: flex;
    gap: 0;
    border-bottom: 2px solid var(--copp-pale);
}

.copp-vacancies__tab {
    padding: 12px 24px;
    font-size: 15px;
    font-weight: 700;
    color: var(--copp-muted);
    background: none;
    border: none;
    cursor: pointer;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    transition: color 0.2s, border-color 0.2s;
}

.copp-vacancies__tab:hover {
    color: var(--copp-red);
}

.copp-vacancies__tab.is-active {
    color: var(--copp-red);
    border-bottom-color: var(--copp-red);
}

.copp-vac-partners {
    display: grid;
    gap: 32px;
}

.copp-vac-partners__group {
    display: grid;
    gap: 16px;
}

.copp-vac-partners__heading {
    font-size: 18px;
    font-weight: 800;
    color: var(--copp-ink);
    margin: 0;
    padding-bottom: 8px;
    border-bottom: 2px solid var(--copp-red);
    display: inline-block;
}

.copp-vac-partners__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 12px;
}

.copp-vac-partner {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 16px;
    background: var(--copp-soft);
    text-decoration: none;
    color: inherit;
    transition: background 0.2s, transform 0.2s;
}

.copp-vac-partner:hover {
    background: var(--copp-pale);
    transform: translateY(-1px);
}

.copp-vac-partner__icon {
    width: 32px;
    height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--copp-red);
    color: #ffffff;
    font-size: 14px;
}

.copp-vac-partner__name {
    font-size: 15px;
    font-weight: 800;
    color: var(--copp-ink);
}

.copp-vac-partner__desc {
    font-size: 13px;
    color: var(--copp-muted);
    line-height: 1.4;
}

.copp-structure-section {
    display: grid;
    gap: 20px;
}

.copp-structure-section + .copp-structure-section {
    border-top: 2px solid var(--copp-soft);
    padding-top: 28px;
}

.copp-structure-section__head {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px 16px;
    justify-content: space-between;
}

.copp-vac-analytics {
    display: grid;
    gap: 24px;
}

.copp-vac-analytics__loading,
.copp-vac-analytics__error {
    padding: 60px 0;
    text-align: center;
    color: var(--copp-muted);
    font-size: 15px;
}

.copp-va-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}

.copp-va-stat {
    background: var(--copp-soft);
    padding: 24px 20px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.copp-va-stat__value {
    font-size: 28px;
    font-weight: 800;
    color: var(--copp-ink);
    line-height: 1.1;
}

.copp-va-stat__value--red {
    color: var(--copp-red);
}

.copp-va-stat__label {
    font-size: 13px;
    font-weight: 600;
    color: var(--copp-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.copp-va-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}

.copp-va-card {
    background: var(--copp-pale);
    border: 1px solid var(--copp-line);
    padding: 20px;
}

.copp-va-card--full {
    grid-column: 1 / -1;
}

.copp-va-section-title {
    font-size: 20px;
    font-weight: 800;
    color: var(--copp-ink);
    margin: 32px 0 16px;
    padding-bottom: 8px;
    border-bottom: 3px solid var(--copp-red);
}

.copp-va-section-title:first-of-type {
    margin-top: 16px;
}

.copp-va-card__title {
    font-size: 16px;
    font-weight: 800;
    color: var(--copp-ink);
    margin: 0 0 16px;
}

.copp-va-chart {
    max-height: 420px;
    cursor: pointer;
}

.copp-va-card:hover {
    border-color: var(--copp-red);
}

.copp-va-filters {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    min-height: 36px;
}

.copp-va-filter-hint {
    font-size: 13px;
    color: var(--copp-muted);
    font-style: italic;
}

.copp-va-filter-tag {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: var(--copp-red);
    color: #ffffff;
    font-size: var(--copp-fs-badge);
    font-weight: var(--copp-fw-bold);
    letter-spacing: var(--copp-ls-label);
    text-transform: uppercase;
    border: none;
    cursor: pointer;
    transition: background 0.2s;
}

.copp-va-filter-tag:hover {
    background: var(--copp-red-dark);
}

.copp-va-filter-tag i {
    font-size: 11px;
    opacity: 0.8;
}

.copp-va-filter-clear {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    background: transparent;
    color: var(--copp-red);
    font-size: 13px;
    font-weight: 600;
    border: 1px solid var(--copp-red);
    cursor: pointer;
    transition: all 0.2s;
}

.copp-va-filter-clear:hover {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-va-search-wrap {
    position: relative;
    max-width: 480px;
}

.copp-va-search-wrap i {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--copp-muted);
    font-size: 14px;
}

.copp-va-search {
    width: 100%;
    padding: 10px 14px 10px 40px;
    border: 1px solid var(--copp-line);
    font-size: 14px;
    color: var(--copp-ink);
    background: var(--copp-pale);
    transition: border-color 0.2s;
}

.copp-va-search:focus {
    outline: none;
    border-color: var(--copp-red);
}

.copp-va-table-wrap {
    overflow-x: auto;
}

.copp-va-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
}

.copp-va-th {
    text-align: left;
    padding: 12px 14px;
    background: var(--copp-soft);
    font-weight: 700;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--copp-muted);
    cursor: pointer;
    user-select: none;
    white-space: nowrap;
    transition: background 0.2s;
}

.copp-va-th:hover {
    background: var(--copp-pale);
}

.copp-va-th.is-desc::after {
    content: ' \25BC';
    font-size: 10px;
}

.copp-va-th.is-asc::after {
    content: ' \25B2';
    font-size: 10px;
}

.copp-va-td {
    padding: 10px 14px;
    border-bottom: 1px solid var(--copp-pale);
    color: var(--copp-ink);
    vertical-align: top;
}

.copp-va-td--name a {
    color: var(--copp-ink);
    text-decoration: none;
    font-weight: 600;
    transition: color 0.2s;
}

.copp-va-td--name a:hover {
    color: var(--copp-red);
}

.copp-va-td--salary {
    font-weight: 700;
    white-space: nowrap;
    color: var(--copp-red);
}

.copp-va-table__empty {
    text-align: center;
    padding: 40px 14px;
    color: var(--copp-muted);
    font-size: 15px;
}

.copp-va-table-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 0;
    flex-wrap: wrap;
    gap: 12px;
}

.copp-va-table-info {
    font-size: 13px;
    color: var(--copp-muted);
}

.copp-va-table-pages {
    display: flex;
    gap: 4px;
}

.copp-va-page {
    padding: 6px 10px;
    font-size: 13px;
    font-weight: 600;
    background: var(--copp-soft);
    border: none;
    cursor: pointer;
    transition: all 0.2s;
    color: var(--copp-ink);
}

.copp-va-page:hover:not(:disabled) {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-va-page:disabled {
    opacity: 0.4;
    cursor: default;
}

.copp-va-page--active {
    background: var(--copp-red);
    color: #ffffff;
}

@media (max-width: 767px) {
    .copp-va-stats {
        grid-template-columns: repeat(2, 1fr);
    }
    .copp-va-grid {
        grid-template-columns: 1fr;
    }
    .copp-va-stat__value {
        font-size: 22px;
    }
    .copp-va-table {
        font-size: 13px;
    }
    .copp-va-th,
    .copp-va-td {
        padding: 8px 10px;
    }
    .copp-va-search-wrap {
        max-width: 100%;
    }
}

.copp-tips {
    display: grid;
    gap: 32px;
}

.copp-tips__intro {
    border-left: 4px solid var(--copp-red);
    padding: 16px 20px;
    background: var(--copp-soft);
    font-size: var(--copp-fs-body);
    color: var(--copp-ink);
    line-height: var(--copp-lh-body);
}

.copp-tips__intro p {
    margin: 0;
}

.copp-tips__road {
    display: grid;
    gap: 0;
}

.copp-tips__step {
    display: grid;
    grid-template-columns: 72px 1fr;
    gap: 0;
}

.copp-tips__step-rail {
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
}

.copp-tips__step-num {
    width: 40px;
    height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--copp-ink);
    color: #ffffff;
    font-size: var(--copp-fs-badge);
    font-weight: var(--copp-fw-bold);
    letter-spacing: var(--copp-ls-eyebrow);
    flex-shrink: 0;
    z-index: 1;
}

.copp-tips__step-line {
    width: 2px;
    flex: 1;
    background: var(--copp-pale);
    min-height: 24px;
}

.copp-tips__step:last-child .copp-tips__step-line {
    display: none;
}

.copp-tips__step-body {
    padding-bottom: 24px;
    min-width: 0;
}

.copp-tips__step:last-child .copp-tips__step-body {
    padding-bottom: 0;
}

.copp-tips__step-header {
    display: flex;
    align-items: center;
    gap: 14px;
    width: 100%;
    background: var(--copp-soft);
    border: none;
    cursor: pointer;
    text-align: left;
    font-family: inherit;
    color: inherit;
    padding: 14px 18px;
    transition: background 0.2s;
}

.copp-tips__step-header:hover {
    background: var(--copp-pale);
}

.copp-tips__step-header[aria-expanded="true"] {
    background: var(--copp-ink);
    color: #ffffff;
}

.copp-tips__step-icon {
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    background: var(--copp-ink);
    color: #ffffff;
    flex-shrink: 0;
    transition: background 0.2s;
}

.copp-tips__step-header[aria-expanded="true"] .copp-tips__step-icon {
    background: var(--copp-red);
}

.copp-tips__step-title-wrap {
    flex: 1;
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.copp-tips__step-title {
    font-size: var(--copp-fs-card-title);
    font-weight: var(--copp-fw-bold);
    line-height: 1.25;
    margin: 0;
}

.copp-tips__step-tier {
    display: inline-flex;
    padding: 2px 10px;
    font-size: var(--copp-fs-badge);
    font-weight: var(--copp-fw-bold);
    letter-spacing: var(--copp-ls-eyebrow);
    text-transform: uppercase;
    background: var(--copp-red);
    color: #ffffff;
    flex-shrink: 0;
}

.copp-tips__step-tier--resume,
.copp-tips__step-tier--cover,
.copp-tips__step-tier--interview,
.copp-tips__step-tier--style,
.copp-tips__step-tier--grow {
    background: var(--copp-red);
}

.copp-tips__step-tier--platforms,
.copp-tips__step-tier--network,
.copp-tips__step-tier--track {
    background: var(--copp-ink);
}

.copp-tips__step-header[aria-expanded="true"] .copp-tips__step-tier {
    background: var(--copp-red);
}

.copp-tips__step-chevron {
    font-size: 14px;
    color: var(--copp-muted);
    flex-shrink: 0;
    transition: transform 0.3s;
}

.copp-tips__step-header[aria-expanded="true"] .copp-tips__step-chevron {
    color: rgba(255,255,255,0.6);
    transform: rotate(180deg);
}

.copp-tips__step-detail {
    display: grid;
    gap: 14px;
    padding: 18px 18px 18px 76px;
    background: var(--copp-soft);
    border-top: 1px solid var(--copp-pale);
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transition: max-height 0.4s ease, opacity 0.3s ease, padding 0.3s ease;
    padding-top: 0;
    padding-bottom: 0;
}

.copp-tips__step.is-open .copp-tips__step-detail {
    max-height: 500px;
    opacity: 1;
    padding: 18px 18px 18px 76px;
}

.copp-tips__step-desc {
    font-size: var(--copp-fs-body);
    color: var(--copp-ink);
    line-height: var(--copp-lh-body);
    margin: 0;
}

.copp-tips__step-pairs {
    display: grid;
    gap: 10px;
}

.copp-tips__pair {
    display: grid;
    grid-template-columns: 120px 1fr;
    gap: 10px;
    align-items: baseline;
    font-size: var(--copp-fs-body);
    line-height: var(--copp-lh-body);
}

.copp-tips__pair-label {
    font-weight: var(--copp-fw-bold);
    display: inline-flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
}

.copp-tips__pair--do .copp-tips__pair-label {
    color: var(--copp-ink);
}

.copp-tips__pair--dont .copp-tips__pair-label {
    color: var(--copp-red);
}

.copp-tips__pair-text {
    color: var(--copp-ink);
}

.copp-tips__step-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: var(--copp-fs-body);
    font-weight: var(--copp-fw-bold);
    color: var(--copp-red);
    text-decoration: none;
}

.copp-tips__step-link:hover {
    text-decoration: underline;
}

.copp-tips__step-link i {
    font-size: 12px;
    transition: transform 0.2s;
}

.copp-tips__step-link:hover i {
    transform: translateX(4px);
}

.copp-tips__outro {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 20px;
    align-items: center;
    padding: 28px 24px;
    background: var(--copp-ink);
    color: #ffffff;
}

.copp-tips__outro h3 {
    font-size: var(--copp-fs-section);
    font-weight: var(--copp-fw-heading);
    margin: 0 0 4px;
    color: #ffffff;
}

.copp-tips__outro p {
    font-size: var(--copp-fs-body);
    margin: 0;
    color: rgba(255,255,255,0.75);
    line-height: var(--copp-lh-body);
}

.copp-tips__outro-actions {
    display: flex;
    gap: 12px;
    flex-shrink: 0;
}

.copp-tips__outro-btn {
    padding: 12px 28px;
    font-size: var(--copp-fs-btn);
    font-weight: var(--copp-fw-bold);
    background: var(--copp-red);
    color: #ffffff;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: var(--copp-ls-eyebrow);
    transition: background 0.2s;
}

.copp-tips__outro-btn:hover {
    background: var(--copp-red-dark);
}

.copp-tips__outro-btn--outline {
    background: transparent;
    color: #ffffff;
    border: 2px solid rgba(255,255,255,0.4);
}

.copp-tips__outro-btn--outline:hover {
    background: #ffffff;
    color: var(--copp-ink);
    border-color: #ffffff;
}

.copp-rights {
    display: grid;
    gap: 24px;
}

.copp-rights__preamble {
    border-left: 4px solid var(--copp-red);
    padding: 16px 20px;
    background: var(--copp-soft);
}

.copp-rights__preamble p {
    font-size: var(--copp-fs-body);
    color: var(--copp-ink);
    line-height: var(--copp-lh-body);
    margin: 0;
    font-weight: var(--copp-fw-bold);
}

.copp-rights__list {
    display: grid;
    gap: 8px;
}

.copp-rights__item {
    background: var(--copp-soft);
    overflow: hidden;
    transition: background 0.2s;
}

.copp-rights__item.is-open {
    background: var(--copp-pale);
}

.copp-rights__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 16px 20px;
    background: none;
    border: none;
    cursor: pointer;
    text-align: left;
    color: var(--copp-ink);
    font-family: inherit;
    gap: 12px;
}

.copp-rights__header:hover {
    background: var(--copp-pale);
}

.copp-rights__header-left {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1;
    min-width: 0;
}

.copp-rights__header h3 {
    font-size: var(--copp-fs-card-title);
    font-weight: var(--copp-fw-bold);
    color: var(--copp-ink);
    margin: 0;
}

.copp-rights__sev {
    display: inline-flex;
    align-items: center;
    padding: 3px 10px;
    font-size: var(--copp-fs-badge);
    font-weight: var(--copp-fw-bold);
    letter-spacing: var(--copp-ls-eyebrow);
    text-transform: uppercase;
    flex-shrink: 0;
}

.copp-rights__sev--critical {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-rights__sev--important {
    background: var(--copp-ink);
    color: #ffffff;
}

.copp-rights__chevron {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    color: var(--copp-muted);
    transition: transform 0.25s;
    flex-shrink: 0;
}

.copp-rights__item.is-open .copp-rights__chevron {
    transform: rotate(180deg);
}

.copp-rights__body {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.35s ease, padding 0.35s ease;
    padding: 0 20px;
}

.copp-rights__item.is-open .copp-rights__body {
    max-height: 300px;
    padding: 0 20px 16px;
}

.copp-rights__body p {
    font-size: var(--copp-fs-body);
    color: var(--copp-muted);
    line-height: var(--copp-lh-body);
    margin: 0 0 12px;
}

.copp-rights__ref {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--copp-soft);
    padding: 6px 12px;
}

.copp-rights__ref-label {
    font-size: var(--copp-fs-badge);
    font-weight: var(--copp-fw-bold);
    text-transform: uppercase;
    letter-spacing: var(--copp-ls-eyebrow);
    color: var(--copp-muted);
}

.copp-rights__ref-val {
    font-size: var(--copp-fs-body);
    font-weight: var(--copp-fw-bold);
    color: var(--copp-red);
}

.copp-rights__ref-val--link {
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.copp-rights__ref-val--link:hover {
    text-decoration: underline;
}

.copp-rights__ref-val--link i {
    font-size: 11px;
}

.copp-rights__footer {
    display: grid;
    gap: 20px;
    padding-top: 12px;
}

.copp-rights__legend {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    justify-content: center;
}

.copp-rights__legend-item {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: var(--copp-fs-badge);
    color: var(--copp-muted);
}

.copp-rights__legend-item .copp-rights__sev {
    padding: 2px 8px;
    font-size: 11px;
}

.copp-rights__links {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 24px;
    justify-content: center;
}

.copp-rights__links a {
    font-size: var(--copp-fs-body);
    font-weight: var(--copp-fw-bold);
    color: var(--copp-red);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.copp-rights__links a:hover {
    text-decoration: underline;
}

.copp-rights__links a i {
    font-size: 11px;
}

.copp-structure-section__head-left {
    align-items: center;
    display: flex;
    gap: 14px;
}

.copp-structure-section__num {
    color: var(--copp-red);
    font-size: 28px;
    font-weight: 900;
    line-height: 1;
}

.copp-structure-section__num--light {
    color: rgba(255, 255, 255, 0.3);
}

.copp-structure-section__head h2 {
    color: var(--copp-ink);
    font-size: 20px;
    font-weight: 900;
    line-height: 1.2;
    margin: 0;
}

.copp-structure-section--benefits .copp-structure-section__head h2 {
    color: #ffffff;
}

.copp-structure-section__head p {
    color: var(--copp-muted);
    font-size: 13px;
    line-height: 1.4;
    margin: 0;
}

.copp-structure-section--benefits .copp-structure-section__head p {
    color: rgba(255, 255, 255, 0.5);
}

.copp-structure-section--flow {
    background: var(--copp-soft);
    border: 1px solid rgba(var(--copp-ink-rgb), 0.06);
    padding: 28px;
}

.copp-structure-section--benefits {
    background: var(--copp-ink);
    padding: 28px;
}

.copp-structure-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(3, 1fr);
}

.copp-structure-card {
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    display: grid;
    gap: 12px;
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto;
    padding: 20px;
    position: relative;
    transition: border-color 0.15s, box-shadow 0.15s;
}

.copp-structure-card:hover {
    border-color: rgba(var(--copp-red-rgb), 0.2);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
}

.copp-structure-card__num {
    color: rgba(var(--copp-ink-rgb), 0.12);
    font-size: 32px;
    font-weight: 900;
    grid-column: 1;
    grid-row: 1 / 3;
    line-height: 1;
}

.copp-structure-card__icon {
    align-items: center;
    background: rgba(var(--copp-red-rgb), 0.08);
    color: var(--copp-red);
    display: inline-flex;
    font-size: 16px;
    grid-column: 2;
    height: 36px;
    justify-content: center;
    width: 36px;
}

.copp-structure-card__body {
    grid-column: 2;
}

.copp-structure-card h3 {
    color: var(--copp-ink);
    font-size: 16px;
    font-weight: 900;
    line-height: 1.2;
    margin: 0 0 6px 0;
}

.copp-structure-card p {
    color: rgba(var(--copp-ink-rgb), 0.65);
    font-size: var(--copp-fs-body);
    line-height: var(--copp-lh-body);
    margin: 0;
}

.copp-structure-flow {
    display: grid;
    gap: 0;
    grid-template-columns: repeat(4, 1fr);
    position: relative;
}

.copp-structure-flow::before {
    content: "";
    position: absolute;
    top: 28px;
    left: 40px;
    right: 40px;
    height: 2px;
    background: linear-gradient(90deg, var(--copp-red) 0%, rgba(var(--copp-red-rgb), 0.15) 100%);
    z-index: 0;
}

.copp-structure-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    padding: 0 16px;
    position: relative;
    text-align: center;
    z-index: 1;
}

.copp-structure-step__num {
    align-items: center;
    background: var(--copp-red);
    color: #ffffff;
    display: inline-flex;
    font-size: 14px;
    font-weight: 900;
    height: 56px;
    justify-content: center;
    width: 56px;
    transform: rotate(45deg);
}

.copp-structure-step__num span,
.copp-structure-step__num {
    transform: rotate(45deg);
}

.copp-structure-step__icon {
    color: var(--copp-red);
    font-size: 20px;
}

.copp-structure-step h3 {
    color: var(--copp-ink);
    font-size: 14px;
    font-weight: 900;
    line-height: 1.2;
    margin: 0;
}

.copp-structure-step p {
    color: rgba(var(--copp-ink-rgb), 0.6);
    font-size: 12px;
    line-height: 1.5;
    margin: 0;
    max-width: 200px;
}

.copp-structure-benefits {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(2, 1fr);
}

.copp-structure-benefit {
    align-items: flex-start;
    display: flex;
    gap: 16px;
}

.copp-structure-benefit__icon {
    align-items: center;
    background: rgba(var(--copp-red-rgb), 0.15);
    color: var(--copp-red);
    display: inline-flex;
    flex-shrink: 0;
    font-size: 16px;
    height: 40px;
    justify-content: center;
    width: 40px;
}

.copp-structure-benefit h3 {
    color: #ffffff;
    font-size: 15px;
    font-weight: 900;
    line-height: 1.2;
    margin: 0 0 4px 0;
}

.copp-structure-benefit p {
    color: rgba(255, 255, 255, 0.6);
    font-size: 13px;
    line-height: 1.5;
    margin: 0;
}

@media (max-width: 991.98px) {
    .copp-structure-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .copp-structure-flow {
        grid-template-columns: repeat(2, 1fr);
        gap: 24px;
    }

    .copp-structure-flow::before {
        display: none;
    }

    .copp-structure-benefits {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 575.98px) {
    .copp-structure-grid {
        grid-template-columns: 1fr;
    }

    .copp-structure-flow {
        grid-template-columns: 1fr;
    }

    .copp-structure-section--flow,
    .copp-structure-section--benefits {
        padding: 20px 16px;
    }

    .copp-structure-section__head-left {
        gap: 10px;
    }

    .copp-structure-section__num {
        font-size: 22px;
    }

    .copp-structure-section__head h2 {
        font-size: 17px;
    }
}

.copp-about-feature-card {
    background:
        linear-gradient(145deg, rgba(var(--copp-red-rgb), 0.08) 0, rgba(var(--copp-red-rgb), 0) 52%),
        #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    border-radius: 0;
    box-shadow: 0 18px 42px rgba(var(--copp-ink-rgb), 0.08);
    display: grid;
    align-content: start;
    gap: 12px;
    min-height: 100%;
    padding: 22px;
}

.copp-about-feature-card--principle,
.copp-about-feature-card--benefit {
    background:
        linear-gradient(145deg, rgba(var(--copp-ink-rgb), 0.03) 0, rgba(var(--copp-ink-rgb), 0) 48%),
        #ffffff;
}

.copp-about-feature-card__icon {
    align-items: center;
    background: rgba(var(--copp-red-rgb), 0.1);
    border-radius: 0;
    color: var(--copp-red);
    display: inline-flex;
    font-size: 18px;
    height: 42px;
    justify-content: center;
    width: 42px;
}

.copp-about-feature-card h3 {
    color: var(--copp-ink);
    font-size: 22px;
    font-weight: 900;
    line-height: 1.16;
    margin: 0;
}

.copp-about-feature-card p {
    color: rgba(var(--copp-ink-rgb), 0.74);
    line-height: 1.6;
    margin: 0;
}

@media (max-width: 991.98px) {
    .copp-about-documents-grid,
    .copp-about-feature-grid,
    .copp-about-feature-grid--compact {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .copp-about-documents-grid,
    .copp-about-feature-grid,
    .copp-about-feature-grid--compact {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-about-page-intro h2,
    .copp-about-page-intro h3,
    .copp-about-feature-card h3 {
        font-size: 22px;
    }
}

.copp-about-directory {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.copp-about-directory__card {
    background:
        linear-gradient(145deg, rgba(var(--copp-red-rgb), 0.08) 0, rgba(var(--copp-red-rgb), 0) 48%),
        #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    border-radius: 0;
    box-shadow: 0 18px 42px rgba(var(--copp-ink-rgb), 0.08);
    color: inherit;
    display: grid;
    gap: 12px;
    min-height: 100%;
    padding: 22px;
    text-decoration: none;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.copp-about-directory__card:hover {
    border-color: rgba(var(--copp-red-rgb), 0.28);
    box-shadow: 0 24px 48px rgba(var(--copp-ink-rgb), 0.12);
    transform: translateY(-2px);
}

.copp-about-directory__icon {
    align-items: center;
    background: rgba(var(--copp-red-rgb), 0.1);
    border-radius: 0;
    color: var(--copp-red);
    display: inline-flex;
    font-size: 18px;
    height: 42px;
    justify-content: center;
    width: 42px;
}

.copp-about-directory__eyebrow {
    color: rgba(var(--copp-ink-rgb), 0.56);
    font-size: var(--copp-fs-eyebrow);
    font-weight: var(--copp-fw-eyebrow);
    letter-spacing: var(--copp-ls-eyebrow);
    text-transform: uppercase;
}

.copp-about-directory__card strong {
    color: var(--copp-ink);
    font-size: 22px;
    font-weight: 900;
    line-height: 1.15;
}

.copp-about-directory__card p {
    color: rgba(var(--copp-ink-rgb), 0.74);
    line-height: 1.6;
    margin: 0;
}

.copp-about-directory__link {
    align-items: center;
    color: var(--copp-red);
    display: inline-flex;
    gap: 10px;
    font-weight: 800;
    margin-top: auto;
}

.copp-about-stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
}

.copp-about-stat {
    min-height: 172px;
    padding: 24px 22px 22px;
    border-radius: 0;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}

.copp-about-stat--light {
    background: var(--copp-pale);
    color: var(--copp-ink);
}

.copp-about-stat--accent {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-about-stat--deep {
    background: var(--copp-red-deep);
    color: #ffffff;
}

.copp-about-stat--dark {
    background: var(--copp-ink);
    color: #ffffff;
}

.copp-about-stat__icon,
.copp-about-mission__badge,
.copp-about-direction__icon,
.copp-about-process__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0;
    line-height: 1;
    overflow: hidden;
    white-space: nowrap;
}

.copp-about-icon::before,
.copp-about-arrow-icon::before {
    content: none;
    display: none;
}

.copp-about-icon--group {
    --copp-about-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath fill='black' d='M22 18a8 8 0 1 1 0 16 8 8 0 0 1 0-16Zm20 2a7 7 0 1 1 0 14 7 7 0 0 1 0-14ZM10 50c0-7 6-12 12-12s12 5 12 12v2H10v-2Zm24 2c0-6 4-10 10-10s10 4 10 10v2H34v-2Z'/%3E%3C/svg%3E");
}

.copp-about-icon--building {
    --copp-about-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath fill='black' d='M12 16h18v36H12V16Zm22 8h18v28H34V24Zm4-12h10a4 4 0 0 1 4 4v4H34v-4a4 4 0 0 1 4-4ZM18 22h6v6h-6v-6Zm0 10h6v6h-6v-6Zm0 10h6v6h-6v-6Zm22-8h6v6h-6v-6Zm0 10h6v6h-6v-6Z'/%3E%3C/svg%3E");
}

.copp-about-icon--user {
    --copp-about-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath fill='black' d='M32 12a10 10 0 1 1 0 20 10 10 0 0 1 0-20Zm-18 36c0-9 8-16 18-16s18 7 18 16v4H14v-4Z'/%3E%3C/svg%3E");
}

.copp-about-icon--marker {
    --copp-about-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath fill='black' d='M32 8c10 0 20 8 20 20 0 13-14 26-18 29a3 3 0 0 1-4 0C26 54 12 41 12 28 12 16 22 8 32 8Zm0 10a10 10 0 1 0 0 20 10 10 0 0 0 0-20Z'/%3E%3C/svg%3E");
}

.copp-about-icon--cap {
    --copp-about-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath fill='black' d='M32 12 8 24l24 12 19-9.5V41h5V24L32 12Zm-14 20v8c4 4 24 4 28 0v-8l-14 7-14-7Z'/%3E%3C/svg%3E");
}

.copp-about-icon--government {
    --copp-about-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath fill='black' d='M8 54h48v-4H8v4Zm4-8h10V28H12v18Zm14 0h12V20H26v26Zm16 0h10V32H42v14Zm-18-30 8-8 8 8h-5v10h-6V16h-5Z'/%3E%3C/svg%3E");
}

.copp-about-icon--gear {
    --copp-about-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath fill='black' d='m28 6 8 0 1 6a20 20 0 0 1 5 2l5-3 6 6-3 5a20 20 0 0 1 2 5l6 1v8l-6 1a20 20 0 0 1-2 5l3 5-6 6-5-3a20 20 0 0 1-5 2l-1 6h-8l-1-6a20 20 0 0 1-5-2l-5 3-6-6 3-5a20 20 0 0 1-2-5l-6-1v-8l6-1a20 20 0 0 1 2-5l-3-5 6-6 5 3a20 20 0 0 1 5-2l1-6Zm4 17a9 9 0 1 0 0 18 9 9 0 0 0 0-18Z'/%3E%3C/svg%3E");
}

.copp-about-icon--atom {
    --copp-about-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Ccircle cx='32' cy='32' r='5' fill='black'/%3E%3Cellipse cx='32' cy='32' rx='21' ry='9' fill='none' stroke='black' stroke-width='3'/%3E%3Cellipse cx='32' cy='32' rx='21' ry='9' fill='none' stroke='black' stroke-width='3' transform='rotate(60 32 32)'/%3E%3Cellipse cx='32' cy='32' rx='21' ry='9' fill='none' stroke='black' stroke-width='3' transform='rotate(120 32 32)'/%3E%3C/svg%3E");
}

.copp-about-icon--unknown {
    --copp-about-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath d='M24 24c0-6 4-10 10-10s10 3 10 9c0 5-4 7-7 9-2 2-3 3-3 6' fill='none' stroke='black' stroke-width='5' stroke-linecap='round' stroke-linejoin='round'/%3E%3Ccircle cx='32' cy='50' r='3.5' fill='black'/%3E%3C/svg%3E");
}

.copp-about-icon--orientation {
    --copp-about-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath fill='black' d='M10 12h44v40H10V12Zm6 6v28h32V18H16Zm4 4h12v8H20v-8Zm16 0h8v20h-8V22ZM20 34h12v8H20v-8Z'/%3E%3C/svg%3E");
}

.copp-about-icon--briefcase {
    --copp-about-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath fill='black' d='M20 16h24a6 6 0 0 1 6 6v4H14v-4a6 6 0 0 1 6-6Zm6-6h12v6H26v-6Zm-12 20h36v18a6 6 0 0 1-6 6H20a6 6 0 0 1-6-6V30Zm14 6v6h8v-6h-8Z'/%3E%3C/svg%3E");
}

.copp-about-icon--chart {
    --copp-about-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath fill='black' d='M12 50h40v4H8V10h4v40Zm8-6h8V30h-8v14Zm12 0h8V20h-8v24Zm12 0h8V14h-8v30Z'/%3E%3C/svg%3E");
}

.copp-about-icon--monitor {
    --copp-about-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath fill='black' d='M12 16h40v28H12V16Zm4 4v20h32V20H16Zm4 24h24v4H20v-4Zm6-18h12v8H26v-8Z'/%3E%3C/svg%3E");
}

.copp-about-icon--target {
    --copp-about-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath fill='black' d='M30 6h4v10h-4V6Zm0 42h4v10h-4V48ZM6 30h10v4H6v-4Zm42 0h10v4H48v-4ZM14 14l3-3 7 7-3 3-7-7Zm26 26 3-3 7 7-3 3-7-7ZM43 24a11 11 0 1 1-22 0 11 11 0 0 1 22 0Zm-11 9c9 0 16 7 16 16h-4c0-7-5-12-12-12s-12 5-12 12h-4c0-9 7-16 16-16Z'/%3E%3C/svg%3E");
}

.copp-about-icon--handshake {
    --copp-about-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath fill='black' d='m20 24 8 8-8 8-8-8 8-8Zm24 0 8 8-8 8-8-8 8-8ZM28 32h8m-16 0h8m8 0h8m-14-8 4-4m0 24-4-4' stroke='black' stroke-width='4' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E");
}

.copp-about-icon--rocket {
    --copp-about-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath fill='black' d='M36 8 14 30h12v20h20V36h8L36 8Zm-2 10 9 12h-5v14H30V30h-5l9-12Z'/%3E%3C/svg%3E");
}

.copp-about-arrow-icon {
    --copp-about-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M4 11h11.2l-3.8-3.8L13 5.6l6.4 6.4L13 18.4l-1.6-1.6 3.8-3.8H4V11Z'/%3E%3C/svg%3E");
}

.copp-about-stat__icon {
    width: 34px;
    height: 34px;
    margin-bottom: 20px;
}

.copp-about-stat__icon svg,
.copp-about-mission__badge svg,
.copp-about-direction__icon svg,
.copp-about-process__icon svg,
.copp-about-mission__arrow svg,
.copp-about-direction__arrow svg {
    width: 100%;
    height: 100%;
}

.copp-about-stat strong {
    display: block;
    margin: 0;
    font-size: 18px;
    font-weight: 800;
    line-height: 1.1;
}

.copp-about-stat strong span {
    display: block;
    margin-top: 8px;
    font-size: 54px;
    line-height: 0.92;
}

.copp-about-stat p {
    margin: 16px 0 0;
    max-width: 150px;
    font-size: 16px;
    line-height: 1.35;
}

@media (max-width: 1199.98px) {
    .copp-contacts-hero .copp-news-hero__inner {
        grid-template-columns: minmax(0, 360px) minmax(0, 1fr);
    }

    .copp-contacts-cards {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .copp-contacts-layout,
    .copp-contacts-faq,
    .copp-contacts-cta__inner {
        grid-template-columns: 1fr;
    }

    .copp-contacts-cta__visual > img {
        right: 0;
        width: min(100%, 360px);
    }
}

@media (max-width: 767.98px) {
    .copp-contacts-content {
        gap: 30px;
    }

    .copp-contacts-hero .copp-news-hero__inner {
        grid-template-columns: 1fr;
        min-height: 0;
    }

    .copp-contacts-hero .copp-news-hero__media {
        min-height: 280px;
    }

    .copp-contacts-hero__subtitle,
    .copp-contacts-hero .copp-news-hero__lead,
    .copp-contacts-cta__copy p {
        max-width: none;
    }

    .copp-contacts-cards {
        grid-template-columns: 1fr;
    }

    .copp-contact-card,
    .copp-contacts-route,
    .copp-contacts-faq__aside {
        min-height: 0;
    }

    .copp-contacts-map {
        min-height: 280px;
    }

    .copp-contacts-map__actions,
    .copp-contacts-map__actions .copp-news-btn,
    .copp-contacts-form__submit {
        width: 100%;
        justify-self: stretch;
    }

    .copp-contacts-faq__item summary {
        min-height: 56px;
        padding: 0 18px;
        font-size: 16px;
    }

    .copp-contacts-faq__answer {
        padding: 0 18px 18px;
    }

    .copp-contacts-cta__inner {
        min-height: 0;
        padding-top: 32px;
        padding-bottom: 32px;
    }

    .copp-contacts-cta__visual {
        min-height: 220px;
    }

    .copp-contacts-cta__visual > img {
        right: 50%;
        transform: translateX(50%);
        width: min(100%, 300px);
        max-height: 220px;
    }
}

.copp-about-section {
    display: grid;
    gap: 24px;
}

.copp-about-section__head {
    display: grid;
    justify-items: start;
    gap: 10px;
}

.copp-about-section__head h2 {
    margin: 0;
    color: var(--copp-ink);
    font-size: 24px;
    font-weight: 800;
    line-height: 1.05;
    text-transform: uppercase;
}

.copp-about-scope {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.copp-about-scope-card {
    border-radius: 0;
    display: grid;
    gap: 16px;
    min-height: 360px;
    overflow: hidden;
    padding: 32px;
    position: relative;
}

.copp-about-scope-card::before {
    background: currentColor;
    content: "";
    display: block;
    height: 46px;
    opacity: 0.1;
    position: absolute;
    right: 26px;
    top: 26px;
    width: 46px;
}

.copp-about-scope-card::after {
    bottom: 0;
    content: "";
    display: block;
    height: 5px;
    left: 0;
    position: absolute;
    right: 0;
}

.copp-about-scope-card--system {
    background: var(--copp-soft);
    color: var(--copp-ink);
}

.copp-about-scope-card--system::after {
    background: var(--copp-red);
}

.copp-about-scope-card--local {
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.16) 0, rgba(255, 255, 255, 0) 44%),
        var(--copp-ink);
    color: #ffffff;
}

.copp-about-scope-card--local::after {
    background: var(--copp-red);
}

.copp-about-scope-card__kicker {
    color: var(--copp-red);
    font-size: var(--copp-fs-eyebrow);
    font-weight: var(--copp-fw-eyebrow);
    letter-spacing: var(--copp-ls-eyebrow);
    line-height: var(--copp-lh-eyebrow);
    text-transform: uppercase;
}

.copp-about-scope-card--local .copp-about-scope-card__kicker {
    color: #ffffff;
}

.copp-about-scope-card h3 {
    font-size: 30px;
    font-weight: 900;
    line-height: 1.08;
    margin: 0;
    max-width: 520px;
    text-transform: uppercase;
}

.copp-about-scope-card p {
    color: currentColor;
    font-size: 16px;
    line-height: 1.65;
    margin: 0;
    max-width: 620px;
    opacity: 0.86;
}

.copp-about-scope-card ul {
    align-self: end;
    display: grid;
    gap: 10px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.copp-about-scope-card li {
    align-items: center;
    display: grid;
    gap: 10px;
    grid-template-columns: 10px minmax(0, 1fr);
    font-size: 15px;
    font-weight: 800;
    line-height: 1.35;
}

.copp-about-scope-card li::before {
    background: var(--copp-red);
    content: "";
    display: block;
    height: 10px;
    width: 10px;
}

.copp-about-equipment-section {
    background: #ffffff;
    position: relative;
    z-index: 20;
}

.copp-about-equipment {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.35fr);
    gap: 22px;
    align-items: stretch;
}

.copp-about-equipment__copy {
    background:
        linear-gradient(135deg, rgba(var(--copp-red-rgb), 0.12) 0, rgba(var(--copp-red-rgb), 0) 40%),
        var(--copp-soft);
    border-radius: 0;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    min-height: 360px;
    padding: 32px;
}

.copp-about-equipment__label {
    color: var(--copp-red);
    font-size: 12px;
    font-weight: 900;
    line-height: 1.2;
    margin-bottom: 18px;
    text-transform: uppercase;
}

.copp-about-equipment__copy h3 {
    color: var(--copp-ink);
    font-size: 32px;
    font-weight: 900;
    line-height: 1.08;
    margin: 0;
    text-transform: uppercase;
}

.copp-about-equipment__copy p {
    color: var(--copp-ink-soft);
    font-size: 16px;
    line-height: 1.62;
    margin: 18px 0 0;
}

.copp-about-equipment__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.copp-about-equipment-card {
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.12);
    border-radius: 0;
    box-shadow: 0 18px 40px rgba(var(--copp-ink-rgb), 0.06);
    color: inherit;
    min-height: 172px;
    padding: 22px;
    position: relative;
    text-decoration: none;
    transition: border-color 180ms ease, box-shadow 180ms ease, transform 180ms ease;
}

.copp-about-equipment-card::after {
    background: var(--copp-red);
    bottom: -1px;
    content: "";
    display: block;
    height: 4px;
    left: 22px;
    position: absolute;
    width: 42px;
}

.copp-about-equipment-card:hover,
.copp-about-equipment-card:focus {
    border-color: rgba(var(--copp-red-rgb), 0.34);
    box-shadow: 0 22px 46px rgba(var(--copp-ink-rgb), 0.1);
    color: inherit;
    text-decoration: none;
    transform: translateY(-2px);
}

.copp-about-equipment-card__icon {
    color: var(--copp-red);
    height: 34px;
    margin-bottom: 18px;
    width: 34px;
}

.copp-about-equipment-card h3 {
    color: var(--copp-ink);
    font-size: 19px;
    font-weight: 900;
    line-height: 1.16;
    margin: 0;
}

.copp-about-equipment-card p {
    color: var(--copp-muted);
    font-size: 15px;
    line-height: 1.5;
    margin: 12px 0 34px;
}

.copp-about-equipment-card__arrow {
    align-items: center;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.16);
    bottom: 18px;
    color: var(--copp-red);
    display: inline-flex;
    height: 32px;
    justify-content: center;
    position: absolute;
    right: 18px;
    width: 32px;
}

.copp-about-gallery {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.copp-about-gallery-card {
    background: var(--copp-pale);
    border-radius: 0;
    color: #ffffff;
    display: block;
    min-height: 320px;
    overflow: hidden;
    position: relative;
    text-decoration: none;
}

.copp-about-gallery-card:hover,
.copp-about-gallery-card:focus {
    color: #ffffff;
    text-decoration: none;
}

.copp-about-gallery-card--wide {
    grid-column: 1 / -1;
    min-height: 360px;
}

.copp-about-gallery-card img {
    display: block;
    height: 100%;
    inset: 0;
    object-fit: cover;
    object-position: right center;
    opacity: 0.9;
    position: absolute;
    transform: scale(1.01);
    width: 100%;
    filter: grayscale(1) contrast(1.18) brightness(0.92);
}

.copp-about-gallery-card::after {
    background: linear-gradient(180deg, rgba(15, 15, 15, 0) 0%, rgba(15, 15, 15, 0.2) 42%, rgba(15, 15, 15, 0.92) 100%);
    content: "";
    display: block;
    inset: 0;
    position: absolute;
}

.copp-about-gallery-card__type {
    background: var(--copp-red);
    color: #ffffff;
    font-size: 12px;
    font-weight: 900;
    line-height: 1;
    padding: 10px 12px;
    position: absolute;
    right: 18px;
    text-transform: uppercase;
    top: 18px;
    z-index: 2;
}

.copp-about-gallery-card__caption {
    bottom: 0;
    display: grid;
    gap: 10px;
    left: 0;
    padding: 24px;
    position: absolute;
    right: 0;
    z-index: 2;
}

.copp-about-gallery-card__caption h3 {
    color: #ffffff;
    font-size: 24px;
    font-weight: 900;
    line-height: 1.1;
    margin: 0;
    text-transform: uppercase;
}

.copp-about-gallery-card__caption p {
    color: rgba(255, 255, 255, 0.86);
    font-size: 15px;
    line-height: 1.45;
    margin: 0;
    max-width: 560px;
}

.copp-equipment-viewer {
    background: var(--copp-soft);
    border: 1px solid rgba(var(--copp-ink-rgb), 0.1);
    border-radius: 0;
    display: grid;
    gap: 0;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
    overflow: hidden;
}

.copp-equipment-viewer__stage {
    background: var(--copp-ink);
    color: #ffffff;
    display: grid;
    grid-template-rows: minmax(360px, 56vh) auto;
    min-width: 0;
}

.copp-equipment-viewer__frame {
    background: var(--copp-dark);
    min-height: 360px;
    overflow: hidden;
    position: relative;
}

.copp-equipment-viewer__frame img,
.copp-equipment-viewer__frame iframe {
    border: 0;
    display: block;
    height: 100%;
    inset: 0;
    position: absolute;
    width: 100%;
}

.copp-equipment-viewer__frame img {
    object-fit: contain;
    object-position: center;
}

.copp-equipment-viewer__caption {
    align-items: end;
    display: grid;
    gap: 12px;
    grid-template-columns: minmax(0, 1fr) auto;
    padding: 24px;
}

.copp-equipment-viewer__caption > span {
    background: var(--copp-red);
    color: #ffffff;
    font-size: 12px;
    font-weight: 900;
    justify-self: start;
    line-height: 1;
    padding: 9px 11px;
    text-transform: uppercase;
}

.copp-equipment-viewer__caption h3 {
    color: #ffffff;
    font-size: clamp(28px, 3vw, 44px);
    font-weight: 900;
    grid-column: 1;
    line-height: 1;
    margin: 0;
    text-transform: uppercase;
}

.copp-equipment-viewer__caption p {
    color: rgba(255, 255, 255, 0.78);
    font-size: 15px;
    grid-column: 1;
    line-height: 1.5;
    margin: 0;
    max-width: 720px;
}

.copp-equipment-viewer__actions {
    align-self: end;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    grid-column: 2;
    grid-row: 1 / span 3;
    justify-content: flex-end;
}

.copp-equipment-viewer__actions a {
    align-items: center;
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 0;
    color: #ffffff;
    display: inline-flex;
    font-size: 12px;
    font-weight: 900;
    min-height: 38px;
    padding: 0 12px;
    text-transform: uppercase;
}

.copp-equipment-viewer__actions a:first-child {
    background: #ffffff;
    border-color: #ffffff;
    color: var(--copp-red);
}

.copp-equipment-viewer__actions a:hover,
.copp-equipment-viewer__actions a:focus {
    border-color: #ffffff;
    text-decoration: none;
}

.copp-equipment-viewer__rail {
    background: #ffffff;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    min-height: 0;
}

.copp-equipment-viewer__rail-head {
    align-items: center;
    border-bottom: 1px solid rgba(var(--copp-ink-rgb), 0.1);
    display: flex;
    justify-content: space-between;
    padding: 18px;
}

.copp-equipment-viewer__rail-head span {
    color: var(--copp-ink);
    font-size: 14px;
    font-weight: 900;
    text-transform: uppercase;
}

.copp-equipment-viewer__rail-head strong {
    align-items: center;
    background: var(--copp-red);
    border-radius: 0;
    color: #ffffff;
    display: inline-flex;
    font-size: 12px;
    height: 28px;
    justify-content: center;
    min-width: 28px;
    padding: 0 9px;
}

.copp-equipment-viewer__thumbs {
    display: grid;
    gap: 0;
    max-height: calc(56vh + 150px);
    overflow: auto;
}

.copp-equipment-viewer__thumb {
    align-items: center;
    background: #ffffff;
    border: 0;
    border-bottom: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    color: inherit;
    cursor: pointer;
    display: grid;
    gap: 12px;
    grid-template-columns: 96px minmax(0, 1fr);
    min-height: 92px;
    padding: 12px 14px;
    text-align: left;
}

.copp-equipment-viewer__thumb:hover,
.copp-equipment-viewer__thumb:focus,
.copp-equipment-viewer__thumb.is-active {
    background: var(--copp-soft);
}

.copp-equipment-viewer__thumb.is-active {
    box-shadow: inset 4px 0 0 var(--copp-red);
}

.copp-equipment-viewer__thumb-media {
    aspect-ratio: 16 / 10;
    background: var(--copp-pale);
    border-radius: 0;
    display: block;
    overflow: hidden;
}

.copp-equipment-viewer__thumb-media img {
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.copp-equipment-viewer__thumb-copy {
    display: grid;
    gap: 6px;
    min-width: 0;
}

.copp-equipment-viewer__thumb-copy b {
    color: var(--copp-red);
    font-size: 11px;
    font-weight: 900;
    line-height: 1;
    text-transform: uppercase;
}

.copp-equipment-viewer__thumb-copy span {
    color: var(--copp-ink);
    font-size: 14px;
    font-weight: 900;
    line-height: 1.15;
    overflow-wrap: anywhere;
}

.copp-equipment-zones {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-top: 16px;
}

.copp-equipment-zones__item {
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.1);
    border-radius: 0;
    color: var(--copp-ink);
    display: grid;
    grid-template-rows: auto 1fr;
    overflow: hidden;
    padding: 0;
}

.copp-equipment-zones__item:hover,
.copp-equipment-zones__item:focus {
    border-color: rgba(var(--copp-red-rgb), 0.35);
    color: var(--copp-red);
    text-decoration: none;
}

.copp-equipment-zones__media {
    align-items: center;
    aspect-ratio: 16 / 9;
    background: var(--copp-ink);
    color: #ffffff;
    display: flex;
    justify-content: center;
    overflow: hidden;
    position: relative;
}

.copp-equipment-zones__media img {
    display: block;
    filter: grayscale(1) contrast(1.08);
    height: 100%;
    object-fit: cover;
    opacity: 0.86;
    width: 100%;
}

.copp-equipment-zones__media i {
    align-items: center;
    background: var(--copp-red);
    bottom: 10px;
    color: #ffffff;
    display: inline-flex;
    height: 36px;
    justify-content: center;
    position: absolute;
    right: 10px;
    width: 36px;
}

.copp-equipment-zones__copy {
    align-content: start;
    display: grid;
    gap: 6px;
    min-height: 132px;
    padding: 13px;
}

.copp-equipment-zones__item strong {
    display: -webkit-box;
    font-size: 14px;
    font-weight: 900;
    line-height: 1.15;
    overflow: hidden;
    overflow-wrap: anywhere;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.copp-equipment-zones__copy p {
    color: rgba(var(--copp-ink-rgb), 0.72);
    display: -webkit-box;
    font-size: 13px;
    line-height: 1.45;
    margin: 0;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
}

.copp-equipment-zones__item em {
    color: rgba(var(--copp-ink-rgb), 0.58);
    font-size: 12px;
    font-style: normal;
    font-weight: 800;
    line-height: 1;
}

.copp-equipment-section__lead {
    color: rgba(var(--copp-ink-rgb), 0.72);
    font-size: 16px;
    font-weight: 700;
    line-height: 1.5;
    margin: -4px 0 18px;
    max-width: 760px;
}

.copp-about-metrics-strip {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.copp-about-metric-card {
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    border-radius: 0;
    display: grid;
    gap: 8px;
    min-height: 124px;
    padding: 18px;
}

.copp-about-metric-card strong {
    color: var(--copp-red);
    font-size: clamp(28px, 3vw, 38px);
    font-weight: 900;
    letter-spacing: 0;
    line-height: 1;
}

.copp-about-metric-card span {
    color: rgba(var(--copp-ink-rgb), 0.78);
    font-size: 14px;
    font-weight: 800;
    line-height: 1.35;
    max-width: 12ch;
}

@media (max-width: 1199.98px) {
    .copp-equipment-zones {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .copp-about-metrics-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .copp-equipment-viewer {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-equipment-viewer__stage {
        grid-template-rows: minmax(320px, 48vh) auto;
    }

    .copp-equipment-viewer__thumbs {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        max-height: none;
        overflow: visible;
    }
}

@media (max-width: 767.98px) {
    .copp-about-metric-card {
        min-height: 110px;
    }

    .copp-equipment-viewer__caption {
        grid-template-columns: minmax(0, 1fr);
        padding: 20px;
    }

    .copp-equipment-viewer__actions {
        grid-column: 1;
        grid-row: auto;
        justify-content: flex-start;
    }

    .copp-about-metrics-strip,
    .copp-equipment-viewer__thumbs,
    .copp-equipment-zones {
        grid-template-columns: minmax(0, 1fr);
    }
}

@media (max-width: 575.98px) {
    .copp-equipment-viewer__stage {
        grid-template-rows: minmax(260px, 42vh) auto;
    }

    .copp-equipment-viewer__frame {
        min-height: 260px;
    }

    .copp-equipment-viewer__thumb {
        grid-template-columns: 82px minmax(0, 1fr);
    }
}

.copp-equipment-media {
    display: grid;
    gap: 18px;
}

.copp-equipment-media__photos,
.copp-equipment-media__panoramas {
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.1);
    border-radius: 0;
    overflow: hidden;
}

.copp-equipment-media__stage {
    background: var(--copp-ink);
    color: #ffffff;
    display: grid;
    grid-template-columns: minmax(0, 1.45fr) minmax(320px, 0.55fr);
    min-height: 430px;
}

.copp-equipment-media__frame {
    background: var(--copp-dark);
    min-height: 430px;
    overflow: hidden;
    position: relative;
}

.copp-equipment-media__frame img {
    display: block;
    height: 100%;
    inset: 0;
    object-fit: cover;
    position: absolute;
    width: 100%;
}

.copp-equipment-media__caption {
    align-content: end;
    display: grid;
    gap: 14px;
    padding: 26px;
}

.copp-equipment-media__caption > span,
.copp-equipment-media__head span {
    background: var(--copp-red);
    color: #ffffff;
    display: inline-flex;
    font-size: 12px;
    font-weight: 900;
    justify-self: start;
    line-height: 1;
    padding: 9px 11px;
    text-transform: uppercase;
}

.copp-equipment-media__caption h3,
.copp-equipment-media__head h3 {
    color: inherit;
    font-size: clamp(26px, 3vw, 42px);
    font-weight: 900;
    line-height: 1;
    margin: 0;
    text-transform: uppercase;
}

.copp-equipment-media__caption p {
    color: rgba(255, 255, 255, 0.78);
    font-size: 15px;
    line-height: 1.5;
    margin: 0;
}

.copp-equipment-media__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.copp-equipment-media__actions a,
.copp-equipment-media__open {
    align-items: center;
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 0;
    color: #ffffff;
    cursor: pointer;
    display: inline-flex;
    font-family: inherit;
    font-size: 12px;
    font-weight: 900;
    justify-content: center;
    min-height: 38px;
    padding: 0 12px;
    text-transform: uppercase;
}

.copp-equipment-media__open {
    background: #ffffff;
    border-color: #ffffff;
    color: var(--copp-red);
}

.copp-equipment-media__actions a:hover,
.copp-equipment-media__actions a:focus,
.copp-equipment-media__open:hover,
.copp-equipment-media__open:focus {
    border-color: #ffffff;
    text-decoration: none;
}

.copp-equipment-photo-thumbs,
.copp-equipment-panorama-list {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    padding: 14px;
    scroll-snap-type: x proximity;
    scrollbar-width: thin;
}

.copp-equipment-photo-thumb {
    align-items: center;
    background: var(--copp-soft);
    border: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    border-radius: 0;
    color: inherit;
    cursor: pointer;
    display: grid;
    flex: 0 0 245px;
    gap: 11px;
    grid-template-columns: 88px minmax(0, 1fr);
    min-height: 88px;
    padding: 10px;
    scroll-snap-align: start;
    text-align: left;
}

.copp-equipment-photo-thumb:hover,
.copp-equipment-photo-thumb:focus,
.copp-equipment-photo-thumb.is-active {
    background: #ffffff;
    border-color: rgba(var(--copp-red-rgb), 0.38);
    box-shadow: 0 12px 24px rgba(var(--copp-ink-rgb), 0.08);
}

.copp-equipment-photo-thumb__media {
    aspect-ratio: 16 / 10;
    background: var(--copp-pale);
    border-radius: 0;
    display: block;
    overflow: hidden;
}

.copp-equipment-photo-thumb__media img,
.copp-equipment-panorama-card__media img {
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.copp-equipment-photo-thumb__copy {
    display: grid;
    gap: 5px;
    min-width: 0;
}

.copp-equipment-photo-thumb__copy b,
.copp-equipment-panorama-card__copy b {
    color: var(--copp-red);
    font-size: 11px;
    font-weight: 900;
    line-height: 1;
    text-transform: uppercase;
}

.copp-equipment-photo-thumb__copy span {
    color: var(--copp-ink);
    font-size: 14px;
    font-weight: 900;
    line-height: 1.15;
    overflow-wrap: anywhere;
}

.copp-equipment-media__head {
    align-items: center;
    background: var(--copp-ink);
    color: #ffffff;
    display: flex;
    gap: 20px;
    justify-content: space-between;
    padding: 24px;
}

.copp-equipment-media__head > div {
    display: grid;
    gap: 10px;
}

.copp-equipment-media__head strong {
    align-items: center;
    background: #ffffff;
    border-radius: 0;
    color: var(--copp-red);
    display: inline-flex;
    font-size: 14px;
    font-weight: 900;
    height: 36px;
    justify-content: center;
    min-width: 36px;
    padding: 0 12px;
}

.copp-equipment-panorama-card {
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.1);
    border-radius: 0;
    color: var(--copp-ink);
    cursor: pointer;
    display: grid;
    flex: 0 0 min(360px, 82vw);
    overflow: hidden;
    padding: 0;
    scroll-snap-align: start;
    text-align: left;
}

.copp-equipment-panorama-card:hover,
.copp-equipment-panorama-card:focus {
    border-color: rgba(var(--copp-red-rgb), 0.4);
    box-shadow: 0 16px 34px rgba(var(--copp-ink-rgb), 0.12);
}

.copp-equipment-panorama-card__media {
    aspect-ratio: 16 / 9;
    background: var(--copp-dark);
    display: block;
    overflow: hidden;
    position: relative;
}

.copp-equipment-panorama-card__media span {
    align-items: center;
    background: var(--copp-red);
    bottom: 12px;
    color: #ffffff;
    display: inline-flex;
    height: 38px;
    justify-content: center;
    position: absolute;
    right: 12px;
    width: 38px;
}

.copp-equipment-panorama-card__copy {
    display: grid;
    gap: 7px;
    padding: 15px;
}

.copp-equipment-panorama-card__copy strong {
    color: var(--copp-ink);
    font-size: 17px;
    font-weight: 900;
    line-height: 1.1;
    overflow-wrap: anywhere;
}

.copp-equipment-panorama-card__copy small {
    color: rgba(var(--copp-ink-rgb), 0.64);
    display: -webkit-box;
    font-size: 13px;
    font-weight: 700;
    line-height: 1.35;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.copp-equipment-objects {
    display: grid;
    gap: 14px;
    margin-top: 26px;
}

.copp-equipment-objects__head {
    display: grid;
    gap: 6px;
}

.copp-equipment-objects__head span {
    color: var(--copp-red);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0;
    line-height: 1;
    text-transform: uppercase;
}

.copp-equipment-objects__head h2 {
    color: var(--copp-ink);
    font-size: clamp(26px, 3vw, 38px);
    font-weight: 900;
    line-height: 1;
    margin: 0;
    text-transform: uppercase;
}

.copp-equipment-objects__list {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(auto-fit, minmax(270px, 340px));
    justify-content: start;
}

.copp-equipment-object-card {
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.1);
    border-radius: 0;
    display: grid;
    grid-template-rows: auto 1fr;
    overflow: hidden;
}

.copp-equipment-object-card__media {
    aspect-ratio: 16 / 8;
    background: var(--copp-dark);
    min-height: 0;
    overflow: hidden;
    position: relative;
}

.copp-equipment-object-card__media img {
    display: block;
    height: 100%;
    inset: 0;
    object-fit: cover;
    position: absolute;
    width: 100%;
}

.copp-equipment-object-card__actions {
    bottom: 10px;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    left: 10px;
    position: absolute;
    right: 10px;
    z-index: 2;
}

.copp-equipment-object-card__actions button {
    align-items: center;
    background: rgba(255, 255, 255, 0.92);
    border: 0;
    border-radius: 0;
    color: var(--copp-ink);
    cursor: pointer;
    display: inline-flex;
    font-family: inherit;
    font-size: 12px;
    font-weight: 900;
    gap: 6px;
    min-height: 30px;
    padding: 0 9px;
    text-transform: uppercase;
}

.copp-equipment-object-card__actions button:hover,
.copp-equipment-object-card__actions button:focus {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-equipment-object-card__body {
    align-content: start;
    display: grid;
    gap: 8px;
    padding: 14px;
}

.copp-equipment-object-card__body h3 {
    color: var(--copp-ink);
    font-size: clamp(20px, 2.2vw, 28px);
    font-weight: 900;
    line-height: 1;
    margin: 0;
    text-transform: uppercase;
}

.copp-equipment-object-card__body > p {
    color: rgba(var(--copp-ink-rgb), 0.72);
    font-size: 14px;
    line-height: 1.45;
    margin: 0;
}

.copp-equipment-object-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.copp-equipment-object-card__meta span {
    align-items: center;
    background: rgba(var(--copp-red-rgb), 0.08);
    border-radius: 0;
    color: var(--copp-red);
    display: inline-flex;
    font-size: 11px;
    font-weight: 900;
    gap: 5px;
    line-height: 1;
    min-height: 24px;
    padding: 0 7px;
    text-transform: uppercase;
}

.copp-equipment-object-gallery {
    display: flex;
    gap: 6px;
    overflow-x: auto;
    padding-bottom: 2px;
    scrollbar-width: thin;
}

.copp-equipment-object-gallery button {
    background: var(--copp-soft);
    border: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    border-radius: 0;
    cursor: pointer;
    flex: 0 0 72px;
    height: 48px;
    overflow: hidden;
    padding: 0;
}

.copp-equipment-object-gallery img {
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.copp-equipment-object-card__details {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.copp-equipment-object-card__detail-panel {
    background: var(--copp-soft);
    border-left: 3px solid var(--copp-red);
    display: grid;
    gap: 6px;
    padding: 9px;
}

.copp-equipment-object-card__detail-title {
    align-items: center;
    color: var(--copp-ink);
    display: flex;
    font-size: 12px;
    font-weight: 900;
    gap: 7px;
    line-height: 1.2;
    text-transform: uppercase;
}

.copp-equipment-object-card__detail-title i {
    color: var(--copp-red);
    flex: 0 0 auto;
}

.copp-equipment-object-card__details ul {
    display: grid;
    gap: 6px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.copp-equipment-object-card__details li {
    display: grid;
    gap: 2px;
}

.copp-equipment-object-card__details strong,
.copp-equipment-object-card__details a {
    color: var(--copp-ink);
    font-size: 13px;
    font-weight: 900;
    line-height: 1.2;
}

.copp-equipment-object-card__details a:hover,
.copp-equipment-object-card__details a:focus {
    color: var(--copp-red);
}

.copp-equipment-object-card__details em {
    color: rgba(var(--copp-ink-rgb), 0.62);
    display: -webkit-box;
    font-size: 12px;
    font-style: normal;
    font-weight: 700;
    line-height: 1.28;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
}

.copp-equipment-object-card__details small {
    color: var(--copp-red);
    font-size: 11px;
    font-weight: 900;
    line-height: 1;
    text-transform: uppercase;
}

.copp-equipment-modal-open {
    overflow: hidden;
}

.copp-photo-modal,
.copp-panorama-modal,
.copp-video-modal {
    align-items: center;
    background: rgba(0, 0, 0, 0.82);
    display: flex;
    inset: 0;
    justify-content: center;
    padding: 24px;
    position: fixed;
    z-index: 2000;
}

.copp-photo-modal[hidden],
.copp-panorama-modal[hidden],
.copp-video-modal[hidden] {
    display: none;
}

.copp-photo-modal__panel,
.copp-panorama-modal__panel,
.copp-video-modal__panel {
    background: var(--copp-dark);
    border-radius: 0;
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.36);
    color: #ffffff;
    max-height: calc(100vh - 48px);
    max-width: min(1180px, 96vw);
    overflow: hidden;
    position: relative;
    width: 100%;
}

.copp-photo-modal__panel {
    display: grid;
    grid-template-rows: minmax(0, 1fr) auto;
}

.copp-photo-modal__panel img {
    display: block;
    max-height: calc(100vh - 120px);
    object-fit: contain;
    width: 100%;
}

.copp-photo-modal__nav,
.copp-panorama-modal__nav {
    align-items: center;
    background: rgba(var(--copp-dark-rgb), 0.68);
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 0;
    color: #ffffff;
    cursor: pointer;
    display: inline-flex;
    font-family: inherit;
    font-size: 44px;
    font-weight: 700;
    height: 72px;
    justify-content: center;
    line-height: 1;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 52px;
    z-index: 4;
}

.copp-photo-modal__nav:hover,
.copp-photo-modal__nav:focus,
.copp-panorama-modal__nav:hover,
.copp-panorama-modal__nav:focus {
    background: var(--copp-red);
    border-color: var(--copp-red);
}

.copp-photo-modal__nav--prev,
.copp-panorama-modal__nav--prev {
    left: 18px;
}

.copp-photo-modal__nav--next,
.copp-panorama-modal__nav--next {
    right: 18px;
}

.copp-photo-modal__title,
.copp-panorama-modal__title,
.copp-video-modal__title {
    background: var(--copp-ink);
    color: #ffffff;
    font-size: 15px;
    font-weight: 900;
    line-height: 1.25;
    padding: 14px 58px 14px 18px;
}

.copp-photo-modal__close,
.copp-panorama-modal__close,
.copp-video-modal__close {
    align-items: center;
    background: var(--copp-red);
    border: 0;
    color: #ffffff;
    cursor: pointer;
    display: inline-flex;
    font-size: 30px;
    height: 42px;
    justify-content: center;
    line-height: 1;
    position: absolute;
    right: 0;
    top: 0;
    width: 42px;
    z-index: 3;
}

.copp-panorama-modal__viewer {
    background: #101010;
    height: 100vh;
    min-height: 0;
    position: relative;
}

.copp-panorama-modal {
    padding: 0;
}

.copp-panorama-modal__panel {
    background: #050505;
    border-radius: 0;
    height: 100vh;
    max-height: none;
    max-width: none;
    width: 100vw;
}

.copp-panorama-modal__title {
    background: rgba(var(--copp-dark-rgb), 0.78);
    border-radius: 0;
    left: 18px;
    max-width: calc(100vw - 120px);
    padding: 12px 16px;
    position: absolute;
    top: 18px;
    z-index: 4;
}

.copp-panorama-modal__close {
    border-radius: 0;
    right: 18px;
    top: 18px;
    z-index: 5;
}

.copp-video-modal__frame {
    aspect-ratio: 16 / 9;
    background: #000000;
    width: 100%;
}

.copp-panorama-modal__viewer iframe,
.copp-panorama-modal__fallback-image,
.copp-video-modal__frame iframe,
.copp-video-modal__frame video {
    border: 0;
    display: block;
    height: 100%;
    object-fit: contain;
    width: 100%;
}

.copp-equipment-article__aside-link {
    background: transparent;
    cursor: pointer;
    font-family: inherit;
}

@media (max-width: 991.98px) {
    .copp-equipment-media__stage {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-equipment-media__frame {
        min-height: 330px;
    }

}

@media (max-width: 575.98px) {
    .copp-equipment-object-card__details {
        grid-template-columns: minmax(0, 1fr);
    }
}

@media (max-width: 575.98px) {
    .copp-equipment-media__caption,
    .copp-equipment-media__head {
        padding: 18px;
    }

    .copp-equipment-photo-thumb {
        flex-basis: 225px;
    }

    .copp-panorama-modal__viewer {
        height: 100vh;
        min-height: 0;
    }

    .copp-photo-modal,
    .copp-video-modal {
        padding: 10px;
    }

    .copp-panorama-modal {
        padding: 0;
    }

    .copp-panorama-modal__title {
        font-size: 13px;
        left: 10px;
        max-width: calc(100vw - 74px);
        padding: 10px 12px;
        top: 10px;
    }

    .copp-panorama-modal__close {
        height: 38px;
        right: 10px;
        top: 10px;
        width: 38px;
    }

    .copp-photo-modal__nav,
    .copp-panorama-modal__nav {
        font-size: 36px;
        height: 58px;
        width: 40px;
    }

    .copp-photo-modal__nav--prev,
    .copp-panorama-modal__nav--prev {
        left: 10px;
    }

    .copp-photo-modal__nav--next,
    .copp-panorama-modal__nav--next {
        right: 10px;
    }
}

.copp-about-mission {
    display: grid;
    grid-template-columns: minmax(0, 300px) minmax(0, 1fr);
    gap: 34px;
    align-items: center;
}

.copp-about-mission__copy p {
    margin: 0;
    color: var(--copp-ink);
    font-size: 17px;
    line-height: 1.65;
}

.copp-about-mission__flow {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, auto));
    justify-content: space-between;
    align-items: center;
    gap: 14px;
}

.copp-about-mission__step {
    display: grid;
    justify-items: center;
    gap: 12px;
    text-align: center;
}

.copp-about-mission__step span {
    color: var(--copp-ink);
    font-size: 13px;
    font-weight: 700;
    line-height: 1.35;
}

.copp-about-mission__badge {
    width: 58px;
    height: 58px;
    border-radius: 0;
    border: 1px solid var(--copp-line);
    color: var(--copp-ink);
}

.copp-about-mission__badge--light {
    background: var(--copp-soft);
}

.copp-about-mission__badge--red {
    background: var(--copp-red);
    border-color: var(--copp-red);
    color: #ffffff;
}

.copp-about-mission__arrow {
    position: relative;
    width: 46px;
    height: 16px;
    color: var(--copp-red);
    font-size: 0;
    opacity: 1;
    overflow: visible;
}

.copp-about-mission__arrow::before {
    content: "";
    position: absolute;
    left: 0;
    right: 10px;
    top: 50%;
    height: 2px;
    margin-top: -1px;
    border-radius: 0;
    background: linear-gradient(90deg, rgba(var(--copp-ink-rgb), 0.18) 0%, rgba(var(--copp-red-rgb), 0.92) 100%);
    -webkit-mask: none;
    mask: none;
}

.copp-about-mission__arrow::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 1px;
    width: 9px;
    height: 9px;
    margin-top: -4px;
    border-top: 2px solid currentColor;
    border-right: 2px solid currentColor;
    transform: rotate(45deg);
}

.copp-about-directions {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 14px;
}

.copp-about-direction {
    position: relative;
    min-height: 198px;
    border-radius: 0;
    padding: 20px 18px 62px;
    display: flex;
    flex-direction: column;
    text-decoration: none;
}

.copp-about-direction--light {
    background: var(--copp-pale);
    color: var(--copp-ink);
}

.copp-about-direction--accent {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-about-direction--deep {
    background: var(--copp-red-deep);
    color: #ffffff;
}

.copp-about-direction--dark {
    background: var(--copp-ink);
    color: #ffffff;
}

.copp-about-direction__icon {
    width: 30px;
    height: 30px;
    margin-bottom: 22px;
}

.copp-about-direction h3 {
    margin: 0;
    font-size: 20px;
    font-weight: 800;
    line-height: 1.15;
}

.copp-about-direction p {
    margin: 14px 0 0;
    font-size: 15px;
    line-height: 1.55;
}

.copp-about-direction__arrow {
    position: absolute;
    right: 18px;
    bottom: 18px;
    width: 38px;
    height: 38px;
    border-radius: 0;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.24);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0;
    overflow: hidden;
}

.copp-about-direction--accent .copp-about-direction__arrow,
.copp-about-direction--deep .copp-about-direction__arrow,
.copp-about-direction--dark .copp-about-direction__arrow {
    border-color: rgba(255, 255, 255, 0.28);
}

.copp-about-process {
    position: relative;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 24px;
    align-items: start;
}

.copp-about-process::before {
    display: none;
}

.copp-about-process__step {
    position: relative;
    display: grid;
    justify-items: center;
    gap: 16px;
    text-align: center;
}

.copp-about-process__step::before {
    content: "";
    position: absolute;
    top: 26px;
    left: calc(100% - 2px);
    width: 42px;
    height: 2px;
    border-radius: 0;
    background: linear-gradient(90deg, rgba(var(--copp-ink-rgb), 0.16) 0%, rgba(var(--copp-red-rgb), 0.92) 100%);
}

.copp-about-process__step::after {
    content: "";
    position: absolute;
    top: 22px;
    right: -17px;
    width: 10px;
    height: 10px;
    border-top: 2px solid var(--copp-red);
    border-right: 2px solid var(--copp-red);
    transform: rotate(45deg);
}

.copp-about-process__step:last-child::before,
.copp-about-process__step:last-child::after {
    display: none;
}

.copp-about-process__icon {
    position: relative;
    z-index: 1;
    width: 54px;
    height: 54px;
    background: #ffffff;
    border: 1px solid var(--copp-pale);
    border-radius: 0;
    color: var(--copp-ink);
    box-shadow: 0 8px 18px rgba(var(--copp-ink-rgb), 0.06);
}

.copp-about-stat__icon,
.copp-about-mission__badge,
.copp-about-direction__icon,
.copp-about-process__icon {
    font-size: 1rem;
    overflow: visible;
    white-space: normal;
    flex-shrink: 0;
}

.copp-about-icon i,
.copp-about-mission__arrow i,
.copp-about-direction__arrow i {
    display: block;
    line-height: 1;
}

.copp-about-stat__icon i {
    font-size: 30px;
}

.copp-about-mission__badge i {
    font-size: 24px;
}

.copp-about-mission__arrow {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    font-size: 1rem;
}

.copp-about-mission__arrow::after {
    display: none;
}

.copp-about-mission__arrow i {
    position: relative;
    z-index: 1;
    padding-left: 8px;
    background: #ffffff;
    font-size: 18px;
}

.copp-about-direction__icon i,
.copp-about-process__icon i {
    font-size: 24px;
}

.copp-about-direction__arrow {
    font-size: 1rem;
    overflow: visible;
}

.copp-about-direction__arrow i {
    font-size: 16px;
}

@keyframes copp-about-timeline-slide {
    0%,
    100% {
        background-position: 0 50%, 0 50%;
        opacity: 0.82;
    }
    50% {
        background-position: 0 50%, 100% 50%;
        opacity: 1;
    }
}

@keyframes copp-about-timeline-node {
    0%,
    100% {
        transform: translateY(-50%) scale(0.88);
        box-shadow: 0 0 0 0 rgba(var(--copp-red-rgb), 0.18);
    }
    50% {
        transform: translateY(-50%) scale(1.08);
        box-shadow: 0 0 0 6px rgba(var(--copp-red-rgb), 0);
    }
}

.copp-about-mission__arrow {
    width: 58px;
    height: 18px;
    color: var(--copp-red);
    font-size: 1rem;
    overflow: visible;
}

.copp-about-mission__arrow::before {
    content: "";
    position: absolute;
    inset: 50% 0 auto 0;
    height: 3px;
    margin-top: -1px;
    border-radius: 0;
    background:
        linear-gradient(90deg, rgba(var(--copp-ink-rgb), 0.14), rgba(var(--copp-ink-rgb), 0.14)) 0 50% / 100% 2px no-repeat,
        linear-gradient(90deg, rgba(var(--copp-red-rgb), 0.28), rgba(var(--copp-red-rgb), 0.96)) 0 50% / 18px 3px no-repeat;
    animation: copp-about-timeline-slide 2.8s ease-in-out infinite;
}

.copp-about-mission__arrow::after {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    right: -1px;
    width: 8px;
    height: 8px;
    border-radius: 0;
    background: var(--copp-red);
    transform: translateY(-50%);
    animation: copp-about-timeline-node 2.8s ease-in-out infinite;
}

.copp-about-mission__arrow i {
    display: none;
}

.copp-about-mission__arrow:nth-of-type(1)::before,
.copp-about-mission__arrow:nth-of-type(1)::after {
    animation-delay: 0.1s;
}

.copp-about-mission__arrow:nth-of-type(2)::before,
.copp-about-mission__arrow:nth-of-type(2)::after {
    animation-delay: 0.45s;
}

.copp-about-mission__arrow:nth-of-type(3)::before,
.copp-about-mission__arrow:nth-of-type(3)::after {
    animation-delay: 0.8s;
}

.copp-about-process__step::before {
    content: "";
    position: absolute;
    top: 26px;
    left: calc(100% + 2px);
    width: 40px;
    height: 3px;
    border-radius: 0;
    background:
        linear-gradient(90deg, rgba(35, 35, 35, 0.12), rgba(35, 35, 35, 0.12)) 0 50% / 100% 2px no-repeat,
        linear-gradient(90deg, rgba(255, 92, 96, 0.24), rgba(var(--copp-red-rgb), 0.94)) 0 50% / 16px 3px no-repeat;
    animation: copp-about-timeline-slide 3.1s ease-in-out infinite;
}

.copp-about-process__step::after {
    content: "";
    position: absolute;
    top: 27px;
    right: -12px;
    width: 8px;
    height: 8px;
    border: 0;
    border-radius: 0;
    background: var(--copp-red);
    transform: translateY(-50%);
    animation: copp-about-timeline-node 3.1s ease-in-out infinite;
}

.copp-about-process__step:nth-child(1)::before,
.copp-about-process__step:nth-child(1)::after {
    animation-delay: 0.1s;
}

.copp-about-process__step:nth-child(2)::before,
.copp-about-process__step:nth-child(2)::after {
    animation-delay: 0.4s;
}

.copp-about-process__step:nth-child(3)::before,
.copp-about-process__step:nth-child(3)::after {
    animation-delay: 0.7s;
}

.copp-about-process__step:nth-child(4)::before,
.copp-about-process__step:nth-child(4)::after {
    animation-delay: 1s;
}

/* Final about-page connectors */
@keyframes copp-about-process-pulse {
    0%,
    10% {
        opacity: 0;
        transform: translate3d(0, 0, 0) scaleX(0);
        transform-origin: left center;
    }
    24% {
        opacity: 1;
        transform: translate3d(0, 0, 0) scaleX(1);
        transform-origin: left center;
    }
    82% {
        opacity: 1;
        transform: translate3d(var(--copp-about-process-pulse-travel), 0, 0) scaleX(1);
        transform-origin: left center;
    }
    100% {
        opacity: 0;
        transform: translate3d(var(--copp-about-process-pulse-travel), 0, 0) scaleX(0);
        transform-origin: right center;
    }
}

.copp-about-mission__arrow {
    position: relative;
    width: 32px;
    height: 20px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--copp-red);
    overflow: visible;
}

.copp-about-mission__arrow::before,
.copp-about-mission__arrow::after {
    display: none;
    content: none;
    animation: none;
}

.copp-about-mission__arrow i {
    display: block;
    padding: 0;
    background: transparent;
    font-size: 22px;
    line-height: 1;
}

.copp-about-process {
    --copp-about-process-gap: 32px;
    --copp-about-process-track-offset: calc(50% + 11px);
    --copp-about-process-track-width: calc(100% + var(--copp-about-process-gap) - 22px);
    --copp-about-process-pulse-width: 28px;
    --copp-about-process-pulse-travel: calc(var(--copp-about-process-track-width) - var(--copp-about-process-pulse-width));
    --copp-about-process-pulse-duration: 720ms;
    padding-top: 8px;
    gap: var(--copp-about-process-gap);
    contain: layout;
}

.copp-about-process__step {
    padding-top: 2px;
    gap: 18px;
}

.copp-about-process__step::before,
.copp-about-process__step::after {
    display: none !important;
    content: none !important;
    animation: none !important;
}

.copp-about-process__icon {
    will-change: transform;
    backface-visibility: hidden;
    transform: translateZ(0);
    transition:
        background-color 420ms ease,
        border-color 420ms ease,
        color 420ms ease,
        transform 420ms ease,
        box-shadow 420ms ease;
}

.copp-about-process__step.is-active .copp-about-process__icon {
    background: var(--copp-red);
    border-color: var(--copp-red);
    color: #ffffff;
    transform: translateZ(0) scale(1.075);
    box-shadow: 0 14px 28px rgba(var(--copp-red-rgb), 0.18);
}

.copp-about-process__step.is-source .copp-about-process__icon {
    transform: translateZ(0) scale(1.1);
    box-shadow: 0 16px 32px rgba(var(--copp-red-rgb), 0.22);
}

.copp-about-process__connector {
    position: absolute;
    top: 26px;
    left: var(--copp-about-process-track-offset);
    width: var(--copp-about-process-track-width);
    height: 4px;
    pointer-events: none;
}

.copp-about-process__connector-line {
    position: absolute;
    inset: 0;
}

.copp-about-process__connector-line {
    top: 1px;
    height: 2px;
    background: rgba(35, 35, 35, 0.14);
    border-radius: 0;
}

.copp-about-process__connector-pulse {
    position: absolute;
    top: 0;
    left: 0;
    width: var(--copp-about-process-pulse-width);
    height: 4px;
    background: linear-gradient(90deg, rgba(255, 110, 114, 0.92), rgba(var(--copp-red-rgb), 1));
    transform: translate3d(0, 0, 0) scaleX(0);
    transform-origin: left center;
    will-change: transform, opacity;
    backface-visibility: hidden;
    opacity: 0;
    border-radius: 0;
}

.copp-about-process__connector.is-traveling .copp-about-process__connector-pulse {
    animation: none;
}

.copp-about-process__step p {
    margin: 0;
    max-width: 180px;
    color: #343434;
    font-size: 14px;
    line-height: 1.5;
}

.copp-about-team {
    align-items: start;
    display: grid;
    gap: 16px;
    grid-template-columns: minmax(260px, 0.42fr) minmax(0, 1fr);
}

.copp-about-team__intro {
    align-content: space-between;
    background: var(--copp-ink);
    border-radius: 0;
    color: #ffffff;
    display: grid;
    gap: 22px;
    min-height: 306px;
    overflow: hidden;
    padding: 28px;
    position: relative;
    position: sticky;
    top: 96px;
}

.copp-about-team__intro::before,
.copp-about-team__intro::after {
    content: "";
    display: block;
    position: absolute;
}

.copp-about-team__intro::before {
    background: rgba(var(--copp-red-rgb), 0.92);
    height: 54px;
    right: 28px;
    top: 28px;
    width: 54px;
}

.copp-about-team__intro::after {
    background: rgba(255, 255, 255, 0.92);
    bottom: 30px;
    height: 30px;
    right: 86px;
    width: 30px;
}

.copp-about-team__eyebrow {
    color: rgba(255, 255, 255, 0.72);
    display: block;
    font-size: var(--copp-fs-eyebrow);
    font-weight: var(--copp-fw-eyebrow);
    letter-spacing: var(--copp-ls-eyebrow);
    line-height: var(--copp-lh-eyebrow);
    position: relative;
    text-transform: uppercase;
    z-index: 1;
}

.copp-about-team__intro strong {
    color: #ffffff;
    display: block;
    font-size: clamp(30px, 3.2vw, 42px);
    font-weight: 900;
    line-height: 1.02;
    max-width: 360px;
    position: relative;
    text-transform: uppercase;
    z-index: 1;
}

.copp-about-team__intro p {
    color: rgba(255, 255, 255, 0.82);
    font-size: 15px;
    line-height: 1.5;
    margin: 0;
    max-width: 360px;
    position: relative;
    z-index: 1;
}

.copp-about-team__list {
    display: grid;
    gap: 18px;
    min-width: 0;
}

.copp-about-team__grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.copp-about-team__more {
    align-items: center;
    background: var(--copp-ink);
    border: 1px solid var(--copp-ink);
    border-radius: 0;
    color: #ffffff;
    display: inline-flex;
    font-size: 14px;
    font-weight: 900;
    gap: 10px;
    justify-self: start;
    line-height: 1.2;
    padding: 13px 16px;
    text-decoration: none;
    text-transform: uppercase;
    transition: background-color 180ms ease, border-color 180ms ease, color 180ms ease;
}

.copp-about-team__more:hover,
.copp-about-team__more:focus {
    background: var(--copp-red);
    border-color: var(--copp-red);
    color: #ffffff;
    text-decoration: none;
}

.copp-about-team__more svg {
    height: 14px;
    width: 14px;
}

.copp-about-team__more-count {
    align-items: center;
    background: var(--copp-red);
    border-radius: 0;
    color: #ffffff;
    display: inline-flex;
    font-size: 12px;
    height: 24px;
    justify-content: center;
    min-width: 24px;
    padding: 0 7px;
}

.copp-about-team__more:hover .copp-about-team__more-count,
.copp-about-team__more:focus .copp-about-team__more-count {
    background: #ffffff;
    color: var(--copp-red);
}

.copp-about-team__toggle-input:not(:checked) ~ .copp-about-team__grid .copp-about-team-card.is-extra {
    display: none;
}

.copp-about-team__toggle {
    align-items: center;
    background: var(--copp-ink);
    border: 1px solid var(--copp-ink);
    border-radius: 0;
    color: #ffffff;
    cursor: pointer;
    display: inline-flex;
    font-size: 14px;
    font-weight: 900;
    gap: 10px;
    justify-self: start;
    line-height: 1.2;
    padding: 13px 16px;
    text-transform: uppercase;
    transition: background-color 180ms ease, border-color 180ms ease, color 180ms ease;
}

.copp-about-team__toggle:hover,
.copp-about-team__toggle:focus {
    background: var(--copp-red);
    border-color: var(--copp-red);
    color: #ffffff;
    text-decoration: none;
}

.copp-about-team__toggle-hide {
    display: none;
}

.copp-about-team__toggle-input:checked ~ .copp-about-team__toggle .copp-about-team__toggle-show,
.copp-about-team__toggle-input:checked ~ .copp-about-team__toggle .copp-about-team__toggle-count {
    display: none;
}

.copp-about-team__toggle-input:checked ~ .copp-about-team__toggle .copp-about-team__toggle-hide {
    display: inline;
}

.copp-about-team__toggle-count {
    align-items: center;
    background: var(--copp-red);
    border-radius: 0;
    color: #ffffff;
    display: inline-flex;
    font-size: 12px;
    height: 24px;
    justify-content: center;
    min-width: 24px;
    padding: 0 7px;
}

.copp-about-team-card {
    border-radius: 0;
    display: grid;
    grid-template-rows: minmax(178px, 1fr) auto;
    min-height: 324px;
    overflow: hidden;
    position: relative;
}

.copp-about-team-card--light {
    background: var(--copp-soft);
    color: var(--copp-ink);
}

.copp-about-team-card--accent {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-about-team-card--deep {
    background: var(--copp-red-deep);
    color: #ffffff;
}

.copp-about-team-card--dark {
    background: var(--copp-ink);
    color: #ffffff;
}

.copp-about-team-card__photo {
    align-items: center;
    display: flex;
    isolation: isolate;
    justify-content: center;
    min-height: 178px;
    overflow: hidden;
    padding: 18px 18px 0;
    position: relative;
}

.copp-about-team-card__photo::before,
.copp-about-team-card__photo::after {
    content: "";
    display: block;
    position: absolute;
    z-index: -1;
}

.copp-about-team-card__photo::before {
    background: rgba(255, 255, 255, 0.16);
    height: 52px;
    right: 20px;
    top: 18px;
    width: 52px;
}

.copp-about-team-card__photo::after {
    background: rgba(35, 35, 35, 0.16);
    bottom: 26px;
    height: 28px;
    left: 22px;
    width: 28px;
}

.copp-about-team-card--light .copp-about-team-card__photo {
    background: linear-gradient(135deg, #ffffff 0%, var(--copp-pale) 100%);
}

.copp-about-team-card--accent .copp-about-team-card__photo {
    background: linear-gradient(135deg, var(--copp-red) 0%, var(--copp-red) 100%);
}

.copp-about-team-card--deep .copp-about-team-card__photo {
    background: linear-gradient(135deg, var(--copp-red) 0%, var(--copp-red-deep) 100%);
}

.copp-about-team-card--dark .copp-about-team-card__photo {
    background: linear-gradient(135deg, var(--copp-ink) 0%, var(--copp-dark) 100%);
}

.copp-about-team-card__photo img {
    display: block;
    filter: grayscale(1);
    height: 100%;
    inset: 0;
    object-fit: cover;
    object-position: center top;
    position: absolute;
    width: 100%;
}

.copp-about-team-card__portrait {
    align-self: end;
    display: block;
    height: 150px;
    position: relative;
    width: 132px;
    z-index: 1;
}

.copp-about-team-card__portrait-head {
    background: linear-gradient(135deg, var(--copp-soft) 0%, #d7d7d7 100%);
    border: 5px solid rgba(255, 255, 255, 0.72);
    border-radius: 0;
    display: block;
    height: 68px;
    left: 50%;
    position: absolute;
    top: 8px;
    transform: translateX(-50%);
    width: 68px;
}

.copp-about-team-card__portrait-body {
    background: linear-gradient(135deg, var(--copp-soft) 0%, #d9d9d9 100%);
    border-radius: 0;
    bottom: 0;
    display: block;
    height: 84px;
    left: 8px;
    position: absolute;
    right: 8px;
}

.copp-about-team-card__portrait-body::before,
.copp-about-team-card__portrait-body::after {
    background: rgba(35, 35, 35, 0.32);
    content: "";
    display: block;
    position: absolute;
}

.copp-about-team-card__portrait-body::before {
    height: 84px;
    left: 50%;
    top: 0;
    width: 2px;
}

.copp-about-team-card__portrait-body::after {
    height: 22px;
    left: 30px;
    top: 16px;
    width: 2px;
}

.copp-about-team-card__portrait-badge {
    align-items: center;
    background: var(--copp-red);
    border: 1px solid rgba(255, 255, 255, 0.66);
    border-radius: 0;
    bottom: 18px;
    color: #ffffff;
    display: inline-flex;
    height: 38px;
    justify-content: center;
    position: absolute;
    right: -6px;
    width: 38px;
}

.copp-about-team-card__portrait-badge i {
    display: block;
    font-size: 17px;
    line-height: 1;
}

.copp-about-team-card--light .copp-about-team-card__portrait-head,
.copp-about-team-card--light .copp-about-team-card__portrait-body {
    border-color: rgba(35, 35, 35, 0.08);
}

.copp-about-team-card--light .copp-about-team-card__portrait-badge {
    background: var(--copp-ink);
}

.copp-about-team-card--dark .copp-about-team-card__portrait-badge {
    background: #ffffff;
    color: var(--copp-ink);
}

.copp-about-team-card__role {
    color: currentColor;
    display: block;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0;
    line-height: 1.2;
    opacity: 0.68;
    text-transform: uppercase;
}

.copp-about-team-card__copy {
    display: grid;
    gap: 9px;
    min-width: 0;
    padding: 20px 22px 22px;
}

.copp-about-team-card__copy h3 {
    color: inherit;
    font-size: 19px;
    font-weight: 900;
    line-height: 1.2;
    margin: 0;
}

.copp-about-team-card__copy p {
    color: currentColor;
    font-size: 14px;
    line-height: 1.45;
    margin: 0;
    opacity: 0.78;
}

@media (max-width: 1199.98px) {
    .copp-about-team__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .copp-about-team {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-about-team__intro {
        min-height: 0;
        position: relative;
        top: auto;
    }
}

@media (max-width: 767.98px) {
    .copp-about-team__grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-about-team-card {
        min-height: 0;
    }

    .copp-about-team-card__photo {
        min-height: 210px;
    }
}

@media (max-width: 575.98px) {
    .copp-about-team__intro,
    .copp-about-team-card__copy {
        padding: 20px;
    }

    .copp-about-team-card__photo {
        min-height: 196px;
    }
}

.copp-team-directory {
    display: grid;
    gap: 18px;
}

.copp-team-directory__lead {
    align-items: end;
    display: flex;
    gap: 18px;
    justify-content: space-between;
}

.copp-team-directory__lead p {
    color: #4d4d4d;
    font-size: 16px;
    line-height: 1.55;
    margin: 0;
    max-width: 620px;
}

.copp-team-empty {
    background: #f4f4f4;
    border-radius: 0;
    color: #4d4d4d;
    font-size: 16px;
    font-weight: 800;
    line-height: 1.45;
    padding: 24px;
}

.copp-team-tree {
    --copp-team-tree-line: var(--copp-red);
    --copp-team-tree-line-soft: rgba(var(--copp-red-rgb), 0.28);
    --copp-team-tree-dark: var(--copp-ink);
    background:
        linear-gradient(135deg, rgba(var(--copp-red-rgb), 0.08) 0, rgba(var(--copp-red-rgb), 0) 38%),
        linear-gradient(90deg, rgba(255, 255, 255, 0.7) 1px, transparent 1px),
        linear-gradient(0deg, rgba(255, 255, 255, 0.7) 1px, transparent 1px),
        #f4f4f4;
    background-size: auto, 48px 48px, 48px 48px, auto;
    border: 1px solid rgba(37, 37, 37, 0.08);
    border-radius: 0;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.7);
    overflow-x: auto;
    padding: 28px;
    position: relative;
}

.copp-team-tree::before,
.copp-team-tree::after {
    content: "";
    display: block;
    pointer-events: none;
    position: absolute;
    z-index: 0;
}

.copp-team-tree::before {
    background: var(--copp-red);
    height: 28px;
    right: 34px;
    top: 24px;
    width: 28px;
}

.copp-team-tree::after {
    background: var(--copp-team-tree-dark);
    bottom: 28px;
    height: 22px;
    left: 34px;
    opacity: 0.92;
    width: 22px;
}

.copp-team-tree__canvas {
    min-width: 1120px;
    position: relative;
    z-index: 1;
}

.copp-team-tree__root {
    display: flex;
    justify-content: center;
    padding-bottom: 54px;
    position: relative;
}

.copp-team-tree__root::after {
    background: linear-gradient(180deg, var(--copp-red) 0%, rgba(32, 32, 32, 0.92) 100%);
    bottom: 0;
    content: "";
    display: block;
    height: 54px;
    left: 50%;
    position: absolute;
    transform: translateX(-50%);
    width: 3px;
}

.copp-team-tree__branches {
    display: grid;
    gap: 24px;
    grid-template-columns: minmax(300px, 1fr) minmax(360px, 1.15fr) minmax(300px, 1fr);
    padding-top: 34px;
    position: relative;
}

.copp-team-tree__branches::before {
    background: linear-gradient(90deg, transparent 0%, var(--copp-team-tree-dark) 8%, var(--copp-red) 50%, var(--copp-team-tree-dark) 92%, transparent 100%);
    content: "";
    display: block;
    height: 3px;
    left: 12%;
    position: absolute;
    right: 12%;
    top: 0;
}

.copp-team-tree__branch {
    align-content: start;
    display: grid;
    gap: 16px;
    position: relative;
}

.copp-team-tree__branch::before {
    background: linear-gradient(180deg, var(--copp-team-tree-dark) 0%, var(--copp-red) 100%);
    content: "";
    display: block;
    height: 34px;
    left: 50%;
    position: absolute;
    top: -34px;
    transform: translateX(-50%);
    width: 3px;
}

.copp-team-tree__branch h3 {
    background: #ffffff;
    border: 1px solid rgba(37, 37, 37, 0.16);
    border-left: 5px solid var(--copp-red);
    border-radius: 0;
    box-shadow: 6px 6px 0 rgba(var(--copp-red-rgb), 0.08);
    color: var(--copp-team-tree-dark);
    font-size: 14px;
    font-weight: 900;
    justify-self: center;
    line-height: 1.18;
    margin: 0;
    max-width: 310px;
    padding: 10px 14px;
    text-align: center;
    text-transform: uppercase;
}

.copp-team-tree__children {
    display: grid;
    gap: 14px;
    padding-top: 22px;
    position: relative;
}

.copp-team-tree__children::before {
    background: linear-gradient(180deg, var(--copp-red) 0%, rgba(32, 32, 32, 0.9) 100%);
    content: "";
    display: block;
    height: 22px;
    left: 50%;
    position: absolute;
    top: 0;
    transform: translateX(-50%);
    width: 3px;
}

.copp-team-tree-card {
    background: #ffffff;
    border: 1px solid rgba(37, 37, 37, 0.12);
    box-shadow: 8px 8px 0 rgba(37, 37, 37, 0.08);
    color: var(--copp-ink);
    display: grid;
    gap: 12px;
    grid-template-columns: 62px minmax(0, 1fr);
    min-height: 106px;
    padding: 14px 18px 14px 14px;
    position: relative;
}

.copp-team-tree-card::before {
    background: var(--copp-red);
    content: "";
    display: block;
    height: 36px;
    left: -1px;
    position: absolute;
    top: -1px;
    width: 5px;
}

.copp-team-tree-card--root {
    background:
        linear-gradient(135deg, rgba(var(--copp-red-rgb), 0.28) 0, rgba(var(--copp-red-rgb), 0) 34%),
        var(--copp-team-tree-dark);
    border-color: var(--copp-team-tree-dark);
    box-shadow: 10px 10px 0 rgba(var(--copp-red-rgb), 0.12);
    color: #ffffff;
    padding-right: 28px;
    width: 390px;
}

.copp-team-tree-card--root::after {
    background: var(--copp-red);
    content: "";
    display: block;
    height: 100%;
    position: absolute;
    right: 0;
    top: 0;
    width: 6px;
}

.copp-team-tree-card--manager {
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.12) 0, rgba(255, 255, 255, 0) 38%),
        var(--copp-red);
    border-color: var(--copp-red);
    box-shadow: 8px 8px 0 rgba(185, 0, 11, 0.16);
    color: #ffffff;
}

.copp-team-tree-card__media {
    align-items: center;
    align-self: start;
    background: var(--copp-soft);
    color: var(--copp-ink);
    display: flex;
    height: 62px;
    justify-content: center;
    overflow: hidden;
    width: 62px;
}

.copp-team-tree-card--root .copp-team-tree-card__media,
.copp-team-tree-card--manager .copp-team-tree-card__media {
    background: #ffffff;
    color: var(--copp-red);
}

.copp-team-tree-card--manager .copp-team-tree-card__media {
    color: var(--copp-red-dark);
}

.copp-team-tree-card__media i {
    font-size: 25px;
}

.copp-team-tree-card__media img {
    display: block;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    width: 100%;
}

.copp-team-tree-card__content {
    display: grid;
    gap: 6px;
    min-width: 0;
}

.copp-team-tree-card__content span {
    color: var(--copp-red);
    display: block;
    font-size: 11px;
    font-weight: 900;
    line-height: 1.18;
    overflow-wrap: anywhere;
    text-transform: uppercase;
}

.copp-team-tree-card--root .copp-team-tree-card__content span,
.copp-team-tree-card--manager .copp-team-tree-card__content span {
    color: rgba(255, 255, 255, 0.82);
}

.copp-team-tree-card__content strong {
    color: currentColor;
    display: block;
    font-size: 19px;
    font-weight: 900;
    line-height: 1.14;
    overflow-wrap: anywhere;
}

.copp-team-tree-card__content em {
    color: #565656;
    display: block;
    font-size: 14px;
    font-style: normal;
    font-weight: 800;
    line-height: 1.25;
    overflow-wrap: anywhere;
}

.copp-team-tree-card--root .copp-team-tree-card__content em,
.copp-team-tree-card--manager .copp-team-tree-card__content em {
    color: rgba(255, 255, 255, 0.86);
}

.copp-about-team__grid--directory {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

@media (max-width: 1199.98px) {
    .copp-about-team__grid--directory {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .copp-about-team__grid--directory {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .copp-team-directory__lead {
        align-items: flex-start;
        flex-direction: column;
    }

    .copp-team-tree {
        overflow-x: visible;
        padding: 18px;
    }

    .copp-team-tree__canvas {
        min-width: 0;
    }

    .copp-team-tree__root {
        padding-bottom: 34px;
    }

    .copp-team-tree__root::after {
        height: 34px;
    }

    .copp-team-tree__branches {
        gap: 28px;
        grid-template-columns: minmax(0, 1fr);
        padding-top: 0;
    }

    .copp-team-tree__branches::before {
        display: none;
    }

    .copp-team-tree__branch {
        border-left: 3px solid var(--copp-team-tree-line);
        padding-left: 18px;
    }

    .copp-team-tree__branch::before {
        display: none;
    }

    .copp-team-tree__branch h3 {
        justify-self: start;
        text-align: left;
    }

    .copp-team-tree__children {
        padding-top: 14px;
    }

    .copp-team-tree__children::before {
        display: none;
    }
}

@media (max-width: 767.98px) {
    .copp-about-team__grid--directory {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-team-tree {
        padding: 14px;
    }

    .copp-team-tree-card,
    .copp-team-tree-card--root {
        grid-template-columns: 52px minmax(0, 1fr);
        min-height: 0;
        padding: 12px 18px 12px 12px;
        width: auto;
    }

    .copp-team-tree-card__media {
        height: 52px;
        width: 52px;
    }

    .copp-team-tree-card--root {
        gap: 10px;
        grid-template-columns: 44px minmax(0, 1fr);
        padding-right: 24px;
    }

    .copp-team-tree-card--root .copp-team-tree-card__media {
        height: 44px;
        width: 44px;
    }

    .copp-team-tree-card__content span {
        font-size: 10px;
    }

    .copp-team-tree-card__content strong {
        font-size: 17px;
    }

    .copp-team-tree-card__content em {
        font-size: 13px;
    }
}

.copp-team-tree {
    --copp-team-tree-line: var(--copp-red);
    --copp-team-tree-line-soft: rgba(var(--copp-red-rgb), 0.2);
    --copp-team-tree-dark: var(--copp-ink);
    background:
        linear-gradient(135deg, rgba(var(--copp-red-rgb), 0.1) 0, rgba(var(--copp-red-rgb), 0) 34%),
        linear-gradient(90deg, rgba(35, 35, 35, 0.04) 1px, transparent 1px),
        linear-gradient(0deg, rgba(35, 35, 35, 0.04) 1px, transparent 1px),
        #f4f4f4;
    background-size: auto, 42px 42px, 42px 42px, auto;
    border: 1px solid rgba(35, 35, 35, 0.1);
    border-radius: 0;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.75);
    overflow: hidden;
    padding: 28px;
    position: relative;
}

.copp-team-tree::before {
    background: var(--copp-red);
    content: "";
    display: block;
    height: 44px;
    opacity: 1;
    position: absolute;
    right: 28px;
    top: 28px;
    width: 44px;
    z-index: 0;
}

.copp-team-tree::after {
    background: var(--copp-ink);
    bottom: 28px;
    content: "";
    display: block;
    height: 30px;
    left: 28px;
    opacity: 0.92;
    position: absolute;
    width: 30px;
    z-index: 0;
}

.copp-team-tree__legend {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 22px;
    position: relative;
    z-index: 1;
}

.copp-team-tree__legend span {
    align-items: center;
    background: #ffffff;
    border: 1px solid rgba(35, 35, 35, 0.1);
    border-radius: 0;
    color: var(--copp-ink);
    display: inline-flex;
    font-size: 12px;
    font-weight: 900;
    gap: 7px;
    line-height: 1;
    padding: 9px 12px;
    text-transform: uppercase;
}

.copp-team-tree__legend i {
    color: var(--copp-red);
}

.copp-team-tree__canvas {
    min-width: 0;
    position: relative;
    z-index: 1;
}

.copp-team-tree__root {
    display: flex;
    justify-content: center;
    padding-bottom: 40px;
    position: relative;
}

.copp-team-tree__root::after {
    background: linear-gradient(180deg, var(--copp-red) 0%, rgba(32, 32, 32, 0.92) 100%);
    bottom: 0;
    content: "";
    display: block;
    height: 40px;
    left: 50%;
    position: absolute;
    transform: translateX(-50%);
    width: 4px;
}

.copp-team-tree__level {
    align-items: center;
    display: grid;
    grid-template-columns: minmax(40px, 1fr) auto minmax(40px, 1fr);
    gap: 16px;
    margin: 0 0 24px;
}

.copp-team-tree__level::before,
.copp-team-tree__level::after {
    background: linear-gradient(90deg, transparent 0%, rgba(var(--copp-red-rgb), 0.92) 100%);
    content: "";
    display: block;
    height: 3px;
}

.copp-team-tree__level::after {
    background: linear-gradient(90deg, rgba(var(--copp-red-rgb), 0.92) 0%, transparent 100%);
}

.copp-team-tree__level span {
    background: var(--copp-team-tree-dark);
    border-radius: 0;
    color: #ffffff;
    font-size: 12px;
    font-weight: 900;
    line-height: 1;
    padding: 11px 16px;
    text-transform: uppercase;
    white-space: nowrap;
}

.copp-team-tree__branches {
    align-items: start;
    display: grid;
    gap: 20px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    padding-top: 0;
    position: relative;
}

.copp-team-tree__branches::before {
    display: none;
}

.copp-team-tree__branch {
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid rgba(35, 35, 35, 0.1);
    border-radius: 0;
    box-shadow: 0 18px 40px rgba(35, 35, 35, 0.06);
    display: grid;
    gap: 14px;
    padding: 16px;
    position: relative;
}

.copp-team-tree__branch::before {
    background: var(--copp-red);
    content: "";
    display: block;
    height: 4px;
    left: 16px;
    position: absolute;
    right: 16px;
    top: 0;
    transform: none;
    width: auto;
}

.copp-team-tree__branch-head {
    align-items: start;
    display: grid;
    gap: 10px 12px;
    grid-template-columns: 44px minmax(0, 1fr);
    padding: 8px 0 4px;
}

.copp-team-tree__branch-head > span {
    align-items: center;
    background: var(--copp-red);
    color: #ffffff;
    display: inline-flex;
    font-size: 16px;
    font-weight: 900;
    height: 44px;
    justify-content: center;
    line-height: 1;
    width: 44px;
}

.copp-team-tree__branch-head h3 {
    background: transparent;
    border: 0;
    box-shadow: none;
    color: var(--copp-team-tree-dark);
    font-size: 18px;
    font-weight: 900;
    justify-self: stretch;
    line-height: 1.16;
    margin: 0;
    max-width: none;
    padding: 0;
    text-align: left;
    text-transform: uppercase;
}

.copp-team-tree__branch-head em {
    color: #666666;
    display: block;
    font-size: 12px;
    font-style: normal;
    font-weight: 900;
    grid-column: 2;
    line-height: 1.1;
    text-transform: uppercase;
}

.copp-team-tree__children {
    display: grid;
    gap: 10px;
    padding-top: 6px;
    position: relative;
}

.copp-team-tree__children::before {
    display: none;
}

.copp-team-tree-card {
    background: #ffffff;
    border: 1px solid rgba(35, 35, 35, 0.1);
    border-radius: 0;
    box-shadow: none;
    color: var(--copp-ink);
    display: grid;
    gap: 12px;
    grid-template-columns: 58px minmax(0, 1fr);
    min-height: 96px;
    padding: 14px;
    position: relative;
}

.copp-team-tree-card::before {
    background: var(--copp-red);
    content: "";
    display: block;
    height: calc(100% - 20px);
    left: -1px;
    position: absolute;
    top: 10px;
    width: 4px;
}

.copp-team-tree-card--root {
    background:
        linear-gradient(135deg, rgba(var(--copp-red-rgb), 0.3) 0, rgba(var(--copp-red-rgb), 0) 38%),
        var(--copp-team-tree-dark);
    border-color: var(--copp-team-tree-dark);
    box-shadow: 12px 12px 0 rgba(var(--copp-red-rgb), 0.14);
    color: #ffffff;
    grid-template-columns: 82px minmax(0, 1fr);
    max-width: 560px;
    min-height: 132px;
    padding: 22px 28px 22px 22px;
    width: 100%;
}

.copp-team-tree-card--root::after {
    background: var(--copp-red);
    content: "";
    display: block;
    height: 100%;
    position: absolute;
    right: 0;
    top: 0;
    width: 7px;
}

.copp-team-tree-card--manager {
    background: var(--copp-red);
    border-color: var(--copp-red);
    color: #ffffff;
}

.copp-team-tree-card--manager::before {
    background: #ffffff;
}

.copp-team-tree-card__media {
    align-items: center;
    align-self: start;
    background: var(--copp-pale);
    border-radius: 0;
    color: var(--copp-ink);
    display: flex;
    height: 58px;
    justify-content: center;
    overflow: hidden;
    width: 58px;
}

.copp-team-tree-card--root .copp-team-tree-card__media {
    background: #ffffff;
    color: var(--copp-red);
    height: 82px;
    width: 82px;
}

.copp-team-tree-card--manager .copp-team-tree-card__media {
    background: #ffffff;
    color: var(--copp-red-dark);
}

.copp-team-tree-card__content {
    align-content: center;
    display: grid;
    gap: 6px;
    min-width: 0;
}

.copp-team-tree-card__content span {
    color: var(--copp-red);
    display: block;
    font-size: 11px;
    font-weight: 900;
    line-height: 1.16;
    overflow-wrap: anywhere;
    text-transform: uppercase;
}

.copp-team-tree-card--root .copp-team-tree-card__content span,
.copp-team-tree-card--manager .copp-team-tree-card__content span {
    color: rgba(255, 255, 255, 0.82);
}

.copp-team-tree-card__content strong {
    color: currentColor;
    display: block;
    font-size: 19px;
    font-weight: 900;
    line-height: 1.12;
    overflow-wrap: anywhere;
}

.copp-team-tree-card--root .copp-team-tree-card__content strong {
    font-size: 28px;
}

.copp-team-tree-card__content em {
    color: #565656;
    display: block;
    font-size: 13px;
    font-style: normal;
    font-weight: 800;
    line-height: 1.3;
    overflow-wrap: anywhere;
}

.copp-team-tree-card--root .copp-team-tree-card__content em,
.copp-team-tree-card--manager .copp-team-tree-card__content em {
    color: rgba(255, 255, 255, 0.86);
}

@media (max-width: 1199.98px) {
    .copp-team-tree__branches {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .copp-about-scope,
    .copp-about-equipment,
    .copp-about-gallery {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-about-scope-card,
    .copp-about-equipment__copy {
        min-height: 0;
    }

    .copp-team-tree {
        padding: 20px;
    }

    .copp-team-tree__branches {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-team-tree__branch {
        border-left: 0;
        padding-left: 16px;
    }

    .copp-about-gallery-card,
    .copp-about-gallery-card--wide {
        min-height: 300px;
    }
}

@media (max-width: 767.98px) {
    .copp-about-scope-card,
    .copp-about-equipment__copy {
        padding: 24px;
    }

    .copp-about-scope-card h3,
    .copp-about-equipment__copy h3 {
        font-size: 26px;
    }

    .copp-about-equipment__grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-about-gallery-card,
    .copp-about-gallery-card--wide {
        min-height: 260px;
    }

    .copp-about-gallery-card__caption {
        padding: 20px;
    }

    .copp-about-gallery-card__caption h3 {
        font-size: 20px;
    }

    .copp-team-tree {
        padding: 16px;
    }

    .copp-team-tree__level {
        grid-template-columns: minmax(0, 1fr);
        justify-items: start;
    }

    .copp-team-tree__level::before,
    .copp-team-tree__level::after {
        display: none;
    }

    .copp-team-tree-card,
    .copp-team-tree-card--root {
        grid-template-columns: 52px minmax(0, 1fr);
        min-height: 0;
        padding: 12px 18px 12px 12px;
        width: auto;
    }

    .copp-team-tree-card__media,
    .copp-team-tree-card--root .copp-team-tree-card__media {
        height: 52px;
        width: 52px;
    }

    .copp-team-tree-card--root .copp-team-tree-card__content strong {
        font-size: 22px;
    }
}

.copp-team-iconostasis {
    background:
        linear-gradient(135deg, rgba(var(--copp-red-rgb), 0.1) 0, rgba(var(--copp-red-rgb), 0) 34%),
        #f4f4f4;
    border: 1px solid rgba(35, 35, 35, 0.1);
    border-radius: 0;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.75);
    overflow: hidden;
    padding: 28px;
    position: relative;
    z-index: 20;
}

.copp-team-iconostasis::before,
.copp-team-iconostasis::after {
    content: "";
    display: block;
    pointer-events: none;
    position: absolute;
    z-index: 0;
}

.copp-team-iconostasis::before {
    background: linear-gradient(90deg, var(--copp-red), var(--copp-ink));
    height: 5px;
    left: 0;
    right: 0;
    top: 0;
}

.copp-team-iconostasis::after {
    content: none;
}

.copp-team-iconostasis__top {
    align-items: stretch;
    display: grid;
    gap: 16px;
    grid-template-columns: minmax(160px, 230px) minmax(0, 1fr);
    margin-bottom: 22px;
    position: relative;
    z-index: 1;
}

.copp-team-iconostasis__top > div {
    background: var(--copp-ink);
    border-radius: 0;
    color: #ffffff;
    display: grid;
    gap: 8px;
    padding: 20px;
}

.copp-team-iconostasis__top span {
    color: rgba(255, 255, 255, 0.82);
    font-size: 12px;
    font-weight: 900;
    line-height: 1.2;
    text-transform: uppercase;
}

.copp-team-iconostasis__top strong {
    color: #ffffff;
    font-size: 54px;
    font-weight: 900;
    line-height: 0.9;
}

.copp-team-iconostasis__chips {
    align-self: stretch;
    background: #ffffff;
    border: 1px solid rgba(35, 35, 35, 0.1);
    border-left: 5px solid var(--copp-red);
    border-radius: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding: 18px 20px;
}

.copp-team-iconostasis__chips span {
    align-items: center;
    background: var(--copp-soft);
    border: 1px solid rgba(35, 35, 35, 0.08);
    border-radius: 0;
    color: #303030;
    display: inline-flex;
    gap: 9px;
    min-height: 38px;
    padding: 9px 12px 9px 14px;
}

.copp-team-iconostasis__chips strong {
    align-items: center;
    background: var(--copp-red);
    border-radius: 0;
    color: #ffffff;
    display: inline-flex;
    font-size: 12px;
    height: 24px;
    justify-content: center;
    line-height: 1;
    min-width: 24px;
}

.copp-team-iconostasis__groups {
    display: grid;
    gap: 18px;
    position: relative;
    z-index: 1;
}

.copp-team-iconostasis__group {
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(35, 35, 35, 0.08);
    border-radius: 0;
    display: grid;
    gap: 16px;
    padding: 18px;
}

.copp-team-iconostasis__group--leaders {
    background: linear-gradient(135deg, rgba(35, 35, 35, 0.06), rgba(255, 255, 255, 0.88));
}

.copp-team-iconostasis__group-head {
    align-items: center;
    display: flex;
    gap: 12px;
    justify-content: space-between;
}

.copp-team-iconostasis__group-head span {
    color: var(--copp-ink);
    font-size: 18px;
    font-weight: 900;
    line-height: 1.1;
    text-transform: uppercase;
}

.copp-team-iconostasis__group-head strong {
    align-items: center;
    background: var(--copp-ink);
    border-radius: 0;
    color: #ffffff;
    display: inline-flex;
    font-size: 13px;
    font-weight: 900;
    height: 30px;
    justify-content: center;
    min-width: 30px;
    padding: 0 9px;
}

.copp-team-iconostasis__grid {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    position: relative;
    z-index: 1;
}

.copp-team-icon-card {
    background: #ffffff;
    border: 1px solid rgba(35, 35, 35, 0.1);
    border-radius: 0;
    box-shadow: 0 18px 40px rgba(35, 35, 35, 0.08);
    display: grid;
    grid-template-columns: 112px minmax(0, 1fr);
    min-height: 170px;
    min-width: 0;
    overflow: hidden;
    position: relative;
}

.copp-team-icon-card::before {
    background: var(--copp-red);
    content: "";
    display: block;
    height: 5px;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 2;
}

.copp-team-icon-card--leader {
    background: var(--copp-ink);
    color: #ffffff;
}

.copp-team-icon-card--manager {
    border-color: rgba(var(--copp-red-rgb), 0.28);
}

.copp-team-icon-card__photo {
    align-items: center;
    background:
        linear-gradient(135deg, rgba(var(--copp-red-rgb), 0.18) 0, rgba(var(--copp-red-rgb), 0) 42%),
        var(--copp-pale);
    color: var(--copp-ink);
    display: flex;
    justify-content: center;
    overflow: hidden;
    position: relative;
}

.copp-team-icon-card--leader .copp-team-icon-card__photo {
    background:
        linear-gradient(135deg, rgba(var(--copp-red-rgb), 0.38) 0, rgba(var(--copp-red-rgb), 0) 44%),
        #303030;
    color: #ffffff;
}

.copp-team-icon-card__photo img {
    display: block;
    height: 100%;
    object-fit: cover;
    object-position: center 18%;
    width: 100%;
}

.copp-team-icon-card__photo i {
    font-size: 42px;
}

.copp-team-icon-card__body {
    align-content: center;
    display: grid;
    gap: 10px;
    min-height: 0;
    padding: 18px;
}

.copp-team-icon-card__meta {
    align-items: flex-start;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.copp-team-icon-card__branch {
    color: var(--copp-red);
    display: block;
    font-size: 11px;
    font-weight: 900;
    line-height: 1.18;
    overflow-wrap: anywhere;
    text-transform: uppercase;
}

.copp-team-icon-card__badge {
    background: rgba(var(--copp-red-rgb), 0.1);
    border: 1px solid rgba(var(--copp-red-rgb), 0.18);
    color: var(--copp-red);
    font-size: var(--copp-fs-badge);
    font-weight: var(--copp-fw-bold);
    letter-spacing: var(--copp-ls-label);
    line-height: 1;
    padding: 7px 8px;
    text-transform: uppercase;
}

.copp-team-icon-card--leader .copp-team-icon-card__branch {
    color: rgba(255, 255, 255, 0.78);
}

.copp-team-icon-card--leader .copp-team-icon-card__badge {
    background: #ffffff;
    border-color: #ffffff;
    color: var(--copp-red);
}

.copp-team-icon-card__body h3 {
    color: currentColor;
    font-size: 22px;
    font-weight: 900;
    line-height: 1.08;
    margin: 0;
    overflow-wrap: anywhere;
}

.copp-team-icon-card__body p {
    color: #555555;
    font-size: 14px;
    font-weight: 800;
    line-height: 1.32;
    margin: 0;
    overflow-wrap: anywhere;
}

.copp-team-icon-card--leader .copp-team-icon-card__body p {
    color: rgba(255, 255, 255, 0.86);
}

@media (max-width: 1199.98px) {
    .copp-team-iconostasis__grid {
        grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
    }
}

@media (max-width: 991.98px) {
    .copp-team-iconostasis {
        padding: 20px;
    }

    .copp-team-iconostasis__top {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-team-iconostasis__grid {
        grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    }
}

@media (max-width: 575.98px) {
    .copp-team-iconostasis {
        padding: 14px;
    }

    .copp-team-iconostasis__top strong {
        font-size: 44px;
    }

    .copp-team-iconostasis__chips {
        padding: 14px;
    }

    .copp-team-iconostasis__grid {
        gap: 14px;
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-team-icon-card {
        grid-template-columns: 92px minmax(0, 1fr);
        min-height: 150px;
    }

    .copp-team-icon-card__body {
        padding: 14px;
    }

    .copp-team-icon-card__body h3 {
        font-size: 19px;
    }

    .copp-team-icon-card__body p {
        font-size: 13px;
    }
}

.copp-team {
    display: grid;
    gap: 24px;
}

.copp-team__bar {
    align-items: center;
    background: var(--copp-ink);
    color: #ffffff;
    display: flex;
    flex-wrap: wrap;
    gap: 0;
}

.copp-team__bar-stat {
    align-items: baseline;
    display: flex;
    gap: 6px;
    padding: 16px 22px;
}

.copp-team__bar-stat + .copp-team__bar-stat {
    border-left: 1px solid rgba(255, 255, 255, 0.1);
}

.copp-team__bar-stat strong {
    color: var(--copp-red);
    font-size: 22px;
    font-weight: 900;
    line-height: 1;
}

.copp-team__bar-stat span {
    color: rgba(255, 255, 255, 0.5);
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
}

.copp-team__bar-cta {
    align-items: center;
    background: var(--copp-red);
    color: #ffffff;
    display: inline-flex;
    font-size: 12px;
    font-weight: 900;
    gap: 6px;
    line-height: 1;
    margin-left: auto;
    min-height: 100%;
    padding: 16px 20px;
    text-decoration: none;
    text-transform: uppercase;
    transition: background 0.15s;
}

.copp-team__bar-cta:hover,
.copp-team__bar-cta:focus {
    background: var(--copp-red);
    color: #ffffff;
    text-decoration: none;
}

.copp-team__bar-cta svg {
    height: 12px;
    width: 12px;
}

@media (max-width: 575.98px) {
    .copp-team__bar {
        flex-wrap: wrap;
    }

    .copp-team__bar-stat {
        padding: 12px 16px;
    }

    .copp-team__bar-cta {
        margin-left: 0;
        padding: 14px 16px;
        width: 100%;
        justify-content: center;
    }
}

.copp-team__clusters {
    display: grid;
    gap: 24px;
}

.copp-team__cluster {
    display: grid;
    gap: 16px;
}

.copp-team__cluster--lead .copp-team__cluster-num {
    color: var(--copp-red);
}

.copp-team__cluster + .copp-team__cluster {
    border-top: 2px solid var(--copp-soft);
    padding-top: 24px;
}

.copp-team__cluster-head {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px 16px;
    justify-content: space-between;
}

.copp-team__cluster-head-left {
    align-items: center;
    display: flex;
    gap: 14px;
}

.copp-team__cluster-num {
    color: rgba(35, 35, 35, 0.2);
    font-size: 28px;
    font-weight: 900;
    line-height: 1;
}

.copp-team__cluster-head h3 {
    color: var(--copp-ink);
    font-size: 18px;
    font-weight: 900;
    line-height: 1.2;
    margin: 0;
}

.copp-team__cluster-head p {
    color: #686868;
    font-size: 13px;
    line-height: 1.4;
    margin: 0;
}

.copp-team__cluster-count {
    background: var(--copp-soft);
    color: rgba(35, 35, 35, 0.6);
    font-size: 11px;
    font-weight: 900;
    min-height: 26px;
    padding: 0 12px;
    display: inline-flex;
    align-items: center;
    text-transform: uppercase;
}

.copp-team__cluster-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
}

.copp-team-card {
    background: #ffffff;
    border: 1px solid rgba(35, 35, 35, 0.1);
    display: grid;
    grid-template-rows: auto 180px;
    overflow: hidden;
    position: relative;
    transition: border-color 0.15s, box-shadow 0.15s;
}

.copp-team-card:hover {
    border-color: rgba(var(--copp-red-rgb), 0.2);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
}

.copp-team-card--leader {
    border-color: rgba(var(--copp-red-rgb), 0.2);
    box-shadow: 0 8px 24px rgba(var(--copp-red-rgb), 0.06);
}

.copp-team-card--leader:hover {
    border-color: rgba(var(--copp-red-rgb), 0.35);
    box-shadow: 0 8px 32px rgba(var(--copp-red-rgb), 0.1);
}

.copp-team-card--manager {
    background: linear-gradient(180deg, #ffffff 0%, var(--copp-soft) 100%);
}

.copp-team-card__body {
    align-content: start;
    display: grid;
    gap: 6px;
    min-width: 0;
    padding: 12px 14px 14px;
}

.copp-team-card__tag {
    background: var(--copp-soft);
    border: 1px solid rgba(35, 35, 35, 0.08);
    color: #4f4f4f;
    display: inline-flex;
    align-items: center;
    font-size: var(--copp-fs-badge);
    font-weight: var(--copp-fw-bold);
    letter-spacing: var(--copp-ls-label);
    line-height: 1;
    min-height: 20px;
    padding: 0 8px;
    text-transform: uppercase;
    width: fit-content;
}

.copp-team-card__tag--accent {
    background: rgba(var(--copp-red-rgb), 0.08);
    border-color: rgba(var(--copp-red-rgb), 0.18);
    color: var(--copp-red);
}

.copp-team-card h3 {
    color: var(--copp-ink);
    display: -webkit-box;
    font-size: 16px;
    font-weight: 900;
    line-height: 1.2;
    margin: 0;
    overflow-wrap: anywhere;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.copp-team-card__position {
    color: #555;
    font-size: 12px;
    font-weight: 700;
    display: -webkit-box;
    line-height: 1.45;
    margin: 0;
    overflow-wrap: anywhere;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.copp-team-card__photo {
    align-items: center;
    background: var(--copp-pale);
    color: var(--copp-ink);
    display: flex;
    height: 100%;
    justify-content: center;
    min-height: 0;
    overflow: hidden;
    width: 100%;
}

.copp-team-card__photo.is-placeholder {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0)),
        linear-gradient(135deg, var(--copp-soft) 0%, #e7e7e7 100%);
}

.copp-team-card__photo img {
    display: block;
    height: 100%;
    object-fit: cover;
    object-position: center 16%;
    width: 100%;
}

.copp-team-card__photo i {
    color: var(--copp-ink);
    font-size: 42px;
}

.copp-team-card__initials {
    align-items: center;
    background: rgba(35, 35, 35, 0.08);
    border: 1px solid rgba(35, 35, 35, 0.08);
    color: var(--copp-ink);
    display: inline-flex;
    font-size: 38px;
    font-weight: 900;
    height: 92px;
    justify-content: center;
    letter-spacing: 0;
    width: 92px;
}

@media (max-width: 1199.98px) {
}

@media (max-width: 991.98px) {
    .copp-team-card {
        grid-template-rows: minmax(0, 1fr) 118px;
    }
}

@media (max-width: 575.98px) {
    .copp-team__cluster-head {
        align-items: start;
        flex-direction: column;
    }

    .copp-team__cluster-grid {
        grid-template-columns: 1fr;
    }
}

.copp-team-minimal__summary {
    align-items: start;
    background: var(--copp-soft);
    border: 1px solid rgba(35, 35, 35, 0.08);
    border-radius: 0;
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(0, 1fr) auto;
    padding: 18px 20px;
}

.copp-team-minimal__summary-main {
    display: grid;
    gap: 4px;
    grid-column: 1;
}

.copp-team-minimal__eyebrow {
    color: rgba(35, 35, 35, 0.56);
    font-size: var(--copp-fs-eyebrow);
    font-weight: var(--copp-fw-eyebrow);
    letter-spacing: var(--copp-ls-eyebrow);
    line-height: var(--copp-lh-eyebrow);
    text-transform: uppercase;
}

.copp-team-minimal__summary-main > strong {
    color: var(--copp-ink);
    font-size: 48px;
    font-weight: 900;
    line-height: 0.9;
}

.copp-team-minimal__summary-label {
    color: rgba(35, 35, 35, 0.6);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0;
    line-height: 1.2;
    text-transform: uppercase;
}

.copp-team-minimal__summary p {
    color: #575757;
    font-size: 14px;
    grid-column: 1;
    line-height: 1.55;
    margin: 0;
    max-width: 640px;
}

.copp-team-minimal__facts {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    grid-column: 2;
    justify-content: flex-end;
    justify-self: end;
}

.copp-team-minimal__facts span {
    align-items: center;
    background: #ffffff;
    border: 1px solid rgba(35, 35, 35, 0.1);
    border-radius: 0;
    color: var(--copp-ink);
    display: inline-flex;
    font-size: 12px;
    font-weight: 900;
    height: 24px;
    justify-content: center;
    padding: 0 10px;
    text-transform: uppercase;
}

.copp-team-minimal__contact {
    align-items: center;
    background: var(--copp-ink);
    border: 1px solid var(--copp-ink);
    border-radius: 0;
    color: #ffffff;
    display: inline-flex;
    font-size: 13px;
    font-weight: 900;
    gap: 8px;
    grid-column: 2;
    justify-content: center;
    justify-self: end;
    line-height: 1;
    min-height: 42px;
    padding: 0 14px;
    text-transform: uppercase;
}

.copp-team-minimal__contact:hover,
.copp-team-minimal__contact:focus {
    background: var(--copp-red);
    border-color: var(--copp-red);
    color: #ffffff;
    text-decoration: none;
}

.copp-team-minimal__contact svg {
    height: 14px;
    width: 14px;
}

.copp-team-minimal__grid {
    display: grid;
    gap: 16px;
}

.copp-team-minimal__cluster {
    display: grid;
    gap: 12px;
}

.copp-team-minimal__cluster + .copp-team-minimal__cluster {
    border-top: 1px solid rgba(35, 35, 35, 0.08);
    padding-top: 16px;
}

.copp-team-minimal__cluster-head {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px 12px;
    justify-content: space-between;
}

.copp-team-minimal__cluster-head-main {
    display: grid;
    gap: 4px;
}

.copp-team-minimal__cluster-head h3 {
    color: var(--copp-ink);
    font-size: 16px;
    font-weight: 900;
    line-height: 1.2;
    margin: 0;
}

.copp-team-minimal__cluster-head p {
    color: #686868;
    font-size: 13px;
    line-height: 1.45;
    margin: 0;
}

.copp-team-minimal__cluster-head span {
    align-items: center;
    background: var(--copp-soft);
    border: 1px solid rgba(35, 35, 35, 0.08);
    border-radius: 0;
    color: rgba(35, 35, 35, 0.72);
    display: inline-flex;
    font-size: 11px;
    font-weight: 900;
    min-height: 24px;
    padding: 0 10px;
    text-transform: uppercase;
}

.copp-team-minimal__cluster-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(auto-fit, minmax(220px, 260px));
    justify-content: start;
}

.copp-team-minimal-card {
    background: #ffffff;
    border: 1px solid rgba(35, 35, 35, 0.1);
    border-radius: 0;
    display: grid;
    gap: 0;
    grid-template-rows: auto 180px;
    overflow: hidden;
}

.copp-team-minimal-card--leader {
    border-color: rgba(var(--copp-red-rgb), 0.18);
    box-shadow: 0 16px 32px rgba(var(--copp-red-rgb), 0.08);
}

.copp-team-minimal-card--manager {
    background: linear-gradient(180deg, #ffffff 0%, #fbfbfb 100%);
}

.copp-team-minimal-card__photo {
    align-items: center;
    background: var(--copp-pale);
    color: var(--copp-ink);
    display: flex;
    height: 100%;
    justify-content: center;
    min-height: 0;
    overflow: hidden;
    width: 100%;
}

.copp-team-minimal-card__photo.is-placeholder {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0)),
        linear-gradient(135deg, var(--copp-soft) 0%, #e7e7e7 100%);
}

.copp-team-minimal-card__photo img {
    display: block;
    height: 100%;
    object-fit: cover;
    object-position: center 16%;
    width: 100%;
}

.copp-team-minimal-card__photo i {
    color: var(--copp-ink);
    font-size: 42px;
}

.copp-team-minimal-card__initials {
    align-items: center;
    background: rgba(35, 35, 35, 0.08);
    border: 1px solid rgba(35, 35, 35, 0.08);
    border-radius: 0;
    color: var(--copp-ink);
    display: inline-flex;
    font-size: 38px;
    font-weight: 900;
    height: 92px;
    justify-content: center;
    letter-spacing: 0;
    width: 92px;
}

.copp-team-minimal-card__body {
    display: grid;
    align-content: start;
    gap: 8px;
    min-width: 0;
    padding: 10px 10px 12px;
}

.copp-team-minimal-card__meta {
    align-items: center;
    display: flex;
    min-height: 22px;
}

.copp-team-minimal-card__tag {
    align-items: center;
    background: var(--copp-soft);
    border: 1px solid rgba(35, 35, 35, 0.08);
    border-radius: 0;
    color: #4f4f4f;
    display: inline-flex;
    font-size: var(--copp-fs-badge);
    font-weight: var(--copp-fw-bold);
    letter-spacing: var(--copp-ls-label);
    line-height: 1.1;
    min-height: 22px;
    padding: 0 8px;
    text-transform: uppercase;
}

.copp-team-minimal-card__tag--accent {
    background: rgba(var(--copp-red-rgb), 0.08);
    border: 1px solid rgba(var(--copp-red-rgb), 0.18);
    color: var(--copp-red);
}

.copp-team-minimal-card h3 {
    color: var(--copp-ink);
    display: -webkit-box;
    font-size: 17px;
    font-weight: 900;
    line-height: 1.2;
    margin: 0;
    overflow-wrap: anywhere;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.copp-team-minimal-card__position {
    color: #555555;
    font-size: 13px;
    font-weight: 700;
    display: -webkit-box;
    line-height: 1.45;
    margin: 0;
    overflow-wrap: anywhere;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    overflow: hidden;
}

@media (max-width: 1199.98px) {
    .copp-team-minimal__summary {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-team-minimal__summary-main,
    .copp-team-minimal__summary p,
    .copp-team-minimal__facts,
    .copp-team-minimal__contact {
        grid-column: auto;
        justify-self: start;
    }

}

@media (max-width: 991.98px) {
    .copp-team-minimal__summary {
        padding: 18px;
    }

    .copp-team-minimal-card {
        grid-template-rows: minmax(0, 1fr) 118px;
    }
}

@media (max-width: 575.98px) {
    .copp-team-minimal {
        padding: 16px;
    }

    .copp-team-minimal__summary {
        padding: 16px;
    }

    .copp-team-minimal-card {
        aspect-ratio: auto;
        grid-template-rows: auto auto;
    }

    .copp-team-minimal__cluster-head {
        align-items: start;
        flex-direction: column;
    }

    .copp-team-minimal__cluster-grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-team-minimal-card__photo {
        min-height: 220px;
    }
}

.copp-news-btn--ghost-light {
    background: transparent;
    border-color: rgba(255, 255, 255, 0.92);
    color: #ffffff;
}

.copp-news-btn--ghost-light:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: #ffffff;
    color: #ffffff;
}

.copp-about-join {
    --copp-about-join-max: 1140px;
    --copp-about-join-gutter: 15px;
    position: relative;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    width: 100vw;
    overflow: hidden;
    background: linear-gradient(135deg, var(--copp-red) 0%, var(--copp-red) 100%);
}

.copp-about-join__inner {
    width: calc(100% - 30px);
    max-width: var(--copp-container-content);
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(360px, 430px) minmax(0, 1fr);
    align-items: center;
    gap: clamp(36px, 4vw, 72px);
    min-height: 248px;
}

.copp-about-join__copy {
    padding: 32px 0;
    color: #ffffff;
}

.copp-about-join__copy h2 {
    margin: 0;
    max-width: 340px;
    color: #ffffff;
    font-size: 24px;
    font-weight: 900;
    line-height: 1.12;
    text-transform: uppercase;
}

.copp-about-join__copy p {
    max-width: 318px;
    margin: 14px 0 0;
    color: rgba(255, 255, 255, 0.92);
    font-size: 15px;
    line-height: 1.45;
}

.copp-about-join__copy .copp-news-btn {
    margin-top: 18px;
    min-width: 144px;
}

.copp-about-join__visual {
    position: relative;
    min-height: 248px;
}

.copp-about-join__scene {
    min-height: 248px;
    width: 100%;
    max-width: none;
    margin-left: auto;
}

.copp-about-join__scene .copp-visual__arc,
.copp-about-join__scene .copp-visual__line {
    display: none;
}

.copp-about-join__scene .copp-visual__tile--one {
    left: 42px;
    top: 130px;
    width: 30px;
    height: 30px;
    background: rgba(255, 255, 255, 0.96);
}

.copp-about-join__scene .copp-visual__tile--two {
    left: 84px;
    top: 112px;
    width: 40px;
    height: 40px;
    background: rgba(255, 255, 255, 0.9);
}

.copp-about-join__scene .copp-visual__tile--three {
    left: 138px;
    top: 98px;
    width: 54px;
    height: 54px;
    background: rgba(35, 35, 35, 0.92);
    box-shadow: none;
}

.copp-about-join__scene .copp-visual__tile--four {
    right: 184px;
    top: 34px;
    width: 18px;
    height: 18px;
    background: rgba(255, 255, 255, 0.88);
}

.copp-about-join__scene .copp-visual__tile--five {
    right: 24px;
    top: 118px;
    width: 36px;
    height: 36px;
    background: rgba(255, 255, 255, 0.18);
}

.copp-about-join__scene .copp-visual__tile--six {
    right: 62px;
    bottom: 24px;
    width: 46px;
    height: 46px;
    background: rgba(255, 255, 255, 0.92);
}

.copp-about-join__scene .copp-visual__block--red {
    top: 24px;
    right: 126px;
    width: 82px;
    height: 82px;
}

.copp-about-join__scene .copp-visual__block--chart {
    top: 110px;
    right: 22px;
    width: 62px;
    height: 62px;
}

.copp-about-join__scene .copp-visual__block--chart svg {
    width: 30px;
    height: 30px;
}

.copp-about-join__scene .copp-person--left {
    left: 206px;
    width: 160px;
    height: 306px;
    transform: scale(0.88);
    transform-origin: bottom center;
}

.copp-about-join__scene .copp-person--right {
    right: 102px;
    width: 152px;
    height: 286px;
    transform: scale(0.9);
    transform-origin: bottom center;
}

.copp-about-join__scene .copp-person__body {
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.copp-news-page {
    padding: 42px 0 64px;
    background: #ffffff;
}

.copp-news-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 32px;
    align-items: start;
}

.copp-news-layout__main {
    min-width: 0;
}

.copp-news-section-head {
    margin-bottom: 24px;
}

.copp-news-section-head--split {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 18px;
}

.copp-news-section-head h2,
.copp-news-sidebar-card h3 {
    margin: 0;
    color: var(--copp-ink);
    font-size: 24px;
    font-weight: 800;
    line-height: 1.05;
    letter-spacing: 0;
    text-transform: uppercase;
}

.copp-news-section-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--copp-red);
    font-size: 16px;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;
    white-space: nowrap;
}

.copp-news-section-link:hover {
    color: var(--copp-red);
    text-decoration: none;
}

.copp-news-sidebar-card {
    padding: 26px;
    border: 1px solid var(--copp-pale);
    border-radius: 0;
    background: var(--copp-soft);
}

.copp-news-layout__sidebar {
    display: grid;
    gap: 22px;
}

.copp-news-sidebar-card p {
    margin: 18px 0 0;
    color: #5f5f5f;
    font-size: 15px;
    line-height: 1.65;
}

.copp-news-category-list {
    margin-top: 18px;
    display: grid;
    gap: 8px;
}

.copp-news-category-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 16px 18px;
    border-radius: 0;
    background: #f1f1f1;
    color: #303030;
    font-size: 15px;
    line-height: 1.4;
    text-decoration: none;
    transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.copp-news-category-link strong {
    color: var(--copp-ink);
    font-size: 15px;
    font-weight: 700;
}

.copp-news-category-link:hover,
.copp-news-category-link.is-active {
    background: #ffffff;
    color: var(--copp-red);
    transform: translateY(-1px);
    box-shadow: 0 12px 20px rgba(35, 35, 35, 0.08);
    text-decoration: none;
}

.copp-news-category-link:hover strong,
.copp-news-category-link.is-active strong {
    color: var(--copp-red);
}

.copp-news-category-link.is-static {
    cursor: default;
}

.copp-news-category-link.is-static:hover {
    transform: none;
    box-shadow: none;
    text-decoration: none;
}

.copp-news-subscribe {
    margin-top: 18px;
}

.copp-news-subscribe input[type="email"] {
    width: 100%;
    height: 52px;
    margin: 0 0 14px;
    padding: 0 16px;
    border: 1px solid #dddddd;
    border-radius: 0;
    background: #ffffff;
    color: var(--copp-ink);
    font-size: 15px;
}

.copp-news-subscribe input[type="email"]:focus {
    outline: none;
    border-color: var(--copp-red);
    box-shadow: 0 0 0 3px rgba(239, 43, 45, 0.08);
}

.copp-news-subscribe__status {
    min-height: 22px;
    margin-top: 12px;
    font-size: 14px;
    line-height: 1.45;
}

.copp-news-subscribe__status.is-loading {
    color: #737373;
}

.copp-news-subscribe__status.is-success {
    color: #0f8a44;
}

.copp-news-subscribe__status.is-error {
    color: var(--copp-red-dark);
}

.copp-news-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 18px;
}

.copp-news-tag {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 8px 14px;
    border-radius: 0;
    background: #f1f1f1;
    color: #353535;
    font-size: var(--copp-fs-badge);
    font-weight: var(--copp-fw-bold);
    letter-spacing: var(--copp-ls-label);
    line-height: 1.2;
    text-decoration: none;
    text-transform: uppercase;
    transition: background-color 0.2s ease, color 0.2s ease;
}

.copp-news-tag:hover {
    background: var(--copp-red);
    color: #ffffff;
    text-decoration: none;
}

.copp-news-tags__empty {
    color: #737373;
    font-size: 14px;
    line-height: 1.5;
}

.copp-news-cta {
    position: relative;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    width: 100vw;
    margin-bottom: -1rem;
    overflow: hidden;
    background: linear-gradient(135deg, var(--copp-red) 0%, var(--copp-red) 100%);
}

.copp-news-cta__inner {
    display: grid;
    grid-template-columns: minmax(0, 430px) minmax(0, 1fr);
    align-items: center;
    gap: 22px;
    min-height: 236px;
}

.copp-news-cta__copy {
    padding: 28px 0;
    color: #ffffff;
}

.copp-news-cta__copy h2 {
    margin: 0;
    color: #ffffff;
    font-size: 34px;
    font-weight: 800;
    line-height: 1.05;
    letter-spacing: 0;
    max-width: 360px;
}

.copp-news-cta__copy p {
    max-width: 360px;
    margin: 14px 0 0;
    color: rgba(255, 255, 255, 0.92);
    font-size: 15px;
    line-height: 1.5;
}

.copp-news-cta__actions {
    margin-top: 20px;
    max-width: 420px;
}

.copp-news-cta__form {
    display: grid;
    gap: 8px;
    margin-top: 0;
}

.copp-news-cta__field-label {
    display: block;
    color: rgba(255, 255, 255, 0.92);
    font-size: 13px;
    font-weight: 700;
    line-height: 1;
}

.copp-news-cta__form-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: stretch;
}

.copp-news-cta__input {
    min-width: 0;
    width: 100%;
    height: 52px;
    padding: 0 16px;
    border: 1px solid rgba(255, 255, 255, 0.58);
    border-radius: 0;
    background: rgba(255, 255, 255, 0.14);
    color: #ffffff;
    font-size: 15px;
}

.copp-news-cta__input::placeholder {
    color: rgba(255, 255, 255, 0.82);
}

.copp-news-cta__input:focus {
    outline: none;
    border-color: #ffffff;
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.16);
}

.copp-news-cta__form-row > .copp-news-btn {
    min-width: 178px;
    min-height: 52px;
    padding-left: 22px;
    padding-right: 22px;
}

.copp-news-cta__status {
    grid-column: 1 / -1;
    margin-top: 0;
    color: rgba(255, 255, 255, 0.94);
}

.copp-news-cta__status.is-loading,
.copp-news-cta__status.is-success,
.copp-news-cta__status.is-error {
    color: #ffffff;
}

.copp-news-cta__visual {
    position: relative;
    min-height: 236px;
}

.copp-news-cta__scene {
    min-height: 236px;
    max-width: 560px;
    margin-left: auto;
}

.copp-news-cta__scene .copp-visual__arc {
    background: rgba(255, 255, 255, 0.12);
    bottom: -44px;
    left: 132px;
    width: 320px;
    height: 150px;
}

.copp-news-cta__scene .copp-visual__line {
    background: rgba(255, 255, 255, 0.26);
    top: 154px;
    right: 62px;
    width: 108px;
}

.copp-news-cta__scene .copp-visual__tile--one {
    left: 116px;
    top: 18px;
}

.copp-news-cta__scene .copp-visual__tile--two {
    left: 158px;
    top: 18px;
    background: rgba(255, 255, 255, 0.88);
}

.copp-news-cta__scene .copp-visual__tile--three {
    left: 196px;
    top: 78px;
    background: rgba(255, 255, 255, 0.16);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.2);
}

.copp-news-cta__scene .copp-visual__tile--four {
    right: 238px;
    top: 34px;
}

.copp-news-cta__scene .copp-visual__tile--five {
    right: 92px;
    top: 112px;
    background: rgba(255, 255, 255, 0.24);
}

.copp-news-cta__scene .copp-visual__tile--six {
    right: 122px;
    bottom: 16px;
    background: rgba(34, 34, 34, 0.86);
    width: 40px;
    height: 62px;
}

.copp-news-cta__scene .copp-visual__block--black {
    top: 82px;
    left: 76px;
}

.copp-news-cta__scene .copp-visual__block--red {
    right: 136px;
    top: 22px;
}

.copp-news-cta__scene .copp-visual__block--chart {
    right: 28px;
    top: 92px;
}

.copp-news-cta__person {
    right: 132px;
    transform: scale(0.84);
    transform-origin: bottom center;
}

.copp-news-cta__person .copp-person__body {
    background: var(--copp-pale);
    border: 3px solid #2b2b2b;
}

.copp-news-cta__person .copp-person__doc {
    background: #f7f7f7;
    border-color: #2b2b2b;
}

.copp-news-feed {
    display: grid;
    gap: 16px;
}

.copp-news-landing {
    display: grid;
    gap: 40px;
}

.copp-news-block {
    display: grid;
    gap: 18px;
}

.copp-news-featured-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 0.98fr);
    align-items: stretch;
    background: #ffffff;
    border: 1px solid var(--copp-pale);
    border-radius: 0;
    overflow: hidden;
}

.copp-news-featured-card__media,
.copp-news-card__media {
    position: relative;
}

.copp-news-featured-card__image,
.copp-news-card__image {
    display: block;
    overflow: hidden;
    background:
        linear-gradient(135deg, rgba(239, 43, 45, 0.16), rgba(35, 35, 35, 0.08)),
        url("/templates/modern/images/news/copp-news-hero.png") center / cover no-repeat;
}

.copp-news-featured-card__image img,
.copp-news-card__image img,
.copp-news-article__hero-media img,
.copp-news-article__hero-fallback img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.copp-news-featured-card__image {
    min-height: 100%;
    aspect-ratio: 1.22 / 1;
}

.copp-news-card__image {
    aspect-ratio: 1.32 / 1;
}

.copp-news-featured-card__image.is-fallback,
.copp-news-card__image.is-fallback {
    position: relative;
}

.copp-news-card__fallback-mark {
    position: absolute;
    inset: auto auto 18px 18px;
    width: 96px;
    height: 96px;
    border: 10px solid rgba(239, 43, 45, 0.84);
    border-top-width: 0;
    border-right-width: 0;
}

.copp-news-date-badge {
    position: absolute;
    top: 16px;
    left: 16px;
    z-index: 2;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 56px;
    min-height: 72px;
    padding: 8px 6px;
    border-radius: 0;
    background: var(--copp-red);
    color: #ffffff;
    text-align: center;
}

.copp-news-date-badge strong {
    display: block;
    font-size: 28px;
    font-weight: 800;
    line-height: 1;
}

.copp-news-date-badge span {
    display: block;
    margin-top: 4px;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
}

.copp-news-featured-card__label,
.copp-news-card__label {
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    padding: 5px 10px;
    border-radius: 0;
    background: #ededed;
    color: #5e5e5e;
    font-size: 12px;
    font-weight: 600;
    line-height: 1;
}

.copp-news-featured-card__label {
    position: absolute;
    top: 18px;
    right: 18px;
    z-index: 2;
}

.copp-news-featured-card__body,
.copp-news-card__body {
    display: flex;
    flex-direction: column;
}

.copp-news-featured-card__body {
    position: relative;
    z-index: 1;
    min-width: 0;
    padding: 32px 58px 28px 32px;
    background: #ffffff;
    box-shadow: inset 1px 0 0 var(--copp-soft);
}

.copp-news-featured-card__body h3,
.copp-news-card__body h3,
.copp-news-article__content h2,
.copp-news-article__content h3 {
    margin: 0;
    color: var(--copp-dark);
    font-weight: 800;
    letter-spacing: 0;
}

.copp-news-featured-card__body h3 {
    max-width: 100%;
    overflow-wrap: anywhere;
    font-size: 26px;
    line-height: 1.28;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
    overflow: hidden;
}

.copp-news-card__body h3 {
    font-size: 22px;
    line-height: 1.32;
}

.copp-news-featured-card__body h3 a,
.copp-news-card__body h3 a {
    color: inherit;
    text-decoration: none;
}

.copp-news-featured-card__body h3 a:hover,
.copp-news-card__body h3 a:hover {
    color: var(--copp-red);
}

.copp-news-featured-card__body p,
.copp-news-card__body p {
    margin: 20px 0 0;
    color: #555555;
    font-size: 18px;
    line-height: 1.55;
}

.copp-news-featured-card__body p {
    max-width: 100%;
    overflow-wrap: anywhere;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 5;
    overflow: hidden;
}

.copp-news-card__body p {
    font-size: 15px;
    line-height: 1.6;
}

.copp-news-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 16px;
    margin-top: 24px;
    color: #6a6a6a;
    font-size: 14px;
    line-height: 1.4;
}

.copp-news-meta span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.copp-news-meta svg {
    width: 15px;
    height: 15px;
    color: var(--copp-red);
}

.copp-news-arrow-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 46px;
    height: 46px;
    border: 1px solid #cfcfcf;
    border-radius: 0;
    color: #2f2f2f;
    font-size: 24px;
    line-height: 1;
    text-decoration: none;
    transition: border-color 0.2s ease, background-color 0.2s ease, color 0.2s ease;
}

.copp-news-arrow-link:hover {
    border-color: var(--copp-red);
    background: var(--copp-red);
    color: #ffffff;
    text-decoration: none;
}

.copp-news-featured-card__body .copp-news-arrow-link {
    position: absolute;
    right: 24px;
    bottom: 24px;
}

.copp-news-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 16px;
}

.copp-news-card {
    display: flex;
    flex-direction: column;
    min-width: 0;
    border: 1px solid var(--copp-pale);
    border-radius: 0;
    overflow: hidden;
    background: #ffffff;
}

.copp-news-card__body {
    flex: 1 1 auto;
    padding: 16px 16px 18px;
}

.copp-news-card__body .copp-news-card__label {
    margin-bottom: 14px;
}

.copp-news-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: auto;
    padding-top: 18px;
}

.copp-news-card__footer .copp-news-meta {
    margin-top: 0;
}

.copp-news-empty {
    padding: 36px;
    border: 1px solid var(--copp-pale);
    border-radius: 0;
    background: var(--copp-soft);
}

.copp-news-empty h3 {
    margin: 0 0 10px;
    color: var(--copp-ink);
    font-size: 24px;
    font-weight: 800;
}

.copp-news-empty p {
    margin: 0;
    color: #5f5f5f;
    font-size: 16px;
    line-height: 1.6;
}

.copp-news-pagination .pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 10px;
    margin: 24px 0 0 !important;
    padding: 0;
    list-style: none;
}

.copp-news-pagination .page-item {
    margin: 0;
}

.copp-news-pagination .page-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-width: 46px;
    height: 46px;
    padding: 0 16px;
    border-radius: 0;
    border: 1px solid #d8d8d8;
    background: #ffffff;
    color: #2c2c2c;
    font-weight: 700;
    line-height: 1;
    box-shadow: none;
    transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.copp-news-pagination .page-item.page-item-prev .page-link,
.copp-news-pagination .page-item.page-item-next .page-link {
    min-width: 46px;
    padding: 0 18px;
}

.copp-news-pagination .page-link svg {
    width: 14px;
    height: 14px;
}

.copp-news-pagination .page-item.disabled .page-link {
    border-color: var(--copp-pale);
    background: #f4f4f4;
    color: #8b8b8b;
}

.copp-news-pagination .page-item.disabled:not(.page-item-prev):not(.page-item-next) .page-link {
    min-width: 46px;
    padding: 0 10px;
}

.copp-news-pagination .page-item.active .page-link {
    border-color: var(--copp-red);
    background: var(--copp-red);
    color: #ffffff;
}

.copp-news-pagination .page-link:hover {
    border-color: var(--copp-red);
    background: #fff4f4;
    color: var(--copp-red);
    transform: translateY(-1px);
}

.copp-news-pagination .page-item.active .page-link:hover {
    background: var(--copp-red);
    color: #ffffff;
    transform: none;
}

.copp-news-pagination .page-item.disabled .page-link:hover {
    border-color: var(--copp-pale);
    background: #f4f4f4;
    color: #8b8b8b;
    transform: none;
}

.copp-news-pagination .page-item.disabled.d-none.d-sm-inline-block {
    display: none !important;
}

.copp-news-article {
    display: grid;
    gap: 28px;
}

.copp-news-article__hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(340px, 520px);
    gap: 30px;
    align-items: center;
    padding: 14px 0 8px;
}

.copp-news-article__hero-copy h1 {
    margin: 0;
    color: var(--copp-dark);
    font-size: clamp(36px, 4vw, 56px);
    font-weight: 800;
    line-height: 1.05;
    letter-spacing: 0;
}

.copp-news-article__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
    margin-top: 20px;
    color: #6a6a6a;
    font-size: 15px;
}

.copp-news-article__hero-media {
    overflow: hidden;
    border-radius: 0;
    background: #f2f2f2;
}

.copp-news-article__hero-media,
.copp-news-article__hero-fallback {
    aspect-ratio: 1.28 / 1;
}

.copp-news-article__content {
    color: #323232;
    font-size: 18px;
    line-height: 1.78;
}

.copp-news-article__content p {
    margin: 0 0 18px;
}

.copp-news-article__content h2,
.copp-news-article__content h3 {
    margin: 30px 0 14px;
}

.copp-news-article__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.copp-news-article__footer {
    padding-top: 8px;
}

@media (max-width: 1199px) {
    .copp-about-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .copp-about-mission {
        grid-template-columns: minmax(0, 280px) minmax(0, 1fr);
        gap: 24px;
    }

    .copp-about-directions {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .copp-about-process {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        row-gap: 28px;
    }

    .copp-about-process::before {
        display: none;
    }

    .copp-about-process__step::before,
    .copp-about-process__step::after {
        display: none;
    }

    .copp-about-process__connector {
        display: none;
    }

    .copp-news-hero {
        --copp-hero-container-max: 960px;
    }

    .copp-news-hero__inner {
        grid-template-columns: minmax(0, 380px) minmax(0, 1fr);
        gap: 28px;
    }

    .copp-about-hero .copp-news-hero__inner {
        grid-template-columns: minmax(0, 408px) minmax(0, 1fr);
        gap: 26px;
        min-height: 420px;
    }

    .copp-news-layout {
        grid-template-columns: minmax(0, 1fr) 292px;
    }

    .copp-news-grid {
        --copp-grid-columns: 2;
    }

    .copp-news-featured-card__body {
        padding-right: 32px;
    }

    .copp-news-article__hero {
        grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
    }

    .copp-news-cta__inner {
        grid-template-columns: minmax(0, 390px) minmax(0, 1fr);
    }

    .copp-news-cta__copy h2 {
        font-size: 31px;
    }

    .copp-news-cta__person {
        right: 102px;
        transform: scale(0.78);
    }
}

@media (min-width: 768px) {
    .copp-news-cta {
        margin-bottom: -1.5rem;
    }

    .copp-about-page-content {
        margin-bottom: -1.5rem !important;
    }

    .copp-partners-page-content {
        margin-bottom: 0 !important;
        padding-bottom: 0;
    }

    .copp-school-page-content,
    .copp-students-page-content,
    .copp-opportunity-page-content {
        margin-bottom: -1.5rem !important;
    }
}

@media (max-width: 991px) {
    .copp-events-hero .copp-news-hero__inner {
        gap: 24px;
        grid-template-columns: minmax(0, 1fr);
        min-height: 0;
    }

    .copp-events-hero__subtitle {
        max-width: 100%;
    }

    .copp-events-hero__media,
    .copp-events-hero__media img {
        min-height: 320px;
    }

    .copp-events-filters__form {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .copp-events-filters__actions {
        grid-column: 1 / -1;
        justify-content: flex-start;
    }

    .copp-events-cards,
    .copp-projects-cards {
        --copp-grid-columns: 2;
    }

    .copp-project-article__hero {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-project-article__copy {
        padding: 32px;
    }

    .copp-events-calendar__layout {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-events-calendar__layout--expanded {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-events-cards--detail,
    .copp-events-summary,
    .copp-events-types__grid {
        --copp-grid-columns: 2;
    }

    .copp-events-calendar__meta {
        flex-direction: column;
    }

    .copp-events-calendar__day {
        aspect-ratio: auto;
        min-height: 60px;
    }

    .copp-events-calendar-preview {
        position: static;
        top: auto;
    }

    .copp-school-hero .copp-news-hero__inner {
        gap: 24px;
        grid-template-columns: minmax(0, 1fr);
        min-height: 0;
    }

    .copp-school-hero__subtitle,
    .copp-school-hero .copp-news-hero__lead {
        max-width: 100%;
    }

    .copp-school-hero__media {
        min-height: 340px;
    }

    .copp-school-hero__scene {
        min-height: 340px;
        transform: scale(0.9);
        transform-origin: center bottom;
    }

    .copp-school-section__head {
        align-items: flex-start;
        flex-direction: column;
    }

    .copp-school-tests {
        --copp-grid-columns: 2;
    }

    .copp-school-events {
        --copp-grid-columns: 2;
    }

    .copp-school-help__process {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .copp-school-cta__inner {
        gap: 0;
        grid-template-columns: minmax(0, 1fr);
        min-height: 0;
    }

    .copp-school-cta__copy {
        padding: 28px 0 30px;
    }

    .copp-school-cta__copy h2,
    .copp-school-cta__copy p {
        max-width: 100%;
    }

    .copp-school-cta__visual {
        display: none;
    }

    .copp-about-mission {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-about-mission__flow {
        grid-template-columns: repeat(4, minmax(0, 1fr));
        justify-content: stretch;
    }

    .copp-about-mission__arrow {
        justify-self: center;
        transform: rotate(90deg);
    }

    .copp-about-directions {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .copp-about-process {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .copp-about-process::before {
        display: none;
    }

    .copp-about-process__step::before {
        display: none;
    }

    .copp-about-process__step::after {
        display: none;
    }

    .copp-about-process__connector {
        display: none;
    }

    .copp-news-hero {
        --copp-hero-container-max: 720px;
        padding-top: 20px;
        padding-bottom: 28px;
        background: var(--copp-soft);
    }

    .copp-news-hero__inner,
    .copp-news-layout,
    .copp-news-featured-card,
    .copp-news-article__hero,
    .copp-equipment-article__hero,
    .copp-equipment-article__layout {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-equipment-article__aside {
        position: relative;
        top: auto;
    }

    .copp-equipment-article__details,
    .copp-equipment-article__photos-grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-news-hero__media {
        min-height: 0;
    }

    .copp-news-hero__media img {
        min-height: 320px;
    }

    .copp-about-hero .copp-news-hero__media,
    .copp-about-hero .copp-news-hero__media img {
        min-height: 340px;
    }

    .copp-news-layout__sidebar {
        order: 2;
    }

    .copp-news-grid {
        order: 3;
    }

    .copp-news-featured-card__body .copp-news-arrow-link {
        position: static;
        margin-top: 20px;
    }

    .copp-news-card__body h3 {
        font-size: 20px;
    }

    .copp-news-cta__inner {
        grid-template-columns: minmax(0, 1fr);
        gap: 0;
        min-height: 0;
        padding: 24px 0 26px;
    }

    .copp-news-cta__copy {
        padding: 0;
        max-width: 560px;
        margin: 0 auto;
    }

    .copp-news-cta__copy h2,
    .copp-news-cta__copy p {
        max-width: 100%;
    }

    .copp-news-cta__actions {
        max-width: 520px;
    }

    .copp-news-cta__visual {
        display: none;
    }

    .copp-about-join {
        left: 50%;
        width: 100vw;
        margin-left: -50vw;
        margin-right: -50vw;
    }

    .copp-about-join__inner {
        grid-template-columns: minmax(0, 1fr);
        gap: 0;
        min-height: 0;
    }

    .copp-about-join__copy {
        padding: 28px 0 30px;
    }

    .copp-about-join__copy h2,
    .copp-about-join__copy p {
        max-width: 100%;
    }

    .copp-about-join__visual {
        display: none;
    }
}

@media (max-width: 767px) {
    .copp-events-page {
        gap: 32px;
    }

    .copp-events-hero__subtitle {
        font-size: 20px;
        max-width: none;
    }

    .copp-events-hero__media,
    .copp-events-hero__media img {
        min-height: 260px;
    }

    .copp-events-filters {
        padding: 16px;
    }

    .copp-events-filters__form {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .copp-events-filters__actions {
        grid-column: 1 / -1;
        align-items: stretch;
        flex-direction: column;
    }

    .copp-events-filters__actions .copp-news-btn {
        width: 100%;
    }

    .copp-events-cards,
    .copp-events-summary,
    .copp-projects-cards {
        --copp-grid-columns: 1;
    }

    .copp-projects-page {
        gap: 32px;
    }

    .copp-projects-section__lead {
        max-width: none;
    }

    .copp-project-article {
        gap: 26px;
    }

    .copp-project-article__copy {
        padding: 24px;
    }

    .copp-project-article__media {
        min-height: 260px;
    }

    .copp-events-cards--detail,
    .copp-events-types__grid {
        --copp-grid-columns: 1;
    }

    .copp-events-card {
        min-height: 0;
    }

    .copp-events-card__body h3 {
        font-size: 20px;
    }

    .copp-events-calendar__item {
        grid-template-columns: 56px minmax(0, 1fr) 36px;
        gap: 10px 14px;
    }

    .copp-events-calendar__item-time {
        grid-column: 2 / 3;
    }

    .copp-events-calendar__item-format {
        grid-column: 2 / 3;
        justify-self: start;
    }

    .copp-events-calendar__item-link {
        align-self: center;
        grid-column: 3 / 4;
        grid-row: 1 / span 3;
    }

    .copp-events-calendar__legend-item,
    .copp-events-calendar__stat {
        min-height: 36px;
        padding-left: 12px;
        padding-right: 12px;
    }

    .copp-events-calendar__weekdays--board span {
        font-size: 11px;
    }

    .copp-events-calendar__day {
        min-height: 112px;
        padding: 10px 9px;
    }

    .copp-events-calendar__day-number {
        font-size: 20px;
    }

    .copp-events-calendar__marker {
        padding: 7px 8px;
    }

    .copp-events-calendar__marker-title {
        font-size: 11px;
    }

    .copp-events-calendar-preview__head h3 {
        font-size: 22px;
    }

    .copp-events-calendar__board {
        overflow-x: auto;
        overflow-y: hidden;
    }

    .copp-events-calendar__weekdays--board,
    .copp-events-calendar__grid--board {
        min-width: 680px;
    }

    .copp-events-types__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .copp-events-type-tile__title {
        font-size: 12px;
    }

    .copp-school-content {
        gap: 32px;
    }

    .copp-school-section__head h2 {
        font-size: 22px;
    }

    .copp-school-hero__subtitle {
        font-size: 22px;
    }

    .copp-school-hero__media {
        min-height: 280px;
    }

    .copp-school-hero__scene {
        min-height: 280px;
        transform: scale(0.72);
        transform-origin: center bottom;
    }

    .copp-school-tests,
    .copp-school-events {
        --copp-grid-columns: 1;
    }

    .copp-school-help__process {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-school-test {
        min-height: 0;
    }

    .copp-school-test h3 {
        font-size: 20px;
    }

    .copp-school-help__step {
        grid-template-columns: 64px minmax(0, 1fr);
        column-gap: 16px;
    }

    .copp-school-help__copy h3,
    .copp-school-help__copy p {
        max-width: none;
    }

    .copp-school-help__index {
        font-size: 62px;
        top: -10px;
    }

    .copp-school-cta__copy h2 {
        font-size: 22px;
    }

    .copp-about-content {
        gap: 34px;
    }

    .copp-about-stats,
    .copp-about-directions,
    .copp-about-process,
    .copp-about-mission__flow {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-about-stat,
    .copp-about-direction {
        min-height: 0;
    }

    .copp-about-section__head h2 {
        font-size: 22px;
    }

    .copp-about-mission__step {
        grid-template-columns: 58px minmax(0, 1fr);
        justify-items: start;
        align-items: center;
        text-align: left;
        column-gap: 14px;
    }

    .copp-about-mission__arrow {
        display: none;
    }

    .copp-about-process__step {
        justify-items: start;
        text-align: left;
        grid-template-columns: 54px minmax(0, 1fr);
        column-gap: 16px;
    }

    .copp-about-process__step p {
        max-width: none;
        padding-top: 4px;
    }

    .copp-about-join__copy h2 {
        font-size: 22px;
    }

    .copp-news-hero {
        --copp-hero-container-max: 540px;
    }
}

@media (max-width: 767px) {
    .copp-news-page {
        padding: 28px 0 44px;
    }

    .copp-news-section-head--split {
        align-items: flex-start;
        flex-direction: column;
    }

    .copp-news-hero__title {
        font-size: 42px;
    }

    .copp-news-hero__lead {
        font-size: 17px;
        margin-top: 18px;
    }

    .copp-about-hero .copp-news-hero__title {
        font-size: 46px;
    }

    .copp-about-hero__subtitle {
        font-size: 19px;
        margin-top: 18px;
    }

    .copp-about-hero .copp-news-hero__lead {
        font-size: 16px;
        margin-top: 20px;
    }

    .copp-news-hero__actions {
        margin-top: 22px;
    }

    .copp-news-hero__media img {
        min-height: 250px;
    }

    .copp-news-hero__badge {
        width: 52px;
        height: 52px;
    }

    .copp-news-hero__badge svg {
        width: 20px;
        height: 20px;
    }

    .copp-news-hero__tile {
        width: calc(var(--tile-size, 20px) * 0.72);
        height: calc(var(--tile-size, 20px) * 0.72);
    }

    .copp-news-hero__tile.is-mobile-hidden {
        display: none;
    }

    .copp-news-section-head h2,
    .copp-news-sidebar-card h3 {
        font-size: 21px;
    }

    .copp-news-sidebar-card {
        padding: 20px;
    }

    .copp-news-grid {
        --copp-grid-columns: 1;
    }

    .copp-news-featured-card__body {
        padding: 22px 20px 20px;
    }

    .copp-news-featured-card__body h3 {
        font-size: 24px;
    }

    .copp-news-featured-card__body p,
    .copp-news-article__content {
        font-size: 16px;
    }

    .copp-equipment-article__copy {
        padding: 28px;
    }

    .copp-equipment-article__media {
        min-height: 260px;
    }

    .copp-equipment-article__aside {
        padding: 16px;
    }

    .copp-news-pagination .pagination {
        gap: 8px;
    }

    .copp-news-pagination .page-link {
        min-width: 42px;
        height: 42px;
        padding: 0 14px;
    }

    .copp-news-meta {
        gap: 12px;
    }

    .copp-news-cta__copy h2 {
        font-size: 26px;
    }

    .copp-news-cta__copy p {
        font-size: 15px;
    }
}

@media (max-width: 560px) {
    .copp-news-cta__actions {
        max-width: none;
    }

    .copp-news-cta__form-row {
        grid-template-columns: minmax(0, 1fr);
    }

    .copp-news-cta__form-row > .copp-news-btn {
        width: 100%;
    }
}

@media (max-width: 1199.98px) {
    .copp-partners-help-grid,
    .copp-partners-offers {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .copp-partners-hero .copp-news-hero__inner {
        grid-template-columns: 1fr;
        gap: 28px;
        min-height: 0;
    }

    .copp-partners-hero .copp-news-hero__copy,
    .copp-partners-hero .copp-news-hero__lead,
    .copp-partners-hero__subtitle,
    .copp-partners-hero .copp-news-hero__title {
        max-width: none;
    }

    .copp-partners-help-grid,
    .copp-partners-offers {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .copp-partners-cta__inner {
        grid-template-columns: 1fr;
        min-height: 0;
        gap: 22px;
    }

    .copp-partners-cta__copy,
    .copp-partners-cta__copy h2,
    .copp-partners-cta__copy p {
        max-width: none;
    }
}

@media (max-width: 767.98px) {
    .copp-partners-hero__subtitle {
        font-size: 24px;
    }

    .copp-partners-help-grid,
    .copp-partners-offers {
        grid-template-columns: 1fr;
    }

    .copp-partners-cta__visual > img {
        right: 0;
        width: min(100%, 320px);
    }
}

.copp-students-page-content {
    margin-bottom: -1rem !important;
}

.copp-students-page-content .field.ft_html.f_content {
    margin-bottom: 0;
}

@media (min-width: 768px) {
    .copp-students-page-content {
        margin-bottom: -1.5rem !important;
    }
}

.copp-students-content {
    display: grid;
    gap: 40px;
}

.copp-students-hero {
    padding-bottom: 96px;
}

.copp-students-hero .copp-news-hero__inner {
    gap: 42px;
    grid-template-columns: minmax(0, 470px) minmax(0, 1fr);
    min-height: 388px;
}

.copp-students-hero .copp-news-hero__copy {
    min-width: 0;
    position: relative;
    z-index: 3;
}

.copp-students-hero .copp-news-hero__title {
    font-size: clamp(46px, 5.2vw, 76px);
    font-weight: 900;
    line-height: var(--copp-lh-hero);
    margin-bottom: 18px;
}

.copp-students-hero__subtitle {
    color: var(--copp-ink);
    font-size: 26px;
    font-weight: 800;
    line-height: 1.3;
    margin: 0;
    max-width: 430px;
}

.copp-students-hero .copp-news-hero__lead {
    color: #424242;
    font-size: 17px;
    line-height: 1.55;
    margin-top: 20px;
    max-width: 390px;
}

.copp-students-hero__media {
    align-self: stretch;
    isolation: isolate;
    justify-self: end;
    min-height: 380px;
    overflow: visible;
    position: relative;
    width: min(100%, 620px);
}

.copp-students-hero__scene {
    height: 100%;
    max-width: none;
    min-height: 380px;
    overflow: visible;
    position: relative;
}

.copp-students-hero__people {
    bottom: -54px;
    height: calc(100% + 52px);
    right: -28px;
    transform: translateY(62px);
    width: min(108%, 724px);
}

.copp-students-hero__people img {
    display: block;
    filter: none;
    height: auto;
    max-height: none;
    max-width: none;
    mix-blend-mode: darken;
    width: 100%;
}

.copp-students-hero .copp-visual__tile--one {
    background: rgba(237, 39, 49, 0.96);
    height: 46px;
    left: 102px;
    top: 16px;
    width: 46px;
}

.copp-students-hero .copp-visual__tile--two {
    background: rgba(220, 220, 220, 0.92);
    height: 42px;
    left: 150px;
    top: 18px;
    width: 42px;
}

.copp-students-hero .copp-visual__tile--three {
    background: rgba(255, 255, 255, 0.84);
    box-shadow: inset 0 0 0 1px rgba(225, 225, 225, 0.78);
    height: 58px;
    left: 128px;
    top: 118px;
    width: 58px;
}

.copp-students-hero .copp-visual__tile--four {
    background: rgba(34, 34, 34, 0.92);
    height: 24px;
    right: 272px;
    top: 72px;
    width: 24px;
}

.copp-students-hero .copp-visual__tile--five {
    background: rgba(237, 39, 49, 0.96);
    height: 34px;
    right: 98px;
    top: 126px;
    width: 34px;
}

.copp-students-hero .copp-visual__tile--six {
    background: rgba(255, 255, 255, 0.9);
    bottom: 20px;
    box-shadow: inset 0 0 0 1px rgba(225, 225, 225, 0.72);
    height: 42px;
    right: 74px;
    width: 42px;
}

.copp-students-hero__halo {
    background: linear-gradient(135deg, rgba(255, 47, 53, 0.96), rgba(210, 0, 20, 0.94));
    border-radius: 0;
    bottom: 0;
    display: block;
    height: 280px;
    left: 12%;
    position: absolute;
    transform: rotate(-8deg);
    width: 72%;
    z-index: 1;
}

.copp-students-hero__badge {
    z-index: 9;
}

.copp-students-hero__badge--cap {
    background: var(--copp-ink);
    left: 34px;
    top: 116px;
}

.copp-students-hero__badge--chart {
    right: 44px;
    top: 20px;
}

.copp-students-hero__badge--briefcase {
    background: var(--copp-ink);
    right: -2px;
    top: 182px;
}

.copp-students-stats {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.copp-students-stats .copp-stat-card {
    min-height: 190px;
    padding: 24px 28px 22px;
}

.copp-students-stats .copp-stat-card__icon {
    margin-bottom: 34px;
}

.copp-students-stats .copp-stat-card__icon i {
    font-size: 32px;
    line-height: 1;
}

.copp-students-stats .copp-stat-card__value {
    font-size: 36px;
    margin-bottom: 12px;
}

.copp-students-section {
    display: grid;
    gap: 18px;
}

.copp-students-section .copp-school-section__heading h2 {
    color: var(--copp-ink);
    font-size: 28px;
    font-weight: 900;
    line-height: 1.05;
    margin: 0;
    text-transform: uppercase;
}

.copp-students-opportunities {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.copp-students-opportunity {
    border-radius: 0;
    color: var(--copp-ink);
    display: grid;
    gap: 14px;
    min-height: 196px;
    padding: 22px 20px 18px;
    position: relative;
    text-decoration: none;
}

.copp-students-opportunity:hover,
.copp-students-opportunity:focus {
    color: inherit;
    text-decoration: none;
}

.copp-students-opportunity--light {
    background: var(--copp-soft);
}

.copp-students-opportunity--coral {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-students-opportunity--red {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-students-opportunity--dark,
.copp-students-opportunity--deep {
    background: var(--copp-ink);
    color: #ffffff;
}

.copp-students-opportunity__icon {
    align-items: center;
    display: inline-flex;
    font-size: 32px;
    height: 36px;
    justify-content: center;
    width: 36px;
}

.copp-students-opportunity h3 {
    color: inherit;
    font-size: 17px;
    font-weight: 800;
    line-height: 1.22;
    margin: 0;
}

.copp-students-opportunity p {
    color: currentColor;
    font-size: 14px;
    line-height: 1.42;
    margin: 0 0 34px;
    opacity: 0.76;
}

.copp-students-opportunity__arrow {
    align-items: center;
    border: 1px solid currentColor;
    border-radius: 0;
    bottom: 16px;
    display: inline-flex;
    height: 32px;
    justify-content: center;
    opacity: 0.84;
    position: absolute;
    right: 16px;
    width: 32px;
}

.copp-students-opportunity__arrow svg {
    height: 15px;
    width: 15px;
}

.copp-students-events .copp-event-card {
    min-height: 134px;
    padding: 18px;
}

.copp-students-help .copp-school-help__process {
    padding-top: 16px;
}

.copp-students-stories {
    align-items: center;
    display: grid;
    gap: 16px;
    grid-template-columns: 44px minmax(0, 1fr) 44px;
}

.copp-students-stories__viewport {
    background: var(--copp-soft);
    border-radius: 0;
    display: grid;
    min-height: 116px;
    overflow: hidden;
    position: relative;
}

.copp-students-story {
    align-items: center;
    display: grid;
    gap: 34px;
    grid-area: 1 / 1;
    grid-template-columns: minmax(170px, 250px) minmax(0, 1fr) auto;
    opacity: 0;
    padding: 22px 58px;
    pointer-events: none;
    transform: translateY(8px);
    transition: opacity 220ms ease, transform 220ms ease;
}

.copp-students-story.is-active {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

.copp-students-story__person {
    align-items: center;
    display: flex;
    gap: 16px;
}

.copp-students-story__avatar {
    align-items: center;
    background: #ffffff;
    border: 3px solid var(--copp-red);
    border-radius: 0;
    color: var(--copp-red);
    display: inline-flex;
    flex: 0 0 auto;
    font-size: 17px;
    font-weight: 900;
    height: 64px;
    justify-content: center;
    width: 64px;
}

.copp-students-story__person strong {
    color: var(--copp-ink);
    display: block;
    font-size: 18px;
    font-weight: 900;
    line-height: 1.2;
}

.copp-students-story__person small {
    color: #626262;
    display: block;
    font-size: 14px;
    line-height: 1.35;
    margin-top: 4px;
}

.copp-students-story blockquote {
    color: #343434;
    font-size: 16px;
    line-height: 1.5;
    margin: 0;
}

.copp-students-story__quote {
    color: rgba(35, 35, 35, 0.08);
    font-size: 72px;
    font-weight: 900;
    line-height: 1;
}

.copp-students-stories__nav {
    align-items: center;
    background: #9f9f9f;
    border: 0;
    border-radius: 0;
    color: #ffffff;
    display: inline-flex;
    height: 44px;
    justify-content: center;
    transition: background-color 180ms ease, transform 180ms ease;
    width: 44px;
}

.copp-students-stories__nav:hover,
.copp-students-stories__nav:focus {
    background: var(--copp-red);
    transform: translateY(-1px);
}

.copp-students-stories__nav svg {
    height: 18px;
    width: 18px;
}

.copp-students-stories__dots {
    align-items: center;
    display: flex;
    gap: 8px;
    justify-content: center;
    margin-top: -10px;
}

.copp-students-stories__dots button {
    background: #cfcfcf;
    border: 0;
    border-radius: 0;
    height: 8px;
    padding: 0;
    width: 8px;
}

.copp-students-stories__dots button.is-active {
    background: var(--copp-red);
    width: 22px;
    border-radius: 0;
}

.copp-students-cta {
    background: linear-gradient(135deg, var(--copp-red) 0%, var(--copp-red) 100%);
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    margin-bottom: -1px;
    overflow: hidden;
    position: relative;
    width: 100vw;
}

.copp-students-cta__inner {
    align-items: center;
    display: grid;
    gap: 34px;
    grid-template-columns: minmax(320px, 470px) minmax(0, 1fr);
    margin: 0 auto;
    max-width: var(--copp-container-content);
    min-height: 238px;
    width: calc(100% - 30px);
}

.copp-students-cta__copy {
    color: #ffffff;
    padding: 32px 0;
    position: relative;
    z-index: 3;
}

.copp-students-cta__copy h2 {
    color: #ffffff;
    font-size: 30px;
    font-weight: 900;
    line-height: 1.1;
    margin: 0;
    max-width: 430px;
    text-transform: uppercase;
}

.copp-students-cta__copy p {
    color: rgba(255, 255, 255, 0.92);
    font-size: 16px;
    line-height: 1.45;
    margin: 14px 0 0;
    max-width: 330px;
}

.copp-students-cta__copy .copp-news-btn {
    margin-top: 20px;
}

.copp-students-cta__visual {
    min-height: 238px;
    position: relative;
}

.copp-students-cta__visual img {
    bottom: -60px;
    filter: grayscale(1);
    height: auto;
    max-width: 500px;
    min-height: 0;
    object-fit: contain;
    position: absolute;
    right: 118px;
    width: min(72%, 500px);
    z-index: 3;
}

.copp-students-cta__badge {
    height: 60px;
    width: 60px;
}

.copp-students-cta__badge--arrow {
    background: var(--copp-ink);
    left: 62px;
    top: 76px;
}

.copp-students-cta__badge--arrow svg {
    transform: rotate(-45deg);
}

.copp-students-cta__badge--briefcase {
    background: #ffffff;
    color: var(--copp-red);
    right: 36px;
    top: 98px;
}

@media (max-width: 1199.98px) {
    .copp-students-stats,
    .copp-students-opportunities {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .copp-students-opportunities {
        grid-auto-rows: minmax(188px, auto);
    }
}

@media (max-width: 991.98px) {
    .copp-students-hero {
        padding-bottom: 136px;
    }

    .copp-students-hero .copp-news-hero__inner {
        grid-template-columns: 1fr;
        min-height: 0;
    }

    .copp-students-hero__media {
        justify-self: stretch;
        min-height: 330px;
        width: 100%;
    }

    .copp-students-hero__scene {
        margin: 0 auto;
        max-width: 560px;
        min-height: 330px;
    }

    .copp-students-hero__people {
        bottom: -72px;
        height: calc(100% + 72px);
        right: -4px;
        transform: translateY(78px);
        width: min(100%, 516px);
    }

    .copp-students-story {
        gap: 20px;
        grid-template-columns: 1fr;
        padding: 24px;
    }

    .copp-students-story__quote {
        display: none;
    }

    .copp-students-cta__inner {
        grid-template-columns: 1fr;
        min-height: 0;
    }

    .copp-students-cta__visual {
        min-height: 220px;
    }

    .copp-students-cta__visual img {
        bottom: -76px;
        right: 14%;
        width: min(80%, 440px);
    }
}

@media (max-width: 767.98px) {
    .copp-students-content {
        gap: 32px;
    }

    .copp-students-hero .copp-news-hero__title {
        font-size: 44px;
    }

    .copp-students-hero__subtitle {
        font-size: 22px;
    }

    .copp-students-stats,
    .copp-students-opportunities,
    .copp-school-events {
        grid-template-columns: 1fr;
    }

    .copp-students-stories {
        grid-template-columns: 38px minmax(0, 1fr) 38px;
        gap: 8px;
    }

    .copp-students-stories__nav {
        height: 38px;
        width: 38px;
    }

    .copp-students-cta__copy h2 {
        font-size: 25px;
    }

    .copp-students-cta__visual {
        min-height: 188px;
    }
}

@media (max-width: 575.98px) {
    .copp-students-hero__media {
        min-height: 260px;
    }

    .copp-students-hero__scene {
        min-height: 260px;
    }

    .copp-students-hero__people {
        width: min(100%, 420px);
    }

    .copp-students-stories {
        grid-template-columns: 1fr;
    }

    .copp-students-stories__nav {
        display: none;
    }

    .copp-students-cta__visual img {
        right: 0;
        width: min(100%, 320px);
    }
}

.copp-about-page-content,
.copp-school-page-content,
.copp-students-page-content,
.copp-opportunity-page-content {
    margin-bottom: -1rem !important;
}

@media (min-width: 768px) {
    .copp-about-page-content,
    .copp-school-page-content,
    .copp-students-page-content,
    .copp-opportunity-page-content {
        margin-bottom: -1.5rem !important;
    }
}

.copp-about-join,
.copp-school-cta,
.copp-students-cta {
    margin-bottom: -2px;
}

/* Align students/regional/accessible heroes to the school-page hero pattern */
.copp-students-hero,
.copp-opportunity-hero {
    padding-bottom: 34px;
}

.copp-students-hero .copp-news-hero__inner,
.copp-opportunity-hero .copp-news-hero__inner {
    gap: 42px;
    grid-template-columns: minmax(0, 470px) minmax(0, 1fr);
    min-height: 396px;
}

.copp-students-hero .copp-news-hero__copy,
.copp-opportunity-hero .copp-news-hero__copy {
    min-width: 0;
    position: relative;
    z-index: 2;
}

.copp-students-hero .copp-news-hero__title,
.copp-opportunity-hero .copp-news-hero__title {
    margin-bottom: 20px;
    max-width: 440px;
    font-size: clamp(42px, 4.4vw, 68px);
    font-weight: 800;
    line-height: var(--copp-lh-hero);
}

.copp-students-hero__subtitle,
.copp-opportunity-hero__subtitle {
    color: var(--copp-ink);
    font-size: 28px;
    font-weight: 800;
    line-height: 1.28;
    margin: 0 0 16px;
    max-width: 420px;
}

.copp-students-hero .copp-news-hero__lead,
.copp-opportunity-hero__lead-copy {
    max-width: 420px;
    color: #383838;
    font-size: 21px;
    line-height: 1.55;
    margin: 24px 0 0;
}

.copp-students-hero .copp-news-hero__actions,
.copp-opportunity-hero .copp-news-hero__actions {
    margin-top: 0;
}

.copp-students-hero__media,
.copp-opportunity-hero .copp-news-hero__media {
    align-self: stretch;
    justify-self: end;
    min-height: 380px;
    overflow: visible;
    position: relative;
    width: min(100%, 560px);
}

.copp-students-hero__scene,
.copp-opportunity-hero .copp-students-hero__scene {
    height: 100%;
    max-width: none;
    min-height: 380px;
    overflow: visible;
    position: relative;
}

.copp-students-hero__people,
.copp-opportunity-hero .copp-students-hero__people {
    bottom: 0;
    height: 100%;
    right: 0;
    transform: none;
    width: min(100%, 560px);
}

.copp-students-hero__people img,
.copp-opportunity-hero .copp-students-hero__people img {
    display: block;
    filter: none;
    height: 100%;
    max-height: none;
    max-width: none;
    mix-blend-mode: darken;
    object-fit: contain;
    object-position: center bottom;
    width: 100%;
}

@media (max-width: 991.98px) {
    .copp-students-hero,
    .copp-opportunity-hero {
        padding-bottom: 34px;
    }

    .copp-students-hero .copp-news-hero__inner,
    .copp-opportunity-hero .copp-news-hero__inner {
        gap: 24px;
        grid-template-columns: minmax(0, 1fr);
        min-height: 0;
    }

    .copp-students-hero__subtitle,
    .copp-opportunity-hero__subtitle,
    .copp-students-hero .copp-news-hero__lead,
    .copp-opportunity-hero__lead-copy {
        max-width: 100%;
    }

    .copp-students-hero__media,
    .copp-opportunity-hero .copp-news-hero__media {
        justify-self: stretch;
        min-height: 340px;
        width: 100%;
    }

    .copp-students-hero__scene,
    .copp-opportunity-hero .copp-students-hero__scene {
        margin: 0 auto;
        max-width: 560px;
        min-height: 340px;
        transform: scale(0.9);
        transform-origin: center bottom;
    }

    .copp-students-hero__people,
    .copp-opportunity-hero .copp-students-hero__people {
        right: 0;
        width: min(100%, 516px);
    }
}

@media (max-width: 767.98px) {
    .copp-students-hero .copp-news-hero__title,
    .copp-opportunity-hero .copp-news-hero__title {
        font-size: 44px;
    }

    .copp-students-hero__subtitle,
    .copp-opportunity-hero__subtitle {
        font-size: 22px;
    }
}

@media (max-width: 575.98px) {
    .copp-students-hero__media,
    .copp-opportunity-hero .copp-news-hero__media {
        min-height: 260px;
    }

    .copp-students-hero__scene,
    .copp-opportunity-hero .copp-students-hero__scene {
        min-height: 260px;
    }

    .copp-students-hero__people,
    .copp-opportunity-hero .copp-students-hero__people {
        width: min(100%, 420px);
    }
}
.copp-knowledge-page {
    display: grid;
    gap: 32px;
}

.copp-knowledge-page-content {
    margin-top: 24px;
}

.copp-knowledge-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
    align-items: center;
    gap: 28px;
    padding: 42px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 0;
    background:
        radial-gradient(circle at top left, rgba(var(--copp-red-rgb), 0.08), transparent 38%),
        linear-gradient(180deg, #ffffff 0%, #f8f8f8 100%);
    box-shadow: 0 28px 60px rgba(15, 23, 42, 0.08);
    overflow: hidden;
}

.copp-knowledge-hero__copy {
    max-width: 620px;
}

.copp-knowledge-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 14px;
    font-size: var(--copp-fs-eyebrow);
    font-weight: var(--copp-fw-eyebrow);
    line-height: var(--copp-lh-eyebrow);
    letter-spacing: var(--copp-ls-eyebrow);
    text-transform: uppercase;
    color: var(--copp-red);
}

.copp-knowledge-hero__title {
    margin: 0;
    font-size: clamp(40px, 4.4vw, 72px);
    font-weight: 800;
    line-height: var(--copp-lh-hero);
    color: var(--copp-ink);
}

.copp-knowledge-hero__subtitle {
    margin: 18px 0 0;
    max-width: 520px;
    font-size: 28px;
    font-weight: 700;
    line-height: 1.1;
    color: var(--copp-ink);
}

.copp-knowledge-hero__lead {
    margin: 18px 0 0;
    max-width: 580px;
    font-size: 17px;
    line-height: 1.72;
    color: #525252;
}

.copp-knowledge-hero__intro {
    margin: 18px 0 0;
    max-width: 580px;
    font-size: 17px;
    line-height: 1.72;
    color: #525252;
}

.copp-knowledge-hero__intro > *:first-child {
    margin-top: 0;
}

.copp-knowledge-hero__intro > *:last-child {
    margin-bottom: 0;
}

.copp-knowledge-hero__intro p {
    margin: 0 0 12px;
}

.copp-knowledge-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 26px;
}

.copp-knowledge-hero__media {
    position: relative;
    min-height: 420px;
}

.copp-knowledge-hero__scene {
    position: relative;
    height: 100%;
    min-height: 420px;
    border-radius: 0;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(249, 249, 249, 0.8)),
        linear-gradient(135deg, rgba(var(--copp-red-rgb), 0.08), rgba(35, 35, 35, 0.02));
}

.copp-knowledge-hero__scene img {
    position: absolute;
    right: 24px;
    bottom: 0;
    width: min(100%, 480px);
    max-height: 100%;
    object-fit: contain;
    z-index: 5;
}

.copp-knowledge-hero__tile,
.copp-knowledge-audience-card__deco {
    position: absolute;
    display: block;
    border-radius: 0;
}

.copp-knowledge-hero__tile--one {
    top: 34px;
    left: 24px;
    width: 20px;
    height: 20px;
    background: var(--copp-ink);
}

.copp-knowledge-hero__tile--two {
    top: 72px;
    left: 98px;
    width: 72px;
    height: 72px;
    background: rgba(var(--copp-red-rgb), 0.92);
}

.copp-knowledge-hero__tile--three {
    top: 168px;
    left: 58px;
    width: 26px;
    height: 26px;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(var(--copp-ink-rgb), 0.08);
}

.copp-knowledge-hero__tile--four {
    right: 66px;
    top: 54px;
    width: 56px;
    height: 56px;
    background: rgba(var(--copp-red-rgb), 0.9);
}

.copp-knowledge-hero__tile--five {
    right: 18px;
    top: 144px;
    width: 24px;
    height: 24px;
    background: rgba(var(--copp-ink-rgb), 0.92);
}

.copp-knowledge-hero__tile--six {
    left: 160px;
    bottom: 56px;
    width: 90px;
    height: 90px;
    background: rgba(var(--copp-red-rgb), 0.14);
}

.copp-knowledge-hero__badge {
    position: absolute;
    z-index: 4;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    border-radius: 0;
    background: var(--copp-dark);
    color: #fff;
    box-shadow: 0 18px 32px rgba(15, 23, 42, 0.14);
}

.copp-knowledge-hero__badge svg {
    width: 26px;
    height: 26px;
}

.copp-knowledge-hero__badge--book {
    left: 20px;
    top: 116px;
}

.copp-knowledge-hero__badge--cap {
    right: 74px;
    top: 14px;
    background: var(--copp-red);
}

.copp-knowledge-hero__badge--doc {
    right: 4px;
    top: 188px;
}

.copp-knowledge-hero__badge--idea {
    right: 36px;
    bottom: 48px;
}

.copp-knowledge-categories {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 16px;
}

.copp-knowledge-category {
    position: relative;
    display: grid;
    gap: 12px;
    min-height: 188px;
    padding: 24px 22px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 0;
    background: #fff;
    color: var(--copp-dark);
    text-decoration: none;
    box-shadow: 0 18px 30px rgba(15, 23, 42, 0.04);
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}

.copp-knowledge-category:hover {
    transform: translateY(-2px);
    box-shadow: 0 22px 40px rgba(15, 23, 42, 0.08);
    text-decoration: none;
}

.copp-knowledge-category.is-active {
    background: linear-gradient(180deg, var(--copp-red) 0%, var(--copp-red) 100%);
    border-color: var(--copp-red);
    color: #fff;
}

.copp-knowledge-category__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    border-radius: 0;
    border: 2px solid currentColor;
}

.copp-knowledge-category__title {
    font-size: 20px;
    font-weight: 700;
    line-height: 1.18;
}

.copp-knowledge-category__meta {
    color: rgba(31, 31, 31, 0.72);
}

.copp-knowledge-category.is-active .copp-knowledge-category__meta {
    color: rgba(255, 255, 255, 0.86);
}

.copp-knowledge-category__arrow {
    margin-top: auto;
    justify-self: end;
}

.copp-knowledge-filters-shell {
    padding: 18px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 0;
    background: #fff;
    box-shadow: 0 18px 30px rgba(15, 23, 42, 0.04);
}

.copp-knowledge-filters {
    display: grid;
    grid-template-columns: minmax(260px, 1.8fr) repeat(4, minmax(150px, 1fr)) auto;
    gap: 12px;
    align-items: end;
}

.copp-knowledge-search,
.copp-knowledge-select {
    display: grid;
    gap: 8px;
}

.copp-knowledge-select span {
    font-size: 12px;
    font-weight: 600;
    color: #6b7280;
}

.copp-knowledge-search {
    position: relative;
}

.copp-knowledge-search input,
.copp-knowledge-select select {
    width: 100%;
    height: 54px;
    padding: 0 16px;
    border: 1px solid rgba(15, 23, 42, 0.14);
    border-radius: 0;
    background: #fff;
    font-size: 15px;
    color: var(--copp-ink);
}

.copp-knowledge-search input {
    padding-right: 58px;
}

.copp-knowledge-search button {
    position: absolute;
    right: 8px;
    bottom: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border: none;
    border-radius: 0;
    background: #f3f4f6;
    color: var(--copp-ink);
}

.copp-knowledge-filters__reset {
    align-self: stretch;
    min-height: 54px;
}

.copp-knowledge-materials {
    display: grid;
    gap: 20px;
}

.copp-knowledge-materials__head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 20px;
}

.copp-knowledge-materials__head h2,
.copp-knowledge-useful__head h2 {
    margin: 0;
    font-size: 34px;
    font-weight: 800;
    line-height: 1;
    color: var(--copp-dark);
}

.copp-knowledge-materials__head p {
    margin: 8px 0 0;
    color: #6b7280;
}

.copp-knowledge-materials__layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 24px;
    align-items: start;
}

.copp-knowledge-materials__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
}

.copp-knowledge-card,
.copp-knowledge-popular__item,
.copp-knowledge-audience-card {
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 0;
    background: #fff;
    box-shadow: 0 18px 30px rgba(15, 23, 42, 0.04);
}

.copp-knowledge-card {
    display: grid;
    grid-template-rows: 208px auto auto auto;
    overflow: hidden;
}

.copp-knowledge-card__media,
.copp-knowledge-popular__media {
    position: relative;
    display: block;
    overflow: hidden;
    background: linear-gradient(135deg, var(--copp-soft) 0%, var(--copp-pale) 100%);
}

.copp-knowledge-card__media img,
.copp-knowledge-popular__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: grayscale(1);
}

.copp-knowledge-card__media.is-placeholder,
.copp-knowledge-popular__media.is-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
}

.copp-knowledge-card__placeholder-icon,
.copp-knowledge-popular__placeholder {
    position: relative;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 72px;
    height: 72px;
    border-radius: 0;
    background: rgba(255, 255, 255, 0.92);
    color: #2a2a2a;
    box-shadow: 0 18px 28px rgba(15, 23, 42, 0.08);
}

.copp-knowledge-card__placeholder-icon svg,
.copp-knowledge-popular__placeholder svg {
    width: 30px;
    height: 30px;
}

.copp-knowledge-card__placeholder-mark {
    position: absolute;
    right: 18px;
    bottom: 18px;
    width: 18px;
    height: 18px;
    background: var(--copp-red);
    z-index: 1;
}

.copp-knowledge-card__body {
    display: grid;
    gap: 12px;
    padding: 20px 20px 16px;
}

.copp-knowledge-card__format,
.copp-knowledge-popular__format,
.copp-knowledge-item__format {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-height: 28px;
    padding: 0 10px;
    border-radius: 0;
    background: rgba(var(--copp-red-rgb), 0.08);
    color: var(--copp-red);
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
    text-transform: uppercase;
}

.copp-knowledge-card h3,
.copp-knowledge-popular__body h4,
.copp-knowledge-audience-card h3 {
    margin: 0;
    font-size: 22px;
    line-height: 1.18;
    color: var(--copp-ink);
}

.copp-knowledge-card h3 a,
.copp-knowledge-popular__body h4 a,
.copp-knowledge-audience-card,
.copp-knowledge-card__link {
    color: inherit;
    text-decoration: none;
}

.copp-knowledge-card p,
.copp-knowledge-audience-card p {
    margin: 0;
    font-size: 14px;
    line-height: 1.65;
    color: #616161;
}

.copp-knowledge-card__meta,
.copp-knowledge-card__footer,
.copp-knowledge-popular__meta,
.copp-knowledge-item__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
}

.copp-knowledge-card__meta {
    padding: 0 20px 14px;
    font-size: 13px;
    color: #8a8a8a;
}

.copp-knowledge-card__footer {
    justify-content: space-between;
    padding: 14px 20px 20px;
    border-top: 1px solid rgba(15, 23, 42, 0.06);
}

.copp-knowledge-card__audience {
    font-size: 13px;
    font-weight: 600;
    color: #525252;
}

.copp-knowledge-card__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 0;
    background: #f3f4f6;
    color: var(--copp-ink);
}

.copp-knowledge-popular {
    display: grid;
    gap: 16px;
    padding: 22px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 0;
    background: #fff;
    box-shadow: 0 18px 30px rgba(15, 23, 42, 0.04);
}

.copp-knowledge-popular__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.copp-knowledge-popular__head h3 {
    margin: 0;
    font-size: 24px;
    font-weight: 800;
    color: var(--copp-dark);
}

.copp-knowledge-popular__head a {
    color: var(--copp-red);
    font-weight: 700;
    text-decoration: none;
}

.copp-knowledge-popular__list {
    display: grid;
    gap: 14px;
}

.copp-knowledge-popular__item {
    display: grid;
    grid-template-columns: 108px minmax(0, 1fr);
    gap: 14px;
    padding: 12px;
}

.copp-knowledge-popular__media {
    min-height: 94px;
    border-radius: 0;
}

.copp-knowledge-popular__body {
    display: grid;
    gap: 8px;
    align-content: start;
}

.copp-knowledge-popular__body h4 {
    font-size: 17px;
}

.copp-knowledge-popular__meta {
    font-size: 12px;
    color: #8a8a8a;
}

.copp-knowledge-popular__meta svg {
    width: 14px;
    height: 14px;
}

.copp-knowledge-useful {
    display: grid;
    gap: 18px;
}

.copp-knowledge-useful__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
}

.copp-knowledge-audience-card {
    position: relative;
    display: grid;
    grid-template-columns: 56px minmax(0, 1fr);
    gap: 18px;
    align-items: start;
    padding: 24px;
    overflow: hidden;
}

.copp-knowledge-audience-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 0;
    background: var(--copp-red);
    color: #fff;
}

.copp-knowledge-audience-card__copy {
    position: relative;
    z-index: 2;
    display: grid;
    gap: 10px;
}

.copp-knowledge-audience-card__copy span {
    color: var(--copp-red);
    font-weight: 700;
}

.copp-knowledge-audience-card__deco--one {
    right: 18px;
    bottom: 20px;
    width: 20px;
    height: 20px;
    background: rgba(var(--copp-red-rgb), 0.94);
}

.copp-knowledge-audience-card__deco--two {
    right: 46px;
    bottom: 52px;
    width: 44px;
    height: 44px;
    background: rgba(17, 24, 39, 0.08);
}

.copp-knowledge-cta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    padding: 32px 36px;
    border-radius: 0;
    background: linear-gradient(135deg, var(--copp-red) 0%, var(--copp-red) 100%);
    color: #fff;
    box-shadow: 0 24px 44px rgba(var(--copp-red-rgb), 0.2);
}

.copp-knowledge-cta__copy {
    max-width: 720px;
}

.copp-knowledge-cta__copy h2 {
    margin: 0 0 10px;
    font-size: 34px;
    font-weight: 800;
    line-height: 1.04;
}

.copp-knowledge-cta__copy p {
    margin: 0;
    color: rgba(255, 255, 255, 0.88);
}

.copp-knowledge-cta__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.copp-knowledge-item {
    display: grid;
    gap: 24px;
}

.copp-knowledge-item__hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 24px;
    align-items: start;
    padding: 30px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 0;
    background: linear-gradient(180deg, #ffffff 0%, var(--copp-soft) 100%);
    box-shadow: 0 20px 36px rgba(15, 23, 42, 0.06);
}

.copp-knowledge-item__back {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 18px;
    font-weight: 700;
    color: #6b7280;
    text-decoration: none;
}

.copp-knowledge-item__copy h1 {
    margin: 12px 0 0;
    font-size: clamp(34px, 4vw, 56px);
    line-height: 1;
}

.copp-knowledge-item__summary {
    margin: 18px 0 0;
    font-size: 18px;
    line-height: 1.7;
    color: #565656;
}

.copp-knowledge-item__meta {
    margin-top: 18px;
    font-size: 14px;
    color: #6b7280;
}

.copp-knowledge-item__facts {
    display: grid;
    gap: 18px;
    padding: 22px;
    border-radius: 0;
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.08);
}

.copp-knowledge-item__facts dl {
    display: grid;
    gap: 14px;
    margin: 0;
}

.copp-knowledge-item__facts dt {
    margin: 0 0 4px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    color: #9ca3af;
}

.copp-knowledge-item__facts dd {
    margin: 0;
    font-size: 16px;
    font-weight: 700;
    color: var(--copp-dark);
}

.copp-knowledge-item__actions {
    display: grid;
    gap: 10px;
}

.copp-knowledge-item__cover {
    margin: 0;
    overflow: hidden;
    border-radius: 0;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: #fff;
    box-shadow: 0 20px 36px rgba(15, 23, 42, 0.05);
}

.copp-knowledge-item__cover img {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    filter: grayscale(1);
}

.copp-knowledge-item__layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 300px;
    gap: 24px;
    align-items: start;
}

.copp-knowledge-item__sidebar {
    display: grid;
    gap: 18px;
    position: sticky;
    top: 104px;
}

.copp-knowledge-item__content {
    padding: 32px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 0;
    background: #fff;
    box-shadow: 0 20px 36px rgba(15, 23, 42, 0.05);
}

.copp-knowledge-item__content > *:last-child {
    margin-bottom: 0;
}

.copp-knowledge-item__toc,
.copp-knowledge-item__prompt {
    display: grid;
    gap: 14px;
    padding: 22px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 0;
    background: #fff;
    box-shadow: 0 18px 30px rgba(15, 23, 42, 0.04);
}

.copp-knowledge-item__toc h2,
.copp-knowledge-item__prompt h3 {
    margin: 0;
    font-size: 20px;
    line-height: 1.1;
    color: var(--copp-ink);
}

.copp-knowledge-item__toc ol {
    display: grid;
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
    counter-reset: kb-outline;
}

.copp-knowledge-item__toc li {
    counter-increment: kb-outline;
}

.copp-knowledge-item__toc li a {
    display: grid;
    grid-template-columns: 28px minmax(0, 1fr);
    gap: 12px;
    align-items: start;
    color: #3f3f46;
    text-decoration: none;
    font-size: 14px;
    line-height: 1.5;
}

.copp-knowledge-item__toc li a::before {
    content: counter(kb-outline);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 0;
    background: rgba(var(--copp-red-rgb), 0.08);
    color: var(--copp-red);
    font-size: 12px;
    font-weight: 800;
}

.copp-knowledge-item__toc li.is-h3 a {
    grid-template-columns: 20px minmax(0, 1fr);
    padding-left: 14px;
    color: #6b7280;
}

.copp-knowledge-item__toc li.is-h3 a::before {
    width: 8px;
    height: 8px;
    margin-top: 9px;
    border-radius: 0;
    background: rgba(var(--copp-red-rgb), 0.88);
    color: transparent;
    content: "";
}

.copp-knowledge-item__prompt p {
    margin: 0;
    color: #5b5b5b;
    line-height: 1.7;
}

.copp-knowledge-item__content h2 {
    margin: 38px 0 16px;
    font-size: clamp(28px, 2.8vw, 36px);
    line-height: 1.08;
    color: var(--copp-ink);
}

.copp-knowledge-item__content h3 {
    margin: 0 0 10px;
    font-size: 22px;
    line-height: 1.18;
    color: var(--copp-ink);
}

.copp-knowledge-item__content p,
.copp-knowledge-item__content li {
    font-size: 16px;
    line-height: 1.75;
    color: #474747;
}

.copp-knowledge-item__content p {
    margin: 0 0 16px;
}

.copp-knowledge-item__content ul:not(.kb-checklist),
.copp-knowledge-item__content ol:not(.kb-steps) {
    margin: 0 0 20px;
    padding-left: 22px;
}

.kb-grid {
    display: grid;
    gap: 16px;
    margin: 24px 0;
}

.kb-grid--2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.kb-panel {
    display: grid;
    gap: 10px;
    padding: 20px;
    border-radius: 0;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: linear-gradient(180deg, #ffffff 0%, var(--copp-soft) 100%);
    box-shadow: 0 12px 24px rgba(15, 23, 42, 0.04);
}

.kb-panel p:last-child {
    margin-bottom: 0;
}

.kb-note {
    display: grid;
    gap: 10px;
    margin: 24px 0;
    padding: 22px 24px;
    border-radius: 0;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: #fff5f5;
}

.kb-note strong {
    font-size: 15px;
    color: var(--copp-ink);
}

.kb-note p:last-child {
    margin-bottom: 0;
}

.kb-note--accent {
    background: linear-gradient(135deg, rgba(var(--copp-red-rgb), 0.12) 0%, rgba(255, 255, 255, 0.96) 100%);
    border-color: rgba(var(--copp-red-rgb), 0.16);
}

.kb-note--soft {
    background: linear-gradient(180deg, #ffffff 0%, #f6f7f9 100%);
}

.kb-steps,
.kb-checklist {
    display: grid;
    gap: 14px;
    margin: 24px 0;
    padding: 0;
    list-style: none;
}

.kb-steps li,
.kb-checklist li {
    position: relative;
    margin: 0;
    padding: 18px 18px 18px 72px;
    border-radius: 0;
    background: var(--copp-soft);
    border: 1px solid rgba(15, 23, 42, 0.08);
}

.kb-steps {
    counter-reset: kb-steps;
}

.kb-steps li::before,
.kb-checklist li::before {
    position: absolute;
    left: 18px;
    top: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 0;
    font-size: 13px;
    font-weight: 800;
}

.kb-steps li::before {
    counter-increment: kb-steps;
    content: counter(kb-steps);
    background: var(--copp-red);
    color: #fff;
}

.kb-checklist li::before {
    content: "✓";
    background: rgba(var(--copp-red-rgb), 0.08);
    color: var(--copp-red);
}

.kb-steps li strong {
    display: block;
    margin-bottom: 6px;
    color: var(--copp-ink);
}

/* Unified card grids and card internals */
.copp-program-grid,
.copp-events-cards,
.copp-projects-cards,
.copp-school-tests,
.copp-school-events,
.copp-students-opportunities,
.copp-about-stats,
.copp-about-directions,
.copp-opportunity-focus,
.copp-knowledge-categories,
.copp-news-grid,
.copp-knowledge-materials__grid,
.copp-knowledge-useful__grid {
    align-items: stretch;
    grid-auto-rows: 1fr;
}

.copp-knowledge-categories {
    --copp-grid-columns: 6;
    grid-template-columns: repeat(var(--copp-grid-columns), minmax(0, 1fr));
}

.copp-news-grid {
    --copp-grid-columns: 3;
    grid-template-columns: repeat(var(--copp-grid-columns), minmax(0, 1fr));
}

.copp-knowledge-materials__grid {
    --copp-grid-columns: 4;
    grid-template-columns: repeat(var(--copp-grid-columns), minmax(0, 1fr));
}

.copp-knowledge-useful__grid {
    --copp-grid-columns: 5;
    grid-template-columns: repeat(var(--copp-grid-columns), minmax(0, 1fr));
}

.copp-about-stats {
    --copp-grid-columns: 4;
    grid-template-columns: repeat(var(--copp-grid-columns), minmax(0, 1fr));
}

.copp-about-directions {
    --copp-grid-columns: 5;
    grid-template-columns: repeat(var(--copp-grid-columns), minmax(0, 1fr));
}

.copp-opportunity-focus {
    --copp-grid-columns: 4;
    grid-template-columns: repeat(var(--copp-grid-columns), minmax(0, 1fr));
}

.copp-program-grid > *,
.copp-events-cards > *,
.copp-projects-cards > *,
.copp-school-tests > *,
.copp-school-events > *,
.copp-students-opportunities > *,
.copp-about-stats > *,
.copp-about-directions > *,
.copp-opportunity-focus > *,
.copp-knowledge-categories > *,
.copp-news-grid > *,
.copp-knowledge-materials__grid > *,
.copp-knowledge-useful__grid > * {
    height: 100%;
    min-width: 0;
}

.copp-program-card,
.copp-program-tile,
.copp-news-card,
.copp-events-card,
.copp-projects-card,
.copp-school-test,
.copp-students-opportunity,
.copp-about-stat,
.copp-about-direction,
.copp-knowledge-card,
.copp-knowledge-category,
.copp-knowledge-audience-card {
    min-width: 0;
}

.copp-program-card {
    gap: 18px;
}

.copp-program-card__title {
    display: -webkit-box;
    min-height: calc(1.35em * 3);
    max-width: none;
    overflow: hidden;
    overflow-wrap: anywhere;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.copp-program-tile__body,
.copp-news-card__body,
.copp-events-card__body,
.copp-knowledge-card__body,
.copp-school-test__cta-copy {
    min-width: 0;
}

.copp-program-tile__body > *,
.copp-news-card__body > *,
.copp-events-card__body > *,
.copp-knowledge-card__body > *,
.copp-school-test__cta-copy > * {
    min-width: 0;
}

.copp-program-tile__body h2,
.copp-program-tile__body h3,
.copp-events-card__body h3,
.copp-school-test h3,
.copp-students-opportunity h3,
.copp-about-direction h3,
.copp-knowledge-card h3,
.copp-knowledge-category__title,
.copp-knowledge-audience-card h3 {
    display: -webkit-box;
    overflow: hidden;
    overflow-wrap: anywhere;
    -webkit-box-orient: vertical;
}

.copp-program-tile__body h2,
.copp-program-tile__body h3 {
    min-height: calc(1.22em * 2);
    -webkit-line-clamp: 2;
}

.copp-events-card__body h3 {
    min-height: calc(1.2em * 3);
    -webkit-line-clamp: 3;
}

.copp-school-test h3 {
    min-height: calc(1.24em * 3);
    -webkit-line-clamp: 3;
}

.copp-students-opportunity h3 {
    min-height: calc(1.22em * 3);
    -webkit-line-clamp: 3;
}

.copp-about-direction h3 {
    min-height: calc(1.15em * 3);
    -webkit-line-clamp: 3;
}

.copp-knowledge-card h3,
.copp-knowledge-category__title,
.copp-knowledge-audience-card h3 {
    min-height: calc(1.18em * 3);
    -webkit-line-clamp: 3;
}

.copp-program-tile__body p,
.copp-news-card__body p,
.copp-events-card__body p,
.copp-school-test p,
.copp-students-opportunity p,
.copp-about-direction p,
.copp-about-stat p,
.copp-knowledge-card p,
.copp-knowledge-category__meta,
.copp-knowledge-audience-card p {
    display: -webkit-box;
    overflow: hidden;
    overflow-wrap: anywhere;
    -webkit-box-orient: vertical;
}

.copp-program-tile__body p {
    min-height: calc(1.55em * 4);
    -webkit-line-clamp: 4;
}

.copp-news-card__body {
    display: grid;
    gap: 14px;
    grid-template-rows: auto auto minmax(calc(1.6em * 4), auto) auto;
}

.copp-news-card__body .copp-news-card__label {
    margin-bottom: 0;
}

.copp-news-card__body h3 {
    min-height: calc(1.32em * 3);
    -webkit-line-clamp: 3;
}

.copp-news-card__body p {
    font-size: 15px;
    line-height: 1.6;
    margin: 0;
    min-height: calc(1.6em * 4);
    -webkit-line-clamp: 4;
}

.copp-news-card__footer {
    align-self: end;
    margin-top: 0;
    padding-top: 0;
}

.copp-events-card__meta b {
    display: -webkit-box;
    overflow: hidden;
    overflow-wrap: anywhere;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.copp-events-card__body p {
    min-height: calc(1.5em * 4);
    -webkit-line-clamp: 4;
}

.copp-events-card__attendance {
    align-self: start;
}

.copp-school-test {
    height: 100%;
}

.copp-school-test:not(.copp-school-test--cta) {
    align-content: start;
    grid-template-rows: auto auto minmax(calc(1.45em * 4), auto) auto;
}

.copp-school-test p {
    min-height: calc(1.45em * 4);
    -webkit-line-clamp: 4;
}

.copp-school-test--cta {
    align-content: start;
    grid-template-rows: auto 1fr auto;
}

.copp-students-opportunity {
    align-content: start;
    grid-template-rows: auto auto 1fr;
    height: 100%;
}

.copp-students-opportunity p {
    min-height: calc(1.42em * 4);
    -webkit-line-clamp: 4;
}

.copp-about-stat {
    height: 100%;
}

.copp-about-stat p {
    max-width: none;
    min-height: calc(1.35em * 3);
    -webkit-line-clamp: 3;
}

.copp-about-direction {
    gap: 14px;
    height: 100%;
}

.copp-about-direction p {
    min-height: calc(1.55em * 4);
    -webkit-line-clamp: 4;
}

.copp-knowledge-category {
    grid-template-rows: auto auto auto 1fr auto;
    height: 100%;
}

.copp-knowledge-category__meta {
    min-height: calc(1.45em * 2);
    -webkit-line-clamp: 2;
}

.copp-knowledge-card {
    grid-template-rows: 208px minmax(0, 1fr) auto auto;
}

.copp-knowledge-card__body {
    align-content: start;
}

.copp-knowledge-card p {
    min-height: calc(1.65em * 4);
    -webkit-line-clamp: 4;
}

.copp-knowledge-audience-card {
    align-content: start;
    height: 100%;
}

.copp-knowledge-audience-card p {
    min-height: calc(1.65em * 4);
    -webkit-line-clamp: 4;
}

.copp-program-tile__facts,
.copp-knowledge-card__meta,
.copp-knowledge-card__footer {
    align-items: stretch;
}

.copp-program-tile__facts div {
    align-content: start;
    display: grid;
    min-height: 74px;
}

.copp-program-tile__facts dd {
    display: -webkit-box;
    overflow: hidden;
    overflow-wrap: anywhere;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

@media (max-width: 1440px) {
    .copp-knowledge-categories {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .copp-knowledge-materials__grid,
    .copp-knowledge-useful__grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 1180px) {
    .copp-knowledge-hero,
    .copp-knowledge-materials__layout,
    .copp-knowledge-item__hero,
    .copp-knowledge-cta {
        grid-template-columns: 1fr;
    }

    .copp-knowledge-item__layout {
        grid-template-columns: 1fr;
    }

    .copp-knowledge-item__sidebar {
        position: static;
    }

    .copp-knowledge-filters {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .copp-knowledge-filters__reset {
        justify-content: center;
    }
}

@media (max-width: 960px) {
    .copp-knowledge-hero {
        padding: 28px;
    }

    .copp-knowledge-categories,
    .copp-knowledge-materials__grid,
    .copp-knowledge-useful__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .copp-knowledge-hero__media,
    .copp-knowledge-hero__scene {
        min-height: 340px;
    }

    .copp-knowledge-item__content {
        padding: 24px;
    }

    .kb-grid--2 {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {
    .copp-knowledge-hero,
    .copp-knowledge-filters-shell,
    .copp-knowledge-popular,
    .copp-knowledge-cta,
    .copp-knowledge-item__hero {
        padding: 22px;
        border-radius: 0;
    }

    .copp-knowledge-filters,
    .copp-knowledge-categories,
    .copp-knowledge-materials__grid,
    .copp-knowledge-useful__grid,
    .copp-knowledge-popular__item,
    .copp-knowledge-audience-card {
        grid-template-columns: 1fr;
    }

    .copp-knowledge-materials__head {
        align-items: start;
        flex-direction: column;
    }

    .copp-knowledge-card {
        grid-template-rows: 188px auto auto auto;
    }

    .copp-knowledge-item__cover,
    .copp-knowledge-item__toc,
    .copp-knowledge-item__prompt {
        border-radius: 0;
    }

    .copp-knowledge-item__toc,
    .copp-knowledge-item__prompt {
        padding: 18px;
    }

    .kb-panel,
    .kb-note,
    .kb-steps li,
    .kb-checklist li {
        border-radius: 0;
    }

    .copp-knowledge-hero__title {
        font-size: 38px;
    }

    .copp-knowledge-hero__subtitle {
        font-size: 22px;
    }

    .copp-knowledge-hero__intro {
        font-size: 16px;
    }

.copp-knowledge-hero__scene img {
        right: 0;
        width: min(100%, 360px);
    }
}

/* Career quiz override */
.copp-pathfinder__shell {
    grid-template-columns: minmax(320px, 0.78fr) minmax(0, 1.22fr);
    min-height: 430px;
}

.copp-pathfinder__intro {
    gap: 28px;
}

.copp-pathfinder__intro-copy {
    display: grid;
    gap: 18px;
}

.copp-pathfinder__stage {
    background: var(--copp-ink);
    display: grid;
    min-height: 430px;
    overflow: visible;
    position: relative;
}

.copp-pathfinder__stage::after {
    background: var(--copp-ink);
    bottom: 0;
    content: "";
    left: 100%;
    pointer-events: none;
    position: absolute;
    top: 0;
    width: 100vw;
}

.copp-pathfinder__preview,
.copp-pathfinder__quiz {
    grid-area: 1 / 1;
    min-width: 0;
    position: relative;
    transition: opacity 280ms ease, transform 280ms ease, visibility 280ms ease;
    z-index: 1;
}

.copp-pathfinder__preview {
    align-items: center;
    background: var(--copp-ink);
    display: flex;
    flex-direction: column;
    gap: 20px;
    justify-content: center;
    opacity: 1;
    padding: 40px 36px 38px;
    transform: translateX(0);
    visibility: visible;
}

.copp-pathfinder__quiz {
    align-content: start;
    background: var(--copp-ink);
    display: flex;
    flex-direction: column;
    gap: 22px;
    opacity: 0;
    padding: 24px 28px 28px;
    pointer-events: none;
    transform: translateX(34px);
    visibility: hidden;
}

.copp-pathfinder__quiz::after {
    content: none;
}

.copp-pathfinder.is-started .copp-pathfinder__preview {
    opacity: 0;
    pointer-events: none;
    transform: translateX(-34px);
    visibility: hidden;
}

.copp-pathfinder.is-started .copp-pathfinder__quiz {
    opacity: 1;
    pointer-events: auto;
    transform: translateX(0);
    visibility: visible;
}

.copp-pathfinder__preview-copy {
    display: grid;
    gap: 16px;
    max-width: 480px;
    width: 100%;
}

.copp-pathfinder__preview-badge {
    align-items: center;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 0;
    color: rgba(255, 255, 255, 0.9);
    display: inline-flex;
    font-size: 12px;
    font-weight: 800;
    justify-self: center;
    letter-spacing: 0.04em;
    min-height: 32px;
    padding: 0 14px;
    text-transform: uppercase;
}

.copp-pathfinder__preview-title {
    color: #ffffff;
    font-size: 26px;
    font-weight: 800;
    line-height: 1.14;
    margin: 0;
    text-align: center;
}

.copp-pathfinder__preview-text {
    color: rgba(255, 255, 255, 0.72);
    font-size: 15px;
    line-height: 1.52;
    margin: 0;
    text-align: center;
}

.copp-pathfinder__preview-points {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.copp-pathfinder__preview-point {
    align-content: start;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 0;
    display: grid;
    gap: 4px;
    min-height: 0;
    padding: 14px 12px 12px;
    text-align: center;
    overflow-wrap: break-word;
    word-break: break-word;
    hyphens: auto;
}

.copp-pathfinder__preview-point strong {
    color: #ffffff;
    display: block;
    font-size: 15px;
    font-weight: 800;
    line-height: 1.28;
}

.copp-pathfinder__preview-point span {
    color: rgba(255, 255, 255, 0.62);
    font-size: 12px;
    font-weight: 600;
    line-height: 1.35;
}

.copp-pathfinder__preview-media {
    align-items: center;
    display: flex;
    justify-content: center;
    min-height: 100%;
}

.copp-pathfinder__preview-frame {
    align-items: end;
    aspect-ratio: 14 / 10;
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.9), rgba(240, 240, 240, 0.76));
    border-radius: 0;
    display: flex;
    justify-content: center;
    max-width: 430px;
    overflow: hidden;
    position: relative;
    width: 100%;
}

.copp-pathfinder__preview-frame img {
    display: block;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    width: 100%;
}

.copp-pathfinder__tile {
    display: block;
    position: absolute;
}

.copp-pathfinder__tile--red {
    background: rgba(var(--copp-red-rgb), 0.9);
}

.copp-pathfinder__tile--light {
    background: rgba(255, 255, 255, 0.88);
}

.copp-pathfinder__tile--dark {
    background: rgba(35, 35, 35, 0.92);
}

.copp-pathfinder__tile--one {
    height: 44px;
    left: 9%;
    top: 16%;
    width: 44px;
}

.copp-pathfinder__tile--two {
    height: 24px;
    left: 19%;
    top: 56%;
    width: 24px;
}

.copp-pathfinder__tile--three {
    height: 28px;
    right: 16%;
    top: 18%;
    width: 28px;
}

.copp-pathfinder__tile--four {
    height: 58px;
    right: 8%;
    top: 52%;
    width: 58px;
}

.copp-pathfinder__tile--five {
    height: 18px;
    right: 28%;
    top: 64%;
    width: 18px;
}

.copp-pathfinder__preview-card {
    align-items: center;
    background: rgba(35, 35, 35, 0.92);
    border-radius: 0;
    color: #ffffff;
    display: inline-flex;
    font-size: 12px;
    font-weight: 800;
    line-height: 1.35;
    max-width: 190px;
    min-height: 38px;
    padding: 9px 12px;
    position: absolute;
}

.copp-pathfinder__preview-card--top {
    left: 7%;
    top: 9%;
}

.copp-pathfinder__preview-card--bottom {
    bottom: 7%;
    right: 7%;
}

.copp-pathfinder__choices {
    gap: 14px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.copp-pathfinder__choice {
    align-items: flex-start;
    flex-direction: row;
    gap: 14px;
    min-height: 116px;
}

.copp-pathfinder__choice-copy {
    display: grid;
    gap: 8px;
}

.copp-pathfinder__choice-label {
    font-size: 16px;
    line-height: 1.4;
}

.copp-pathfinder__choice-hint {
    color: rgba(255, 255, 255, 0.58);
    display: block;
    font-size: 13px;
    font-weight: 600;
    line-height: 1.5;
}

.copp-pathfinder__result-points {
    display: grid;
    gap: 6px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.copp-pathfinder__result-points li {
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 0;
    color: rgba(255, 255, 255, 0.88);
    font-size: 13px;
    font-weight: 600;
    line-height: 1.45;
    padding: 8px 12px;
}

@media (max-width: 1199.98px) {
    .copp-pathfinder__shell {
        grid-template-columns: minmax(280px, 0.78fr) minmax(0, 1.22fr);
    }

    .copp-pathfinder__preview {
        grid-template-columns: minmax(0, 1fr);
        padding: 24px 24px 26px;
    }

    .copp-pathfinder__preview-media {
        justify-content: flex-start;
    }

    .copp-pathfinder__quiz {
        padding: 24px 24px 26px;
    }
}

@media (max-width: 991.98px) {
    .copp-pathfinder__shell {
        grid-template-columns: 1fr;
    }

    .copp-pathfinder__stage {
        min-height: 460px;
    }

    .copp-pathfinder__preview,
    .copp-pathfinder__quiz {
        padding: 24px 24px 24px;
    }

    .copp-pathfinder__preview-title {
        font-size: 24px;
    }

    .copp-pathfinder__preview-points {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .copp-pathfinder__choices {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .copp-pathfinder__preview,
    .copp-pathfinder__quiz {
        padding: 20px 18px;
    }

    .copp-pathfinder__preview-title {
        font-size: 21px;
    }

    .copp-pathfinder__preview-points {
        grid-template-columns: 1fr;
    }

    .copp-pathfinder__preview-frame {
        aspect-ratio: 4 / 3;
    }

    .copp-pathfinder__choice {
        flex-direction: column;
    }
}

.copp-palette-switcher {
    position: fixed;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    z-index: 9998;
    display: flex;
    align-items: center;
}

.copp-palette-switcher__toggle {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    padding: 14px 10px;
    border: none;
    border-radius: 999px 0 0 999px;
    background: var(--copp-dark);
    color: #ffffff;
    cursor: pointer;
    box-shadow: -2px 2px 12px rgba(0, 0, 0, 0.25);
    transition: background 0.3s, box-shadow 0.3s;
    font-family: inherit;
    writing-mode: vertical-rl;
    text-orientation: mixed;
}

.copp-palette-switcher__toggle:hover {
    background: var(--copp-red);
    box-shadow: -3px 3px 20px rgba(var(--copp-red-rgb), 0.4);
}

.copp-palette-switcher__toggle:active {
    box-shadow: -2px 2px 12px rgba(0, 0, 0, 0.25);
}

.copp-palette-switcher__icon {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    writing-mode: horizontal-tb;
}

.copp-palette-switcher__label {
    font-size: 13px;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.05em;
    white-space: nowrap;
}

.copp-palette-switcher__panel {
    position: absolute;
    right: calc(100% + 12px);
    top: 50%;
    transform: translateY(-50%) translateX(8px);
    background: var(--copp-dark);
    border-radius: 0;
    box-shadow: 0 8px 40px rgba(0, 0, 0, 0.35);
    padding: 0;
    display: flex;
    flex-direction: column;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.25s, visibility 0.25s, transform 0.25s;
    min-width: 280px;
    overflow: hidden;
}

.copp-palette-switcher.is-open .copp-palette-switcher__panel {
    opacity: 1;
    visibility: visible;
    transform: translateY(-50%) translateX(0);
}

.copp-palette-switcher__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.copp-palette-switcher__title {
    font-size: 15px;
    font-weight: 700;
    color: #ffffff;
    letter-spacing: 0.02em;
}

.copp-palette-switcher__close {
    background: none;
    border: none;
    color: rgba(255, 255, 255, 0.4);
    font-size: 22px;
    cursor: pointer;
    line-height: 1;
    padding: 0 2px;
    transition: color 0.2s;
}

.copp-palette-switcher__close:hover {
    color: #ffffff;
}

.copp-palette-switcher__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 6px;
    padding: 12px;
}

.copp-palette-btn {
    display: flex;
    align-items: center;
    gap: 10px;
    border: 2px solid transparent;
    background: rgba(255, 255, 255, 0.04);
    cursor: pointer;
    padding: 8px 10px;
    border-radius: 0;
    transition: border-color 0.2s, background 0.2s;
    text-align: left;
}

.copp-palette-btn:hover {
    border-color: rgba(255, 255, 255, 0.2);
    background: rgba(255, 255, 255, 0.08);
}

.copp-palette-btn.is-active {
    border-color: var(--copp-red);
    background: rgba(var(--copp-red-rgb), 0.1);
}

.copp-palette-btn__swatch {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2px;
    width: 36px;
    height: 36px;
    flex-shrink: 0;
}

.copp-palette-btn__dot {
    width: 100%;
    height: 100%;
    border-radius: 0;
}

.copp-palette-btn__name {
    font-size: 13px;
    color: rgba(255, 255, 255, 0.6);
    line-height: 1.2;
    transition: color 0.2s;
    white-space: nowrap;
}

.copp-palette-btn:hover .copp-palette-btn__name {
    color: rgba(255, 255, 255, 0.85);
}

.copp-palette-btn.is-active .copp-palette-btn__name {
    color: var(--copp-red);
    font-weight: 600;
}

@media (max-width: 991.98px) {
    .copp-palette-switcher {
        right: 0;
        top: auto;
        bottom: 76px;
        transform: none;
    }

    .copp-palette-switcher__toggle {
        padding: 10px 8px;
        gap: 4px;
    }

    .copp-palette-switcher__icon {
        width: 16px;
        height: 16px;
    }

    .copp-palette-switcher__label {
        font-size: 11px;
    }

    .copp-palette-switcher__panel {
        right: calc(100% + 8px);
        top: auto;
        bottom: 0;
        transform: translateX(8px);
        min-width: 260px;
    }

    .copp-palette-switcher.is-open .copp-palette-switcher__panel {
        transform: translateX(0);
    }

    .copp-palette-btn__swatch {
        width: 30px;
        height: 30px;
    }

    .copp-palette-btn__name {
        font-size: 12px;
    }
}

/* ========== DIMENSIONAL RIFT PALETTE SWITCHER ========== */
.copp-rift {
    position: fixed;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    z-index: 9999;
    display: flex;
    align-items: center;
}

.copp-rift__seam {
    position: relative;
    width: 4px;
    height: 100px;
    background: var(--copp-red);
    cursor: pointer;
    box-shadow: 0 0 8px rgba(var(--copp-red-rgb), 0.6), 0 0 20px rgba(var(--copp-red-rgb), 0.3);
    transition: box-shadow 300ms ease;
    z-index: 2;
}

.copp-rift__seam::after {
    content: "";
    position: absolute;
    top: -14px;
    left: -28px;
    right: 0;
    bottom: -14px;
}

.copp-rift__seam::before {
    content: "";
    position: absolute;
    top: -20px;
    left: -30px;
    right: -30px;
    bottom: -20px;
    background: rgba(var(--copp-red-rgb), 0.15);
    filter: blur(12px);
    pointer-events: none;
}

.copp-rift:hover .copp-rift__seam {
    box-shadow: 0 0 12px rgba(var(--copp-red-rgb), 0.8), 0 0 30px rgba(var(--copp-red-rgb), 0.4);
}

@keyframes copp-rift-pulse {
    0%, 100% { opacity: 0.7; }
    50% { opacity: 1; }
}

.copp-rift__seam {
    animation: copp-rift-pulse 2s ease-in-out infinite;
}

.copp-rift__shards {
    position: absolute;
    right: 4px;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    gap: 2px;
    z-index: 1;
}

.copp-rift__shard {
    width: 14px;
    height: 22px;
    transition: transform 400ms cubic-bezier(0.34, 1.56, 0.64, 1), opacity 300ms;
}

.copp-rift.is-open .copp-rift__shard {
    opacity: 0;
    transform: translateX(20px) rotate(15deg);
}

.copp-rift__panel {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%) rotateY(-95deg);
    transform-origin: right center;
    perspective: 900px;
    background: var(--copp-ink);
    border: 1px solid rgba(var(--copp-red-rgb), 0.2);
    box-shadow: -4px 0 20px rgba(0, 0, 0, 0.3);
    padding: 16px;
    min-width: 220px;
    z-index: 3;
    opacity: 0;
    pointer-events: none;
    transition: transform 500ms cubic-bezier(0.34, 1.56, 0.64, 1), opacity 300ms;
}

.copp-rift.is-open .copp-rift__panel {
    transform: translateY(-50%) rotateY(0deg);
    opacity: 1;
    pointer-events: auto;
}

.copp-rift__panel-head {
    color: #ffffff;
    font-size: 14px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 12px;
    padding-bottom: 8px;
    border-bottom: 2px solid var(--copp-red);
}

.copp-rift__nodes {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.copp-rift__node {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 6px 8px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid transparent;
    cursor: pointer;
    transition: background 200ms, border-color 200ms, transform 200ms;
}

.copp-rift__node:hover {
    background: rgba(255, 255, 255, 0.1);
    transform: translateX(-4px);
}

.copp-rift__node.is-active {
    border-color: var(--copp-red);
    background: rgba(var(--copp-red-rgb), 0.15);
}

.copp-rift__node-dots {
    display: flex;
    gap: 3px;
    flex-shrink: 0;
}

.copp-rift__node-dot {
    width: 10px;
    height: 10px;
}

.copp-rift__node-label {
    color: rgba(255, 255, 255, 0.8);
    font-size: 13px;
    font-weight: 700;
}

.copp-rift__node.is-active .copp-rift__node-label {
    color: #ffffff;
}

/* ========== ONBOARDING TOOLTIPS ========== */
.copp-ob {
    position: fixed;
    inset: 0;
    z-index: 99999;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.3s;
}

.copp-ob.is-active {
    opacity: 1;
    pointer-events: auto;
}

.copp-ob__overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.65);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    z-index: 0;
    clip-path: none;
    transition: clip-path 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}

.copp-ob__border {
    position: fixed;
    border: 3px solid var(--copp-red);
    z-index: 2;
    pointer-events: none;
    transition: top 0.45s cubic-bezier(0.22, 1, 0.36, 1), left 0.45s cubic-bezier(0.22, 1, 0.36, 1), width 0.45s cubic-bezier(0.22, 1, 0.36, 1), height 0.45s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.3s;
}

.copp-ob__border-glow {
    position: absolute;
    inset: -6px;
    border: 2px solid rgba(var(--copp-red-rgb), 0.3);
    animation: copp-ob-glow 1.5s ease-in-out infinite;
}

@keyframes copp-ob-glow {
    0%, 100% { opacity: 0.4; }
    50% { opacity: 1; }
}

.copp-ob__arrow {
    position: fixed;
    z-index: 3;
    width: 0;
    height: 0;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.3s;
}

.copp-ob__arrow--up {
    border-left: 8px solid transparent;
    border-right: 8px solid transparent;
    border-bottom: 10px solid var(--copp-red);
}

.copp-ob__arrow--down {
    border-left: 8px solid transparent;
    border-right: 8px solid transparent;
    border-top: 10px solid var(--copp-red);
}

.copp-ob__arrow--left {
    border-top: 8px solid transparent;
    border-bottom: 8px solid transparent;
    border-right: 10px solid var(--copp-red);
}

.copp-ob__arrow--right {
    border-top: 8px solid transparent;
    border-bottom: 8px solid transparent;
    border-left: 10px solid var(--copp-red);
}

.copp-ob__tip {
    position: fixed;
    z-index: 4;
    max-width: 320px;
    min-width: 240px;
    background: #ffffff;
    padding: 20px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
    transition: top 0.45s cubic-bezier(0.22, 1, 0.36, 1), left 0.45s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.3s;
}

.copp-ob__tip--center {
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%);
}

.copp-ob__tip-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background: rgba(var(--copp-red-rgb), 0.1);
    color: var(--copp-red);
    font-size: 18px;
    margin-bottom: 10px;
}

.copp-ob__tip-body {
    margin-bottom: 14px;
}

.copp-ob__tip-title {
    font-size: 18px;
    font-weight: 800;
    margin: 0 0 6px;
    color: var(--copp-ink);
}

.copp-ob__tip-text {
    font-size: 14px;
    line-height: 1.55;
    margin: 0;
    color: rgba(var(--copp-ink-rgb), 0.72);
}

.copp-ob__tip-footer {
    display: flex;
    align-items: center;
    gap: 12px;
}

.copp-ob__tip-dots {
    display: flex;
    gap: 6px;
    flex: 1;
}

.copp-ob__dot {
    width: 8px;
    height: 8px;
    background: rgba(var(--copp-ink-rgb), 0.15);
    transition: background 200ms, transform 200ms;
}

.copp-ob__dot.is-current {
    background: var(--copp-red);
    transform: scale(1.3);
}

.copp-ob__dot.is-done {
    background: var(--copp-ink);
}

.copp-ob__tip-skip {
    background: none;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.15);
    padding: 6px 14px;
    font-size: 13px;
    color: rgba(var(--copp-ink-rgb), 0.55);
    cursor: pointer;
    transition: border-color 200ms, color 200ms;
}

.copp-ob__tip-skip:hover {
    border-color: var(--copp-red);
    color: var(--copp-red);
}

.copp-ob__tip-next {
    background: var(--copp-red);
    border: none;
    color: #ffffff;
    padding: 8px 18px;
    font-size: 13px;
    font-weight: 800;
    cursor: pointer;
    transition: background 200ms;
}

.copp-ob__tip-next:hover {
    background: var(--copp-red-dark, #b51219);
}

/* --- Rift mobile --- */
@media (max-width: 767.98px) {
    .copp-rift__seam {
        height: 60px;
    }

    .copp-rift__panel {
        min-width: 180px;
        padding: 12px;
    }

    .copp-rift__node-dot {
        width: 8px;
        height: 8px;
    }

    .copp-rift__node-label {
        font-size: 12px;
    }
}

/* --- Onboarding mobile --- */
@media (max-width: 767.98px) {
    .copp-ob__overlay {
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
    }

    .copp-ob__border {
        display: none;
    }

    .copp-ob__arrow {
        display: none;
    }

    .copp-ob__tip {
        position: fixed;
        top: auto !important;
        bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        max-width: 100%;
        min-width: 0;
        border-top: 3px solid var(--copp-red);
        box-shadow: none;
        transform: translateY(100%);
        padding: 16px;
    }

    .copp-ob.is-active .copp-ob__tip {
        transform: translateY(0);
    }

    .copp-ob__tip--center {
        top: auto !important;
        bottom: 0 !important;
        left: 0 !important;
        transform: translateY(0) !important;
    }

    .copp-ob__tip-icon {
        width: 32px;
        height: 32px;
        font-size: 14px;
        margin-bottom: 8px;
    }

    .copp-ob__tip-title {
        font-size: 16px;
    }

    .copp-ob__tip-text {
        font-size: 13px;
    }
}

.copp-partners-card__placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    min-height: 140px;
    background: rgba(var(--copp-accent-rgb, 0,120,120), 0.08);
    color: rgba(var(--copp-accent-rgb, 0,120,120), 0.4);
    font-size: 48px;
}

.copp-partners-card__placeholder--big {
    min-height: 260px;
    font-size: 80px;
}

.copp-partners-card__featured {
    background: rgba(var(--copp-accent-rgb, 0,120,120), 0.15);
    color: rgb(var(--copp-accent-rgb, 0,120,120));
}

.copp-partners-card__url {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: rgba(0,0,0,0.5);
    font-size: 13px;
}

.copp-partners-card__media img {
    display: block;
    width: 100%;
    height: 140px;
    object-fit: cover;
    object-position: center;
}

.copp-partner-article__logo {
    max-width: 100%;
    max-height: 320px;
    object-fit: contain;
}

.copp-partner-page {
    display: grid;
    gap: 32px;
}

.copp-partner-page__header {
    align-items: center;
    background: var(--copp-soft);
    display: flex;
    gap: 24px;
    margin: 0 -15px;
    padding: 32px 24px;
}

.copp-partner-page__header-logo {
    align-items: center;
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.06);
    box-shadow: 0 4px 20px rgba(0,0,0,0.06);
    display: flex;
    flex: 0 0 140px;
    height: 140px;
    justify-content: center;
    overflow: hidden;
    padding: 20px;
}

.copp-partner-page__header-logo img {
    max-height: 100%;
    max-width: 100%;
    object-fit: contain;
}

.copp-partner-page__header-icon {
    align-items: center;
    background: rgba(var(--copp-red-rgb), 0.08);
    color: var(--copp-red);
    display: flex;
    flex: 0 0 140px;
    font-size: 48px;
    height: 140px;
    justify-content: center;
}

.copp-partner-page__header-icon svg {
    height: 48px;
    width: 48px;
}

.copp-partner-page__header-info {
    display: grid;
    gap: 10px;
    min-width: 0;
}

.copp-partner-page__header-info h1 {
    color: var(--copp-ink);
    font-size: clamp(24px, 3vw, 40px);
    font-weight: 900;
    line-height: 1.1;
    margin: 0;
}

.copp-partner-page__header-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.copp-partner-page__badge {
    align-items: center;
    background: var(--copp-red);
    border-radius: 999px;
    color: #ffffff;
    display: inline-flex;
    font-size: 13px;
    font-weight: 800;
    gap: 6px;
    line-height: 1;
    padding: 7px 14px;
    white-space: nowrap;
}

.copp-partner-page__badge svg {
    height: 12px;
    width: 12px;
}

.copp-partner-page__badge--link {
    background: #ffffff;
    color: var(--copp-red);
    text-decoration: none;
    border: 2px solid var(--copp-red);
}

.copp-partner-page__badge--link:hover {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-partner-page__body {
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.06);
    box-shadow: 0 2px 12px rgba(0,0,0,0.04);
    color: var(--copp-ink);
    font-size: 18px;
    line-height: 1.78;
    padding: 48px 56px;
}

.copp-partner-page__body p {
    margin: 0 0 20px;
}

.copp-partner-page__body h2 {
    font-size: 28px;
    font-weight: 900;
    line-height: 1.2;
    margin: 40px 0 16px;
}

.copp-partner-page__body h3 {
    font-size: 22px;
    font-weight: 800;
    line-height: 1.3;
    margin: 32px 0 12px;
}

.copp-partner-page__body ul,
.copp-partner-page__body ol {
    margin: 0 0 20px;
    padding-left: 24px;
}

.copp-partner-page__body li {
    margin-bottom: 6px;
}

.copp-partner-page__body a {
    color: var(--copp-red);
    text-decoration: underline;
    text-underline-offset: 3px;
}

.copp-partner-page__body a:hover {
    color: var(--copp-ink);
}

.copp-partner-page__body img {
    max-width: 100%;
    height: auto;
}

.copp-partner-page__body blockquote {
    border-left: 4px solid var(--copp-red);
    font-style: italic;
    margin: 24px 0;
    padding: 16px 24px;
    color: var(--copp-muted);
}

.copp-partner-page__body table {
    border-collapse: collapse;
    margin: 20px 0;
    width: 100%;
}

.copp-partner-page__body th,
.copp-partner-page__body td {
    border: 1px solid rgba(var(--copp-ink-rgb), 0.12);
    padding: 10px 14px;
    text-align: left;
}

.copp-partner-page__body th {
    background: var(--copp-soft);
    font-weight: 800;
}

.copp-partner-page__footer {
    align-items: center;
    border-top: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    padding-top: 24px;
}

@media (max-width: 991px) {
    .copp-partner-page__header {
        flex-direction: column;
        text-align: center;
        padding: 32px 24px;
    }

    .copp-partner-page__header-info {
        justify-items: center;
    }

    .copp-partner-page__header-badges {
        justify-content: center;
    }

    .copp-partner-page__body {
        padding: 32px 28px;
    }
}

@media (max-width: 575px) {
    .copp-partner-page__header {
        padding: 24px 16px;
    }

    .copp-partner-page__header-logo,
    .copp-partner-page__header-icon {
        flex: 0 0 100px;
        height: 100px;
        width: 100px;
    }

    .copp-partner-page__header-logo {
        padding: 14px;
    }

    .copp-partner-page__header-icon svg {
        height: 36px;
        width: 36px;
    }

    .copp-partner-page__header-info h1 {
        font-size: 22px;
    }

    .copp-partner-page__body {
        padding: 24px 20px;
        font-size: 16px;
    }
}

.copp-partners-card__url svg {
    width: 12px;
    height: 12px;
}

/* ===== Accessibility (Visually Impaired Mode) ===== */

.copp-a11y-btn {
    position: fixed;
    right: 16px;
    top: 16px;
    z-index: 9990;
    width: 48px;
    height: 48px;
    border: 2px solid var(--copp-line);
    background: var(--copp-soft);
    color: var(--copp-ink);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 8px rgba(0,0,0,0.12);
    transition: background 0.2s, color 0.2s;
}

.copp-a11y-btn:hover {
    background: var(--copp-ink);
    color: var(--copp-soft);
}

.copp-a11y-btn svg {
    width: 24px;
    height: 24px;
}

.copp-a11y-panel {
    position: fixed;
    right: 16px;
    top: 76px;
    z-index: 9991;
    width: 320px;
    max-height: calc(100vh - 100px);
    overflow-y: auto;
    background: var(--copp-soft);
    border: 2px solid var(--copp-ink);
    box-shadow: 0 4px 24px rgba(0,0,0,0.15);
    display: none;
    flex-direction: column;
    color: var(--copp-ink);
    font-size: 14px;
    line-height: 1.4;
}

.copp-a11y-panel.is-open {
    display: flex;
}

.copp-a11y-panel__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    font-weight: 700;
    font-size: 15px;
    border-bottom: 2px solid var(--copp-line);
}

.copp-a11y-panel__close {
    background: none;
    border: none;
    font-size: 22px;
    cursor: pointer;
    color: var(--copp-ink);
    padding: 0 4px;
}

.copp-a11y-panel__group {
    padding: 10px 16px;
    border-bottom: 1px solid var(--copp-line);
}

.copp-a11y-panel__label {
    display: block;
    font-weight: 600;
    margin-bottom: 6px;
    font-size: 13px;
}

.copp-a11y-panel__controls {
    display: flex;
    align-items: center;
    gap: 8px;
}

.copp-a11y-panel__btn {
    padding: 4px 12px;
    border: 2px solid var(--copp-ink);
    background: var(--copp-soft);
    color: var(--copp-ink);
    font-weight: 700;
    cursor: pointer;
    font-size: 14px;
    transition: background 0.15s, color 0.15s;
}

.copp-a11y-panel__btn:hover {
    background: var(--copp-ink);
    color: var(--copp-soft);
}

.copp-a11y-panel__btn--scheme.is-active {
    background: var(--copp-ink);
    color: var(--copp-soft);
}

.copp-a11y-panel__btn--reset {
    font-size: 12px;
    padding: 4px 10px;
}

.copp-a11y-panel__btn--off {
    font-size: 12px;
    padding: 4px 10px;
    background: var(--copp-ink);
    color: var(--copp-soft);
}

.copp-a11y-panel__value {
    min-width: 36px;
    text-align: center;
    font-weight: 700;
    font-size: 15px;
}

.copp-a11y-panel__schemes {
    gap: 6px;
}

.copp-a11y-panel__footer {
    display: flex;
    gap: 8px;
    padding: 12px 16px;
    border-top: 2px solid var(--copp-line);
}

/* ===== A11Y Override: BW (black on white, high contrast) ===== */

[data-a11y="on"][data-a11y-scheme="bw"] {
    --copp-red: #000000;
    --copp-red-rgb: 0, 0, 0;
    --copp-red-dark: #000000;
    --copp-red-deep: #000000;
    --copp-pale: #f0f0f0;
    --copp-pale-rgb: 240, 240, 240;
    --copp-soft: #ffffff;
    --copp-soft-rgb: 255, 255, 255;
    --copp-ink: #000000;
    --copp-ink-rgb: 0, 0, 0;
    --copp-ink-soft: #000000;
    --copp-ink-soft-rgb: 0, 0, 0;
    --copp-dark: #000000;
    --copp-dark-rgb: 0, 0, 0;
    --copp-muted: #333333;
    --copp-muted-rgb: 51, 51, 51;
    --copp-line: #000000;
    --copp-line-rgb: 0, 0, 0;
    --copp-accent-rgb: 0, 0, 0;
}

[data-a11y="on"][data-a11y-scheme="bw"] .copp-a11y-panel {
    background: #fff;
    color: #000;
    border-color: #000;
}

[data-a11y="on"][data-a11y-scheme="bw"] .copp-a11y-panel__btn {
    background: #fff;
    color: #000;
    border-color: #000;
}

[data-a11y="on"][data-a11y-scheme="bw"] .copp-a11y-panel__btn--scheme.is-active,
[data-a11y="on"][data-a11y-scheme="bw"] .copp-a11y-panel__btn--off {
    background: #000;
    color: #fff;
}

/* ===== A11Y Override: WB (white on black) ===== */

[data-a11y="on"][data-a11y-scheme="wb"] {
    --copp-red: #ffffff;
    --copp-red-rgb: 255, 255, 255;
    --copp-red-dark: #ffffff;
    --copp-red-deep: #ffffff;
    --copp-pale: #1a1a1a;
    --copp-pale-rgb: 26, 26, 26;
    --copp-soft: #111111;
    --copp-soft-rgb: 17, 17, 17;
    --copp-ink: #ffffff;
    --copp-ink-rgb: 255, 255, 255;
    --copp-ink-soft: #ffffff;
    --copp-ink-soft-rgb: 255, 255, 255;
    --copp-dark: #000000;
    --copp-dark-rgb: 0, 0, 0;
    --copp-muted: #cccccc;
    --copp-muted-rgb: 204, 204, 204;
    --copp-line: #ffffff;
    --copp-line-rgb: 255, 255, 255;
    --copp-accent-rgb: 255, 255, 255;
}

[data-a11y="on"][data-a11y-scheme="wb"] .copp-a11y-panel {
    background: #1a1a1a;
    color: #fff;
    border-color: #fff;
}

[data-a11y="on"][data-a11y-scheme="wb"] .copp-a11y-panel__btn {
    background: #1a1a1a;
    color: #fff;
    border-color: #fff;
}

[data-a11y="on"][data-a11y-scheme="wb"] .copp-a11y-panel__btn--scheme.is-active,
[data-a11y="on"][data-a11y-scheme="wb"] .copp-a11y-panel__btn--off {
    background: #fff;
    color: #000;
}

/* ===== A11Y Override: YB (yellow on black) ===== */

[data-a11y="on"][data-a11y-scheme="yb"] {
    --copp-red: #ffdd00;
    --copp-red-rgb: 255, 221, 0;
    --copp-red-dark: #ffdd00;
    --copp-red-deep: #ffdd00;
    --copp-pale: #1a1a00;
    --copp-pale-rgb: 26, 26, 0;
    --copp-soft: #111100;
    --copp-soft-rgb: 17, 17, 0;
    --copp-ink: #ffdd00;
    --copp-ink-rgb: 255, 221, 0;
    --copp-ink-soft: #ffdd00;
    --copp-ink-soft-rgb: 255, 221, 0;
    --copp-dark: #000000;
    --copp-dark-rgb: 0, 0, 0;
    --copp-muted: #ccaa00;
    --copp-muted-rgb: 204, 170, 0;
    --copp-line: #ffdd00;
    --copp-line-rgb: 255, 221, 0;
    --copp-accent-rgb: 255, 221, 0;
}

[data-a11y="on"][data-a11y-scheme="yb"] .copp-a11y-panel {
    background: #1a1a00;
    color: #ffdd00;
    border-color: #ffdd00;
}

[data-a11y="on"][data-a11y-scheme="yb"] .copp-a11y-panel__btn {
    background: #1a1a00;
    color: #ffdd00;
    border-color: #ffdd00;
}

[data-a11y="on"][data-a11y-scheme="yb"] .copp-a11y-panel__btn--scheme.is-active,
[data-a11y="on"][data-a11y-scheme="yb"] .copp-a11y-panel__btn--off {
    background: #ffdd00;
    color: #000;
}

/* ===== A11Y global readability rules ===== */

[data-a11y="on"] a {
    text-decoration: underline !important;
    text-underline-offset: 3px;
}

[data-a11y="on"] img {
    outline: 2px solid var(--copp-ink);
    outline-offset: 1px;
}

[data-a11y="on"] button,
[data-a11y="on"] input,
[data-a11y="on"] select,
[data-a11y="on"] textarea {
    border: 2px solid var(--copp-ink) !important;
}

[data-a11y="on"] .copp-a11y-btn {
    border-color: var(--copp-ink);
    background: var(--copp-ink);
    color: var(--copp-soft);
}

[data-a11y="on"] .copp-rift {
    display: none;
}

[data-a11y="on"] .copp-mobile-nav {
    border-top: 3px solid var(--copp-ink);
}

[data-a11y="on"] .copp-footer-legal__age-badge {
    border-width: 3px;
}

[data-a11y="on"] .copp-program-tile__badge,
[data-a11y="on"] .copp-projects-card__level,
[data-a11y="on"] .copp-projects-card__badge,
[data-a11y="on"] .copp-events-card__chip {
    border: 2px solid var(--copp-ink);
}

@media (max-width: 767px) {
    .copp-a11y-btn {
        right: 8px;
        top: 8px;
        width: 40px;
        height: 40px;
    }

    .copp-a11y-btn svg {
        width: 20px;
        height: 20px;
    }

    .copp-a11y-panel {
        left: 8px;
        right: 8px;
        width: auto;
        top: 56px;
    }
}

.copp-resources-archive {
    max-width: var(--copp-container-lg);
    margin: 0 auto;
    padding: 0 24px;
}

.copp-resources-archive__hero {
    padding: 48px 0 40px;
}

.copp-resources-archive__hero h1 {
    font-family: var(--copp-font-heading);
    font-size: 48px;
    font-weight: var(--copp-fw-heading-bold);
    text-transform: uppercase;
    line-height: var(--copp-lh-section);
    color: var(--copp-ink);
    margin: 0 0 14px;
    letter-spacing: var(--copp-ls-section);
}

.copp-resources-archive__hero h1 span {
    color: var(--copp-red);
}

.copp-resources-archive__hero p {
    font-size: 17px;
    line-height: var(--copp-lh-body);
    color: var(--copp-muted);
    max-width: 720px;
    margin: 0 0 18px;
}

.copp-resources-archive__meta {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.copp-resources-archive__meta span {
    background: rgba(var(--copp-ink-rgb), 0.05);
    font-size: var(--copp-fs-label);
    font-weight: var(--copp-fw-eyebrow);
    padding: 10px 14px;
    text-transform: uppercase;
    letter-spacing: var(--copp-ls-label);
    color: var(--copp-ink);
}

.copp-resources-archive__filters {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    padding-bottom: 24px;
    border-bottom: 1px solid rgba(var(--copp-ink-rgb), 0.06);
    margin-bottom: 24px;
}

.copp-resource-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 18px;
    background: var(--copp-soft);
    font-size: 14px;
    font-weight: var(--copp-fw-bold);
    color: var(--copp-ink);
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: var(--copp-ls-label);
    transition: background 0.18s ease, color 0.18s ease;
}

.copp-resource-chip:hover,
.copp-resource-chip:focus {
    background: rgba(var(--copp-red-rgb), 0.08);
    color: var(--copp-red);
}

.copp-resource-chip.is-active {
    background: var(--copp-red);
    color: #ffffff;
}

.copp-resource-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
}

@media (max-width: 1199px) {
    .copp-resource-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .copp-resource-grid {
        grid-template-columns: 1fr;
    }
    .copp-resources-archive__hero h1 {
        font-size: 32px;
    }
    .copp-resource-chip {
        padding: 10px 14px;
        font-size: 12px;
    }
}

.copp-resource-tile {
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    border-radius: 0;
    display: flex;
    flex-direction: column;
    position: relative;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.copp-resource-tile:hover {
    box-shadow: 0 18px 38px rgba(var(--copp-ink-rgb), 0.1);
    transform: translateY(-2px);
}

.copp-resource-tile__body {
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 14px;
    flex: 1;
}

.copp-resource-tile__state {
    display: flex;
    gap: 8px;
}

.copp-resource-tile__state span {
    font-size: var(--copp-fs-badge);
    font-weight: var(--copp-fw-bold);
    padding: 4px 10px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.copp-resource-tile__state .is-open {
    background: rgba(24, 160, 88, 0.12);
    color: #17824b;
}

.copp-resource-tile__state .is-attention {
    background: rgba(var(--copp-red-rgb), 0.1);
    color: var(--copp-red);
}

.copp-resource-tile__state .is-closed {
    background: rgba(var(--copp-ink-rgb), 0.06);
    color: var(--copp-muted);
}

.copp-resource-tile__body h2 {
    font-family: var(--copp-font-heading);
    font-size: var(--copp-fs-card-title);
    font-weight: var(--copp-fw-bold);
    line-height: var(--copp-lh-card-title);
    margin: 0;
}

.copp-resource-tile__body h2 a {
    color: var(--copp-ink);
    text-decoration: none;
    transition: color 0.15s ease;
}

.copp-resource-tile__body h2 a:hover {
    color: var(--copp-red);
}

.copp-resource-tile__body > p {
    font-size: var(--copp-fs-body-sm);
    line-height: var(--copp-lh-body);
    color: var(--copp-muted);
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.copp-resource-tile__facts {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
    margin: 0;
}

.copp-resource-tile__facts div {
    background: var(--copp-soft);
    padding: 10px 12px;
}

.copp-resource-tile__facts dt {
    font-size: var(--copp-fs-eyebrow);
    font-weight: var(--copp-fw-eyebrow);
    color: var(--copp-muted);
    text-transform: uppercase;
    letter-spacing: var(--copp-ls-eyebrow);
    display: block;
    margin-bottom: 2px;
}

.copp-resource-tile__facts dd {
    font-size: var(--copp-fs-body-sm);
    font-weight: var(--copp-fw-bold);
    color: var(--copp-ink);
    margin: 0;
}

.copp-resource-tile__chips {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}

.copp-resource-tile__chip {
    background: rgba(var(--copp-red-rgb), 0.06);
    color: var(--copp-red-dark);
    font-size: var(--copp-fs-badge);
    font-weight: var(--copp-fw-bold);
    padding: 4px 10px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.copp-resource-tile__link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-size: var(--copp-fs-body-sm);
    font-weight: var(--copp-fw-bold);
    color: var(--copp-red);
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-top: auto;
    transition: color 0.15s ease, gap 0.15s ease;
}

.copp-resource-tile__link:hover {
    color: var(--copp-red-dark);
    gap: 14px;
}

.copp-resources-empty {
    padding: 64px 24px;
    text-align: center;
}

.copp-resources-empty h3 {
    font-family: var(--copp-font-heading);
    font-size: 20px;
    font-weight: var(--copp-fw-bold);
    color: var(--copp-ink);
    text-transform: uppercase;
}

.copp-resources-empty p {
    color: var(--copp-muted);
    font-size: var(--copp-fs-body-sm);
}

.copp-resource-article {
    max-width: var(--copp-container-lg);
    margin: 0 auto;
    padding: 0 24px;
}

.copp-resource-article__hero {
    background: linear-gradient(135deg, #ffffff 0%, var(--copp-soft) 100%);
    padding: 48px 0 40px;
    margin-bottom: 40px;
}

.copp-resource-article__copy {
    max-width: 760px;
}

.copp-resource-article__copy h1 {
    font-family: var(--copp-font-heading);
    font-size: 46px;
    font-weight: var(--copp-fw-heading-bold);
    text-transform: uppercase;
    line-height: 1;
    color: var(--copp-ink);
    margin: 0 0 14px;
    letter-spacing: var(--copp-ls-section);
}

.copp-resource-article__lead {
    font-size: 18px;
    line-height: var(--copp-lh-body);
    color: #585858;
    max-width: 760px;
    margin: 0 0 18px;
}

.copp-resource-article__meta {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.copp-resource-article__meta span {
    background: #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    font-size: var(--copp-fs-label);
    font-weight: var(--copp-fw-eyebrow);
    padding: 8px 14px;
    text-transform: uppercase;
    letter-spacing: var(--copp-ls-label);
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.copp-resource-article__meta .is-open {
    background: rgba(24, 160, 88, 0.12);
    color: #17824b;
    border-color: transparent;
}

.copp-resource-article__meta .is-attention {
    background: rgba(var(--copp-red-rgb), 0.1);
    color: var(--copp-red);
    border-color: transparent;
}

.copp-resource-article__meta .is-closed {
    background: rgba(var(--copp-ink-rgb), 0.06);
    color: var(--copp-muted);
    border-color: transparent;
}

.copp-resource-article__meta i {
    font-size: 12px;
    color: var(--copp-muted);
}

.copp-resource-article__layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 320px);
    gap: 32px;
    align-items: start;
}

.copp-resource-article__section {
    margin-bottom: 32px;
}

.copp-resource-article__section h2 {
    font-family: var(--copp-font-heading);
    font-size: var(--copp-fs-section);
    font-weight: var(--copp-fw-heading);
    text-transform: uppercase;
    line-height: var(--copp-lh-section);
    color: var(--copp-ink);
    margin: 0 0 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid rgba(var(--copp-ink-rgb), 0.08);
}

.copp-resource-article__section p {
    font-size: var(--copp-fs-body);
    line-height: var(--copp-lh-body);
    color: var(--copp-ink);
}

.copp-resource-article__chips {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.copp-resource-article__chip {
    background: rgba(var(--copp-red-rgb), 0.06);
    color: var(--copp-red-dark);
    font-size: var(--copp-fs-badge);
    font-weight: var(--copp-fw-bold);
    padding: 8px 14px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.copp-resource-article__body-text {
    line-height: var(--copp-lh-body);
    color: var(--copp-ink);
}

.copp-resource-article__footer {
    margin-top: 32px;
    padding-top: 24px;
    border-top: 1px solid rgba(var(--copp-ink-rgb), 0.08);
}

.copp-resource-article__aside {
    background: var(--copp-ink);
    border-radius: 0;
    color: #ffffff;
    display: grid;
    gap: 14px;
    padding: 22px;
    position: sticky;
    top: 100px;
}

.copp-resource-article__fact {
    background: rgba(255, 255, 255, 0.06);
    padding: 14px 16px;
}

.copp-resource-article__fact--links strong {
    font-size: var(--copp-fs-body-sm);
    font-weight: var(--copp-fw-medium);
    line-height: var(--copp-lh-body);
}

.copp-resource-article__fact span {
    color: rgba(255, 255, 255, 0.66);
    font-size: var(--copp-fs-eyebrow);
    font-weight: var(--copp-fw-eyebrow);
    text-transform: uppercase;
    letter-spacing: var(--copp-ls-eyebrow);
    display: block;
    margin-bottom: 4px;
}

.copp-resource-article__fact strong {
    color: #ffffff;
    font-size: 18px;
    font-weight: var(--copp-fw-black);
    display: block;
}

.copp-resource-article__aside-btn {
    width: 100%;
    justify-content: center;
}

@media (max-width: 767px) {
    .copp-resource-article__layout {
        grid-template-columns: 1fr;
    }

    .copp-resource-article__copy h1 {
        font-size: 32px;
    }

    .copp-resource-article__aside {
        position: static;
    }

    .copp-resource-tile__facts {
        grid-template-columns: 1fr 1fr;
    }
}

.copp-partners-hero__actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.copp-employer-content {
    overflow: hidden;
}

.copp-employer-intro {
    font-size: 16px;
    line-height: var(--copp-lh-body);
    color: rgba(var(--copp-ink-rgb), 0.74);
    max-width: 680px;
    margin: 0 0 32px;
}

.copp-employer-success {
    background: var(--copp-soft);
    padding: 64px 32px;
    text-align: center;
}
.copp-employer-success__icon {
    font-size: 48px;
    color: var(--copp-red);
    margin-bottom: 16px;
}
.copp-employer-success h2 {
    font-family: var(--copp-font-heading);
    font-size: var(--copp-fs-section);
    font-weight: var(--copp-fw-heading-bold);
    text-transform: uppercase;
    color: var(--copp-ink);
    margin: 0 0 12px;
}
.copp-employer-success p {
    color: var(--copp-muted);
    max-width: 560px;
    margin: 0 auto 24px;
}

.copp-employer-actions-section {
    background: var(--copp-soft);
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    width: 100vw;
    overflow: hidden;
    padding: 48px 0;
}
.copp-employer-actions-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
    max-width: var(--copp-container-content);
    width: calc(100% - 30px);
    margin: 0 auto;
}
.copp-employer-action-card {
    background:
        linear-gradient(145deg, rgba(var(--copp-red-rgb), 0.08) 0, rgba(var(--copp-red-rgb), 0) 52%),
        #ffffff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    border-radius: 0;
    box-shadow: 0 18px 42px rgba(var(--copp-ink-rgb), 0.08);
    padding: 22px;
    display: flex;
    flex-direction: column;
    gap: 14px;
    min-height: 100%;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}
.copp-employer-action-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 24px 48px rgba(var(--copp-ink-rgb), 0.12);
    border-color: rgba(var(--copp-red-rgb), 0.28);
}
.copp-employer-action-card__body {
    flex: 1;
    min-width: 0;
}
.copp-employer-action-card__body h3 {
    color: var(--copp-ink);
    font-size: 22px;
    font-weight: 900;
    line-height: 1.16;
    margin: 0 0 6px;
}
.copp-employer-action-card__body p {
    color: rgba(var(--copp-ink-rgb), 0.74);
    line-height: 1.6;
    margin: 0;
}
.copp-employer-action-card__btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: none;
    border: 1px solid var(--copp-red);
    padding: 10px 20px;
    font-family: var(--copp-font-heading);
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--copp-red);
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
    white-space: nowrap;
    flex-shrink: 0;
    align-self: flex-start;
}
.copp-employer-action-card__btn:hover {
    background: var(--copp-red);
    color: #fff;
}
.copp-employer-action-card__btn svg {
    width: 12px;
    height: 12px;
}

.copp-employer-forms {
    background: var(--copp-soft);
    padding: 0;
}
.copp-employer-form {
    background: #ffffff;
    padding: 36px 22px;
    max-width: 720px;
    margin: 32px auto;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.06);
    box-shadow: 0 18px 42px rgba(var(--copp-ink-rgb), 0.08);
}
.copp-employer-form__head h2 {
    font-family: var(--copp-font-heading);
    font-size: var(--copp-fs-section);
    font-weight: var(--copp-fw-heading-bold);
    text-transform: uppercase;
    color: var(--copp-ink);
    margin: 0 0 8px;
}
.copp-employer-form__head p {
    color: var(--copp-muted);
    margin: 0 0 24px;
    font-size: var(--copp-fs-body-sm);
}
.copp-employer-form__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}
.copp-employer-form__grid label {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.copp-employer-form__grid label span {
    font-size: var(--copp-fs-eyebrow);
    font-weight: var(--copp-fw-eyebrow);
    text-transform: uppercase;
    letter-spacing: var(--copp-ls-eyebrow);
    color: var(--copp-ink);
}
.copp-employer-form__grid label.copp-employer-form__full {
    grid-column: 1 / -1;
}
.copp-employer-form__grid input,
.copp-employer-form__grid select,
.copp-employer-form__grid textarea {
    border: 1px solid rgba(var(--copp-ink-rgb), 0.12);
    border-radius: 0;
    padding: 12px 14px;
    font-size: 15px;
    font-family: inherit;
    background: #ffffff;
    color: var(--copp-ink);
    transition: border-color 0.15s ease;
}
.copp-employer-form__grid input:focus,
.copp-employer-form__grid select:focus,
.copp-employer-form__grid textarea:focus {
    border-color: var(--copp-red);
    outline: none;
}
.copp-employer-form__grid textarea {
    resize: vertical;
    min-height: 60px;
}
.copp-employer-form__actions {
    display: flex;
    gap: 12px;
    margin-top: 24px;
}
.copp-employer-form__close {
    opacity: 0.7;
}
.copp-employer-form__close:hover {
    opacity: 1;
}

.copp-employer-step__copy {
    display: grid;
    gap: 6px;
    justify-items: center;
}
.copp-employer-step__copy h3 {
    font-family: var(--copp-font-heading);
    font-size: 16px;
    font-weight: 800;
    color: var(--copp-ink);
    margin: 0;
}
.copp-employer-step__copy p {
    font-size: 14px;
    line-height: 1.45;
    color: rgba(var(--copp-ink-rgb), 0.7);
    margin: 0;
}

.copp-employer-partners {
    background: var(--copp-ink);
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    width: 100vw;
    overflow: hidden;
    padding: 48px 0;
}
.copp-employer-partners__inner {
    max-width: var(--copp-container-content);
    width: calc(100% - 30px);
    margin: 0 auto;
}
.copp-employer-section__head--light h2 {
    color: #fff;
}
.copp-employer-section__head--light .copp-section-accent span {
    background: var(--copp-red);
}
.copp-employer-partners__grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 12px;
}
.copp-employer-partner {
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.08);
    min-height: 88px;
    padding: 16px 24px;
    text-decoration: none;
    transition: background 0.2s, border-color 0.2s;
}
.copp-employer-partner:hover {
    background: rgba(255,255,255,0.07);
    border-color: rgba(255,255,255,0.16);
}
.copp-employer-partner__logo {
    max-height: 48px;
    max-width: 120px;
    object-fit: contain;
    filter: brightness(0) invert(1);
    opacity: 0.8;
}
.copp-employer-partner:hover .copp-employer-partner__logo {
    opacity: 1;
}
.copp-employer-partner__name {
    font-family: var(--copp-font-heading);
    font-size: 18px;
    font-weight: 900;
    text-transform: uppercase;
    color: rgba(255,255,255,0.7);
    letter-spacing: 0.02em;
}
.copp-employer-partner:hover .copp-employer-partner__name {
    color: #fff;
}
.copp-employer-partner--has-logo {
    padding: 12px 20px;
}

.copp-employer-track {
    background: var(--copp-soft);
    padding: 32px 0;
    position: relative;
}
.copp-employer-track__inner {
    max-width: var(--copp-container-content);
    width: calc(100% - 30px);
    margin: 0 auto;
    display: flex;
    align-items: center;
    gap: 20px;
}
.copp-employer-track__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    font-size: 18px;
    background: rgba(var(--copp-red-rgb), 0.1);
    color: var(--copp-red);
    flex-shrink: 0;
}
.copp-employer-track__body h2 {
    font-family: var(--copp-font-heading);
    font-size: 18px;
    font-weight: 900;
    text-transform: uppercase;
    color: var(--copp-ink);
    margin: 0 0 2px;
}
.copp-employer-track__body p {
    font-size: 13px;
    color: var(--copp-muted);
    margin: 0;
}
.copp-employer-track__form {
    margin-left: auto;
    flex-shrink: 0;
    display: flex;
    gap: 10px;
}
.copp-employer-track__form input {
    padding: 10px 14px;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.12);
    background: #ffffff;
    font-size: 14px;
    font-family: inherit;
    border-radius: 0;
    transition: border-color .2s;
    width: 240px;
}
.copp-employer-track__form input:focus {
    outline: none;
    border-color: var(--copp-red);
    box-shadow: 0 0 0 3px rgba(var(--copp-red-rgb), 0.08);
}
.copp-employer-track__results {
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    background: #fff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.08);
    box-shadow: 0 12px 32px rgba(var(--copp-ink-rgb), 0.1);
    padding: 20px 28px;
    z-index: 10;
}
.copp-employer-track__empty {
    padding: 24px;
    text-align: center;
    background: #fff;
    font-size: 15px;
    color: var(--copp-muted);
}
.copp-employer-track__item {
    background: #fff;
    border: 1px solid rgba(var(--copp-ink-rgb), 0.06);
    padding: 20px 24px;
    margin-bottom: 12px;
    display: flex;
    align-items: flex-start;
    gap: 20px;
}
.copp-employer-track__item-status {
    flex-shrink: 0;
    width: 12px;
    height: 12px;
    margin-top: 6px;
    border-radius: 50%;
}
.copp-employer-track__item-status--new { background: #f0ad4e; }
.copp-employer-track__item-status--accepted,
.copp-employer-track__item-status--in_work,
.copp-employer-track__item-status--specialist_assigned { background: var(--copp-red); }
.copp-employer-track__item-status--clarification { background: #6c757d; }
.copp-employer-track__item-status--program_found { background: #0d6efd; }
.copp-employer-track__item-status--done { background: #28a745; }
.copp-employer-track__item-status--rejected { background: #dc3545; }
.copp-employer-track__item-body {
    flex: 1;
    min-width: 0;
}
.copp-employer-track__item-top {
    display: flex;
    align-items: baseline;
    gap: 12px;
    margin-bottom: 4px;
}
.copp-employer-track__item-type {
    font-family: Montserrat, sans-serif;
    font-size: 14px;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--copp-dark);
}
.copp-employer-track__item-badge {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 3px 10px;
    border-radius: 0;
}
.copp-employer-track__item-badge--new { background: rgba(240,173,78,0.15); color: #c77d00; }
.copp-employer-track__item-badge--accepted,
.copp-employer-track__item-badge--in_work,
.copp-employer-track__item-badge--specialist_assigned { background: rgba(var(--copp-red-rgb), 0.12); color: var(--copp-red); }
.copp-employer-track__item-badge--clarification { background: rgba(108,117,125,0.12); color: #495057; }
.copp-employer-track__item-badge--program_found { background: rgba(13,110,253,0.12); color: #0d6efd; }
.copp-employer-track__item-badge--done { background: rgba(40,167,69,0.12); color: #1a7a33; }
.copp-employer-track__item-badge--rejected { background: rgba(220,53,69,0.12); color: #b02a37; }
.copp-employer-track__item-org {
    font-size: 13px;
    color: var(--copp-muted);
    margin-bottom: 2px;
}
.copp-employer-track__item-date {
    font-size: 12px;
    color: var(--copp-muted);
    opacity: 0.7;
}
.copp-employer-track__item-comment {
    margin-top: 8px;
    padding: 10px 14px;
    background: var(--copp-soft);
    font-size: 13px;
    line-height: 1.5;
    color: var(--copp-dark);
}
.copp-employer-track__item-comment::before {
    content: '\041A\043E\043C\043C\0435\043D\0442\0430\0440\0438\0439 \0441\043F\0435\0446\0438\0430\043B\0438\0441\0442\0430:';
    display: block;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--copp-muted);
    margin-bottom: 4px;
}
.copp-employer-track__error {
    padding: 20px 24px;
    background: rgba(220,53,69,0.06);
    border: 1px solid rgba(220,53,69,0.2);
    color: #721c24;
    font-size: 14px;
    text-align: center;
}
.copp-employer-track__loading {
    text-align: center;
    padding: 24px;
    color: var(--copp-muted);
    font-size: 14px;
}

@media (max-width: 1199.98px) {
    .copp-employer-partners__grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .copp-employer-actions-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .copp-employer-form__grid {
        grid-template-columns: 1fr;
    }
    .copp-employer-form {
        padding: 24px 16px;
        margin: 24px auto;
    }
    .copp-employer-track__inner {
        flex-wrap: wrap;
    }
    .copp-employer-track__form {
        margin-left: 0;
        width: 100%;
    }
    .copp-employer-track__form input {
        flex: 1;
        width: auto;
    }
    .copp-employer-partners__grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .copp-employer-actions-grid {
        grid-template-columns: 1fr;
    }
    .copp-employer-track__inner {
        flex-direction: column;
        align-items: stretch;
    }
    .copp-employer-track__form {
        flex-direction: column;
    }
    .copp-employer-track__form input {
        width: 100%;
    }
    .copp-employer-track__item {
        flex-direction: column;
        gap: 12px;
    }
    .copp-employer-track__item-status {
        display: none;
    }
    .copp-employer-partners__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .copp-employer-partners__grid {
        grid-template-columns: 1fr;
    }
}
/* ===== Партнёры ===== */
.copp-partners__hero {
    background: var(--copp-dark);
    padding: 64px 0 56px;
    text-align: center;
}
.copp-partners__hero-inner {
    max-width: 800px;
    margin: 0 auto;
    padding: 0 24px;
}
.copp-partners__hero-label {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--copp-red);
    margin-bottom: 12px;
}
.copp-partners__hero-title {
    font-family: Montserrat, sans-serif;
    font-size: 32px;
    font-weight: 800;
    text-transform: uppercase;
    color: #fff;
    margin: 0 0 16px;
}
.copp-partners__hero-lead {
    font-size: 15px;
    line-height: 1.6;
    color: rgba(255,255,255,0.72);
    margin: 0;
}

.copp-partners__section {
    padding: 48px 0 24px;
}
.copp-partners__section-head {
    display: flex;
    align-items: baseline;
    gap: 12px;
    margin-bottom: 32px;
    padding: 0 24px;
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
}
.copp-partners__section-title {
    font-family: Montserrat, sans-serif;
    font-size: 22px;
    font-weight: 800;
    text-transform: uppercase;
    color: var(--copp-dark);
    margin: 0;
}
.copp-partners__section-count {
    font-size: 13px;
    color: var(--copp-red);
    font-weight: 700;
}

.copp-partners__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}
.copp-partners__grid--featured {
    grid-template-columns: repeat(3, 1fr);
}

.copp-partners__card {
    background: #fff;
    border: 1px solid #eee;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 28px 16px 20px;
    transition: box-shadow .2s, border-color .2s;
}
.copp-partners__card:hover {
    box-shadow: 0 4px 20px rgba(0,0,0,0.08);
    border-color: var(--copp-red);
}
.copp-partners__card--featured {
    padding: 32px 24px 24px;
}
.copp-partners__card-link {
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    width: 100%;
}
.copp-partners__card-link:hover {
    text-decoration: none;
    color: inherit;
}
.copp-partners__card-logo {
    width: 80px;
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
    flex-shrink: 0;
}
.copp-partners__card--featured .copp-partners__card-logo {
    width: 96px;
    height: 96px;
}
.copp-partners__card-logo img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}
.copp-partners__card-initials {
    width: 64px;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--copp-dark);
    color: #fff;
    font-family: Montserrat, sans-serif;
    font-size: 20px;
    font-weight: 800;
    border-radius: 0;
}
.copp-partners__card-title {
    font-family: Montserrat, sans-serif;
    font-size: 14px;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--copp-dark);
    margin: 0;
}
.copp-partners__card--featured .copp-partners__card-title {
    font-size: 16px;
}
.copp-partners__card-body {
    width: 100%;
}
.copp-partners__card-desc {
    font-size: 13px;
    line-height: 1.5;
    color: var(--copp-muted);
    margin: 8px 0 0;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.copp-partners__cta {
    background: var(--copp-dark);
    padding: 64px 0;
    margin-top: 48px;
}
.copp-partners__cta-inner {
    max-width: 680px;
    margin: 0 auto;
    text-align: center;
    padding: 0 24px;
}
.copp-partners__cta-title {
    font-family: Montserrat, sans-serif;
    font-size: 26px;
    font-weight: 800;
    text-transform: uppercase;
    color: #fff;
    margin: 0 0 12px;
}
.copp-partners__cta-text {
    font-size: 15px;
    line-height: 1.6;
    color: rgba(255,255,255,0.72);
    margin: 0 0 28px;
}
.copp-partners__cta-actions {
    display: flex;
    gap: 16px;
    justify-content: center;
    flex-wrap: wrap;
}
.copp-partners__cta-btn {
    display: inline-block;
    font-family: Montserrat, sans-serif;
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 14px 32px;
    border-radius: 0;
    text-decoration: none;
    transition: background .2s, color .2s, border-color .2s;
}
.copp-partners__cta-btn--primary {
    background: var(--copp-red);
    color: #fff;
    border: 2px solid var(--copp-red);
}
.copp-partners__cta-btn--primary:hover {
    background: #fff;
    color: var(--copp-red);
    border-color: #fff;
}
.copp-partners__cta-btn--outline {
    background: transparent;
    color: #fff;
    border: 2px solid rgba(255,255,255,0.3);
}
.copp-partners__cta-btn--outline:hover {
    border-color: #fff;
    color: #fff;
}

@media (max-width: 991px) {
    .copp-partners__grid {
        grid-template-columns: repeat(3, 1fr);
    }
    .copp-partners__grid--featured {
        grid-template-columns: repeat(2, 1fr);
    }
}
@media (max-width: 767px) {
    .copp-partners__hero {
        padding: 40px 0 36px;
    }
    .copp-partners__hero-title {
        font-size: 24px;
    }
    .copp-partners__grid,
    .copp-partners__grid--featured {
        grid-template-columns: repeat(2, 1fr);
    }
    .copp-partners__cta-title {
        font-size: 20px;
    }
}
.copp-edu-orgs-hero {
    background: linear-gradient(135deg, var(--copp-ink) 0%, #1a1f36 100%);
}

.copp-edu-orgs-hero .copp-news-hero__title span {
    color: var(--copp-red);
}

.copp-edu-orgs-content {
    overflow: hidden;
}

.copp-edu-orgs-stats {
    background: var(--copp-ink);
    padding: 40px 0;
}

.copp-edu-orgs-stats__inner {
    max-width: 960px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    text-align: center;
}

.copp-edu-orgs-stat__number {
    display: block;
    font-family: var(--copp-font-heading);
    font-size: 40px;
    font-weight: 800;
    color: var(--copp-red);
    line-height: 1.1;
}

.copp-edu-orgs-stat__label {
    display: block;
    font-size: 14px;
    color: rgba(255,255,255,0.7);
    margin-top: 4px;
}

.copp-edu-orgs-filters {
    padding: 40px 0 24px;
    background: var(--copp-soft);
}

.copp-edu-orgs-filters__inner {
    max-width: 960px;
    margin: 0 auto;
    padding: 0 20px;
}

.copp-edu-orgs-filters__heading {
    font-family: var(--copp-font-heading);
    font-size: var(--copp-fs-section);
    font-weight: 800;
    color: var(--copp-ink);
    margin-bottom: 20px;
}

.copp-edu-orgs-filters__bar {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
}

.copp-edu-orgs-filter__select {
    width: 100%;
    padding: 10px 36px 10px 14px;
    border: 2px solid rgba(var(--copp-ink-rgb), 0.15);
    border-radius: 10px;
    background: #fff;
    font-size: 14px;
    font-family: inherit;
    color: var(--copp-ink);
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%231C1F33' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    transition: border-color 0.2s;
}

.copp-edu-orgs-filter__select:focus {
    outline: none;
    border-color: var(--copp-red);
}

.copp-edu-orgs-grid-section {
    padding: 24px 0 48px;
    background: var(--copp-soft);
}

.copp-edu-orgs-grid-section__inner {
    max-width: 960px;
    margin: 0 auto;
    padding: 0 20px;
}

.copp-edu-orgs-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
}

.copp-edu-org-card {
    background: #fff;
    border-radius: 16px;
    padding: 24px;
    display: flex;
    flex-direction: column;
    border: 2px solid rgba(var(--copp-ink-rgb), 0.06);
    transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
}

.copp-edu-org-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(var(--copp-ink-rgb), 0.1);
    border-color: rgba(var(--copp-red-rgb), 0.25);
}

.copp-edu-org-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}

.copp-edu-org-card__badge {
    display: inline-flex;
    align-items: center;
    padding: 3px 10px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    background: rgba(var(--copp-ink-rgb), 0.08);
    color: var(--copp-ink);
}

.copp-edu-org-card__partner {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    color: var(--copp-red);
    font-weight: 600;
}

.copp-edu-org-card__partner i {
    font-size: 11px;
}

.copp-edu-org-card__name {
    font-family: var(--copp-font-heading);
    font-size: 18px;
    font-weight: 800;
    color: var(--copp-ink);
    line-height: 1.3;
    margin: 0 0 4px;
}

.copp-edu-org-card__type {
    font-size: 13px;
    color: rgba(var(--copp-ink-rgb), 0.5);
    margin: 0 0 12px;
}

.copp-edu-org-card__meta {
    display: flex;
    gap: 16px;
    margin-bottom: 12px;
}

.copp-edu-org-card__meta-item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: rgba(var(--copp-ink-rgb), 0.65);
}

.copp-edu-org-card__meta-item i {
    color: var(--copp-red);
    font-size: 12px;
}

.copp-edu-org-card__directions {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 12px;
}

.copp-edu-org-card__direction {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 12px;
    background: rgba(var(--copp-ink-rgb), 0.06);
    color: var(--copp-ink);
}

.copp-edu-org-card__direction--more {
    background: rgba(var(--copp-red-rgb), 0.1);
    color: var(--copp-red);
    font-weight: 600;
}

.copp-edu-org-card__features {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 12px;
}

.copp-edu-org-card__feature {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    color: rgba(var(--copp-ink-rgb), 0.6);
}

.copp-edu-org-card__feature i {
    color: #22c55e;
    font-size: 10px;
}

.copp-edu-org-card__resources {
    margin-bottom: 16px;
    padding: 10px 12px;
    background: rgba(var(--copp-ink-rgb), 0.03);
    border-radius: 8px;
}

.copp-edu-org-card__resources-label {
    font-size: 12px;
    font-weight: 600;
    color: rgba(var(--copp-ink-rgb), 0.5);
    display: block;
    margin-bottom: 4px;
}

.copp-edu-org-card__resource {
    display: inline-block;
    font-size: 12px;
    color: rgba(var(--copp-ink-rgb), 0.7);
    margin-right: 8px;
}

.copp-edu-org-card__resource:not(:last-child)::after {
    content: '·';
    margin-left: 8px;
}

.copp-edu-org-card__actions {
    margin-top: auto;
    display: flex;
    gap: 8px;
}

.copp-edu-org-card__btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 600;
    font-family: inherit;
    cursor: pointer;
    transition: background 0.2s, color 0.2s;
    border: 2px solid transparent;
    text-decoration: none;
}

.copp-edu-org-card__btn--primary {
    background: var(--copp-red);
    color: #fff;
}

.copp-edu-org-card__btn--primary:hover {
    background: #c0202e;
}

.copp-edu-org-card__btn--secondary {
    background: transparent;
    color: var(--copp-ink);
    border-color: rgba(var(--copp-ink-rgb), 0.15);
}

.copp-edu-org-card__btn--secondary:hover {
    border-color: var(--copp-red);
    color: var(--copp-red);
}

.copp-edu-orgs-empty {
    text-align: center;
    padding: 60px 20px;
}

.copp-edu-orgs-empty__icon {
    font-size: 48px;
    color: rgba(var(--copp-ink-rgb), 0.2);
    margin-bottom: 16px;
}

.copp-edu-orgs-empty h3 {
    font-family: var(--copp-font-heading);
    font-size: 20px;
    font-weight: 700;
    color: var(--copp-ink);
    margin: 0 0 8px;
}

.copp-edu-orgs-empty p {
    font-size: 14px;
    color: rgba(var(--copp-ink-rgb), 0.5);
    margin: 0 0 20px;
}

.copp-edu-orgs-logic {
    padding: 56px 0;
    background: #fff;
}

.copp-edu-orgs-logic__inner {
    max-width: 960px;
    margin: 0 auto;
    padding: 0 20px;
    text-align: center;
}

.copp-edu-orgs-logic__title {
    font-family: var(--copp-font-heading);
    font-size: var(--copp-fs-section);
    font-weight: 800;
    color: var(--copp-ink);
    margin: 0 0 8px;
}

.copp-edu-orgs-logic__lead {
    font-size: 16px;
    color: rgba(var(--copp-ink-rgb), 0.6);
    margin: 0 0 40px;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}

.copp-edu-orgs-process .copp-about-process__step {
    background: var(--copp-soft);
}

.copp-edu-orgs-step__copy {
    padding: 0 4px;
}

.copp-edu-orgs-links-section {
    padding: 48px 0;
    background: var(--copp-soft);
}

.copp-edu-orgs-links-section__inner {
    max-width: 960px;
    margin: 0 auto;
    padding: 0 20px;
}

.copp-edu-orgs-links-section__title {
    font-family: var(--copp-font-heading);
    font-size: var(--copp-fs-section);
    font-weight: 800;
    color: var(--copp-ink);
    margin: 0 0 24px;
}

.copp-edu-orgs-links-grid {
    grid-template-columns: repeat(4, 1fr);
}

.copp-edu-orgs-cta {
    background: var(--copp-red);
    padding: 48px 0;
}

.copp-edu-orgs-cta__inner {
    max-width: 960px;
    margin: 0 auto;
    padding: 0 20px;
}

.copp-edu-orgs-cta__copy {
    text-align: center;
    max-width: 600px;
    margin: 0 auto;
}

.copp-edu-orgs-cta__title {
    font-family: var(--copp-font-heading);
    font-size: 28px;
    font-weight: 800;
    color: #fff;
    margin: 0 0 12px;
}

.copp-edu-orgs-cta__text {
    font-size: 16px;
    color: rgba(255,255,255,0.85);
    margin: 0 0 24px;
}

.copp-edu-orgs-cta .copp-news-btn--primary {
    background: #fff;
    color: var(--copp-red);
}

.copp-edu-orgs-cta .copp-news-btn--primary:hover {
    background: rgba(255,255,255,0.9);
}

.copp-edu-org-detail-overlay {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity 0.3s;
    opacity: 0;
    pointer-events: none;
}

.copp-edu-org-detail-overlay[aria-hidden="false"] {
    opacity: 1;
    pointer-events: auto;
}

.copp-edu-org-detail-overlay__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.5);
}

.copp-edu-org-detail-overlay__panel {
    position: relative;
    background: #fff;
    border-radius: 20px;
    padding: 32px;
    max-width: 640px;
    width: 90%;
    max-height: 80vh;
    overflow-y: auto;
    box-shadow: 0 24px 48px rgba(0,0,0,0.2);
}

.copp-edu-org-detail-overlay__close {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: none;
    background: rgba(var(--copp-ink-rgb), 0.08);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    color: var(--copp-ink);
    transition: background 0.2s;
}

.copp-edu-org-detail-overlay__close:hover {
    background: rgba(var(--copp-ink-rgb), 0.15);
}

.copp-edu-org-detail__badge {
    display: inline-flex;
    padding: 3px 10px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    background: rgba(var(--copp-ink-rgb), 0.08);
    color: var(--copp-ink);
    margin-bottom: 8px;
}

.copp-edu-org-detail__name {
    font-family: var(--copp-font-heading);
    font-size: 22px;
    font-weight: 800;
    color: var(--copp-ink);
    margin: 0 0 4px;
    padding-right: 40px;
}

.copp-edu-org-detail__type {
    font-size: 14px;
    color: rgba(var(--copp-ink-rgb), 0.5);
    margin: 0 0 16px;
}

.copp-edu-org-detail__description {
    font-size: 14px;
    line-height: 1.7;
    color: rgba(var(--copp-ink-rgb), 0.75);
    margin: 0 0 20px;
}

.copp-edu-org-detail__section {
    margin-bottom: 20px;
}

.copp-edu-org-detail__section-title {
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: rgba(var(--copp-ink-rgb), 0.5);
    margin: 0 0 8px;
}

.copp-edu-org-detail__directions {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.copp-edu-org-detail__direction {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 6px;
    font-size: 13px;
    background: rgba(var(--copp-red-rgb), 0.08);
    color: var(--copp-red);
    font-weight: 600;
}

.copp-edu-org-detail__contacts {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

.copp-edu-org-detail__contact {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: rgba(var(--copp-ink-rgb), 0.75);
}

.copp-edu-org-detail__contact i {
    color: var(--copp-red);
    width: 16px;
    text-align: center;
}

.copp-edu-org-detail__contact a {
    color: var(--copp-red);
    text-decoration: none;
}

.copp-edu-org-detail__contact a:hover {
    text-decoration: underline;
}

.copp-edu-org-detail__program-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 8px;
}

.copp-edu-org-detail__program {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: rgba(var(--copp-ink-rgb), 0.03);
    border-radius: 8px;
    font-size: 14px;
    color: var(--copp-ink);
}

.copp-edu-org-detail__program-icon {
    color: var(--copp-red);
    flex-shrink: 0;
}

.copp-edu-org-detail__program-info {
    flex: 1;
}

.copp-edu-org-detail__program-title {
    font-weight: 600;
    display: block;
}

.copp-edu-org-detail__program-meta {
    font-size: 12px;
    color: rgba(var(--copp-ink-rgb), 0.5);
    display: block;
}

@media (max-width: 1200px) {
    .copp-edu-orgs-stats__inner {
        max-width: 720px;
    }
    .copp-edu-orgs-filters__inner,
    .copp-edu-orgs-grid-section__inner,
    .copp-edu-orgs-logic__inner,
    .copp-edu-orgs-links-section__inner,
    .copp-edu-orgs-cta__inner {
        max-width: 720px;
    }
    .copp-edu-orgs-links-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 992px) {
    .copp-edu-orgs-filters__bar {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .copp-edu-orgs-stats__inner {
        grid-template-columns: repeat(2, 1fr);
        gap: 16px;
    }
    .copp-edu-orgs-stat__number {
        font-size: 32px;
    }
    .copp-edu-orgs-filters__bar {
        grid-template-columns: 1fr;
    }
    .copp-edu-orgs-grid {
        grid-template-columns: 1fr;
    }
    .copp-edu-org-card__actions {
        flex-direction: column;
    }
    .copp-edu-org-card__btn {
        justify-content: center;
    }
    .copp-edu-orgs-cta__title {
        font-size: 22px;
    }
    .copp-edu-orgs-links-grid {
        grid-template-columns: 1fr;
    }
    .copp-edu-org-detail__contacts {
        grid-template-columns: 1fr;
    }
    .copp-edu-org-detail-overlay__panel {
        padding: 24px;
        width: 95%;
        max-height: 90vh;
    }
}
