/**
Theme Name: astra-child
Author: Brainstorm Force
Author URI: http://wpastra.com/about/
Description: Astra is the fastest, fully customizable & beautiful theme suitable for blogs
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: astra-child
Template: astra
*/

:root {
    --f_blue: #003478;
}

body {
    font-family: 'Helvetica', sans-serif !important;
}


h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: "League Spartan", sans-serif !important;
}

.hero h1 {
    font-size: 5.6em;
}

.hero h2 {
    font-size: 1.7em !important;
    font-weight: 300 !important;
}

#wp-admin-bar-elementor_edit_page {
    display: none
}

.site-header-section .ast-builder-menu {
    margin-left: 30px !important;
}

.home-hero span {
    color: #3F9C35;
}

/* News Archive */
.wp-element-caption {
    font-size: 0.8em;
}

.blog figure img {
    min-width: 100%;
}

/* language switcher */
body .trp-language-switcher {
    height: auto;
    width: auto;
}

.trp-language-switcher>div {
    width: 40px !important;
    border: none;
    padding: 0px;
    background-position: center right;
}

.trp-language-switcher>div>a {
    padding: 0px;
    font-size: 0.85em;
}

.trp-language-switcher:focus .trp-ls-shortcode-language,
.trp-language-switcher:hover .trp-ls-shortcode-language {
    visibility: visible;
    max-height: 250px;
    padding: 0px 10px;
    height: auto;
    overflow-y: auto;
    position: absolute;
    left: 0;
    top: 0;
    display: inline-block !important;
    min-height: auto;
    width: 45px !important;
    border: 1px solid #e7e7e7;
    top: 2px;
    left: -10px;
}

body .elementor-shortcode .trp-ls-shortcode-current-language {
    width: 40px !important;
}

/* google map */
/* Style for the info window content */
.marker-info-window {
    position: relative;
    padding: 0px;
    font-size: 14px;
    line-height: 1.5;
    /* max-width: 400px; */
    white-space: normal;
    /* padding-right: 35px; */
}

/* Padding for main content below the heading */
.marker-info-window p {
    padding-top: 2px;
    margin: 0;
    font-size: 14px;
    color: #333;
}

.marker-info-window .popup-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.marker-info-window .popup-footer .category-name {
    font-size: 0.9em;
}

/* Overflow content handling inside the scrollable container */
.gm-style-iw-d {
    max-height: 200px;
    overflow-y: auto;
    padding-top: 15px;
}

/* Close button adjustment */
.gm-style-iw-chr {
    position: absolute;
    right: 0;
    top: 0;
    z-index: 99;
}

.acf-map {
    height: 75vh !important;
}

.marker-info-window ul {
    list-style-type: none;
    padding-left: 0;
    margin: 10px 0px;
}

.marker-info-window li {
    display: flex;
    justify-content: space-between;
    align-items: start;
    padding-bottom: 10px;
    margin-top: 8px;
}

.marker-info-window li:not(:last-of-type) {

    border-bottom: 1px solid #d7d7d7;
}

.marker-info-window strong {
    flex-grow: 1;
    font-weight: 600;
}

.marker-info-window a {
    display: inline-block;
    background: none;
    padding: 0;
    color: #000;
}

.marker-info-window a:hover {
    color: #003478
}

.marker-info-window .project-info a:last-of-type::after {
    content: '→';
    font-size: 1.2em;
    color: #333;
}

.marker-info-window .project-info a:last-of-type::after:hover {
    color: #003478
}

.acf-map {
    display: none;
    width: 100%;
    height: 100%;
    transition: width 0.3s ease;
    float: right;
}

.acf-map-wrapper {
    position: relative;
    width: 100%;
    height: 75vh;
}

.acf-map.map-with-sidebar {
    width: calc(100% - 300px);
}

.acf-map.map-full-width {
    width: 100%;
}

.side-panel {
    position: absolute;
    left: 0;
    top: 0;
    width: 300px;
    height: 100%;
    background-color: #f8f8f8;
    border-right: 1px solid #ccc;
    padding: 0px 20px 20px 20px;
    box-shadow: 2px 0px 5px rgba(0, 0, 0, 0.2);
    overflow-y: auto;
    z-index: 9;
    display: none;
    /* Hidden initially */
}

/* Increase sidebar width for screens larger than 1500px */
@media (min-width: 1350px) {
    .side-panel {
        width: 450px;
    }
}

.side-panel h3 {
    margin-top: 0;
    line-height: 1em;
    font-size: 2em;
}

.locations {
    font-size: 0.85em;
    margin-bottom: 0px;
}

.locations-tooltip {
    margin-top: 3px;
}

.side-panel .locations {
    font-size: 0.85em;
    margin-top: 5px;
}

.side-panel a {
    color: #003478;
    text-decoration: none;
    font-weight: bold;
    font-size: 1em;
    line-height: 1.2em;
    display: inline-block;
}

.project-info {
    margin-top: 5px;
}

.project-info p {
    line-height: 1.25em;
    margin-bottom: 0px;
}

.side-panel-content {
    margin-top: 20px;
}

.side-panel-content ul {
    padding: 0px;
    margin: 0px;
    list-style: none;
}

.side-panel-content>h3 {
    margin-bottom: 5px
}

/* Project category label */
.project-category {
    display: block;
    font-size: 0.85em;
    color: #666;
    margin-bottom: 2px;
    margin-top: 3px;
    font-style: italic;
}

/* Layout for the project item in the sidebar */
.marker-info-window li {
    display: flex;
    flex-direction: column;
    margin-bottom: 20px;
}

/* Sidebar styles */
.project-hero-image {
    width: 100px;
    height: 80px;
    object-fit: cover;
    margin-right: 10px;
    float: left;
}

/* Title with image next to it */
.marker-info-window strong {
    font-size: 1.1em;
    flex-grow: 1;
    margin-bottom: 10px;
}

/* Ensure the content below the image is displayed properly */
.marker-info-window p {
    clear: both;
    font-size: 0.9em;
}

#side-panel .project-item {
    display: flex;
    flex-direction: column;
    min-width: 100%;
    margin-bottom: 30px;
}


#side-panel .project-image a {
    min-width: 100%;
}

#side-panel .project-image a img {
    min-width: 100%;
    aspect-ratio: 3.5 / 1;
    object-fit: cover;
}

#close-sidebar {
    padding: 5px 9px;
    font-size: 0.6em;
    position: absolute;
    right: 0px;
    background: black;
    top: 0px;
    border-radius: 0px;
}

/* Spinner styles */
.spinner {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    border: 8px solid #f3f3f3;
    border-top: 8px solid #003478;
    border-radius: 50%;
    width: 50px;
    height: 50px;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

/* Style the overall tooltip box */
.map-tooltip {
    border-radius: 4px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15) !important;
    font-size: 14px;
    line-height: 1.3;
    max-width: 280px !important;
    border: 1px solid #ccc;
    padding: 15px !important;
    background: #fff;
}

/* Style the tooltip heading (e.g., the country name) */
.map-tooltip h3 {
    margin-top: 0;
    margin-bottom: -2px !important;
    font-size: 18px;
}

/* Bullet list styling */
.map-tooltip ul {
    margin: 0;
    padding-left: 1.2em;
    list-style: disc;
}

/* List items: spacing, divider line, etc. */
.map-tooltip ul li {
    margin: 4px 0;
    padding: 6px 0;
    border-bottom: 1px solid #eee;
}

.map-tooltip ul li a {
    color: #003478;
}

.map-tooltip ul li a:hover {
    opacity: 0.8;
}

/* Remove bottom border for the last item */
.map-tooltip ul li:last-child {
    border-bottom: none;
}

.project-grid-title {
    margin-top: 60px;
    text-align: center;
}

body .project-grid-title h2.elementor-heading-title {
    color: #000;
}

.project-grid {
    display: flex;
    flex-wrap: wrap;
    max-width: var(--content-width);
    margin: 0 auto;
    margin-top: 10px;
    gap: 30px;
    /* Space between items */
    padding: 0px 20px;
}

.project-grid .project-item {
    flex: 0 0 calc(33.33% - 20px);
    position: relative;
    overflow: hidden;
    aspect-ratio: 1;

}

@media (min-width: 1024px) {
    .elementor-nav-menu li.menu-item-2378 {
        display: none;
    }
}

.elementor-nav-menu li.menu-item-2378>a {
    background: #fdc82f;
    color: #000;
}



.project-grid .project-item a {
    text-decoration: none;
    color: white;
}

.project-grid .project-item .background {
    background-size: cover;
    background-position: center;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 15px;
    position: relative;
}

.project-grid .project-item .background::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-image: linear-gradient(4deg, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0) 100%);
    z-index: 1;
}

.project-grid .project-item h6 {
    margin: 0;
    color: white;
    z-index: 2;
}

.project-grid .project-item h3 {
    margin: 0;
    color: white;
    z-index: 2;
}

/* tribe */
.single-tribe_events .tribe-events-c-subscribe-dropdown .tribe-events-c-subscribe-dropdown__button.tribe-events-c-subscribe-dropdown__button--active,
.single-tribe_events .tribe-events-c-subscribe-dropdown .tribe-events-c-subscribe-dropdown__button:focus,
.single-tribe_events .tribe-events-c-subscribe-dropdown .tribe-events-c-subscribe-dropdown__button:focus-within,
.single-tribe_events .tribe-events-c-subscribe-dropdown .tribe-events-c-subscribe-dropdown__button:hover,
.tribe-events .tribe-events-c-subscribe-dropdown .tribe-events-c-subscribe-dropdown__button.tribe-events-c-subscribe-dropdown__button--active,
.tribe-events .tribe-events-c-subscribe-dropdown .tribe-events-c-subscribe-dropdown__button:focus,
.tribe-events .tribe-events-c-subscribe-dropdown .tribe-events-c-subscribe-dropdown__button:focus-within,
.tribe-events .tribe-events-c-subscribe-dropdown .tribe-events-c-subscribe-dropdown__button:hover {
    background-color: var(--f_blue) !important;
    color: var(--tec-color-background);
}

body .tribe-events .tribe-events-calendar-list__event-row--featured .tribe-events-calendar-list__event-date-tag-datetime:after {
    background-color: var(--f_blue);
}

body .tribe-common--breakpoint-medium.tribe-events .tribe-events-calendar-list__event-datetime-featured-text {
    color: var(--f_blue);
}

body .tribe-common .tribe-common-c-svgicon {
    color: var(--f_blue);
}

body .tribe-common .tribe-common-c-btn-border,
body .tribe-common a.tribe-common-c-btn-border {
    color: var(--f_blue);
    border: 1px solid var(--f_blue);
}

body .tribe-events .tribe-events-c-search__button,
body .tribe-events button.tribe-events-c-search__button {
    background-color: var(--f_blue);
}

body .tribe-events-c-top-bar {
    display: none !important;
}

body .tribe-common--breakpoint-medium.tribe-events .tribe-events-l-container {
    padding-top: 60px;
}


/* Project Navigation Layout */
.project-navigation {
    display: flex;
    justify-content: space-between;
    margin-top: 30px;
}

/* Each nav item is 50% wide */
.project-nav-item {
    width: 50%;
    box-sizing: border-box;
    padding: 0 10px;
}

/* Make the entire item clickable */
.project-nav-link {
    display: block;
    text-decoration: none;
    color: #333;
}

/* Right-align the Next Project */
.next-project .project-nav-link {
    text-align: right;
}

/* Style for the post titles */
.project-nav-title {
    font-size: 1.1rem;
    font-weight: bold;
}

/* Single Project Page Logos */
.project-logos-container {
    display: flex;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    gap: 20px;
    width: 100%;
}

/* Each logo container can shrink or grow to fit the row */
.project-logo-item {
    flex: 1 1 auto;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Logo images: maintain aspect ratio, max-height 180px */
.project-logo-item img {
    max-height: 60px;
    width: auto;
    height: auto;
    object-fit: contain;
}

/* Facetwp */
body .facetwp-facet {
    margin-bottom: 0px;
}

body .facetwp-facet input.facetwp-search {
    max-width: 100%;
    min-width: initial;
}

body .facetwp-checkbox {
    margin-bottom: 15px;
    padding-left: 25px;
    line-height: 18px;
    font-size: 0.95em;
    letter-spacing: -0.5px;
}

body .facetwp-checkbox.checked {
    background-image: url(https://nabsaclimate.org/wp-content/uploads/2025/03/Checkbox_on_cf.png);
}

body .facetwp-selections ul {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 0;
    margin: 0;
    list-style: none;
}

body .facetwp-selections ul>li {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
    background: none;
    padding: 0;
}

body .facetwp-selections .facetwp-selection-label {
    display: none
}

body .facetwp-selections .facetwp-selection-value {
    display: inline-flex;
    align-items: center;
    background: #003478;
    color: #fff;
    padding: 6px 10px;
    border-radius: 4px;
    /* white-space: nowrap; */
}

body .facetwp-selections .facetwp-selection-value::after {
    content: " ×";
    cursor: pointer;
    font-size: 14px;
    margin-left: 6px;
}

body .facetwp-type-reset {
    margin-top: 10px;
}

body a.facetwp-reset {
    font-size: 0.8em;
}

body .facetwp-slider-reset {
    display: none;
}

body .slider-years {
    display: flex;
    justify-content: space-between;
    font-weight: 600;
    font-size: 1.1em;
}

body .facetwp-type-slider .facetwp-slider-label {
    display: none;
}

body .facetwp-flyout-open {
    background: #0a97d9;
    width: 100%;
}

body .facetwp-flyout .name-sort_results,
body .facetwp-flyout .name-selected_facets>h3 {
    display: none;
}

body .facetwp-flyout .flyout-row {
    padding: 20px;
}

.resource-tags-list {
    font-weight: 400;
    font-style: italic;
    color: #959595
}

.resource-tags-list strong {
    font-weight: 600;
    font-style: normal;
    color: #000
}

.external-link-icon {
    width: 13px;
    display: inline-block;
    color: #003478;
}

.facetwp-type-sort select {
    font-size: 0.9em;
    padding: 5px;
}

/* Adds shadow only when filters are active */
body .filters-active {
    padding: 20px;
    box-shadow: 1px 1px 10px 4px rgba(0, 0, 0, 0.1);
}

/* Keeps the selected filters label visible */
body .selections-label {
    font-weight: 600;
    font-size: 1.1em;
    margin-bottom: 10px;
    display: block;
}

/* Add line between loop grid items */
body .elementor-loop-container:not(#home-loop .elementor-loop-container) .e-loop-item:not(:last-of-type) {
    border-bottom: 1px solid #f0f0f0;
    padding-bottom: 30px;
}


/* Dialogue side menu & tabs */
.dialogue-menu {
    position: sticky;
    top: 20px;
    background: #003478;
    padding: 20px;
    border-radius: 4px;
    padding-bottom: 1px;
}

.dialogue-menu ul {
    list-style: none;
    padding: 0;
    margin: 0px;
}

.dialogue-menu li {
    margin-bottom: 0px;
}

.dialogue-menu a {
    color: white;
    text-decoration: none;
    font-weight: 550;
    display: block;
    padding: 8px 12px;
    border-radius: 5px;
    transition: background 0.3s;
}

.dialogue-menu a:hover {
    background: rgba(255, 255, 255, 0.2);
    color: #fff;
}

.dialogue-category-title {
    color: #fdc82f;
    border-bottom: 1px solid #ffffff42;
    padding-bottom: 3px;
    text-transform: capitalize;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.dialogue-group-toggle {
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.4);
    border-radius: 999px;
    color: #fdc82f;
    width: 28px;
    min-width: 28px;
    height: 28px;
    min-height: 28px;
    flex: 0 0 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    padding: 0;
}

.dialogue-group-toggle:focus-visible {
    outline: 2px solid #fdc82f;
    outline-offset: 2px;
}

.dialogue-group-toggle .toggle-icon {
    position: relative;
    width: 14px;
    height: 14px;
    display: block;
}

.dialogue-group-toggle .toggle-icon::before,
.dialogue-group-toggle .toggle-icon::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    background: currentColor;
    transform: translate(-50%, -50%);
    border-radius: 1px;
}

.dialogue-group-toggle .toggle-icon::before {
    width: 12px;
    height: 2px;
}

.dialogue-group-toggle .toggle-icon::after {
    width: 2px;
    height: 12px;
    opacity: 0;
    transition: opacity 0.2s ease;
}

.dialogue-category-group.is-collapsed .dialogue-group-toggle .toggle-icon::after {
    opacity: 1;
}

.dialogue-menu>.dialogue-category-group {
    margin-bottom: 15px;
}



/* Single Dialogue */
#single-dialogue-container blockquote {
    font-size: 1.3em;
}

#single-dialogue-container blockquote>p {
    margin-bottom: 0px;
}

#single-dialogue-container blockquote>p small {
    font-size: 0.7em;
}

#single-dialogue-container img {
    min-width: 100%;
}

/* Next/Prev dialogue */
.dialogue-navigation {
    display: flex;
    justify-content: space-between;
    margin-top: 30px;
}

.dialogue-nav-item {
    width: 50%;
    box-sizing: border-box;
    padding: 0 10px;
}

.dialogue-nav-item a.dialogue-nav-link {
    display: block;
    font-size: 0.9rem;
    text-decoration: none;
    color: #333;
    margin-bottom: 5px;
}

.dialogue-nav-item .dialogue-nav-title {
    font-size: 1.1rem;
    font-weight: bold;
}

.next-dialogue .dialogue-nav-link {
    text-align: right;
}

#d-description p:last-of-type {
    margin-bottom: 0px
}

#d-description .e-con {
    padding: 0px;
}

.pdf-slide-button {
    display: none;
}

@media (min-width: 768px) {
    .dialogues-tabs .e-n-tabs-heading {
        order: 2 !important;
    }

    .dialogues-tabs .e-n-tabs-content {
        order: 1 !important;
    }
}

/* Task force */
/* Next/Prev task-force */
.task-force-navigation {
    display: flex;
    justify-content: space-between;
    margin-top: 30px;
}

.task-force-nav-item {
    width: 50%;
    box-sizing: border-box;
    padding: 0 10px;
}

.task-force-nav-item a.task-force-nav-link {
    display: block;
    font-size: 0.9rem;
    text-decoration: none;
    color: #333;
    margin-bottom: 5px;
}

.task-force-nav-item .task-force-nav-title {
    font-size: 1.1rem;
    font-weight: bold;
}

.next-task-force .task-force-nav-link {
    text-align: right;
}


/* for lightbox */
body .dialog-message .elementor-slideshow__title {
    display: none;
    ;
}


.trp-language-switcher:hover {
    height: auto !important;
}

/* Fix for dialogue video language tabs height */
.dialogue-section .lang-tabs li {
    display: flex;
}

.dialogue-section .lang-tabs li a {
    flex-grow: 1;
    text-align: center;
}

/* Fix for Elementor video tabs height on dialogue pages */
.e-n-tabs-heading {
    display: flex;
    align-items: stretch;
    /* Ensure all tabs have the same height */
}

.e-n-tab-title {
    display: flex;
    /* Allow flex properties to align content */
    flex-direction: column;
}

.e-n-tab-title>a {
    flex-grow: 1;
    /* Allow link to fill the tab height */
    display: flex;
    align-items: center;
    /* Vertically center text */
    justify-content: center;
    /* Horizontally center text */
}


body.single-post .category-newsletter .entry-content>p {
    display: none;
}


#news_stories_repeater .ae-acf-repeater-inner>div,
#news_stories_repeater .ae-acf-repeater-inner>div>div,
#news_stories_repeater .ae-acf-repeater-inner>div>div>div,
#news_stories_repeater .ae-acf-repeater-inner>div>div>div>div,
#news_stories_repeater .ae-acf-repeater-inner>div>div>div>div>div {
    height: 100%;
}



/* Override the default SearchWP spinner */
.spinner {
    width: 40px !important;
    height: 40px !important;
    position: relative;
    display: block !important;
    background: transparent !important;
    animation: none !important;
    left: 50% !important;
    top: 35% !important;
}

.spinner>* {
    display: none !important;
    animation: none !important;
    background: transparent !important;
}

.spinner:after {
    content: "";
    box-sizing: border-box;
    position: absolute;
    top: 50%;
    left: 50%;
    width: 40px;
    height: 40px;
    margin: -20px 0 0 -20px;
    border: 4px solid #f3f3f3;
    border-top: 4px solid #3498db;
    border-radius: 50%;
    animation: spin 1s linear infinite;
    z-index: 100;
    background: white;
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}


/* Hide the top header inside external IUCN embed by cropping the iframe */
.iucn-contribution-embed {
    position: relative;
    overflow: hidden;
    /* visible height for the user — adjust as you like */
    height: 820px;
    /* set how many pixels of the top to crop */
    --crop-top: 80px;
}

.iucn-contribution-embed iframe {
    position: relative;
    top: calc(-1 * var(--crop-top));
    /* increase the iframe’s own height so content below isn’t cut off */
    height: calc(820px + var(--crop-top));
    width: 100%;
    border: 0;
}


#event-filters .elementor-shortcode {
    display: flex !important;
    gap: 20px;
}

#event-filters .facetwp-no-options {
    display: none;
}

.event-datetime.is-split {
    display: grid;
    grid-template-columns: 1fr auto;
    /* date left, time right */
    align-items: baseline;
    gap: .5rem 1rem;
}

.event-datetime.is-stack {
    display: grid;
    grid-template-columns: 1fr;
    gap: .25rem;
}

.event-dt-left {
    font-weight: 600;
}

.event-dt-right .lbl {
    font-size: .875em;
    opacity: .8;
    margin-right: .25em;
}

.event-datetime .sep {
    opacity: .5;
}


/* ===== NABSA FAQ Category Grid ===== */
.nabsa-faq-grid {
    display: grid;
    gap: 1.25rem;
    align-items: stretch;
}

.nabsa-faq-grid--cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.nabsa-faq-grid--cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.nabsa-faq-grid--cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

@media (max-width: 900px) {

    .nabsa-faq-grid--cols-3,
    .nabsa-faq-grid--cols-4 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 560px) {

    .nabsa-faq-grid--cols-2,
    .nabsa-faq-grid--cols-3,
    .nabsa-faq-grid--cols-4 {
        grid-template-columns: 1fr;
    }
}

.nabsa-faq-card {
    display: flex;
    flex-direction: column;
    border: 1px solid #eee;
    border-radius: 14px;
    padding: 18px;
    text-decoration: none;
    background: #fff;
    background-color: #fff;
    transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    text-align: center;
    color: #111;
    cursor: pointer;
    font: inherit;
    appearance: none;
    -webkit-appearance: none;
}

.nabsa-faq-card:hover,
.nabsa-faq-card:focus {
    transform: translateY(-2px);
    border-color: #e6e6e6;
    box-shadow: 0 6px 18px rgba(0, 0, 0, .06);
    outline: none;
    background-color: #fff;
    color: #111;
}

.nabsa-faq-card:focus-visible {
    outline: 2px solid #003478;
    outline-offset: 3px;
}

.nabsa-faq-card__media {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 14px;
}

.nabsa-faq-card__icon-img {
    width: 96px;
    height: 96px;
    max-width: 100%;
    object-fit: contain;
    display: block;
}

.nabsa-faq-card__topline {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: .75rem;
}

.nabsa-faq-card__title {
    margin: 0;
    font-size: 1.05rem;
    line-height: 1.25;
    color: #111;
}

.nabsa-faq-grid .nabsa-faq-card__title {
    display: block;
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.nabsa-faq-card--category .nabsa-faq-card__title {
    white-space: normal;
    overflow: visible;
    text-overflow: unset;
}

.nabsa-faq-card__count {
    flex-shrink: 0;
    font-size: .85rem;
    color: #444;
    background: #f5f5f7;
    border-radius: 999px;
    padding: 2px 10px;
}

.nabsa-faq-card__desc {
    margin: .5rem 0 0;
    color: #555;
    font-size: .95rem;
    margin-bottom: 0px !important;
}

.nabsa-faq-card__cta {
    margin-top: auto;
    display: inline-block;
    color: #6a6a6a;
    font-size: .9rem;
}

/* Make the whole card act as a clean link with no underlines */
.nabsa-faq-card,
.nabsa-faq-card:link,
.nabsa-faq-card:visited {
    text-decoration: none !important;
    color: inherit;
}

.nabsa-faq-card * {
    text-decoration: none !important;
    color: inherit;
    box-sizing: inherit;
}

/* Body area becomes a vertical stack; meta sticks to bottom */
.nabsa-faq-card__body {
    display: flex;
    flex-direction: column;
    gap: .5rem;
    height: 100%;
    width: 100%;
    padding: 0 1.25rem;
    align-items: center;
    text-align: center;
}

.nabsa-faq-card__title {
    margin: 0;
    font-size: 1.15rem;
    line-height: 1.25;
}

.nabsa-faq-card__desc {
    margin: 0;
    color: #555;
    font-size: .95rem;
}

/* Bottom meta line: replaces the badge + button */
.nabsa-faq-card__meta {
    margin-top: auto;
    /* push to bottom */
    padding-top: .75rem;
    font-size: .9rem;
    color: #6a6a6a;
    border-top: 1px dashed #eee;
    width: 100%;
    text-align: center;
}

.nabsa-faq-links {
    display: flex;
    flex-direction: row;
    gap: 1.5rem;
    padding: 0;
    align-items: start;
    justify-content: space-evenly;
    margin-top: 10px;
    margin-bottom: -15px;
}

.nabsa-faq-links__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    max-width: 210px;
    text-decoration: none !important;
    color: inherit;
    text-align: center;
    line-height: 1.2;
}

.nabsa-faq-links__item:focus {
    outline: 2px solid rgba(59, 130, 246, .45);
    outline-offset: 6px;
    border-radius: 1.25rem;
}

.nabsa-faq-links__item img {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 1.25rem;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.12);
    margin-bottom: 10px;
    max-width: 150px;
}

@media (max-width: 768px) {
    .nabsa-faq-links {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 40px;
    }

    .nabsa-faq-links__item {
        max-width: 85%;
    }

    .nabsa-faq-links__item img  {
        max-width: 100%;
    }
}

/* If you kept any old badge styles, you can safely remove them */
.nabsa-faq-card__count,
.nabsa-faq-card__cta {
    display: none !important;
}

/* ===== FAQ Archive Header ===== */
.nabsa-faq-archive-header {
    margin-bottom: 2rem;
    text-align: center;
}

.nabsa-faq-archive-title {
    font-size: 2rem;
    margin: 0 0 .5rem;
}

.nabsa-faq-archive-desc {
    font-size: 1.1rem;
    color: #555;
    max-width: 720px;
    margin: 0 auto;
}

/* ===== Breadcrumbs ===== */
.nabsa-faq-breadcrumbs {
    margin: 0 0 1rem;
    font-size: .95rem;
    color: #6a6a6a;
}

.nabsa-faq-breadcrumbs .crumbs {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
    align-items: center;
}

.nabsa-faq-breadcrumbs .crumb a {
    text-decoration: none;
    color: inherit;
    border-bottom: 1px solid rgba(0, 0, 0, .12);
}

.nabsa-faq-breadcrumbs .crumb a:hover {
    border-bottom-color: rgba(0, 0, 0, .35);
}

.nabsa-faq-breadcrumbs .sep {
    color: #a0a0a0;
}

.nabsa-faq-breadcrumbs .current {
    color: #333;
    font-weight: 600;
    border-bottom: none;
}

/* Single FAQ header */
.nabsa-faq-single-title {
    margin: 0 0 1rem;
    font-size: 2rem !important;
    line-height: 1.2;
}

/* Body spacing */
.nabsa-faq-single-body {
    margin-bottom: 2.5rem;
}

/* Breadcrumbs (reuse earlier styles) */
.nabsa-faq-breadcrumbs {
    margin-bottom: 1rem;
}

/* Breadcrumbs (category link enabled) */
.nabsa-faq-breadcrumbs {
    margin: 0 0 1rem;
    font-size: .95rem;
    color: #6a6a6a;
}

.nabsa-faq-breadcrumbs .crumbs {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
}

.nabsa-faq-breadcrumbs .crumb a {
    text-decoration: none;
    color: inherit;
    border-bottom: 1px solid rgba(0, 0, 0, .12);
}

.nabsa-faq-breadcrumbs .crumb a:hover {
    border-bottom-color: rgba(0, 0, 0, .35);
}

.nabsa-faq-breadcrumbs .sep {
    color: #a0a0a0;
}

.nabsa-faq-breadcrumbs .current {
    font-weight: 600;
    color: #333;
}

/* Prev/Next row */
.nabsa-faq-nextprev {
    margin-top: 2rem;
    border-top: 1px solid #eaecef;
    padding-top: 1rem;
}

.nabsa-faq-nextprev ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: 1.25rem;
    justify-content: space-between;
    display: grid;
    grid-template-columns: 1fr 1fr;
}

.nabsa-faq-nextprev li {
    display: flex;
    flex-direction: column;
    gap: .35rem;
    max-width: 100%;
}

.nabsa-faq-nextprev .prev {
    align-items: flex-start;
}

.nabsa-faq-nextprev .next {
    align-items: flex-end;
    text-align: right;
}

.nabsa-faq-nextprev .label {
    display: block;
    margin: 0;
    text-transform: uppercase;
    letter-spacing: .04em;
    font-size: .82rem;
    color: #6b7280;
}

.nabsa-faq-nextprev a {
    text-decoration: none !important;
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    color: #003478;
    font-weight: 600;
}

.nabsa-faq-nextprev .prev a::before {
    content: '←';
    color: #6b7280;
}

.nabsa-faq-nextprev .next a::after {
    content: '→';
    color: #6b7280;
}

.nabsa-faq-nextprev .disabled {
    opacity: .45;
}

/* FAQ single layout tweaks */
.nabsa-faq-divider {
    border: 0;
    margin: 30px 0px !important;
}

body .nabsa-faq-section-title {
    font-size: 1.2em;
    ;
}

.nabsa-faq-single-section {
    margin-bottom: 3rem;
}

.nabsa-faq-single-section:last-of-type {
    margin-bottom: 0;
}

.nabsa-faq-single-section .nabsa-faq-card__body {
    gap: 0.5rem;
}

.nabsa-faq-single-section .nabsa-faq-card__desc {
    display: none;
}



.nabsa-faq-featured {
    display: grid;
    gap: 1rem;
}

.nabsa-faq-featured--cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr));
}

.nabsa-faq-featured--cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.nabsa-faq-featured--cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.nabsa-faq-featured--cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.nabsa-faq-featured__item {
    border: 1px solid #eee;
    border-radius: 14px;
    padding: 18px;
    background: #003478;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    font-size: 1rem;
    font-weight: 600;
    color: inherit;
    cursor: pointer;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    text-align: left;
    transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
    box-sizing: border-box;
}

.nabsa-faq-featured__item:hover,
.nabsa-faq-featured__item:focus {
    border-color: #e6e6e6;
    box-shadow: 0 6px 18px rgba(0, 0, 0, .06);
    transform: translateY(-2px);
    outline: none;
    background: #064394;
    color: inherit;
}

.nabsa-faq-featured__icon {
    font-size: 1.25rem;
    color: #94a3b8;
    transition: color .2s ease;
}

.nabsa-faq-featured__modal {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.55);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
    z-index: 1000;
}

.nabsa-faq-featured__dialog {
    background: #fff;
    max-width: 720px;
    width: 100%;
    border-radius: 18px;
    padding: 2rem;
    max-height: calc(90vh - 85px);
    overflow-y: auto;
    position: relative;
}

.nabsa-faq-featured__close {
    position: absolute;
    top: -.08rem;
    right: .01rem;
    border: none;
    background: transparent;
    font-size: 1.5rem;
    cursor: pointer;
    color: #475569;
}

.nabsa-faq-featured__close:hover {
    background: #033578;
}

.nabsa-faq-featured__modal-title {
    margin-top: 0;
}

.nabsa-faq-featured__modal-term {
    margin: 0 0 .75rem;
    font-size: .75rem;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: #6b7280;
    display: flex;
    align-items: center;
    gap: .5rem;
}

.nabsa-faq-featured__modal-term .term {
    font-weight: 600;
}

.nabsa-faq-featured__modal-term .count {
    letter-spacing: normal;
    text-transform: none;
    font-weight: 500;
    font-size: .7rem;
    color: #9ca3af;
}

.nabsa-faq-featured__modal-term .sep {
    font-size: .7rem;
    color: #d1d5db;
}

body.faq-modal-open {
    overflow: hidden;
}




.nabsa-faq-featured__modal[hidden] {
    display: none !important;
}

.nabsa-faq-featured__title {
    margin: 0;
    font-size: 1.15rem;
    line-height: 1.25;
    font-weight: 700;
    color: #fff;
}


.nabsa-faq-nextprev li {
    width: 100%;
}

.nabsa-faq-nextprev a {
    white-space: normal;
    display: inline;
}


@supports (gap: 1rem) {
    .nabsa-faq-nextprev ul {
        flex-wrap: wrap;
    }

    .nabsa-faq-featured__item {
        display: grid;
        grid-template-columns: 1fr auto;
        align-items: center;
    }

    .nabsa-faq-featured__title {
        line-height: 1.25;
    }
}


@media (max-width: 544px) {
    .nabsa-faq-featured__item {
        grid-template-columns: 1fr auto;
        gap: 0.75rem;
    }

    .nabsa-faq-featured__icon {
        justify-self: end;
    }

    .nabsa-faq-featured__title {
        font-size: 1.15rem;
        line-height: 1.25;
        word-break: break-word;
    }
}

@media (max-width: 600px) {

    .nabsa-faq-grid,
    .nabsa-faq-featured,
    .nabsa-faq-featured--cols-2,
    .nabsa-faq-featured--cols-3,
    .nabsa-faq-featured--cols-4 {
        margin-left: 0;
        margin-right: 0;
    }

    .nabsa-faq-featured--cols-2,
    .nabsa-faq-featured--cols-3,
    .nabsa-faq-featured--cols-4 {
        grid-template-columns: repeat(1, minmax(0, 1fr));
    }

    .nabsa-faq-nextprev ul {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 0.75rem;
    }

    .nabsa-faq-nextprev .prev {
        align-items: start;
        text-align: left;
    }

    .nabsa-faq-nextprev .next {
        align-items: end;
        text-align: right;
    }

    .nabsa-faq-featured {
        overflow: hidden;
    }

    .nabsa-faq-featured,
    .nabsa-faq-featured--cols-2,
    .nabsa-faq-featured--cols-3,
    .nabsa-faq-featured--cols-4 {
        grid-template-columns: repeat(1, minmax(0, 1fr));
    }

    .nabsa-faq-featured__item {
        font-size: 1rem;
        padding: 0.875rem 1rem;
    }

    .nabsa-faq-featured__title {
        font-size: 1.15rem;
        line-height: 1.25;
    }

    .nabsa-faq-nextprev .label {
        display: none;
    }

    .nabsa-faq-nextprev .prev a,
    .nabsa-faq-nextprev .next a {
        font-size: 0;
        justify-content: center;
    }

    .nabsa-faq-nextprev .prev a::before,
    .nabsa-faq-nextprev .prev a::after,
    .nabsa-faq-nextprev .next a::before,
    .nabsa-faq-nextprev .next a::after {
        font-size: 1rem;
        color: inherit;
    }

    .nabsa-faq-nextprev .prev a::before {
        content: '←';
        color: #6b7280;
    }

    .nabsa-faq-nextprev .prev a::after {
        content: 'Previous';
    }

    .nabsa-faq-nextprev .next a::before {
        content: 'Next';
    }

    .nabsa-faq-nextprev .next a::after {
        content: '→';
        color: #6b7280;
    }
}




@media (max-width: 768px) {
    .project-grid .project-item {
        flex: 0 0 100%;
    }
}


/* Demo mega menu scoped styles */
.nabsa-demo-menu {
  position: relative;
  width: 100%;
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin: 0 auto;
  --nabsa-demo-gap: 22px;
  --nabsa-demo-font-color: #0b213f;
  --nabsa-demo-muted: rgba(11, 33, 63, 0.62);
  --nabsa-demo-border: rgba(5, 18, 51, 0.09);
  --nabsa-demo-shadow: 0 28px 50px rgba(2, 24, 54, 0.18);
}

.nabsa-demo-menu__container {
  width: 100%;
  max-width: none;
  margin: 0 auto;
  display: flex;
  justify-content: center;
  padding: 0 8px;
}

.nabsa-demo-menu__mobile-trigger {
  display: none;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  padding: 0;
  color: #003478;
  background: transparent;
  box-shadow: none;
  border: none;
  cursor: pointer;
  transition: opacity 140ms ease;
  margin-right: 40px;
}

.nabsa-demo-menu__mobile-trigger:focus-visible {
  outline: 2px solid #003478;
  outline-offset: 3px;
  border-radius: 50%;
  background: transparent;
  color: #003478;
}

.nabsa-demo-menu__mobile-trigger:focus,
.nabsa-demo-menu__mobile-trigger:active {
  color: #003478;
  background: transparent;
  box-shadow: none;
}

.nabsa-demo-menu__mobile-trigger:hover {
  color: #003478;
  opacity: 0.85;
  background: transparent;
}

.nabsa-demo-menu__mobile-icon {
  display: inline-flex;
  width: 26px;
  height: 20px;
}

.nabsa-demo-menu__mobile-icon svg {
  width: 100%;
  height: 100%;
}

.nabsa-demo-menu__top {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  gap: var(--nabsa-demo-gap);
  list-style: none;
  padding: 0;
  margin: 0;
}

.nabsa-demo-menu__top-item {
  position: relative;
}

.nabsa-demo-menu__top-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 14px 6px;
  text-decoration: none;
  font-family: "Helvetica", sans-serif;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.01em;
  color: var(--nabsa-demo-font-color);
  transition: color 150ms ease;
  font-size: 0.9em;
}

.nabsa-demo-menu__top-link:hover,
.nabsa-demo-menu__top-link:focus-visible,
.nabsa-demo-menu__top-item.is-open > .nabsa-demo-menu__top-link {
  color: #003478;
  outline: none;
}

.nabsa-demo-menu__caret {
  display: inline-flex;
  width: 8px;
  height: 8px;
  position: relative;
}

.nabsa-demo-menu__caret::before {
  content: "";
  position: absolute;
  top: 40%;
  left: 50%;
  transform: translate(-50%, -30%);
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 5px solid rgba(11, 33, 63, 0.4);
  transition: border-color 140ms ease, transform 140ms ease;
}

.nabsa-demo-menu__top-item:hover .nabsa-demo-menu__caret::before,
.nabsa-demo-menu__top-item:focus-within .nabsa-demo-menu__caret::before,
.nabsa-demo-menu__top-item.is-open .nabsa-demo-menu__caret::before {
  border-top-color: #003478;
  transform: translate(-50%, 0);
}

.nabsa-demo-menu__top-item::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 0;
  height: 3px;
  border-radius: 999px;
  background: #003478;
  opacity: 0;
  transform: translateX(-50%);
  transition: width 140ms ease, opacity 140ms ease;
}

.nabsa-demo-menu__top-item:hover::after,
.nabsa-demo-menu__top-item:focus-within::after,
.nabsa-demo-menu__top-item.is-open::after {
  width: 26px;
  opacity: 1;
}

.nabsa-demo-menu__dropdown {
  --nabsa-demo-menu-shift: 0px;
  position: absolute;
  left: 50%;
  top: calc(100% + 6px);
  width: min(410px, calc(100vw - 32px));
  background: #fff;
  border: 1px solid var(--nabsa-demo-border);
  border-radius: 18px;
  box-shadow: var(--nabsa-demo-shadow);
  padding: 18px 0;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translate(-50%, 12px) translateX(var(--nabsa-demo-menu-shift));
  transition: opacity 160ms ease, transform 160ms ease, visibility 160ms ease;
  z-index: 30;
}

.nabsa-demo-menu__dropdown::before {
  content: "";
  position: absolute;
  top: -14px;
  left: 0;
  right: 0;
  height: 14px;
}

.nabsa-demo-menu__top-item.has-children:hover > .nabsa-demo-menu__dropdown,
.nabsa-demo-menu__top-item.has-children:focus-within > .nabsa-demo-menu__dropdown,
.nabsa-demo-menu__top-item.is-open > .nabsa-demo-menu__dropdown {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translate(-50%, 0) translateX(var(--nabsa-demo-menu-shift));
}

.nabsa-demo-menu__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.nabsa-demo-menu__list-item + .nabsa-demo-menu__list-item {
  border-top: 1px solid rgba(2, 20, 48, 0.06);
}

.nabsa-demo-menu__child-link {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 28px;
  text-decoration: none;
  color: var(--nabsa-demo-font-color);
  transition: background 140ms ease, color 140ms ease;
}

.nabsa-demo-menu__child-link:hover,
.nabsa-demo-menu__child-link:focus-visible {
  background: rgba(0, 52, 120, 0.07);
}

.nabsa-demo-menu__child-link:focus-visible {
  outline: 2px solid #003478;
  outline-offset: -2px;
}

.nabsa-demo-menu__child-text {
  display: flex;
  flex-direction: column;
  gap: 3px;
  flex: 1;
  padding-right: 6px;
}

.nabsa-demo-menu__child-title {
  font-weight: 700;
  color: var(--nabsa-demo-font-color);
  line-height: 1.3;
}

.nabsa-demo-menu__child-desc {
  color: var(--nabsa-demo-muted);
  font-size: 0.92rem;
  line-height: 1.4;
}

.nabsa-demo-menu__child-chevron {
  width: 14px;
  height: 14px;
  position: relative;
  display: inline-flex;
}

.nabsa-demo-menu__child-chevron::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
  border-top: 4px solid transparent;
  border-bottom: 4px solid transparent;
  border-left: 5px solid rgba(11, 33, 63, 0.35);
  transition: border-color 160ms ease, transform 160ms ease;
}

.nabsa-demo-menu__child-link:hover .nabsa-demo-menu__child-chevron::before,
.nabsa-demo-menu__child-link:focus-visible .nabsa-demo-menu__child-chevron::before {
  border-left-color: #003478;
  transform: translate(4px, -50%);
}

@media (max-width: 980px) {
  .nabsa-demo-menu {
    justify-content: flex-end;
    width: auto;
    flex: 0 0 auto;
  }

  .nabsa-demo-menu__container {
    display: none;
  }

  .nabsa-demo-menu__mobile-trigger {
    display: inline-flex;
    margin-right: 40px;
    background: transparent !important;
    box-shadow: none !important;
  }
  #language_switch {
    max-width: 20px!important;
  }     
}

@media (min-width: 981px) {
  .nabsa-demo-menu__mobile-trigger {
    display: none;
  }

}





/* Mobile popup menu */
.nabsa-mobile-menu-root {
  width: 100%;
  padding: 12px 18px calc(70px + env(safe-area-inset-bottom, 0px));
  max-height: calc(100vh - 40px);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  margin-bottom: env(safe-area-inset-bottom, 0px);
  scrollbar-width: none;
}

.nabsa-mobile-menu-root::-webkit-scrollbar {
  display: none;
}

.nabsa-mobile-menu {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%;
}

.nabsa-mobile-menu__section {
  padding: 4px 0 10px;
  border-bottom: 1px solid rgba(11, 33, 63, 0.08);
}

.nabsa-mobile-menu__parent {
  margin-bottom: 6px;
}

.nabsa-mobile-menu__parent-link {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  gap: 6px;
}

.nabsa-mobile-menu__parent-link:focus-visible {
  outline: 2px solid #003478;
  outline-offset: 3px;
  border-radius: 6px;
  padding: 2px 4px;
}

.nabsa-mobile-menu__parent-label {
  display: inline-block;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 700;
  color: #0b213f;
  font-size: 0.95rem;
}

.nabsa-mobile-menu__child-list {
  list-style: none;
  margin: 0;
  padding: 0 2px 6px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.nabsa-mobile-menu__child-item,
.nabsa-mobile-menu__single-link {
  width: 100%;
}

.nabsa-mobile-menu__child-link,
.nabsa-mobile-menu__single-link {
  display: flex;
  align-items: center;
  gap: 14px;
  text-decoration: none;
  padding: 8px 0;
  border-radius: 10px;
  color: #0b213f;
  transition: color 140ms ease;
  min-height: 40px;
}

.nabsa-mobile-menu__child-link:focus-visible,
.nabsa-mobile-menu__single-link:focus-visible {
  outline: 2px solid #003478;
  outline-offset: 2px;
}

.nabsa-mobile-menu__child-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
}

.nabsa-mobile-menu__child-title {
  font-size: 0.98rem;
  font-weight: 600;
}

.nabsa-mobile-menu__child-desc {
  color: rgba(11, 33, 63, 0.7);
  font-size: 0.85rem;
  line-height: 1.35;
}

.nabsa-mobile-menu__single-link {
  justify-content: space-between;
  padding-left: 0;
  padding-right: 0;
}

.nabsa-mobile-menu__single-link .nabsa-mobile-menu__child-text {
  flex-direction: row;
  gap: 8px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.nabsa-mobile-menu__child-chevron {
  display: none;
}


.nabsa-footer-menu {
  --nabsa-footer-muted: rgba(255, 255, 255, 0.75);
  margin-top: clamp(18px, 2.2vw, 28px);
}

.nabsa-footer-menu__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: start;
  gap: 12px 20px;
}

.elementor-element.elementor-element-1d52794 > .elementor-widget-container,
.elementor-element.elementor-element-1d52794 .elementor-shortcode {
  margin: 0;
}

@media (max-width: 767px) {
  .elementor-element.elementor-element-1d52794 {
    margin-top: 18px;
  }

  .nabsa-footer-menu {
    margin: 12px 0 0;
    max-width: 100%;
  }

  .nabsa-footer-menu__grid {
    gap: 8px 22px;
  }

  .nabsa-footer-menu__link {
    font-size: 0.95rem;
  }
}

.nabsa-footer-menu__list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.nabsa-footer-menu__link {
  display: inline-flex;
  color: #ffffff;
  font-size: 1rem;
  line-height: 1.25;
  text-decoration: none;
}

.nabsa-footer-menu__link:hover,
.nabsa-footer-menu__link:focus-visible {
  text-decoration: underline;
}

@media (min-width: 768px) {
  .elementor-element.elementor-element-1d52794 {
    margin-top: 0;
  }

  .elementor-element.elementor-element-1d52794 > .elementor-widget-container {
    display: flex;
    justify-content: center;
  }

  .nabsa-footer-menu {
    margin-top: 6px;
    margin-left: 0;
  }

  .nabsa-footer-menu__grid {
    width: fit-content;
    max-width: 100%;
    grid-template-columns: repeat(2, max-content);
    column-gap: clamp(18px, 1.8vw, 26px);
    row-gap: 0;
  }
}


/* ppt loader */
.pptx-embed-wrapper {
    position: relative;
    display: flex;
    width: 100%;
    aspect-ratio: 16 / 9;
    max-height: 80vh;
    background: #ffffff;
}

.pptx-embed-wrapper iframe {
    width: 100%;
    height: 100%;
    border: 0;
}

.pptx-loader {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 48px;
    height: 48px;
    transform: translate(-50%, -50%);
    border-radius: 50%;
    border: 4px solid #e5e5e5;
    border-top-color: #1f4fbf;
    animation: pptx-spin 0.9s linear infinite;
    z-index: 2;
}

.pptx-embed-wrapper:not(.is-loading) .pptx-loader {
    display: none;
}

@keyframes pptx-spin {
    to {
        transform: translate(-50%, -50%) rotate(360deg);
    }
}
