/**
 * CESCE Pro - Navigation & Mega Menu Styles
 * Premium institutional responsive navigation
 * 
 * @package cesceprotheme
 */

/* ============================================================================
   CUSTOM PROPERTIES - CESCE BRANDING
   ============================================================================ */

:root {
    /* CESCE Colors */
    --cesce-navy: #002B55;
    --cesce-blue: #123B6D;
    --cesce-gold: #D49A19;
    --cesce-white: #FFFFFF;
    --cesce-cream: #F8F2E7;
    --cesce-border: rgba(0, 0, 0, 0.08);
    
    /* Navigation Dimensions */
    --cesce-header-height: 92px;
    --cesce-mega-gap: 28px;
    --cesce-mega-width: min(1280px, calc(100vw - 32px));
    --cesce-mega-column-gap: 24px;
}

/* ============================================================================
   PRIMARY MENU - ENHANCED FOR CESCE
   ============================================================================ */

.primary-menu {
    gap: clamp(20px, 2.5vw, 38px);
}

.primary-menu a {
    font-family: var(--cesce-font-body);
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.5px;
    line-height: 1.5;
}

.primary-menu a::after {
    background: var(--cesce-gold);
    height: 2px;
    bottom: 28px;
}

.primary-menu a:hover,
.primary-menu a:focus,
.primary-menu .current-menu-item > a,
.primary-menu .current-menu-ancestor > a {
    color: var(--cesce-blue);
}

.primary-menu > li:last-child > a {
    min-height: 46px;
    padding: 14px 24px;
    border-radius: 5px;
    background: var(--cesce-gold);
    color: var(--cesce-white);
    box-shadow: 0 14px 28px rgba(212, 154, 25, 0.24);
    line-height: 1.2;
    text-align: center;
    transition: background 200ms ease, box-shadow 200ms ease, color 200ms ease, transform 200ms ease;
}

.primary-menu > li:last-child > a::after {
    display: none;
}

.primary-menu > li:last-child > a:hover,
.primary-menu > li:last-child > a:focus {
    background: var(--cesce-blue);
    color: var(--cesce-white);
    box-shadow: 0 14px 30px rgba(18, 59, 109, 0.2);
    transform: translateY(-1px);
}

/* Menu item with mega menu styling */
.cesce-has-mega > a {
    position: relative;
    color: var(--cesce-text, #1e1e24);
}

.cesce-has-mega > a:hover,
.cesce-has-mega:focus-within > a,
.cesce-has-mega.is-submenu-open > a {
    color: var(--cesce-blue);
}

/* ============================================================================
   MEGA MENU PANEL - CESCE PRO
   ============================================================================ */

.cesce-mega-panel {
    position: fixed;
    top: var(--cesce-header-height);
    left: 50%;
    z-index: 999;
    width: var(--cesce-mega-width);
    max-width: 100%;
    margin-top: 0;
    padding: 0;
    background: var(--cesce-white);
    border: 1px solid var(--cesce-border);
    border-radius: 0;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.1);
    opacity: 0;
    visibility: hidden;
    transform: translate(-50%, -8px);
    transition: opacity 200ms ease-out, transform 200ms ease-out, visibility 200ms ease-out;
    pointer-events: none;
}

/* Show mega menu on hover/focus/active */
.cesce-mega-trigger:hover > .cesce-mega-panel,
.cesce-mega-trigger:focus-within > .cesce-mega-panel,
.cesce-mega-trigger.is-open > .cesce-mega-panel {
    opacity: 1;
    visibility: visible;
    transform: translate(-50%, 0);
    pointer-events: auto;
}

/* Close transition */
.cesce-mega-panel[aria-hidden="true"] {
    opacity: 0;
    visibility: hidden;
    transform: translate(-50%, -8px);
    pointer-events: none;
}

/* Inner Container */
.cesce-mega-inner {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--cesce-mega-gap);
    padding: 32px;
    align-items: start;
}

.cesce-mega-inner.no-cta {
    grid-template-columns: 1fr;
}

/* Columns Layout */
.cesce-mega-columns {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: var(--cesce-mega-column-gap);
    width: 100%;
}

/* Individual Column */
.cesce-mega-col {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* Column Title */
.cesce-col-title {
    margin: 0;
    padding: 0;
    font-family: var(--cesce-font-body);
    font-size: 14px;
    font-weight: 700;
    line-height: 1.4;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    color: var(--cesce-blue);
    position: relative;
    padding-bottom: 10px;
}

.cesce-col-title::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 32px;
    height: 3px;
    background: var(--cesce-gold);
    border-radius: 2px;
}

/* Column Links */
.cesce-col-links {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.cesce-col-links li {
    margin: 0;
}

.cesce-col-links a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 7px 0;
    font-family: var(--cesce-font-body);
    font-size: 14px;
    font-weight: 500;
    line-height: 1.5;
    color: #1e1e24;
    transition: color 180ms ease, transform 180ms ease;
    position: relative;
}

.cesce-col-links a:hover,
.cesce-col-links a:focus {
    color: var(--cesce-gold);
    transform: translateX(4px);
}

.cesce-col-links a::after {
    display: none;
}

/* Sections (for admin/legal groups) */
.cesce-col-sections {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.cesce-section {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.cesce-section-label {
    display: block;
    margin: 0;
    padding: 0;
    font-family: var(--cesce-font-body);
    font-size: 12px;
    font-weight: 600;
    color: var(--cesce-blue);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    opacity: 0.8;
}

.cesce-section-links {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.cesce-section-links a {
    font-size: 13px;
    color: #1e1e24;
}

/* Dynamic Posts Section */
.cesce-dynamic-posts {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 6px;
}

.cesce-latest-items {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.cesce-latest-items li {
    margin: 0;
}

.cesce-latest-items a {
    display: flex;
    flex-direction: column;
    gap: 3px;
    padding: 0;
    font-size: 13px;
    font-weight: 500;
    color: #1e1e24;
}

.cesce-latest-items small {
    display: block;
    font-size: 11px;
    color: #666;
    font-weight: 400;
}

/* ============================================================================
   MEGA MENU CTA SECTION
   ============================================================================ */

.cesce-mega-cta {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    gap: 14px;
    padding: 24px;
    background: var(--cesce-cream);
    border-radius: 12px;
    width: 280px;
    min-height: fit-content;
}

.cesce-cta-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    color: var(--cesce-blue);
    background: rgba(18, 59, 109, 0.06);
    border: 1px solid rgba(18, 59, 109, 0.12);
    border-radius: 14px;
    line-height: 1;
}

.cesce-cta-icon svg {
    display: block;
    width: 28px;
    height: 28px;
}

.cesce-mega-cta h3 {
    margin: 0;
    padding: 0;
    font-family: var(--cesce-font-body);
    font-size: 16px;
    font-weight: 700;
    line-height: 1.4;
    color: var(--cesce-blue);
}

.cesce-mega-cta p {
    margin: 0;
    padding: 0;
    font-size: 13px;
    font-weight: 400;
    line-height: 1.6;
    color: #1e1e24;
}

.cesce-cta-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 18px;
    margin-top: 8px;
    background: var(--cesce-gold);
    color: #fff;
    font-size: 13px;
    font-weight: 700;
    line-height: 1.2;
    text-decoration: none;
    border-radius: 6px;
    transition: all 200ms ease;
    align-self: flex-start;
}

.cesce-cta-btn:hover,
.cesce-cta-btn:focus {
    background: var(--cesce-blue);
    transform: translateY(-2px);
    box-shadow: 0 8px 16px rgba(18, 59, 109, 0.2);
}

/* Featured publication section */
.cesce-mega-featured {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 18px;
    background: #f0f0f0;
    border-radius: 8px;
    width: 260px;
}

.cesce-featured-image {
    display: block;
    width: 100%;
    height: 120px;
    object-fit: cover;
    border-radius: 6px;
}

.cesce-mega-featured h3 {
    margin: 0;
    padding: 0;
    font-size: 14px;
    font-weight: 700;
    color: var(--cesce-blue);
    line-height: 1.4;
}

.cesce-mega-featured p {
    margin: 0;
    padding: 0;
    font-size: 12px;
    color: #1e1e24;
    line-height: 1.5;
}

.cesce-featured-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 14px;
    background: var(--cesce-gold);
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    text-decoration: none;
    border-radius: 6px;
    transition: all 180ms ease;
    margin-top: 4px;
}

.cesce-featured-btn:hover {
    background: var(--cesce-blue);
    transform: translateY(-1px);
}

/* Highlight section */
.cesce-mega-highlight {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 20px;
    background: linear-gradient(135deg, var(--cesce-blue) 0%, #0a1f3a 100%);
    border-radius: 8px;
    color: white;
    width: 280px;
}

.cesce-mega-highlight h3 {
    margin: 0;
    padding: 0;
    font-size: 15px;
    font-weight: 700;
    color: white;
    line-height: 1.4;
}

.cesce-mega-highlight p {
    margin: 0;
    padding: 0;
    font-size: 13px;
    color: rgba(255, 255, 255, 0.9);
    line-height: 1.6;
}

.cesce-highlight-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 11px 16px;
    background: var(--cesce-gold);
    color: #fff;
    font-size: 13px;
    font-weight: 700;
    text-decoration: none;
    border-radius: 6px;
    transition: all 180ms ease;
    margin-top: 4px;
    align-self: flex-start;
}

.cesce-highlight-btn:hover {
    background: #fff;
    color: var(--cesce-blue);
    transform: translateY(-2px);
}

/* ============================================================================
   DROPDOWN MENUS (SIMPLE - AGENDA, GALERIE)
   ============================================================================ */

.primary-menu .sub-menu {
    min-width: 240px;
    max-width: 280px;
    background: var(--cesce-white);
    border: 1px solid var(--cesce-border);
    border-radius: 8px;
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.12);
    padding: 12px 0;
    list-style: none;
}

.primary-menu .sub-menu a {
    padding: 11px 16px;
    font-size: 14px;
    font-weight: 500;
    color: #1e1e24;
    text-transform: none;
}

.primary-menu .sub-menu a:hover {
    color: var(--cesce-gold);
    background: rgba(212, 154, 25, 0.08);
}

/* ============================================================================
   MOBILE MENU TOGGLE
   ============================================================================ */

.menu-toggle {
    display: none;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    padding: 0;
    background: transparent;
    border: none;
    cursor: pointer;
    z-index: 1001;
}

.menu-toggle span:not(.screen-reader-text) {
    display: block;
    width: 24px;
    height: 2px;
    background: var(--cesce-blue);
    transition: all 200ms ease;
    border-radius: 2px;
}

.menu-toggle span:nth-child(1) {
    margin-bottom: 5px;
}

.menu-toggle span:nth-child(2) {
    margin-bottom: 5px;
}

.menu-toggle[aria-expanded="true"] span:nth-child(1) {
    transform: rotate(45deg) translate(10px, 10px);
}

.menu-toggle[aria-expanded="true"] span:nth-child(2) {
    opacity: 0;
}

.menu-toggle[aria-expanded="true"] span:nth-child(3) {
    transform: rotate(-45deg) translate(7px, -7px);
}

/* ============================================================================
   RESPONSIVE - TABLET (768px - 1023px)
   ============================================================================ */

@media (max-width: 1199px) {
    .cesce-mega-inner {
        grid-template-columns: 1fr;
        padding: 24px;
        gap: 20px;
    }
    
    .cesce-mega-columns {
        grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
        gap: 18px;
    }
    
    .cesce-mega-cta,
    .cesce-mega-featured,
    .cesce-mega-highlight {
        width: 100%;
    }
    
    .cesce-mega-panel {
        width: 95vw;
    }
}

@media (max-width: 991px) {
    /* Hide mega menu on tablet and smaller */
    .cesce-mega-panel {
        display: none;
    }
    
    /* Show menu toggle */
    .menu-toggle {
        display: flex;
    }
    
    /* Responsive header */
    .header-inner {
        min-height: 80px;
        gap: 16px;
    }
    
    .site-navigation {
        position: fixed;
        top: 80px;
        left: 0;
        right: 0;
        bottom: 0;
        background: var(--cesce-white);
        border-top: 1px solid var(--cesce-border);
        max-height: calc(100vh - 80px);
        overflow-y: auto;
        z-index: 999;
        opacity: 0;
        visibility: hidden;
        transition: opacity 200ms ease, visibility 200ms ease;
    }
    
    .site-navigation.is-open {
        opacity: 1;
        visibility: visible;
    }
    
    /* Accordion style primary menu */
    .primary-menu {
        display: flex;
        flex-direction: column;
        gap: 0;
        padding: 16px 0;
    }
    
    .primary-menu li {
        position: relative;
        width: 100%;
    }
    
    .primary-menu a {
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        padding: 14px 20px;
        text-transform: none;
        border-bottom: 1px solid var(--cesce-border);
    }
    
    .primary-menu a::after {
        display: none;
    }
    
    .primary-menu a:hover {
        background: rgba(18, 59, 109, 0.05);
        color: var(--cesce-blue);
    }
    
    /* Chevron indicator for items with submenu */
    .primary-menu .menu-item-has-children > a::before {
        content: '';
        display: block;
        width: 6px;
        height: 6px;
        border-right: 2px solid var(--cesce-blue);
        border-bottom: 2px solid var(--cesce-blue);
        transform: rotate(-45deg);
        order: 2;
        transition: transform 200ms ease;
    }
    
    .primary-menu .is-submenu-open > a::before {
        transform: rotate(45deg) translateY(-2px);
    }
    
    /* Submenu accordion */
    .primary-menu .sub-menu {
        position: static;
        display: none;
        width: 100%;
        max-width: none;
        max-height: 0;
        margin: 0;
        padding: 0;
        background: rgba(18, 59, 109, 0.05);
        border: none;
        border-radius: 0;
        box-shadow: none;
        opacity: 1;
        visibility: visible;
        transform: none;
        overflow: hidden;
        transition: max-height 200ms ease;
    }
    
    .primary-menu .is-submenu-open > .sub-menu {
        display: block;
        max-height: 600px;
        padding: 8px 0;
    }
    
    .primary-menu .sub-menu a {
        padding: 11px 40px 11px 30px;
        font-size: 14px;
        border: none;
    }
    
    .primary-menu .sub-menu li + li {
        margin-top: 0;
    }
    
    /* Nested sub-menus */
    .primary-menu .sub-menu .menu-item-has-children > a::before {
        content: '';
        display: inline-block;
        width: 5px;
        height: 5px;
        border-right: 2px solid #1e1e24;
        border-bottom: 2px solid #1e1e24;
        transform: rotate(-45deg);
        margin-left: auto;
        margin-right: 8px;
    }

    .primary-menu > li:last-child {
        padding: 12px 20px 0;
    }

    .primary-menu > li:last-child > a {
        justify-content: center;
        width: 100%;
        min-height: 48px;
        padding: 14px 20px;
        border-bottom: 0;
    }
    
    .header-cta {
        display: none;
    }
}

/* ============================================================================
   RESPONSIVE - MOBILE (< 768px)
   ============================================================================ */

@media (max-width: 767px) {
    :root {
        --cesce-header-height: 70px;
    }
    
    .site-header {
        border-bottom: 1px solid var(--cesce-border);
    }
    
    .header-inner {
        min-height: 70px;
        gap: 12px;
        padding: 0 12px;
    }
    
    .site-brand {
        width: var(--cesce-header-logo-width, 140px);
    }
    
    .site-navigation {
        top: 70px;
        max-height: calc(100vh - 70px - 56px); /* Account for mobile CTA button */
    }
    
    .primary-menu {
        padding: 12px 0;
    }
    
    .primary-menu a {
        padding: 12px 16px;
        font-size: 14px;
    }
    
    .primary-menu .sub-menu a {
        padding: 10px 36px 10px 24px;
        font-size: 13px;
    }
    
    /* Mobile CTA button at bottom */
    .header-cta {
        position: fixed;
        bottom: 16px;
        left: 16px;
        right: 16px;
        width: calc(100% - 32px);
        min-height: 48px;
        z-index: 998;
        display: flex;
        align-items: center;
        justify-content: center;
        margin: 0;
        background: var(--cesce-gold);
        border: none;
        border-radius: 8px;
        color: white;
        font-weight: 700;
        font-size: 14px;
        box-shadow: 0 8px 24px rgba(212, 154, 25, 0.3);
    }
    
    .header-cta:hover {
        background: var(--cesce-blue);
        box-shadow: 0 8px 28px rgba(18, 59, 109, 0.25);
    }
    
    .menu-toggle {
        width: 40px;
        height: 40px;
    }
    
    .menu-toggle span:nth-child(1),
    .menu-toggle span:nth-child(2) {
        margin-bottom: 4px;
    }
}

/* ============================================================================
   ACCESSIBILITY
   ============================================================================ */

/* Focus visible for keyboard navigation */
.cesce-mega-panel a:focus-visible,
.primary-menu a:focus-visible {
    outline: 2px solid var(--cesce-gold);
    outline-offset: 2px;
}

/* Skip links remain accessible */
.skip-link:focus {
    z-index: 10000;
}

/* Reduce motion for users who prefer it */
@media (prefers-reduced-motion: reduce) {
    .cesce-mega-panel,
    .primary-menu .sub-menu,
    .cesce-col-links a,
    .cesce-cta-btn,
    .menu-toggle span {
        transition: none;
    }
}

/* ============================================================================
   PRINT STYLES
   ============================================================================ */

@media print {
    .site-header,
    .menu-toggle {
        display: none;
    }
}

/* ============================================================================
   PREMIUM INSTITUTIONAL MEGA MENU REFINEMENT
   ============================================================================ */

:root {
    --cesce-mega-width: min(1248px, calc(100vw - 48px));
    --cesce-mega-gap: clamp(28px, 3vw, 44px);
    --cesce-mega-column-gap: clamp(24px, 2.6vw, 38px);
    --cesce-ink: #152235;
    --cesce-muted: #5f6b7a;
    --cesce-gold-soft: #e7b64e;
    --cesce-cream-panel: #fbf5ea;
    --cesce-shadow-premium: 0 22px 55px rgba(0, 31, 66, 0.14), 0 4px 18px rgba(0, 31, 66, 0.08);
}

.cesce-mega-panel {
    top: calc(var(--cesce-header-height) + 8px);
    overflow: hidden;
    background: var(--cesce-white);
    border: 1px solid rgba(0, 43, 85, 0.08);
    border-radius: 18px;
    box-shadow: var(--cesce-shadow-premium);
    transform: translate(-50%, -10px) scale(0.985);
    transition: opacity 200ms ease, transform 200ms ease, visibility 200ms ease;
}

.cesce-mega-panel::before {
    content: '';
    position: absolute;
    inset: 0 0 auto;
    height: 4px;
    background: linear-gradient(90deg, var(--cesce-blue), var(--cesce-gold), var(--cesce-blue));
    opacity: 0.9;
}

.cesce-mega-trigger:hover > .cesce-mega-panel,
.cesce-mega-trigger:focus-within > .cesce-mega-panel,
.cesce-mega-trigger.is-open > .cesce-mega-panel {
    transform: translate(-50%, 0) scale(1);
}

.cesce-mega-panel[aria-hidden="true"] {
    transform: translate(-50%, -10px) scale(0.985);
}

.cesce-mega-inner {
    grid-template-columns: minmax(0, 1fr) minmax(260px, 315px);
    gap: var(--cesce-mega-gap);
    width: 100%;
    max-width: 1248px;
    padding: clamp(34px, 3.2vw, 46px);
    margin: 0 auto;
}

.cesce-mega-inner.no-cta {
    grid-template-columns: 1fr;
}

.cesce-mega-columns {
    grid-template-columns: repeat(auto-fit, minmax(178px, 1fr));
    gap: var(--cesce-mega-column-gap);
    align-items: start;
}

.cesce-mega-col {
    min-width: 0;
    gap: 18px;
}

.cesce-col-title {
    font-family: var(--cesce-font-body);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.12em;
    color: var(--cesce-blue);
    padding-bottom: 13px;
}

.cesce-col-title::after {
    width: 42px;
    height: 2px;
    background: linear-gradient(90deg, var(--cesce-gold), var(--cesce-gold-soft));
}

.cesce-col-links,
.cesce-section-links,
.cesce-latest-items {
    gap: 7px;
}

.cesce-col-links a,
.cesce-section-links a,
.cesce-latest-items a {
    width: 100%;
    min-height: 34px;
    padding: 6px 0;
    font-family: var(--cesce-font-body);
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 0.01em;
    color: var(--cesce-ink);
    border-radius: 9px;
    transition: color 200ms ease, transform 200ms ease, background-color 200ms ease;
}

.cesce-col-links a::before,
.cesce-section-links a::before {
    content: '';
    width: 15px;
    height: 15px;
    flex: 0 0 15px;
    border: 1.7px solid rgba(18, 59, 109, 0.72);
    border-radius: 4px;
    background: transparent;
    box-shadow: inset 0 0 0 2px var(--cesce-white);
    transform: none;
    transition: border-color 200ms ease, background-color 200ms ease, transform 200ms ease;
}

.cesce-col-links a:hover,
.cesce-col-links a:focus,
.cesce-section-links a:hover,
.cesce-section-links a:focus,
.cesce-latest-items a:hover,
.cesce-latest-items a:focus {
    color: var(--cesce-gold);
    background: rgba(212, 154, 25, 0.075);
    transform: translateX(3px);
}

.cesce-col-links a:hover::before,
.cesce-col-links a:focus::before,
.cesce-section-links a:hover::before,
.cesce-section-links a:focus::before {
    border-color: var(--cesce-gold);
    background: rgba(212, 154, 25, 0.14);
    transform: translateX(1px);
}

.cesce-section-label {
    color: var(--cesce-muted);
    font-size: 11px;
    letter-spacing: 0.13em;
}

.cesce-mega-cta,
.cesce-mega-featured,
.cesce-mega-highlight {
    width: 100%;
    min-height: 100%;
    padding: 28px;
    border: 1px solid rgba(212, 154, 25, 0.18);
    border-radius: 16px;
    background: linear-gradient(145deg, var(--cesce-cream-panel), #fffaf1);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
}

.cesce-mega-cta .cesce-cta-icon,
.cesce-mega-highlight .cesce-cta-icon {
    margin-bottom: 2px;
}

.cesce-mega-cta h3,
.cesce-mega-featured h3,
.cesce-mega-highlight h3 {
    font-family: var(--cesce-font-body);
    font-weight: 700;
    color: var(--cesce-blue);
    letter-spacing: -0.01em;
}

.cesce-mega-cta p,
.cesce-mega-featured p,
.cesce-mega-highlight p,
.cesce-latest-items small {
    color: var(--cesce-muted);
}

.cesce-cta-btn,
.cesce-featured-btn,
.cesce-highlight-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    padding: 11px 18px;
    border: 1px solid var(--cesce-gold);
    border-radius: 6px;
    background: var(--cesce-gold);
    color: var(--cesce-white);
    font-family: var(--cesce-font-body);
    font-size: 13px;
    font-weight: 700;
    box-shadow: 0 10px 22px rgba(207, 145, 24, 0.18);
    transition: color 200ms ease, border-color 200ms ease, background-color 200ms ease, box-shadow 200ms ease, transform 200ms ease;
}

.cesce-cta-btn:hover,
.cesce-cta-btn:focus,
.cesce-featured-btn:hover,
.cesce-featured-btn:focus,
.cesce-highlight-btn:hover,
.cesce-highlight-btn:focus {
    color: var(--cesce-white);
    border-color: #b77f0f;
    background: #b77f0f;
    box-shadow: 0 12px 26px rgba(183, 127, 15, 0.24);
    transform: translateY(-1px);
}

@media (max-width: 1199px) {
    .cesce-mega-panel {
        width: min(96vw, 1120px);
    }

    .cesce-mega-inner {
        grid-template-columns: 1fr;
        padding: 30px;
    }

    .cesce-mega-cta,
    .cesce-mega-featured,
    .cesce-mega-highlight {
        min-height: auto;
    }
}

@media (max-width: 991px) {
    .cesce-mega-panel {
        display: none;
    }

    .primary-menu {
        overflow-x: hidden;
    }
}

@media (max-width: 767px) {
    .primary-menu .sub-menu {
        box-shadow: none;
        border-radius: 0;
    }

    .primary-menu .sub-menu a {
        min-height: 42px;
    }
}

/* ============================================================================
   MOBILE MENU VIEWPORT FIX
   ============================================================================
   Keep the mobile drawer fully visible on real mobile browsers where 100vh can
   include hidden browser chrome. This also overrides the legacy max-height
   rules from theme.css and the earlier CTA subtraction in this file.
*/

@media (max-width: 991px) {
    :root {
        --cesce-header-height: 80px;
    }

    .site-navigation {
        top: var(--cesce-header-height, 80px);
        bottom: 0;
        height: calc(100dvh - var(--cesce-header-height, 80px));
        max-height: none;
        overflow-y: auto;
        overscroll-behavior: contain;
        -webkit-overflow-scrolling: touch;
    }

    .site-navigation.is-open {
        display: block;
    }

    .primary-menu {
        min-height: 100%;
        max-height: none;
        overflow: visible;
        padding-bottom: calc(24px + env(safe-area-inset-bottom, 0px));
    }
}

@supports not (height: 100dvh) {
    @media (max-width: 991px) {
        .site-navigation {
            height: calc(100vh - var(--cesce-header-height, 80px));
        }
    }
}

/* ============================================================================
   SPLIT DESKTOP / MOBILE-TABLET NAVIGATION
   ============================================================================ */

.mobile-tablet-navigation {
    display: none;
}

@media (min-width: 992px) {
    .desktop-navigation {
        display: block;
    }

    .mobile-tablet-navigation,
    .mobile-tablet-navigation.is-open {
        display: none;
    }
}

@media (max-width: 991px) {
    .desktop-navigation {
        display: none;
    }

    .mobile-tablet-navigation {
        position: fixed;
        top: var(--cesce-header-height, 80px);
        left: 0;
        right: 0;
        bottom: 0;
        height: calc(100dvh - var(--cesce-header-height, 80px));
        max-height: none;
        overflow-y: auto;
        overscroll-behavior: contain;
        -webkit-overflow-scrolling: touch;
        z-index: 999;
        background: var(--cesce-white);
        border-top: 1px solid var(--cesce-border);
        opacity: 0;
        visibility: hidden;
        transition: opacity 200ms ease, visibility 200ms ease;
    }

    .mobile-tablet-navigation.is-open {
        display: block;
        opacity: 1;
        visibility: visible;
    }

    .mobile-tablet-menu {
        display: flex;
        flex-direction: column;
        gap: 0;
        min-height: 100%;
        max-height: none;
        overflow: visible;
        padding: 16px 0 calc(24px + env(safe-area-inset-bottom, 0px));
    }

    .mobile-tablet-menu > li:last-child {
        padding: 0;
    }

    .mobile-tablet-menu > li:last-child > a {
        justify-content: space-between;
        min-height: 0;
        padding: 14px 20px;
        border-radius: 0;
        background: transparent;
        box-shadow: none;
        color: var(--cesce-text, #1e1e24);
        transform: none;
    }

    .mobile-tablet-menu > li:last-child > a:hover,
    .mobile-tablet-menu > li:last-child > a:focus {
        background: rgba(18, 59, 109, 0.05);
        box-shadow: none;
        color: var(--cesce-blue);
        transform: none;
    }
}

@media (max-width: 767px) {
    .mobile-tablet-navigation {
        top: var(--cesce-header-height, 70px);
        height: calc(100dvh - var(--cesce-header-height, 70px));
    }
}

@supports not (height: 100dvh) {
    @media (max-width: 991px) {
        .mobile-tablet-navigation {
            height: calc(100vh - var(--cesce-header-height, 80px));
        }
    }
}

/* ============================================================================
   REFERENCE MOCKUP ALIGNMENT - DESKTOP MEGA MENU ONLY
   ============================================================================ */

@media (min-width: 992px) {
    :root {
        --cesce-mega-width: min(1216px, calc(100vw - 96px));
        --cesce-mega-gap: 42px;
        --cesce-mega-column-gap: 42px;
    }

    .cesce-mega-panel {
        top: calc(var(--cesce-header-height) + 1px);
        border-color: rgba(0, 43, 85, 0.13);
        border-radius: 5px;
        box-shadow: 0 16px 42px rgba(0, 28, 61, 0.14), 0 2px 8px rgba(0, 28, 61, 0.08);
    }

    .cesce-mega-panel::before {
        display: none;
    }

    .cesce-mega-inner {
        grid-template-columns: minmax(0, 1fr) 216px;
        gap: 44px;
        max-width: 1216px;
        padding: 30px 34px 34px;
        align-items: stretch;
    }

    .cesce-mega-columns {
        grid-template-columns: repeat(4, minmax(150px, 1fr));
        gap: 44px;
    }

    .cesce-mega-col {
        gap: 20px;
    }

    .cesce-col-title {
        font-size: 15px;
        line-height: 1.25;
        letter-spacing: 0.01em;
        padding-bottom: 14px;
    }

    .cesce-col-title::after {
        width: 30px;
        height: 1.5px;
    }

    .cesce-col-links,
    .cesce-section-links,
    .cesce-latest-items {
        gap: 15px;
    }

    .cesce-col-links a,
    .cesce-section-links a,
    .cesce-latest-items a {
        min-height: 25px;
        padding: 0;
        gap: 13px;
        font-size: 14px;
        line-height: 1.35;
        color: #0d2345;
        background: transparent;
        border-radius: 0;
        transform: none;
    }

    .cesce-col-links a::before,
    .cesce-section-links a::before {
        width: 18px;
        height: 18px;
        flex-basis: 18px;
        border-color: #10284c;
        border-radius: 3px;
        box-shadow: inset 0 0 0 3px #fff;
        opacity: 0.88;
    }

    .cesce-col-links a:hover,
    .cesce-col-links a:focus,
    .cesce-section-links a:hover,
    .cesce-section-links a:focus,
    .cesce-latest-items a:hover,
    .cesce-latest-items a:focus {
        color: var(--cesce-gold);
        background: transparent;
        transform: translateX(2px);
    }

    .cesce-section {
        gap: 13px;
    }

    .cesce-col-sections {
        gap: 19px;
    }

    .cesce-section + .cesce-section {
        padding-top: 17px;
        border-top: 1px solid rgba(16, 40, 76, 0.18);
    }

    .cesce-section-label {
        font-size: 12px;
        font-weight: 700;
        letter-spacing: 0.02em;
        color: var(--cesce-blue);
    }

    .cesce-mega-cta,
    .cesce-mega-featured,
    .cesce-mega-highlight {
        align-items: center;
        justify-content: center;
        min-height: 245px;
        padding: 28px 20px;
        text-align: center;
        border-color: rgba(212, 154, 25, 0.12);
        border-radius: 5px;
        background: linear-gradient(135deg, #fbf6ee 0%, #f6efe4 100%);
        box-shadow: none;
    }

    .cesce-cta-icon {
        width: 64px;
        height: 64px;
        margin: 0 auto 14px;
        color: var(--cesce-blue);
        background: #f8fafc;
        border: 1px solid rgba(16, 40, 76, 0.16);
        border-radius: 50%;
        box-shadow: 0 7px 18px rgba(0, 43, 85, 0.08);
    }

    .cesce-cta-icon svg {
        width: 36px;
        height: 36px;
    }

    .cesce-mega-cta h3,
    .cesce-mega-featured h3,
    .cesce-mega-highlight h3 {
        margin: 0;
        font-size: 16px;
        line-height: 1.25;
        text-transform: uppercase;
        color: var(--cesce-blue);
    }

    .cesce-mega-cta p,
    .cesce-mega-featured p,
    .cesce-mega-highlight p {
        max-width: 170px;
        margin: 0 auto;
        font-size: 14px;
        line-height: 1.55;
        color: #263a5b;
    }

    .cesce-cta-btn,
    .cesce-featured-btn,
    .cesce-highlight-btn {
        width: 100%;
        min-height: 42px;
        margin-top: 14px;
        padding: 11px 14px;
        border: 0;
        border-radius: 4px;
        background: linear-gradient(180deg, #dca21d 0%, #c98d06 100%);
        color: #fff;
        font-size: 12px;
        font-weight: 700;
        text-transform: uppercase;
        box-shadow: 0 7px 16px rgba(212, 154, 25, 0.24);
    }

    .cesce-cta-btn::after,
    .cesce-featured-btn::after,
    .cesce-highlight-btn::after {
        content: '\203A';
        margin-left: 9px;
        font-size: 18px;
        line-height: 0;
    }

    .cesce-cta-btn:hover,
    .cesce-cta-btn:focus,
    .cesce-featured-btn:hover,
    .cesce-featured-btn:focus,
    .cesce-highlight-btn:hover,
    .cesce-highlight-btn:focus {
        background: linear-gradient(180deg, #e2aa2e 0%, #d09610 100%);
        transform: translateY(-1px);
    }
}

@media (min-width: 992px) and (max-width: 1199px) {
    .cesce-mega-inner {
        grid-template-columns: 1fr 210px;
        gap: 28px;
        padding: 28px;
    }

    .cesce-mega-columns {
        gap: 26px;
    }
}

/* ============================================================================
   LE CESCE EXACT MOCKUP LOCKUP
   ============================================================================ */

@media (min-width: 992px) {
    .cesce-mega-panel[data-cesce-mega="cesce-institution"] {
        width: min(1240px, calc(100vw - 96px));
        border-radius: 4px;
        box-shadow: 0 14px 34px rgba(0, 29, 63, 0.13), 0 2px 7px rgba(0, 29, 63, 0.08);
    }

    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-mega-inner {
        grid-template-columns: minmax(0, 1fr) 220px;
        gap: 44px;
        max-width: 1240px;
        min-height: 292px;
        padding: 28px 32px 30px 32px;
        align-items: start;
    }

    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-mega-columns {
        grid-template-columns: repeat(4, minmax(0, 1fr));
        column-gap: 46px;
        row-gap: 0;
        align-items: start;
    }

    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-mega-col {
        gap: 19px;
        align-self: start;
    }

    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-col-title {
        min-height: 32px;
        margin: 0;
        padding: 0 0 12px 0;
        font-size: 15px;
        line-height: 1.2;
        font-weight: 700;
        letter-spacing: 0.01em;
        color: var(--cesce-blue);
    }

    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-col-title::after {
        width: 30px;
        height: 1.5px;
        background: var(--cesce-gold);
    }

    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-col-links,
    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-section-links {
        gap: 16px;
    }

    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-col-links a,
    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-section-links a {
        min-height: 24px;
        padding: 0;
        gap: 13px;
        font-size: 14px;
        line-height: 1.35;
        color: #10264b;
        white-space: nowrap;
    }

    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-col-links a::before,
    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-section-links a::before {
        width: 17px;
        height: 17px;
        flex: 0 0 17px;
        border-width: 1.4px;
        border-color: #10264b;
        border-radius: 3px;
        opacity: 0.9;
    }

    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-col-sections {
        gap: 18px;
    }

    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-section {
        gap: 13px;
    }

    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-section + .cesce-section {
        padding-top: 17px;
        border-top: 1px solid rgba(16, 38, 75, 0.18);
    }

    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-section-label {
        font-size: 12px;
        line-height: 1.2;
        font-weight: 700;
        letter-spacing: 0.01em;
        color: var(--cesce-blue);
    }

    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-mega-cta {
        width: 220px;
        min-height: 245px;
        align-self: stretch;
        justify-content: center;
        padding: 26px 19px;
        border-radius: 5px;
        background: #f7f1e8;
    }

    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-cta-icon {
        width: 64px;
        height: 64px;
        margin-bottom: 14px;
    }

    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-cta-icon svg {
        width: 36px;
        height: 36px;
    }

    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-mega-cta h3 {
        font-size: 16px;
        line-height: 1.25;
        text-transform: uppercase;
    }

    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-mega-cta p {
        max-width: 174px;
        font-size: 14px;
        line-height: 1.55;
    }

    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-cta-btn {
        width: 100%;
        min-height: 42px;
        margin-top: 14px;
        border-radius: 4px;
        text-align: center;
    }
}

/* ============================================================================
   DESKTOP MEGA MENU TYPOGRAPHY LIGHTENING
   ============================================================================ */

@media (min-width: 992px) {
    .cesce-mega-inner {
        align-items: start;
    }

    .cesce-mega-columns {
        align-items: start;
        column-gap: 36px;
        row-gap: 24px;
    }

    .cesce-mega-col {
        align-self: start;
        gap: 16px;
    }

    .cesce-col-title,
    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-col-title {
        min-height: 0;
        margin: 0;
        padding-bottom: 12px;
        font-size: 16px;
        font-weight: 600;
        line-height: 1.25;
        letter-spacing: 0;
        text-transform: none;
    }

    .cesce-col-title::after,
    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-col-title::after {
        width: 30px;
        height: 2px;
        background: var(--cesce-gold);
    }

    .cesce-col-links,
    .cesce-section-links,
    .cesce-latest-items,
    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-col-links,
    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-section-links {
        gap: 8px;
    }

    .cesce-col-links a,
    .cesce-section-links a,
    .cesce-latest-items a,
    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-col-links a,
    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-section-links a {
        min-height: 0;
        padding: 0;
        gap: 10px;
        font-family: Inter, var(--cesce-font-body);
        font-size: 14px;
        font-weight: 400;
        line-height: 1.6;
        letter-spacing: 0;
        color: var(--cesce-ink);
        white-space: normal;
    }

    .cesce-section-links a,
    .cesce-latest-items a,
    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-section-links a {
        padding-left: 10px;
        font-size: 13px;
        color: var(--cesce-muted);
    }

    .cesce-section-label,
    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-section-label {
        font-size: 12px;
        font-weight: 600;
        line-height: 1.3;
        letter-spacing: 0.02em;
    }

    .cesce-section,
    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-section {
        gap: 10px;
    }

    .cesce-col-sections,
    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-col-sections {
        gap: 18px;
    }

    .cesce-mega-cta,
    .cesce-mega-featured,
    .cesce-mega-highlight,
    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-mega-cta {
        align-self: start;
        justify-content: flex-start;
        min-height: auto;
        gap: 14px;
        padding: 24px 20px;
    }

    .cesce-mega-cta h3,
    .cesce-mega-featured h3,
    .cesce-mega-highlight h3,
    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-mega-cta h3 {
        font-size: 18px;
        font-weight: 600;
        line-height: 1.3;
        letter-spacing: 0;
    }

    .cesce-mega-cta p,
    .cesce-mega-featured p,
    .cesce-mega-highlight p,
    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-mega-cta p {
        font-size: 14px;
        font-weight: 400;
        line-height: 1.6;
    }

    .cesce-cta-btn,
    .cesce-featured-btn,
    .cesce-highlight-btn,
    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-cta-btn {
        width: fit-content;
        min-width: 0;
        min-height: 40px;
        margin: 4px auto 0;
        padding: 11px 20px;
        border-radius: 5px;
        background: var(--cesce-gold);
        color: var(--cesce-white);
        font-size: 14px;
        font-weight: 600;
        line-height: 1.25;
        text-transform: uppercase;
        box-shadow: 0 10px 22px rgba(212, 154, 25, 0.2);
    }

    .cesce-cta-btn::after,
    .cesce-featured-btn::after,
    .cesce-highlight-btn::after {
        content: none;
    }

    .cesce-cta-btn:hover,
    .cesce-cta-btn:focus,
    .cesce-featured-btn:hover,
    .cesce-featured-btn:focus,
    .cesce-highlight-btn:hover,
    .cesce-highlight-btn:focus {
        background: #b77f0f;
        color: var(--cesce-white);
        box-shadow: 0 12px 24px rgba(183, 127, 15, 0.24);
    }

    .cesce-mega-panel[data-cesce-mega="cesce-publications"] .cesce-cta-btn,
    .cesce-mega-panel[data-cesce-mega="cesce-works"] .cesce-highlight-btn,
    .cesce-mega-panel[data-cesce-mega="cesce-news"] .cesce-cta-btn {
        width: fit-content;
        min-width: 0;
        min-height: 40px;
        margin: 4px auto 0;
        padding: 11px 20px;
        border-radius: 5px;
        background: var(--cesce-gold);
        color: var(--cesce-white);
        font-size: 14px;
        font-weight: 600;
        line-height: 1.25;
        text-transform: uppercase;
        box-shadow: 0 10px 22px rgba(212, 154, 25, 0.2);
    }

    .cesce-mega-panel[data-cesce-mega="cesce-publications"] .cesce-cta-btn:hover,
    .cesce-mega-panel[data-cesce-mega="cesce-publications"] .cesce-cta-btn:focus,
    .cesce-mega-panel[data-cesce-mega="cesce-works"] .cesce-highlight-btn:hover,
    .cesce-mega-panel[data-cesce-mega="cesce-works"] .cesce-highlight-btn:focus,
    .cesce-mega-panel[data-cesce-mega="cesce-news"] .cesce-cta-btn:hover,
    .cesce-mega-panel[data-cesce-mega="cesce-news"] .cesce-cta-btn:focus {
        background: #b77f0f;
        color: var(--cesce-white);
    }

    .cesce-mega-panel[data-cesce-mega="cesce-publications"] .cesce-mega-inner,
    .cesce-mega-panel[data-cesce-mega="cesce-works"] .cesce-mega-inner,
    .cesce-mega-panel[data-cesce-mega="cesce-news"] .cesce-mega-inner {
        grid-template-columns: minmax(0, 1fr) 216px;
        gap: 36px;
    }

    .cesce-mega-panel[data-cesce-mega="cesce-publications"] .cesce-mega-columns,
    .cesce-mega-panel[data-cesce-mega="cesce-works"] .cesce-mega-columns,
    .cesce-mega-panel[data-cesce-mega="cesce-news"] .cesce-mega-columns {
        column-gap: 28px;
        row-gap: 22px;
    }

    .cesce-mega-panel[data-cesce-mega="cesce-publications"] .cesce-mega-columns {
        grid-template-columns:
            minmax(0, 1fr)
            minmax(0, 1.08fr)
            minmax(0, 1.02fr);
    }

    .cesce-mega-panel[data-cesce-mega="cesce-works"] .cesce-mega-columns {
        grid-template-columns:
            minmax(0, 1fr)
            minmax(0, 0.82fr)
            minmax(0, 1.22fr);
    }

    .cesce-mega-panel[data-cesce-mega="cesce-news"] .cesce-mega-columns {
        grid-template-columns:
            minmax(0, 1.12fr)
            minmax(0, 1fr)
            minmax(0, 1.05fr);
    }

    .cesce-mega-panel[data-cesce-mega="cesce-publications"] .cesce-mega-cta,
    .cesce-mega-panel[data-cesce-mega="cesce-works"] .cesce-mega-highlight,
    .cesce-mega-panel[data-cesce-mega="cesce-news"] .cesce-mega-cta {
        width: 216px;
    }
}

@media (min-width: 1200px) {
    .cesce-mega-panel[data-cesce-mega="cesce-publications"] .cesce-col-links a,
    .cesce-mega-panel[data-cesce-mega="cesce-works"] .cesce-col-links a,
    .cesce-mega-panel[data-cesce-mega="cesce-news"] .cesce-col-links a {
        white-space: nowrap;
    }

    .cesce-mega-panel[data-cesce-mega="cesce-news"] .cesce-latest-items a {
        white-space: normal;
    }
}

/* ============================================================================
   MEGA MENU LEVEL-2 TITLE HARMONIZATION
   ============================================================================ */

@media (min-width: 992px) {
    .cesce-mega-panel .cesce-col-title,
    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-col-title {
        display: flex;
        align-items: flex-start;
        min-height: 42px;
        margin: 0 0 2px;
        padding: 0 0 13px;
        font-family: var(--cesce-font-body, Inter, sans-serif);
        font-size: clamp(13px, 0.92vw, 14px);
        font-weight: 800;
        line-height: 1.35;
        letter-spacing: 0.08em;
        text-transform: uppercase;
        color: var(--cesce-blue);
    }

    .cesce-mega-panel .cesce-col-title::after,
    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-col-title::after {
        width: 38px;
        height: 3px;
        border-radius: 999px;
        background: linear-gradient(90deg, var(--cesce-gold), rgba(212, 154, 25, 0.35));
    }

    .cesce-mega-panel .cesce-mega-col,
    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-mega-col {
        gap: 15px;
    }

    .cesce-mega-panel .cesce-section-label,
    .cesce-mega-panel[data-cesce-mega="cesce-institution"] .cesce-section-label {
        font-family: var(--cesce-font-body, Inter, sans-serif);
        font-size: 11px;
        font-weight: 800;
        line-height: 1.35;
        letter-spacing: 0.09em;
        text-transform: uppercase;
        color: rgba(18, 59, 109, 0.82);
    }
}

@media (min-width: 1200px) {
    .cesce-mega-panel:not([data-cesce-mega="cesce-institution"]) .cesce-col-title {
        white-space: nowrap;
    }
}
