:root {
    --camimex-ink: #13212b;
    --camimex-muted: #5f6b72;
    --camimex-line: #d6dde2;
    --camimex-paper: #f5f2ec;
    --camimex-surface: #ffffff;
    --camimex-tint: #e5ecef;
    --camimex-accent: #725e43;
    --camimex-accent-deep: #6c512f;
    --camimex-shadow: 0 18px 45px rgba(19, 33, 43, 0.08);
    --section-scroll-offset: 7rem;
    --bs-body-font-family: "Instrument Sans", sans-serif;
    --bs-body-color: var(--camimex-ink);
    --bs-body-bg: #fcfbf8;
}

html {
    scroll-behavior: smooth;
}

body {
    color: var(--camimex-ink);
    background: radial-gradient(circle at top right, rgba(139, 106, 62, 0.08), transparent 40%), linear-gradient(180deg, #f8f5ef 0%, #fcfbf8 24%, #fcfbf8 100%);
}

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

a {
    color: var(--camimex-accent-deep);
    text-decoration-thickness: 1px;
    text-underline-offset: 0.16em;
}

a:hover,
a:focus {
    color: var(--camimex-ink);
}

h1,
h2,
h3,
h4,
.table-title {
    font-family: "DM Sans", sans-serif;
    letter-spacing: -0.01em;
}

h1 {
    font-size: clamp(2rem, 3vw, 3rem);
    line-height: 1.15;
    margin-bottom: 1.25rem;
}

h2 {
    font-size: clamp(1.5rem, 2.4vw, 2.4rem);
    line-height: 1.25;
    margin-bottom: 1rem;
}

h3 {
    font-size: clamp(1.35rem, 2vw, 1.85rem);
    line-height: 1.25;
}

h4 {
    font-size: 1.15rem;
    line-height: 1.25;
}

p {
    color: var(--camimex-muted);
    line-height: 1.35;
}

.fw-thin {
    font-weight: 200 !important;
}

.fw-light {
    font-weight: 300 !important;
}

.skip-link {
    position: absolute;
    left: 1rem;
    top: 1rem;
    z-index: 1200;
    padding: 0.75rem 1rem;
    background: var(--camimex-ink);
    color: #fff;
    border-radius: 0;
}

.site-header {
    position: relative;
}

.navbar {
    padding: 0.9rem 0;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1030;
    backdrop-filter: blur(0);
    background: transparent;
    border-bottom: 1px solid transparent;
    transition: background-color 0.5s ease, border-color 0.5s ease, backdrop-filter 0.5s ease, box-shadow 0.5s ease;
}

.navbar.is-scrolled {
    backdrop-filter: blur(8px);
    background: rgba(17, 52, 96, 0.7);
    border-bottom: 1px solid rgba(255, 255, 255, 0.14);
    box-shadow: 0 10px 30px rgba(8, 24, 48, 0.18);
}

.navbar-brand {
    display: grid;
    gap: 0.2rem;
    text-decoration: none;
}

.brand-kicker {
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--camimex-accent-deep);
}

.brand-title {
    color: var(--camimex-ink);
    font-weight: 600;
    font-size: 1rem;
}

.navbar-toggler {
    border-color: rgba(255, 255, 255, 0.28);
}

.navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 1%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

.navbar-nav {
    gap: 0.35rem;
}

.nav-link {
    color: var(--camimex-muted);
    font-weight: 500;
    border-radius: 0;
    padding: 0.55rem 0.95rem !important;
}

.nav-link.active,
.nav-link:hover,
.nav-link:focus {
    color: #ffffff;
    background: rgba(255, 255, 255, 0.08);
}

.navbar.is-scrolled .nav-link.active,
.navbar.is-scrolled .nav-link:hover,
.navbar.is-scrolled .nav-link:focus {
    background: rgba(255, 255, 255, 0.12);
}

.navbar.is-scrolled .navbar-toggler {
    border-color: rgba(255, 255, 255, 0.24);
}

.masthead {
    position: relative;
    padding: 7.25rem 0 1.75rem;
    min-height: 36rem;
    overflow: hidden;
    isolation: isolate;
}

.masthead::before {
    content: "";
    position: absolute;
    inset: 0;
    background: url("../img/principal.jpg") 25% 70% / cover no-repeat;
    z-index: 0;
}

.masthead::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(5, 18, 39, 0.84) 0%, rgba(5, 18, 39, 0.56) 34%, rgba(5, 18, 39, 0.12) 66%, rgba(5, 18, 39, 0.04) 100%), linear-gradient(180deg, rgba(5, 18, 39, 0.2) 0%, rgba(5, 18, 39, 0.08) 34%, rgba(5, 18, 39, 0.64) 100%);
    z-index: 0;
}

.hero-kicker {
    text-transform: uppercase;
    letter-spacing: .08em;
    font-size: clamp(0.8rem, 1vw, 1rem);
    font-weight: 500 !important;
    color: rgba(255, 255, 255, .78);
}

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

.masthead-layout {
    min-height: 36rem;
    align-items: stretch;
}

.masthead-copy {
    min-height: 100%;
    display: flex;
    align-items: center;
    padding: 1.5rem 0;
}

.masthead-copy>div {
    max-width: 38rem;
}

.masthead-copy h1 {
    color: #ffffff;
    font-size: clamp(3.6rem, 6.4vw, 5.6rem);
    letter-spacing: 0.02em;
    line-height: .95;
    text-shadow: 4px 4px 4px rgba(19, 20, 20, 0.75);
    margin-bottom: 1.5rem;
}

.lead {
    font-size: 1.08rem;
    max-width: 54rem;
}

.eyebrow {
    margin-bottom: 0.8rem;
    color: var(--camimex-accent-deep);
    text-transform: uppercase;
    letter-spacing: 0.16em;
    font-size: 0.76rem;
    font-weight: 700;
}

.headline-panel,
.editorial-block,
.overview-card,
.info-card,
.metric-card,
.editorial-panel,
.summary-tile,
.table-panel,
.feature-brief,
.category-block {
    background: var(--camimex-surface);
    border: 1px solid rgba(19, 33, 43, 0.08);
    box-shadow: var(--camimex-shadow);
}

.headline-panel {
    padding: 1.5rem;
    border-radius: 0;
}

.headline-panel-rail {
    min-height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 2rem;
    background: rgba(255, 255, 255, 0.18);
    border: 1px solid rgba(255, 255, 255, 0.18);
    box-shadow: none;
    backdrop-filter: blur(10px);
}

.panel-label,
.metric-label,
.section-tag,
.mini-note,
.tile-index,
.info-badge {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    border-radius: 0;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.04em;
}

.panel-label,
.metric-label,
.section-tag,
.tile-index,
.info-badge {
    background: #efe5d7;
    color: var(--camimex-accent-deep);
    padding: 0.35rem 0.7rem;
}

.mini-note {
    background: var(--camimex-tint);
    color: var(--camimex-ink);
    padding: 0.45rem 0.75rem;
}

.headline-metric {
    font-size: clamp(3.2rem, 5vw, 4.4rem);
    line-height: 0.9;
    font-family: "DM Sans", sans-serif;
    margin: 0.85rem 0 0.55rem;
}

.headline-split {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.85rem;
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--camimex-line);
}

.headline-split strong {
    display: block;
    font-size: 1.5rem;
    color: var(--camimex-ink);
}

.headline-split span {
    color: var(--camimex-muted);
    font-size: 0.92rem;
}

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

.section-soft {
    background: linear-gradient(180deg, #000918, #000000), transparent;
}

#panorama {
    background: url("../img/secundario.jpg") center / cover no-repeat;
}

.section-heading {
    max-width: 54rem;
    margin-bottom: 2rem;
}

.section-copy {
    margin-top: 1rem;
}

#logos {
    position: relative;
    overflow: hidden;
    background: linear-gradient(90deg, rgba(3, 18, 43, 0.96) 0%, rgba(4, 24, 62, 0.6) 48%, rgba(4, 24, 62, 0.96) 100%), url("../img/premios-reconocimientos-intro.jpg") center bottom / cover no-repeat;
}

#logos::before {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 42%;
    background: linear-gradient(180deg, rgba(1, 10, 27, 0) 0%, rgba(1, 10, 27, 0.72) 55%, rgba(1, 10, 27, 0.94) 100%);
    pointer-events: none;
}

#logos .container {
    position: relative;
    z-index: 1;
}

.logos-hero {
    min-height: 42rem;
}

.logos-copy {
    padding: 1.5rem 0 6rem;
}

.logos-copy .eyebrow {
    color: #97c91c;
}

.logos-copy .eyebrow::after,
.recognition-scorecard-kicker::after {
    content: "";
    display: block;
    width: 2rem;
    height: 2px;
    margin-top: 0.7rem;
    background: #97c91c;
}

.logos-copy h2 {
    font-size: clamp(2.7rem, 5vw, 4.35rem);
    line-height: 0.98;
    margin-bottom: 1.25rem;
}

.masthead-copy span,
.logos-copy h2 span,
.logos-pillar p span,
.recognition-scorecard strong,
.recognition-scorecard-stat strong,
.recognition-scorecard-kicker {
    color: #97c91c;
}

.logos-copy .section-copy {
    color: rgba(233, 240, 250, 0.86);
    font-size: 1.08rem;
    line-height: 1.55;
    margin-bottom: 2rem;
}

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

.logos-pillar {
    padding: 0 1rem;
    border-right: 1px solid rgba(255, 255, 255, 0.12);
}

.logos-pillar:last-child {
    border-right: 0;
    padding-right: 0;
}

.logos-pillar-icon {
    width: 3.2rem;
    height: 3.2rem;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    color: #f6f1ea;
    margin-bottom: 0.8rem;
}

.logos-pillar-icon svg,
.logos-pillar-icon img,
.recognition-scorecard-icon svg {
    width: 100%;
    height: 100%;
}

.logos-pillar p,
.recognition-scorecard-title,
.recognition-scorecard-stat p {
    margin: 0;
    color: #f3f5f7;
}

.logos-pillar p {
    font-size: 1rem;
    line-height: 1.25;
}

.recognition-scorecard {
    margin-left: auto;
    padding: 1.7rem 1.35rem 1.5rem;
    border-radius: 1.35rem;
    background: linear-gradient(180deg, rgba(5, 37, 87, 0.96) 0%, rgba(6, 33, 77, 0.98) 100%);
    border: 1px solid rgba(44, 111, 211, 0.34);
    box-shadow: 0 22px 48px rgba(0, 5, 18, 0.45);
    text-align: center;
}

.recognition-scorecard-kicker {
    margin: 0;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.92rem;
    font-weight: 700;
}

.recognition-scorecard-kicker::after {
    margin: 0.6rem auto 0;
}

.recognition-scorecard>strong {
    display: block;
    font-family: "DM Sans", sans-serif;
    font-size: clamp(5.5rem, 10vw, 6.6rem);
    line-height: 0.95;
    color: #f5f1eb;
    margin: 1rem 0 0.55rem;
}

.recognition-scorecard-title {
    font-size: 1.35rem;
    line-height: 1.3;
}

.recognition-scorecard-divider {
    width: 100%;
    height: 1px;
    margin: 1.4rem 0 1.5rem;
    background: rgba(255, 255, 255, 0.17);
}

.recognition-scorecard-stats {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.recognition-scorecard-stat {
    padding: 0 1rem;
}

.recognition-scorecard-stat+.recognition-scorecard-stat {
    border-left: 1px solid rgba(255, 255, 255, 0.14);
}

.recognition-scorecard-icon {
    width: 5rem;
    height: 5rem;
    color: #97c91c;
    margin: 0 auto 0.8rem;
}

.recognition-scorecard-icon-a {
    width: 7rem;
    height: 5.6rem;
    color: #97c91c;
    margin: 0 auto;
}

.recognition-scorecard-stat strong {
    display: block;
    font-family: "DM Sans", sans-serif;
    font-size: clamp(3.6rem, 6vw, 4.45rem);
    line-height: 0.95;
    margin-bottom: 0.45rem;
}

.recognition-scorecard-stat p {
    font-size: 1.1rem;
}

.editorial-block {
    padding: 2rem;
    border-radius: 0;
    background: transparent;
    border: 0;
    box-shadow: none;
}

.media-card {
    height: 100%;
    min-height: 100%;
    overflow: hidden;
    border-radius: 0;
    background: linear-gradient(135deg, rgba(19, 33, 43, 0.12), rgba(139, 106, 62, 0.08)), #dde4e7;
    border: 1px solid rgba(19, 33, 43, 0.08);
}

.media-card img,
.feature-brief img,
.metric-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.media-card-tall {
    min-height: 100%;
}

.environment-feature-row>[class*="col-"] {
    display: flex;
}

.environment-feature-row .media-card,
.environment-feature-row>.col-lg-8>.row {
    height: 100%;
}

.summary-tile {
    height: 100%;
    padding: 1.5rem;
    border-radius: 0;
}

.summary-tile h3 {
    font-size: 1.35rem;
    margin: 1rem 0 0.65rem;
}

.logo-item {
    margin: 0;
    aspect-ratio: 1 / 1;
    min-height: 0;
    padding: 0.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.74);
    border: 1px solid rgba(19, 33, 43, 0.08);
    border-radius: 0;
}

.logo-item img {
    width: 100%;
    max-width: 88%;
    max-height: 88%;
    object-fit: contain;
    filter: saturate(0.96) contrast(1.02);
}

.overview-card {
    padding: 1.7rem;
    border-radius: 0;
}

.overview-header {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
    margin-bottom: 1rem;
}

.compact-list {
    padding-left: 1.05rem;
    margin-bottom: 0;
    color: var(--camimex-muted);
}

.compact-list li+li {
    margin-top: 0.45rem;
}

.category-block {
    padding: 1.7rem;
    border-radius: 0;
    margin-bottom: 1.6rem;
}

.category-heading {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1.4rem;
}

.category-heading h3 {
    margin: 0.9rem 0 0;
}

.info-card {
    padding: 1.35rem;
    border-radius: 0;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.info-card:hover,
.info-card:focus-within {
    transform: translateY(-2px);
    box-shadow: 0 24px 42px rgba(19, 33, 43, 0.11);
}

.info-card h4 {
    margin: 0.95rem 0 0.8rem;
}

.editorial-panel {
    padding: 1.8rem;
    border-radius: 0;
}

.stacked-metrics {
    display: grid;
    gap: 0.9rem;
    margin-top: 1.5rem;
}

.stacked-metric {
    padding: 1rem 1.1rem;
    border-radius: 0;
    background: var(--camimex-paper);
}

.stacked-metric strong {
    display: block;
    font-size: 1.9rem;
    color: var(--camimex-ink);
}

.feature-brief {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border-radius: 0;
}

.feature-brief img {
    min-height: 220px;
}

.feature-brief-body {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 1.35rem;
}

.feature-brief-body>img,
.feature-brief-body>figure:not(.logo-item) img {
    width: 100%;
    max-height: 100%;
    object-fit: cover;
    display: block;
}

.feature-brief-body>figure:not(.logo-item) {
    margin: 0 0 1rem;
    overflow: hidden;
}

.feature-brief-body>a {
    margin-top: auto;
}

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

.metric-card {
    min-height: 185px;
    padding: 1.4rem;
    border-radius: 0;
}

.metric-card strong {
    display: block;
    font-size: clamp(2rem, 4vw, 3rem);
    line-height: 1;
    margin: 0.8rem 0 0.6rem;
    font-family: "DM Sans", sans-serif;
}

.metric-card p {
    margin-bottom: 0;
}

.metric-card-image {
    padding: 0;
    overflow: hidden;
    background: #dce4e7;
}

.table-panel {
    padding: 1.5rem;
    border-radius: 0;
    margin-top: 2.25rem;
}

#logos,
#nacionales,
.section-anchor {
    scroll-margin-top: var(--section-scroll-offset);
}

.section-anchor {
    position: relative;
    visibility: hidden;
}

.table-title {
    margin-bottom: 0;
}

.table-note {
    color: var(--camimex-muted);
    max-width: 30rem;
}

.recognition-table {
    --bs-table-bg: transparent;
    --bs-table-color: var(--camimex-ink);
    --bs-table-border-color: rgba(19, 33, 43, 0.1);
    table-layout: fixed;
    width: 100%;
}

.recognition-table thead th {
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--camimex-muted);
    white-space: normal;
    word-break: break-word;
    padding-top: 1rem;
    padding-bottom: 1rem;
}

.recognition-table tbody td {
    padding-top: 1rem;
    padding-bottom: 1rem;
    min-width: 0;
}

.recognition-table th:nth-child(1),
.recognition-table td:nth-child(1) {
    width: 13%;
}

.recognition-table th:nth-child(2),
.recognition-table td:nth-child(2) {
    width: 24%;
}

.recognition-table th:nth-child(3),
.recognition-table td:nth-child(3) {
    width: 14%;
}

.recognition-table th:nth-child(4),
.recognition-table td:nth-child(4) {
    width: 34%;
}

.recognition-table th:nth-child(5),
.recognition-table td:nth-child(5) {
    width: 15%;
}

.recognition-table tbody tr:nth-child(odd) td {
    background: var(--camimex-surface);
}

.recognition-table tbody tr:nth-child(even) td {
    background: var(--camimex-paper);
}

.recognition-summary-section {
    background: linear-gradient(180deg, #f5f8fd 0%, #f9fbff 100%);
}

.recognition-summary-shell {
    padding: 1.25rem;
    border-radius: 1.75rem;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(18, 45, 96, 0.08);
    box-shadow: 0 24px 60px rgba(18, 45, 96, 0.08);
}

.recognition-summary-header {
    margin-bottom: 1rem;
}

.recognition-summary-header .eyebrow {
    color: #7faf19;
    margin-bottom: 0.55rem;
}

.recognition-summary-header .eyebrow::after {
    content: "";
    display: block;
    width: 2.3rem;
    height: 3px;
    margin-top: 0.7rem;
    background: #7faf19;
}

.recognition-summary-header .table-title {
    color: #173267;
    font-size: clamp(1.9rem, 3vw, 2.6rem);
}

.recognition-summary-table {
    --bs-table-bg: transparent;
    --bs-table-color: #173267;
    --bs-table-border-color: rgba(23, 50, 103, 0.1);
    overflow: hidden;
    border-collapse: separate;
    border-spacing: 0;
    min-width: 980px;
    background: #ffffff;
    border: 1px solid rgba(23, 50, 103, 0.08);
    border-radius: 1.35rem;
}

.recognition-summary-table thead th {
    padding: 1.35rem 1rem;
    background: #f8fbff;
    color: #173267;
    font-family: "DM Sans", sans-serif;
    font-size: 0.92rem;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: none;
    vertical-align: middle;
    border-bottom-width: 1px;
}

.recognition-summary-table tbody th,
.recognition-summary-table tbody td,
.recognition-summary-table tfoot th,
.recognition-summary-table tfoot td {
    padding: 1rem;
    vertical-align: middle;
    background: #ffffff;
}

.recognition-summary-table tbody tr+tr td,
.recognition-summary-table tbody tr+tr th,
.recognition-summary-table tfoot th,
.recognition-summary-table tfoot td {
    border-top: 1px solid rgba(23, 50, 103, 0.08);
}

.recognition-summary-focus {
    min-width: 16rem;
    width: 16rem;
}

.recognition-summary-focus-inner {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.recognition-summary-focus-icon {
    width: 3.35rem;
    height: 3.35rem;
    flex: 0 0 auto;
}

.recognition-summary-focus-icon svg {
    width: 100%;
    height: 100%;
}

.recognition-summary-focus span {
    display: block;
    font-family: "DM Sans", sans-serif;
    font-size: 1.05rem;
    line-height: 1.3;
}

.focus-safety {
    color: #5b8a13;
}

.focus-social {
    color: #7c4ae1;
}

.focus-sustainability {
    color: #60911c;
}

.focus-systems {
    color: #3767ff;
}

.recognition-summary-standard {
    display: grid;
    grid-template-columns: 12rem minmax(0, 1fr);
    gap: 1rem;
    align-items: center;
}

.recognition-summary-logo {
    margin: 0;
    aspect-ratio: 1 / 1;
    border-radius: 1rem;
    background: #ffffff;
    border: 1px solid rgba(23, 50, 103, 0.08);
    padding: 0.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.recognition-summary-logo img {
    width: 100%;
    max-width: 100%;
    height: 9rem;
    object-fit: contain;
}

.recognition-summary-standard strong {
    color: #203a72;
    font-family: "DM Sans", sans-serif;
    font-size: 1rem;
    line-height: 1.3;
}

.recognition-summary-count,
.recognition-summary-total {
    color: #173267;
    font-family: "DM Sans", sans-serif;
    font-size: 1.5rem;
    font-weight: 700;
    text-align: center;
}

.recognition-summary-link {
    border: 0;
    background: transparent;
    color: #1c4084;
    font-weight: 700;
    text-decoration: underline;
    text-underline-offset: 0.18em;
}

.recognition-summary-link:hover,
.recognition-summary-link:focus {
    color: #0f2753;
}

.recognition-summary-table tfoot th {
    text-transform: uppercase;
    color: #173267;
    font-family: "DM Sans", sans-serif;
    font-size: 0.98rem;
    letter-spacing: 0.08em;
}

.recognition-modal {
    border: 0;
    border-radius: 1.5rem;
    overflow: hidden;
    box-shadow: 0 28px 70px rgba(4, 18, 44, 0.25);
}

.recognition-modal .modal-header {
    padding: 1.25rem 1.35rem 0;
    border-bottom: 0;
}

.recognition-modal .modal-body {
    padding: 1.35rem;
}

.recognition-modal-grid {
    display: grid;
    grid-template-columns: 13rem minmax(0, 1fr);
    gap: 1.5rem;
    align-items: start;
}

.recognition-modal-logo {
    border-radius: 1.25rem;
    border: 1px solid rgba(23, 50, 103, 0.08);
    background: #f8fbff;
    padding: 0rem;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 11rem;
}

.recognition-modal-logo img {
    max-width: 100%;
    max-height: 12rem;
    object-fit: contain;
}

.recognition-modal-scope {
    display: inline-flex;
    margin-bottom: 0.75rem;
    padding: 0.4rem 0.7rem;
    border-radius: 999px;
    background: #edf3ff;
    color: #1c4084;
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.recognition-modal-copy h4 {
    color: #173267;
    margin-bottom: 0.9rem;
}

.recognition-modal-copy p {
    color: #4b5d78;
    line-height: 1.55;
}

.recognition-modal-copy a {
    color: #1c4084;
    font-weight: 700;
}

.modal-backdrop {
    --bs-backdrop-bg: #041d3c;
    --bs-backdrop-opacity: 0.95;
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
}

.site-footer {
    padding: 2rem 0 3rem;
}

.site-footer p {
    color: var(--camimex-muted);
    font-size: 0.95rem;
}

@media (max-width: 991.98px) {
     :root {
        --section-scroll-offset: 6.5rem;
    }
    .masthead {
        min-height: 40rem;
        padding: 6.5rem 0 1.5rem;
    }
    .masthead::before {
        background-position: 64% 50%;
    }
    .masthead::after {
        background: linear-gradient(90deg, rgba(5, 18, 39, 0.84) 0%, rgba(5, 18, 39, 0.36) 34%, rgba(5, 18, 39, 0.12) 66%, rgba(5, 18, 39, 0) 100%), linear-gradient(180deg, rgba(5, 18, 39, 0.2) 0%, rgba(5, 18, 39, 0.08) 34%, rgba(5, 18, 39, 0.64) 100%);
    }
    .masthead-layout {
        min-height: auto;
    }
    .masthead-copy {
        min-height: 32rem;
        align-items: flex-end;
        padding: 1rem 0 1.75rem;
    }
    .masthead-copy>div {
        max-width: 31rem;
    }
    .masthead-copy h1 {
        font-size: clamp(3.15rem, 9.6vw, 4.85rem);
    }
    .headline-panel-rail {
        min-height: auto;
    }
    .category-heading {
        flex-direction: column;
    }
    .logos-hero {
        min-height: auto;
    }
    .logos-copy {
        max-width: none;
        padding-bottom: 0;
    }
    .recognition-scorecard {
        max-width: none;
        margin-left: 0;
    }
}

@media (max-width: 767.98px) {
     :root {
        --section-scroll-offset: 6rem;
    }
    .masthead {
        min-height: clamp(34rem, 92svh, 44rem);
        padding: 5.75rem 0 1.25rem;
    }
    .masthead::before {
        background-position: 70% 50%;
        transform: scale(1.04);
    }
    .masthead::after {
        background: linear-gradient(90deg, rgba(5, 18, 39, 0.84) 0%, rgba(5, 18, 39, 0.36) 34%, rgba(5, 18, 39, 0.12) 66%, rgba(5, 18, 39, 0) 100%), linear-gradient(180deg, rgba(5, 18, 39, 0.2) 0%, rgba(5, 18, 39, 0.08) 34%, rgba(5, 18, 39, 0.64) 100%);
    }
    .masthead-copy {
        min-height: clamp(28rem, 76svh, 36rem);
        padding: 0.5rem 0 2rem;
    }
    .masthead-copy>div {
        max-width: 100%;
    }
    .masthead-copy h1 {
        font-size: clamp(2.8rem, 14vw, 3.15rem);
        line-height: 0.92;
        margin-bottom: 1rem;
    }
    .hero-kicker {
        max-width: 100%;
        font-size: 0.88rem;
        line-height: 1.4;
        letter-spacing: 0.07em;
        color: rgba(255, 255, 255, 0.88);
    }
    .section-space {
        padding: 3.5rem 0;
    }
    .editorial-block,
    .headline-panel,
    .overview-card,
    .category-block,
    .editorial-panel,
    .table-panel {
        padding: 1.3rem;
        border-radius: 0;
    }
    .media-card,
    .feature-brief img {
        min-height: 220px;
    }
    .logos-copy h2 {
        font-size: clamp(2.2rem, 8vw, 3rem);
    }
    .logos-pillars {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 1rem 1.2rem;
    }
    .logos-pillar,
    .logos-pillar:last-child {
        padding-right: 0;
        border-right: 0;
    }
    .recognition-scorecard {
        padding: 1.5rem 1.2rem 1.35rem;
    }
    .recognition-scorecard-stats {
        grid-template-columns: 1fr;
        gap: 1.2rem;
    }
    .recognition-scorecard-stat {
        padding: 0;
    }
    .recognition-scorecard-stat+.recognition-scorecard-stat {
        border-left: 0;
        border-top: 1px solid rgba(255, 255, 255, 0.14);
        padding-top: 1.2rem;
    }
    .recognition-summary-shell {
        padding: 0.8rem;
        border-radius: 1.2rem;
    }
    .recognition-summary-focus {
        min-width: 13rem;
        width: 13rem;
    }
    .recognition-summary-focus-inner {
        gap: 0.8rem;
    }
    .recognition-summary-focus-icon {
        width: 2.6rem;
        height: 2.6rem;
    }
    .recognition-summary-standard {
        grid-template-columns: 1fr;
        gap: 0.75rem;
    }
    .recognition-summary-logo {
        width: 100%;
        max-width: 7.2rem;
    }
    .recognition-modal-grid {
        grid-template-columns: 1fr;
    }
    .recognition-modal-logo {
        min-height: 8rem;
    }
    .metrics-grid {
        grid-template-columns: 1fr;
    }
    .headline-split {
        grid-template-columns: 1fr;
    }
    .logo-item {
        padding: 0.65rem;
    }
    .logo-item img {
        max-width: 90%;
        max-height: 90%;
    }
}