#page {
    position: relative;
/*    overflow: hidden;*/
}
/* Primary Navigation */
nav.primary-nav {
    padding-block: 1rem;
    position: relative;
}
nav.primary-nav .logo-wrapper a {
    display: inline-block;
}
nav.primary-nav .logo-wrapper img {
   height: 5rem;
   width: auto;
}
nav.primary-nav .nav-wrapper {
    display: flex;
    align-items: center;
    width: 100%;
}
.nav-header-primary {
    width: 100%;
}
ul.menu, .menu ul {
    list-style: none;
}
nav.primary-nav .menu {
    width: 100%;
    display: flex;
    justify-content: flex-start;
    align-items: stretch;
    gap: 2rem;
}
.menu-item-back-to-sdg2 {
    /*margin-left: auto; */
}
.nav-header-primary > .menu > li {
    display: flex;
    gap: 0.5rem;
    align-items: center;
}
.nav-header-primary li > a > svg {
    transition: rotate 150ms linear;
    margin-left: 0.5rem;
}
.nav-header-primary li.active > a > svg {
    rotate: -90deg;
}

nav.primary-nav .btn-menu, nav.primary-nav .btn-close {
    display: none;
}
nav.primary-nav .btn-search {margin-left: auto;}
nav.primary-nav .btn-search span {
    display: none;
}
nav.primary-nav .btn-search .menu-section-title { display: none; }

nav.primary-nav.full-image {
    background-color: transparent;
    color: var(--clr-white);
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 4;
    transition: all 150ms ease;
}
nav.primary-nav.full-image:hover {
    background-color: var(--clr-gray);
    color: var(--clr-black);
}

.nav-wrapper, .nav-wrapper > div {
    height: 100%;
    display: flex;
    align-items: center;
}
.nav-wrapper .menu {
    margin-bottom: 0;
    height: 100%;
}

/* MEGA MENU! */
.menu .sub-wrapper { 
    display: none; 
    position: absolute;
    z-index: 1000;
    left: 0;
    top: calc(100% - 1px);
    /*background-color: var(--clr-gray);*/
    width: 100%;
    padding: 2rem var(--xy-gutter) 2rem;

    grid-template-columns: repeat(12, 1fr);
    row-gap: var(--xy-row-gap);
    column-gap: var(--xy-col-gap);

    color: var(--clr-black);
}
.sub-menu .sub-wrapper { display: none !important; }

.menu .sub-wrapper .menu-section-title {
    grid-column: 3 / 5;
}
.menu-section-title p:last-child {
    margin-bottom: 0;
}
.menu-section-title p + p {
    margin-top: 1.5rem;
    /*font-weight: bold;*/
    font-size: var(--text-sm);
    font-family: var(--font-headings);
}

.menu .sub-wrapper .sub-menu {
    grid-column: 5 / 11;
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 1rem 2rem;
    padding-left: 3rem;
    margin-bottom: 0;
}

.menu .menu-item:not(.show-child-descriptions) .sub-wrapper .sub-menu {
    flex-wrap: nowrap;
    gap: 1rem 1rem;
}
.menu-item-description {
    display: none;
    font-weight: normal;
    font-size: var(--text-sm);
    margin-top: 0.25rem;
}
.menu-item.show-child-descriptions .menu-item-description { display: block; }

.menu-item.show-child-descriptions .menu-item {
    flex-basis: calc( (100% - 4rem) / 3);
}
.menu-item.has-menu-icon:not(.show-child-descriptions) .menu-item {
    flex-basis: 25%;
}
.menu-item .menu-item > a,
.menu-item .menu-item > span {
    display: flex;
    gap: 1rem;
}
.menu-item:not(.show-child-descriptions) .menu-item.has-menu-icon {	
    width: 10%;
    flex: 1 1 0;
}
img.menu-icon {
    border-radius: 0.25rem;
    aspect-ratio: 1;
    object-fit: contain;
}
.menu-item:not(.show-child-descriptions) .menu-item.has-menu-icon > a,
.menu-item:not(.show-child-descriptions) .menu-item.has-menu-icon > span {
    text-align: center;
    display: block;
}
.menu-item:not(.show-child-descriptions) .menu-item.has-menu-icon > a div:first-child,
.menu-item:not(.show-child-descriptions) .menu-item.has-menu-icon > span div:first-child {
    margin-bottom: 0.5rem;
}

.menu-item:not(.show-child-descriptions) .menu-item .menu-icon-wrapper {
    padding: 1rem;
    margin-inline: 1rem;
    background-color: var(--clr-white);
    aspect-ratio: 1 / 1;
    display: flex;
    align-items: center;
    border-radius: calc(var(--rounded) * 1);

    box-shadow: 0px 2px 7px -3px color-mix(in srgb, var(--clr-black) 30%, transparent);
}

.menu-item.show-child-descriptions .menu-icon {
    width: 3.25rem;
    min-width: 60px;
}

.menu-item-title {
    display: block;
    text-wrap: balance;
}

.sub-menu .menu-item .menu-item-title {
    font-family: var(--font-headings);
}
.btn-back-mobile {
    border-width: 0;
    background-color: transparent;
    color: currentColor;
    display: none;
}
.btn-back-mobile svg {
    rotate: 90deg;
}

.menu .sub-wrapper .sub-menu.menu-search-wrapper {
    grid-column: 3 / 11;
    padding-left: 0;
    display: block;
}

.menu .search-form {
    margin-top: 2rem;
    margin-bottom: 4rem;
    padding-bottom: 0.5rem;
    width: 100%;
    border-bottom: solid 1px var(--clr-black);
    font-size: var(--text-xl);
    display: flex;
}
.menu .search-form label {
    width: 100%;
    position: relative;
    display: flex;
    gap: 1rem;
    align-items: center;
}
.menu .search-form label::before {
    content: '';
    display: block;
    background-image: url('../images/icons/magnifier.svg');
    background-size: contain;
    background-repeat: no-repeat;
    width: 3.5rem;
    height: 3.5rem;
}
.menu .search-form input[type="search"] {
    width: 100%;
    border: 0;
    background-color: transparent;
}
.menu .search-form input[type="submit"] {
    border: 0;
    padding: 0;
    outline-color: transparent;
    background-color: var(--clr-yellow);
    color: transparent;
    border-radius: var(--rounded-full);
    overflow: hidden;
    min-width: 4rem;
    max-width: 4rem;
    min-height: 4rem;
    max-height: 4rem;
    background-image: url('../images/icons/arrow-right.svg');
    background-size: 60%;
    background-repeat: no-repeat;
    background-position: center center;
    aspect-ratio: 1 / 1;
    display: block;
    cursor: pointer;
    transition:  all 150ms ease;
}
.menu .search-form input[type="submit"]:hover {
    scale: 1.1;
    filter: brightness(1.1);
}
.nav-header-primary li.btn-search.active > a > svg {
    rotate: 0deg;
    scale: 1.3;
    transition: all 150ms ease;
}

/* Nav themes */
.btn-menu-item {
    display: block;
    padding: 0.5rem 1.5rem;
    border: solid 2px currentColor;
    border-radius: calc(var(--rounded) * 4);
}

nav.primary-nav.full-image.nav-hfa,
nav.primary-nav.full-image.nav-bih,
nav.primary-nav.full-image.nav-cm,
nav.primary-nav.full-image.nav-gffa,
nav.primary-nav.full-image.nav-c3 {
    position: relative;
}
nav.primary-nav.nav-hfa,
nav.primary-nav.nav-bih,
nav.primary-nav.nav-cm,
nav.primary-nav.nav-gffa,
nav.primary-nav.nav-c3 {
    background-color: var(--clr-gray);
    color: var(--clr-black);
}

nav.primary-nav.full-image.nav-hfa + .site-header.layout-full-image,
nav.primary-nav.full-image.nav-bih + .site-header.layout-full-image,
nav.primary-nav.full-image.nav-cm + .site-header.layout-full-image,
nav.primary-nav.full-image.nav-gffa + .site-header.layout-full-image,
nav.primary-nav.full-image.nav-c3 +.site-header.layout-full-image {
    min-height: calc(100vh - 9rem);
    min-height: calc(100svh - 9rem);
}

.mobile-controls .menu-btn {
    border-width: 0;
    background-color: transparent;
    color: currentColor;

    position: absolute;
    z-index: 15;
    top: 1rem;
    right: var(--xy-gutter);
}
.mobile-controls .menu-btn svg {
    height: var(--text-xl);
    width: auto;
}
.mobile-controls {
    display: none;
}

/* Beans is how logo */
nav.primary-nav.nav-bih .logo-wrapper > a {
    height: 5rem;
    display: flex;
    align-items: center;
    width: 100%;
}
nav.primary-nav.nav-bih .logo-wrapper img {
    width: auto;
    height: auto;
	max-width: 8rem;
}
/* Hungry for Action logo */

nav.primary-nav.nav-hfa .logo-wrapper img {
    width: auto;
    height: 5rem;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}
/* C3 logo */

nav.primary-nav.nav-c3 .logo-wrapper img {
    width: auto;
    height: 5rem;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
    object-fit: contain;
}

/* MEGA NAV INTERACTIVITY */
/*
li.entering { color: orange !important; }
li.active { color: hotpink !important; }
li.exiting { color: greenyellow !important; }
*/

nav .nav-inner { position: relative; z-index: 4;}

nav.primary-nav.active { color: var(--clr-black); }
nav.primary-nav .nav-underlay {
    background-color: var(--clr-gray);
    width: calc(100% + 2rem);
    height: 0rem;
    position: absolute;
    left: -1rem;
    right: -1rem;
    top: -1rem;

    z-index: 3;
    transition: all 350ms ease;
}
nav.primary-nav.active .nav-underlay {
    height: 26rem;
    box-shadow: 1px -1px 11px -3px color-mix(in srgb, var(--clr-black) 50%, transparent);
}

.menu .menu-item .sub-wrapper {
    opacity: 0;
    transition: all 150ms ease;
}
.menu .menu-item.entering .sub-wrapper {
    display: grid;
    min-height: 14rem;
}
.menu .menu-item.active .sub-wrapper {
    display: grid;
    /*min-height: 14rem;*/
    opacity: 1;
    transition-duration: 250ms;
}
.menu .menu-item.exiting .sub-wrapper {
    opacity: 0;
}

.menu .menu-section-title, .menu .sub-wrapper .sub-menu { opacity: 0; translate: 0rem 1rem; transition: all 200ms ease; }
.menu .menu-section-title { transition-delay: 50ms; }
.menu .sub-wrapper .sub-menu { transition-delay: 200ms; }
.menu .menu-item.active .menu-section-title,
.menu .menu-item.active .sub-wrapper .sub-menu { opacity: 1;  translate: 0rem 0rem; }
.menu-section-title p > a {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

/* Site Headers */
.site-header {
    min-height: 90vh;
    min-height: 90svh;
    display: flex;
    align-items: stretch;
    --overlay-tint : 80%;
}
.site-header.layout-full-image {
    min-height: 100vh;
    min-height: 100svh;
}

.site-header .inner {
    --overlay-clr : color-mix(in srgb, var(--clr-black-bg) var(--overlay-tint), transparent);
    display: flex;
    align-items: center;
    padding-block: 6rem;
    padding-inline: var(--xy-gutter);

    background-position: center center;
    background-size: cover;

    overflow: hidden;
    width: 100%;
}

.site-header.layout-full-image .text-wrapper {
    max-width: 48rem; 
    margin: 0 auto;
    text-align: center;
}

.site-header .text-wrapper .wysiwyg > *:last-child {
    margin-bottom: 0;
}

body.search-results header.site-header .wysiwyg h1 {
    color: var(--clr-white);
}


.site-header.layout-inset-image {
    padding-inline: var(--xy-gutter);
    padding-block: 1rem 4rem;
}

.site-header.layout-inset-image .inner {
    border-radius: var(--rounded);
    padding: var(--xy-gutter);

    justify-content: flex-start;
    align-items: end;
}
.site-header.layout-simple {
    min-height: 0;
}
.site-header.layout-simple .inner {
    justify-content: center;
}


.site-header .video-wrapper {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 0;
}

.site-header video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.site-header.has-video {
    --overlay-origin: 180deg;
}
.site-header.layout-inset-image.has-video {
    --overlay-origin: 60deg;

}
.site-header.has-video .inner {
    position: relative;
}
.site-header.has-video .text-wrapper {
    position: relative;
    z-index: 2;
}

.site-header.has-video .inner::after {
    content: '';
    position: absolute;
    inset: 0 0 0 0;
    background: linear-gradient( var(--overlay-origin), var(--overlay-clr) 20%, var(--overlay-clr) );
}

/* Header Slider */
.site-header.layout-slider {
    min-height: auto;
}
.site-header.layout-slider .inner {
    padding-inline : 0;
    position: relative;
}
.header-slider-wrapper {
    width: 100%;
}

.header-slider-wrapper .slide {
    width: calc(100% - var(--xy-gutter) * 6);
    margin-right: 0rem;

}
.header-slider-wrapper .slide-inner {
    scale: 0.9;
    background-color: var(--clr-black-bg);
    border-radius: var(--rounded);
    transition: scale 250ms linear;
    aspect-ratio: 16 / 9;
}
.header-slider-wrapper .slide.is-selected .slide-inner {
    scale: 1;
}

.header-slider-wrapper  .slide-inner {
    position: relative;
    overflow: hidden;
}
.header-slider-wrapper  .slide-inner img {
    position: relative;
    z-index: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    aspect-ratio: 16 / 9;
    
}
.header-slider-wrapper  .slide-inner::after {
    content: '';
    z-index: 1;
    position: absolute;
    inset: 0 0 0 0;
    background-color: rgba(0,0,0,0.4);
}
.header-slider-wrapper  .slide-inner .title-wrap {
    padding: 2rem;
    position: absolute;
    z-index: 2;
    bottom : 0;
}
.header-slider-wrapper h3 {
    margin-bottom: 0;
}
.header-slider-wrapper .title-wrap > div {
    padding-bottom: 0.25rem;
    text-transform: uppercase;
}

.header-slider-wrapper .flickity-page-dots {
    bottom: -4rem;
}
.header-slider-wrapper .flickity-page-dots .dot {
    padding: 0;
    border-radius: 0;
    margin: 0;
    width: 3rem;
    height: 0.25rem;
    background: var(--clr-gray);
}
.header-slider-wrapper .flickity-page-dots .dot.is-selected {
    background: var(--clr-gray);
}
.header-slider-wrapper .flickity-page-dots .dot:hover {
    background-color: var(--clr-highlight);
    opacity: 1;
}
.header-slider-wrapper .flickity-prev-next-button {
    position: absolute;
    background-color: transparent;
    color: var(--clr-white);
    border: solid 1px var(--clr-white);

    top: unset;
    bottom: -5rem;
    left: unset;
    right: unset;
    transform: unset;
    margin-top: 0.5rem;
    scale : 1.1;
}
.header-slider-wrapper .flickity-prev-next-button.previous {
    left: unset;
    right: calc(var(--xy-gutter)*5);
    z-index: 4;
}
.header-slider-wrapper .flickity-prev-next-button.next {
    z-index: 3;
    right: calc(var(--xy-gutter)*3);
    margin-left: 5rem;
}
.header-slider-wrapper .flickity-prev-next-button::before {
    content: '';
    display: block;
    width: 100%;
    aspect-ratio: 1 / 1;
    background-image: url('../images/icons/caro-left.svg');
    background-repeat: no-repeat;
    background-size: 80%;
    background-position: center center;
}
.header-slider-wrapper .flickity-prev-next-button.previous::before {
    rotate: 180deg;
}

.header-slider-wrapper .flickity-prev-next-button:hover {
    background: color-mix(in srgb, var(--clr-highlight) 80%, transparent);
}
.site-header.layout-slider .inner-title {
    color: var(--clr-highlight);
    margin-bottom: 0;
    position: absolute;
    left: calc(var(--xy-gutter)*3);
    bottom: 2rem;
    font-size: var(--text-lg);
}
/*
.site-header.layout-slider .inner::after {
    content: '';
    position: absolute;
    bottom: -3rem;
    left: var(--xy-gutter);
    right: var(--xy-gutter);
    border-top: solid 2px color-mix(in srgb, var(--clr-gray) 30%, transparent);
}*/