/* Custom theme styles */

:root {
  --bg-color: #001c27;

  --deep-space: #003247;
  --deep-space-light: #335e6f;
  --deep-space-lighter: #8197a6;

  --neutral-space: #e8e8e4;
  --neutral-space: #fafafa;
  --enlight-yellow-light: #ffcc4e;
  --enlight-yellow: #fbab18;
  --enlight-yellow-dark: #f47920;
  --enlight-yellow-darker: #a75534;

  --orange: #ffa800;

  --excite-red-light: #f1666a;
  --excite-red: #ed1b2f;
  --excite-red-dark: #cf1d39;
  --excite-red-darker: #960136;

  --pure-teal-light: #76c8ae;
  --pure-teal: #00ae9d;
  --pure-teal-dark: #008e7a;
  --pure-teal-darker: #006762;

  --trusty-azure-light: #6dcff6;
  --trusty-azure: #009bdb;
  --trusty-azure-dark: #00619e;
  --trusty-azure-darker: #1e3378;

  /* --black: #000000; */
  --black: #002635;
  --white: #ffffff;

  --notesesa: "notesesa", sans-serif;
}

/* Color classes */
.pure-teal {
  color: var(--pure-teal);
}
.neutral-space {
  color: var(--neutral-space);
}
/* Background color */
.bg-color {
  color: var(--bg-color);
}
.bg-color-bg {
  background-color: var(--bg-color);
}
.bg-color-black {
  background-color: var(--black);
}

/* Custom backgrounds */

.bg-gradient {
  background-color: var(--pure-teal-darker);

  width: 100vw;
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  padding: 6rem 0;
}
.bg-gradient > * {
  z-index: 10;
}
.bg-gradient-linear {
  /* background-color: var(--pure-teal-darker); */
  width: 100vw;
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  padding: 6rem 0;
}
.bg-gradient-linear::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0.1) 0.01%,
    rgba(0, 174, 157, 0) 100%
  );
}
@media (min-width: 992px) {
  .single-partnership-projects .bg-gradient-linear,
  .page-template-page-with-content .bg-gradient-linear {
    left: 76%;
  }
}
@media (min-width: 1200px) {
  .single-partnership-projects .bg-gradient-linear,
  .page-template-page-with-content .bg-gradient-linear {
    left: 33%;
  }
}
@media (min-width: 1580px) {
  .single-partnership-projects .bg-gradient-linear,
  .page-template-page-with-content .bg-gradient-linear {
    left: 50%;
  }
}
/* .bg-gradient-linear > * {
  z-index: 10;
} */

.bg-gradient-circle-1 {
  background-color: var(--pure-teal-darker);
  width: 100vw;
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  padding: 6rem 1.5rem;
}
.bg-gradient-circle-1::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    #001f2c 0%,
    rgba(0, 174, 157, 0) 50%,
    #001f2c 100%
  );
}
.bg-gradient-circle-1::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("images/circles-bg-1.png") center top no-repeat;
  background-size: contain;
  /* opacity: 0.7; */
  z-index: 0;
}

.bg-gradient-circle-1 > * {
  z-index: 10;
  position: relative;
}
/* Ninja form overrides */

#ninja_forms_required_items,
.nf-field-container {
  margin-bottom: 0 !important;
}
input.ninja-forms-field,
select.ninja-forms-field,
textarea.ninja-forms-field {
  border-radius: 0.125rem;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.04);
  color: rgba(255, 255, 255, 0.8);
  padding: 0.44rem 0.75rem;
}

.field-wrap .pikaday__display,
.field-wrap > div input {
  border-radius: 0.125rem;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.04);
  color: rgba(255, 255, 255, 0.8);
}

.field-wrap .pikaday__display {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%238197a6' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 1.25rem;
  padding-right: 2.5rem;
}

input.ninja-forms-field[type="checkbox"] {
  appearance: none;
  width: 1.25rem;
  height: 1.25rem;
  border: 2px solid #fff;
  border-radius: 0.25rem;
  background-color: transparent;
  transition: all 0.3s ease;
  cursor: pointer;
  padding: 0.5rem;
}

input.ninja-forms-field[type="checkbox"]:checked {
  background-color: var(--pure-teal);
  border-color: var(--pure-teal-dark);
  position: relative;
}

input.ninja-forms-field[type="checkbox"]:checked::after {
  content: "✔";
  color: #fff;
  font-size: 0.75rem;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

input.ninja-forms-field[type="checkbox"]:hover {
  background-color: rgba(0, 174, 157, 0.2);
  border-color: var(--pure-teal);
}

input.ninja-forms-field[type="submit"] {
  border-radius: 0.375rem;
  background: rgba(255, 255, 255, 1);
  color: #001f2c;
  font-family: var(--notesesa);
  font-size: 1.1rem;
  padding: 1rem;
  text-transform: uppercase;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}

input.ninja-forms-field[type="submit"]:hover {
  background: rgba(255, 255, 255, 0.7);
  text-decoration: none;
  outline: 2px solid var(--pure-teal);
}

.nf-field-label label,
.nf-label-span {
  color: #54a2bf !important;
  font-size: 0.8125rem;
  font-style: normal;
  font-weight: 400;
  line-height: 150%; /* 1.21875rem */
  letter-spacing: 0.00813rem;
  font-weight: normal !important;
  margin-top: 1rem !important;
  display: block;
}
.nf-field-element input:focus {
  color: rgba(255, 255, 255, 0.8) !important;
}
#nf-description-208 {
  order: 20 !important;
}
#nf-description-208 p {
  color: #54a2bf;
  font-size: 0.8125rem;
  font-style: normal;
  font-weight: 400;
  line-height: 150%; /* 1.21875rem */
  letter-spacing: 0.00813rem;
  margin-top: 0.25rem;
}

#nf-field-228-wrap .nf-field-element ul {
  display: flex;
  width: 100%;
  justify-content: space-between;
  flex-wrap: nowrap;
  gap: 1rem;
}
#nf-field-228-wrap .nf-field-element li label {
  padding-left: 0.5rem;
}
#nf-field-228-wrap .nf-field-element li input {
  margin-top: 0;
}
#nf-field-228-wrap .nf-field-element li {
  border-radius: 0.1875rem;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.1);
  padding: 1rem !important;
  width: 100%;

  display: flex;
  justify-content: flex-start;
  align-content: center;
  align-items: center;
}

.nf-form-fields-required {
  font-size: 0.9375rem !important;
  margin-bottom: 1rem !important;
}

.nf-field-element .btn-success {
  background-color: var(--pure-teal) !important ;
}
.nf-fu-progress {
  background-color: var(--deep-space) !important ;
}
.nf-fu-progress-bar,
.nf-progress {
  background-color: var(--pure-teal-dark) !important ;
}
.files_uploaded {
  font-family: var(--notesesa);
}
.nf-field-description p {
  font-size: 0.9375rem !important;
  margin-bottom: 0.5rem !important;
  display: block;
}
.nf-form-layout p,
.nf-form-layout p span {
  font-size: 0.9375rem !important;
}
.nf-form-layout h3 {
  font-family: var(--notesesa);
  font-size: 1rem;
  font-style: normal;
  font-weight: 700;
  line-height: 1rem; /* 100% */
  letter-spacing: 0.06rem;
  text-transform: uppercase;
  margin-top: 1.5rem;
  margin-bottom: 0;
}
.checkbox-wrap .nf-field-label label {
  margin-top: 0 !important;
}
.checkbox-wrap {
  margin-top: 1rem !important;
}
.submit-wrap {
  margin-block: 1.5rem;
}
.jBox-container ul li,
.jBox-container ol li {
  font-size: 0.875rem !important;
}
.jBox-container,
.jBox-pointer::after {
  background: var(--deep-space) !important;
}
li.active .nf-breadcrumb {
  text-decoration: underline !important;
}
/* Bootstrap overrides and integrations */

@media (min-width: 1400px) {
  .container,
  .container-lg,
  .container-md,
  .container-sm,
  .container-xl,
  .container-xxl {
    max-width: 1440px;
  }
}

.post,
.page {
  margin: 0;
}
.force-container-fluid {
  width: 100vw;
  /* max-width: 100%; */
  margin-left: 0;
  margin-right: 0;
  padding-left: 0;
  padding-right: 0;
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
}

.page-id-24331 .force-container-fluid {
  margin-left: -50vw;
}
@media (min-width: 992px) {
  .page-id-24331 .force-container-fluid {
    margin-left: calc(-50vw + 11rem);
  }
}
@media (min-width: 1200px) {
  .page-id-24331 .force-container-fluid {
    margin-left: calc(-50vw - 6rem);
  }
}
@media (min-width: 1850px) {
  .page-id-24331 .force-container-fluid {
    margin-left: -50vw;
  }
}

.force-container-fluid .container,
.force-container-fluid .container-fluid,
.force-container-fluid [class*="container-"] {
  /* max-width: 100%; */
  /* margin-left: 0;
  margin-right: 0; */
  max-width: 1320px;
  margin: 0 auto;
  width: 100%;
}

/* WORDPRESS OVERRIDES AND INTEGRATIONS */

.wp-block-button {
  border-radius: 0.5rem;
  background: #fff;
  color: #001f2c;
  font-family: "notesesa", sans-serif;
  font-size: 0.875rem;
  letter-spacing: 0.0875rem;
  opacity: 0.9;

  text-transform: uppercase;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.wp-block-button:hover {
  text-decoration: none;
  opacity: 1;
  outline: 2px solid var(--pure-teal);
}
.wp-block-button__link {
  color: #001f2c;
  background-color: #fff;
  border-radius: 0.5rem;
  font-family: "notesesa", sans-serif;
}

.wp-block-button.is-style-outline {
  border-radius: 0.5rem;
  background: transparent;
  color: #fff;
  font-family: "notesesa", sans-serif;
  font-size: 0.875rem;
  letter-spacing: 0.0875rem;
  opacity: 0.9;
  outline: 0;
  text-transform: uppercase;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.wp-block-button.is-style-outline:hover {
  text-decoration: none;
  background-color: rgba(118, 200, 174, 0.2);
  opacity: 1;
  outline: 0;
}
.wp-block-button.is-style-outline .wp-block-button__link {
  color: #fff;
  background-color: transparent;
  font-family: "notesesa", sans-serif;
}

.rounded-section {
  border-radius: 0.5rem;
  padding: 3.75rem;
  background-color: var(--deep-space);
}

/**** Video embed */
.wp-block-embed-youtube iframe {
  width: 100% !important;
}
.wp-block-embed-youtube.wp-embed-aspect-16-9 .wp-block-embed__wrapper,
.wp-block-embed-youtube.wp-embed-aspect-16-9 .wp-block-embed__wrapper iframe {
  aspect-ratio: 16 / 9 !important;
  height: auto;
}

.quick-links-section {
  position: sticky;
  top: 0;
  transform: translateX(-1rem);
  background-color: var(--bg-color);
  padding: 0.875rem 0.5rem;
  height: auto;
  width: auto;
  margin: 0 auto;
  overflow: visible;
  z-index: 1050;
}
@media (min-width: 576px) {
  .quick-links-section {
    transform: translateX(-7vw);
  }
}
@media (min-width: 992px) {
  .quick-links-section {
    transform: translateX(0);
  }
}
.quick-links {
  padding: 0 1.5rem;
}
.quick-links h5 {
  color: #677f8e;
  font-family: var(--notesesa), sans-serif;
  font-size: 0.875rem;
  font-style: normal;
  line-height: 120%; /* 1.05rem */
  letter-spacing: 0.09625rem;
  text-transform: uppercase;
  margin-bottom: 0;
}
.quick-links ul {
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.quick-links ul li {
  list-style: none;
  margin-bottom: 0;
  color: #fff;
  font-family: var(--notesesa), sans-serif;
  font-size: 0.875rem;
  line-height: 120%; /* 1.05rem */
  letter-spacing: 0.09625rem;
  text-transform: uppercase;
  border-right: 1px solid var(--pure-teal);
  padding-right: 0.5rem;
}
.quick-links ul li:last-child {
  border-right: none;
  padding-right: 0;
}
.quick-links ul li a {
  color: #fff;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.quick-links ul li a:hover,
.quick-links ul li a.active {
  color: var(--pure-teal);
  text-decoration: none;
}

/* Typography */
@font-face {
  font-family: "notesesa";
  src: url("fonts/notesesabold.woff2") format("woff2"),
    url("fonts/notesesabold.woff") format("woff");
  font-weight: 700;
  font-style: normal;
}

@font-face {
  font-family: "notesesa";
  src: url("fonts/notesesa.woff2") format("woff2"),
    url("fonts/notesesa.woff") format("woff");
  font-weight: 500;
  font-style: normal;
}
.notesesa {
  font-family: "notesesa", sans-serif;
}
.notesesa.hover-pure-teal a:hover {
  color: var(--pure-teal);
  text-decoration: none;
}
.text-light a {
  color: #fff;
}

h1,
h2,
h3,
h4,
h5,
h6,
.h1,
.h2,
.h3,
.h4,
.h5,
.h6 {
  font-family: "notesesa", sans-serif;
  color: #fff;
  margin-bottom: 1rem;
}
.h1 {
  font-size: clamp(2.6rem, 5vw, 3rem) !important;
  font-style: normal !important;
  font-weight: 700 !important;
  font-family: var(--notesesa) !important;
  letter-spacing: -0.12rem !important;
  color: #fff !important;
}
h2 {
  font-size: 1.75rem;
  font-style: normal;
  font-weight: 700;
  line-height: 120%; /* 2.1rem */
  letter-spacing: -0.035rem;
}

h6,
.h6 {
  color: #00ae9d;
  /* font-feature-settings: 'liga' off, 'clig' off; */
  font-family: var(--notesesa), sans-serif;
  font-size: 0.75rem;
  font-style: normal;
  font-weight: 400;
  line-height: 120%; /* 0.9rem */
  letter-spacing: 0.0825rem;
  text-transform: uppercase;
}
html,
body {
  scroll-padding-top: 60px;
  scroll-behavior: smooth;
}
body {
  background-color: var(--bg-color);
  font-family: Arial, Helvetica, sans-serif;
  color: #fff;

  /* overflow-x: hidden; */
}

p,
.wp-block-cover p:not(.has-text-color) {
  /* color: #fff; */
  color: rgba(255, 255, 255, 0.8);
  font-family: Arial, Helvetica, sans-serif;
  font-size: 1.125rem;
  font-style: normal;
  font-weight: 400;
  line-height: 152%; /* 1.71rem */
  letter-spacing: 0.01125rem;
}
p.muted {
  color: rgba(255, 255, 255, 0.8) !important;
}

p.smaller,
.smaller-text p {
  font-size: 0.9375rem !important;
}
p.much-smaller {
  font-size: 0.625rem !important;
}
p.bigger {
  font-size: 1.1875rem !important;
}
p.much-bigger {
  font-size: 1.5rem !important;
}

p.underlined {
  border-bottom: 2px solid var(--pure-teal);
  padding-bottom: 0.5rem;
  margin-bottom: 1.5rem;
  width: fit-content;
}

a {
  color: var(--pure-teal);
  text-decoration: none;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.single-news_and_events a {
  text-decoration: underline;
}

a:focus,
a:hover,
a:active {
  color: var(--pure-teal) !important;
  text-decoration: none;
  outline: none;
}
a:visited {
  color: unset !important;
}

ul,
ol {
  margin: 0 0 1.5em 0;
}
ul li,
ol li {
  font-size: 1.125rem;
  letter-spacing: 0.01125rem;
  line-height: 152%; /* 1.71rem */
}
ul.muted li,
ol.muted li {
  color: rgba(255, 255, 255, 0.8) !important;
}

blockquote {
  border-left: 2px solid #00ae9d;
  margin: 0;
  padding-left: 1rem;
}

/* Checkbox */
.mt-checkbox {
  display: block;
  position: relative;
  padding-left: 28px;
  margin-bottom: 0.5rem;
  cursor: pointer;
  font-size: 1rem;
  user-select: none;
}

.mt-checkbox input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
  height: 0;
  width: 0;
}

.mt-checkbox .checkmark {
  position: absolute;
  top: 2px;
  left: 0;
  height: 18px;
  width: 18px;
  background-color: #002635;
  border: solid 1px #fff;
  transition: background-color 0.3s ease, border-color 0.3s ease;
}

.mt-checkbox input ~ .checkmark:hover {
  background-color: #003247;
}

.mt-checkbox input:checked ~ .checkmark {
  background-color: var(--pure-teal);
  border: solid 1px var(--pure-teal-dark);
}

.mt-checked {
  color: var(--light-green);
}

.checkmark:after {
  content: "";
  position: absolute;
  display: none;
}

.mt-checkbox input:checked ~ .checkmark:after {
  display: block;
}

.mt-checkbox .checkmark:after {
  left: 6px;
  top: 3px;
  width: 5px;
  height: 10px;
  border: solid 2px #fff;
  border-width: 0 3px 3px 0;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}
.mt-checkbox .checkmark-label {
  padding-left: 0.25rem;
}
.accordion-checkboxes {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: flex-start;
  -ms-justify-content: flex-start;
  justify-content: flex-start;
  -webkit-align-items: flex-start;
  -ms-align-items: flex-start;
  align-items: flex-start;
  -webkit-align-content: flex-start;
  -ms-align-content: flex-start;
  align-content: flex-start;
  flex-direction: column;
  gap: 0 1.8rem;
}
@media (min-width: 768px) {
  .accordion-checkboxes {
    flex-direction: row;
    gap: 0 2.4rem;
  }
}

/* Arrow bullet list */
.arrow-list {
  padding-left: 0;
  margin-left: 0;
}

.arrow-list li {
  list-style: none;
  padding-left: 2.5rem;
  position: relative;
  margin-bottom: 1rem;
}

.arrow-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.1rem;
  width: 1.5rem;
  height: 1.5rem;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M12 2.25C6.615 2.25 2.25 6.615 2.25 12C2.25 17.385 6.615 21.75 12 21.75C17.385 21.75 21.75 17.385 21.75 12C21.75 6.615 17.385 2.25 12 2.25ZM16.28 12.53C16.4205 12.3894 16.4993 12.1988 16.4993 12C16.4993 11.8012 16.4205 11.6106 16.28 11.47L13.28 8.47C13.2113 8.39631 13.1285 8.33721 13.0365 8.29622C12.9445 8.25523 12.8452 8.23318 12.7445 8.23141C12.6438 8.22963 12.5438 8.24816 12.4504 8.28588C12.357 8.3236 12.2722 8.37974 12.201 8.45096C12.1297 8.52218 12.0736 8.60701 12.0359 8.7004C11.9982 8.79379 11.9796 8.89382 11.9814 8.99452C11.9832 9.09522 12.0052 9.19454 12.0462 9.28654C12.0872 9.37854 12.1463 9.46134 12.22 9.53L13.94 11.25H8.25C8.05109 11.25 7.86032 11.329 7.71967 11.4697C7.57902 11.6103 7.5 11.8011 7.5 12C7.5 12.1989 7.57902 12.3897 7.71967 12.5303C7.86032 12.671 8.05109 12.75 8.25 12.75H13.94L12.22 14.47C12.1463 14.5387 12.0872 14.6215 12.0462 14.7135C12.0052 14.8055 11.9832 14.9048 11.9814 15.0055C11.9796 15.1062 11.9982 15.2062 12.0359 15.2996C12.0736 15.393 12.1297 15.4778 12.201 15.549C12.2722 15.6203 12.357 15.6764 12.4504 15.7141C12.5438 15.7518 12.6438 15.7704 12.7445 15.7686C12.8452 15.7668 12.9445 15.7448 13.0365 15.7038C13.1285 15.6628 13.2113 15.6037 13.28 15.53L16.28 12.53Z' fill='white'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
}

/* Widget */
.widget-title {
  color: #fff;
  font-family: var(--notesesa), sans-serif;
  font-size: 1.125rem;
  font-style: normal;
  font-weight: 700;
  line-height: 140%; /* 1.575rem */
  letter-spacing: 0.0225rem;
  text-transform: uppercase;
}

/* Navigation */
.navbar {
  background-color: var(--bg-color);
  z-index: 1055;
  width: 100%;
}
.navbar-collapse {
  position: absolute;
  top: 64px;
  right: 0;
  left: 0;
  bottom: 0;
  padding-left: 1.5rem;

  padding-right: 1.5rem;
  padding-top: 3rem;
  min-width: min(100vw, 24rem);

  min-height: 100vh;
  transform: translateX(100%);
  background: var(--bg-color);
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.navbar-collapse.show {
  transform: translateX(0);
}
@media (min-width: 992px) {
  .navbar-collapse {
    /* position: unset !important;
    top: 45px;
    right: unset;
    padding-right: unset;
    padding-top: unset;
    min-width: unset;
    min-height: unset;
    transform: translateX(0); */
  }
}
@media (min-width: 1400px) {
  .navbar-collapse {
    top: 0;
    position: unset !important;

    right: unset;
    padding-right: unset;
    padding-top: unset;
    min-width: unset;
    min-height: unset;
    transform: translateX(0);
  }
}
.navbar .navbar-brand {
  font-family: "notesesa";
  text-transform: uppercase;
  font-size: clamp(0.7rem, 1vw, 0.8rem);
}
.navbar .navbar-brand img.navbar-logo {
  max-width: 160px;
  height: auto;
  border-right: 1px solid var(--pure-teal);
  padding-right: 1rem;
}

.navbar .navbar-nav {
  font-family: "notesesa";
  font-size: 1rem;
  color: #fff;
  align-items: flex-start;
}
@media (min-width: 1400px) {
  .navbar .navbar-nav {
    font-size: 1rem;
    margin-left: 2em;
    align-items: center;
  }
}
.navbar-nav li.nav-item {
  cursor: pointer;
}

.navbar-nav a.nav-link {
  color: var(--white);
}
.navbar-nav a.nav-link:hover,
.navbar-nav a.nav-link.active {
  color: var(--pure-teal);
}
.navbar-toggler:focus {
  box-shadow: 0 0 0 0;
}
.navbar .navbar-nav > li a {
  letter-spacing: 0.04rem;
  margin: 0 0.4rem;
  text-transform: uppercase;
}

.navbar .navbar-nav > li a.stretched-link {
  margin: 0;
}

.navbar-dark .navbar-toggler {
  border-color: transparent;
}

.nav-left {
  width: 100%;
  justify-content: space-between;
}

@media (min-width: 1400px) {
  .nav-left {
    width: auto;
    justify-content: flex-start;
  }
}
.nav-separator {
  display: none;
  padding: 0;
  margin: 0 0.5rem;
  border-left: 1px solid var(--pure-teal);
  max-height: 1.2rem;
  width: 1px;
}
@media (min-width: 1400px) {
  .nav-separator {
    display: inline-block;
  }
}
.nav-separator a {
  display: block;
  width: 0;
  overflow: hidden;
}
/* Multilevel navigation */
/* .dropdown-menu .dropdown-toggle:hover {
  cursor: pointer;
} */
.dropdown-menu {
  /* position: absolute;
  z-index: 1000;
  display: none;
  min-width: 10rem;

  margin: 0;
    margin-top: 0px;
  font-size: 1rem; */
  padding: 0.2rem 0;
  color: #fff;
  background-color: var(--deep-space);
  border: none sans-serif;
  border-radius: 0;
}
.dropdown-menu .menu-item {
  padding: 0.2rem 0;
}
.dropdown-menu .dropdown-menu .menu-item {
  padding: 0;
}
.dropdown-menu.depth_0 {
  border-left: var(--grey) 2px solid;
  margin-left: 0.8rem;
}
.dropdown-item {
  /* display: block;
  width: 100%; */
  padding: 0;
  /* clear: both;
  font-weight: 400;
  color: #212529;
  text-align: inherit;
  text-decoration: none;
  white-space: nowrap;
  background-color: transparent;
  border: 0; */
}
.dropdown-menu li a {
  color: rgba(255, 255, 255, 0.85);
  margin: 0 !important;
  padding: 0.3rem 1rem !important;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}

.dropdown-item:focus,
.dropdown-item:hover,
.dropdown-item:active {
  color: rgba(255, 255, 255, 0.95);
  background-color: var(--deep-space);
  text-decoration: none;
}
.dropdown-menu li a:hover {
  color: rgba(255, 255, 255, 0.95) sans-serif;
}
.dropdown-menu .dropdown-menu {
  display: block;
}

ul.dropdown-menu li.dropdown-menu {
  position: relative !important;
}
.dropdown-menu .dropdown-menu .sub-menu {
  display: none;
  position: relative;
}

.dropdown-menu .dropdown-menu .sub-menu.show {
  display: block;
}

.dropdown-menu .dropdown-menu .sub-menu .dropdown-item {
  background-color: var(--deep-space-light);
  color: rgba(255, 255, 255, 0.95);
  font-size: 0.9rem;
  padding: 0.6rem 1rem;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}

.dropdown-menu .dropdown-menu .sub-menu .dropdown-item:hover {
  background-color: var(--bg-color);
  color: rgba(255, 255, 255, 0.95);
}

.dropdown-item.active {
  background-color: var(--bg-color);
  color: var(--pure-teal);
}

.dropdown-menu .dropdown-menu .sub-menu .dropdown-item.active {
  color: var(--pure-teal);
  font-weight: bold;
}
/* Small menu. */
.menu-toggle,
.main-navigation.toggled ul {
  display: block;
}

.menu-toggle {
  display: none;
}

.main-navigation ul {
  display: flex;
  flex-direction: column;
  /* justify-content: flex-end;
  align-content: flex-end;
  align-items: flex-end; */
  width: 100%;
}

@media (min-width: 1400px) {
  .main-navigation ul {
    flex-direction: row;
    align-items: center;
  }
}
.main-navigation ul ul {
  display: flex;
  gap: 0;
  float: unset !important;
  position: unset !important;
  top: unset !important;
  left: unset !important;
  box-shadow: unset !important;
  flex-direction: column;
  justify-content: flex-start;
  align-content: flex-start;
  align-items: flex-start;
}

.main-navigation ul ul li ul li {
  list-style: disc;
  color: var(--pure-teal);
}
.mega-menu-container ul li a {
  width: 100%;
  line-height: 112%;
}

/* Mega menu */
/* Reset e stili base del menu */
.main-navigation {
  position: unset !important;
  z-index: 1055;
  display: flex;
  justify-content: center;
  font-family: var(--notesesa), sans-serif;
  width: 100vw;
}
@media (min-width: 992px) {
  .main-navigation {
    width: 100vw;
    padding-right: 1.5rem;
    height: 50px;
  }
}
@media (min-width: 1400px) {
  .main-navigation {
    width: auto;
  }
}
.main-navigation li {
  position: unset !important;
}
.main-navigation ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 2rem;
}
.main-navigation ul li a {
  text-transform: uppercase;
  color: #fff;
  text-decoration: none;
}
.main-navigation ul li.current_page_item a,
.main-navigation a:hover {
  color: var(--pure-teal);
}

/* Menu principale con mega menu */
.main-navigation .menu > li.has-mega-menu {
  position: relative;
}

.main-navigation .menu > li.has-mega-menu > a {
  cursor: pointer;
}

.main-navigation .menu > li.has-mega-menu > a::after {
  content: "▼";
  font-size: 11px;
  margin-left: 6px;
  transition: transform 0.3s ease;
  display: inline-block;
  transform: rotate(0deg) translateY(-2px);
}

/* Styling per il menu attivo */
.main-navigation .menu > li.has-mega-menu > a.active::after {
  transform: rotate(180deg) translateY(2px);
  color: var(--pure-teal);
}

/* Container del mega menu */
.mega-menu-container {
  position: absolute;
  right: 0;
  top: 0;
  left: 0;
  width: 100vw;
  background: var(--deep-space);
  max-height: 85vh; /* Altezza massima per permettere lo scrolling */
  height: auto;
  min-height: 65vh;
  overflow-y: auto; /* Assicura lo scrolling verticale */
  -webkit-overflow-scrolling: touch; /* Scrolling fluido sui dispositivi touch */
  padding: 2rem;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
  flex-wrap: wrap;
  gap: 2rem;
  z-index: 1055;
  display: none;
}

/* Mega menu close button */
.mega-menu-close {
  position: absolute;
  top: 10px;
  right: 15px;
  background: transparent;
  border: none;
  color: white;
  font-size: 1.5rem;
  cursor: pointer;
  z-index: 10;
  padding: 10px;
  width: 40px;
  height: 40px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.mega-menu-close:hover {
  color: var(--pure-teal);
}

@media (min-width: 1400px) {
  .mega-menu-container {
    left: -288px;
    right: 0;
    top: 58px;
    /* max-height: 90vh;  */
    min-height: calc(100vh - 36px);
    overflow-y: auto;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
  }
}

/* Colonne del mega menu */
.mega-menu-column {
  flex: 1;
  min-width: 200px;
  list-style: none;
  margin: 0;
  padding: 0;
  overflow-x: hidden; /* Evita scrolling orizzontale nelle colonne */
}

/* Titoli delle colonne (unclickable-menu-item) */
.mega-menu-column .unclickable-menu-item {
  margin-bottom: 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--deep-space-light);
}

.mega-menu-column .unclickable-menu-item a {
  color: var(--pure-teal);
  font-family: var(--notesesa), sans-serif;
  font-size: 0.9rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05rem;
  text-decoration: none;
  cursor: default;
  pointer-events: none;
}

/* Elementi normali del mega menu */
.mega-menu-column li:not(.unclickable-menu-item) {
  margin-bottom: 0.5rem;
}

.mega-menu-column li:not(.unclickable-menu-item) a {
  color: rgba(255, 255, 255, 0.85);
  font-size: 0.85rem;
  text-decoration: none;
  padding: 0.25rem 0;
  display: block;
  transition: color 0.3s ease;
}

.mega-menu-column li:not(.unclickable-menu-item) a:hover {
  color: var(--pure-teal) !important;
  text-decoration: none;
}

/* Sottomenu all'interno delle colonne */
.mega-menu-column ul.mega-submenu {
  margin: 0.5rem 0 0 1rem;
  padding: 0;
  list-style: none;
}

.mega-menu-column ul.mega-submenu li {
  margin-bottom: 0.3rem;
}

.mega-menu-column ul.mega-submenu a {
  color: rgba(255, 255, 255, 0.7);
  font-size: 0.8rem;
  padding: 0.2rem 0;
}

.mega-menu-column ul.mega-submenu a:hover {
  color: rgba(255, 255, 255, 0.9);
}

.mega-menu-column {
  min-width: 100%;
  margin-bottom: 1.5rem;
}

.main-navigation .menu {
  padding: 0 20px;
}

.main-navigation .menu > li {
  margin-right: 20px;
}

/* Tablet styles */
@media (min-width: 768px) {
  .mega-menu-container {
    gap: 1rem;
    height: 100vh;
  }

  .mega-menu-column {
    min-width: 180px;
  }
}

/* Desktop styles */
/* @media (min-width: 1400px) {
  .mega-menu-container {
    width: 100vw;
    left: -12px;
    gap: 0;
    margin: 0;
    top: 58px;
  }

  .mega-menu-column {
    min-width: 200px;
  }
} */

@media (min-width: 1200px) {
  /* .mega-menu-container {
    gap: 80px;
    padding: 60px 40px;
    left: -10px;
  } */

  .mega-menu-column {
    min-width: 240px;
  }
}
/* @media (min-width: 1200px) {
  .mega-menu-container {
    left: -288px;
  } 
}*/

/*  modals */

/* .modal-body {
  background-color: var(--bg-color);
}

.modal-header {
  background-color: var(--deep-space);
  border: none;
  margin-top: 60px;
} */
/* 
.modal {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1055;
  width: 100%;
  height: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  outline: 0;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

.modal.show {
  opacity: 1;
  visibility: visible;
}

.modal-backdrop {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1040;
  width: 100vw;
  height: 100vh;
  background-color: #003247d9;
} */
.btn-close {
  padding: 0.4rem;
  font-size: 0.6rem;
}
.modal-dialog {
  margin-top: 120px;
}
@media (min-width: 992px) {
  .modal-dialog {
    margin-top: 128px;
  }
}

.modal-content {
  text-align: left;
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 40rem;
  margin: auto;
  pointer-events: auto;
  background-color: #001f2c;
  background-clip: padding-box;
  border: none;
  border-radius: 0.75rem;
  outline: 0;
  color: #fff;
  transform: scale(0.8);
  transition: transform 0.3s ease;
}

.modal.show .modal-content {
  transform: scale(1);
}

.modal-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 1rem 1rem 0.5rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}
.modal-footer {
  border: none;
}

.modal-title {
  margin: 0;
  line-height: 1.5;
  font-size: 1.25rem;
  font-weight: bold;
  color: #fff;
}

.modal-close {
  padding: 0;
  background-color: transparent;
  border: 0;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1;
  color: #fff;
  opacity: 0.8;
  cursor: pointer;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.btn-close {
  border: 2px solid;
  border-radius: 50%;
  padding: 0.7rem;
  aspect-ratio: 1;
}
.btn-close:hover {
  border: 2px solid var(--pure-teal);
}
.modal .form-control::placeholder {
  color: rgba(255, 255, 255, 0.6);
  font-size: 1rem;
}
.modal .form-label {
  text-align: left;
  color: #54a2bf;
  font-size: 0.8125rem;
  font-style: normal;
  font-weight: 400;
  line-height: 150%; /* 1.21875rem */
  letter-spacing: 0.00813rem;
}
/* .modal input[type="text"],
.modal select {
  font-size: 1rem;
  color: rgba(255, 255, 255, 0.8);
  padding: 0.3rem 1rem;
  background-color: transparent;
  border: 1px solid #fff;
  border-radius: 0.8rem;
  width: clamp(100%, 30vw, 80vw);
  outline: 0;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
} */
.modal input:focus {
  color: #fff;
  background-color: rgba(255, 255, 255, 0.2);
  border: 1px solid var(--pure-teal);
  outline: 0;
}
.modal select,
input[type="file"],
input.form-control {
  border-radius: 0.125rem;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background-color: rgba(255, 255, 255, 0.04);
  color: rgba(255, 255, 255, 0.8);
}
.form-select {
  color: rgba(255, 255, 255, 0.8);
}
.form-control::file-selector-button {
  border: none;
  background: var(--deep-space);
  color: rgba(255, 255, 255, 0.8);
  padding: 0.5rem 1rem;
  border-radius: 0.25rem;
  margin-right: 1rem;
  cursor: pointer;
  font-size: 0.875rem;
  text-transform: uppercase;
  font-weight: 600;
}
.form-control:hover::file-selector-button {
  background: var(--pure-teal-dark) !important;
}
/* Search */

#searchModal .modal-dialog {
  background-color: #001f2c;
}
.modal-body .search-container {
  display: grid;
  place-items: center;
  height: 50vh;
}
.modal-body .search-container btn-close {
  aspect-ratio: 1;
}
.modal-body .search-container form {
  overflow: hidden;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: nowrap;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-justify-content: center;
  -ms-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-align-content: center;
  -ms-align-content: center;
  align-content: center;
  flex-direction: column;
  gap: 1rem;
}
@media (min-width: 768px) {
  .modal-body .search-container form {
    flex-direction: row;
  }
}

.search-field input,
input#search {
  font-size: 1.4rem;
  color: var(--neutral-space);
  padding: 0.3rem 1rem;
  background-color: transparent;
  border: 1px solid #fff;
  border-radius: 0.8rem;
  width: clamp(100%, 24vw, 25rem);
  outline: 0;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}

.search-field input:focus,
input#search:focus {
  color: #fff;
  background-color: rgba(255, 255, 255, 0.2);
  border: 1px solid var(--pure-teal);
  outline: 0;
}

button.reset-search {
  position: absolute;
  right: 0.5rem;
  top: 50%;
  transform: translateY(-50%);
  display: grid;
  color: #fff;
  border: none;
  outline: none;
  background-color: transparent;
  padding: 0.25rem 0.5rem;
  opacity: 0.6;
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
  z-index: 10;
}
button.reset-search:hover {
  opacity: 1;
  color: var(--pure-teal);
}
.search-chips {
  background-color: var(--deep-space);
  color: var(--deep-space-lighter);
}
/* Buttons */

a.btn-primary,
.btn-primary {
  font-family: var(--notesesa);
  color: #001f2c !important;
  letter-spacing: 0.05rem;
  text-transform: uppercase;
  font-size: 0.875rem;
  background-color: rgba(255, 255, 255, 1);
  border-radius: 0.5rem;
  border: 1px solid #fff;
  padding: 0.5rem 1rem;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
  outline: none;
}

.btn-primary:focus,
.btn-primary:active {
  background-color: rgba(255, 255, 255, 0.7) !important;
  color: #001f2c !important;
}
.btn-primary:hover {
  border: 1px solid rgba(255, 255, 255, 0.7);
  background-color: rgba(255, 255, 255, 0.7);
}

a.btn-secondary,
.btn-secondary {
  font-family: var(--notesesa);
  color: #fff !important;
  letter-spacing: 0.0875rem;
  text-transform: uppercase;
  font-size: 0.875rem;
  border-radius: 0.25rem;
  background-color: rgba(0, 174, 157, 0.1);
  border: none;
  padding: 0.75rem 1rem;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
  outline: none;
}

.btn-secondary:focus,
.btn-secondary:hover,
.btn-secondary:active {
  background: rgba(0, 174, 157, 0.3) !important;
  color: #fff !important;
}

.btn-outline-transparent {
  font-family: var(--notesesa);

  letter-spacing: 0.05rem;
  text-transform: uppercase;
  font-size: 0.875rem;
  background-color: rgba(255, 255, 255, 0);
  border-radius: 0.5rem;
  border: 1px solid #fff;
  padding: 0.5rem 1rem;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
  color: #fff;
  outline: none;
}
.btn-outline-transparent:hover {
  background-color: rgba(255, 255, 255, 0.1);
  border-color: #fff;
  outline: none;
  color: #fff;
}
.btn-outline-transparent.btn-sm {
  padding: 0.6rem 0.9rem;
  font-size: clamp(0.75rem, 1vw, 0.875rem);
}
.btn-outline-secondary {
  font-family: "notesesa";
  font-weight: 700;
  letter-spacing: 0.05rem;
  text-transform: uppercase;
  font-size: 1rem;
  background-color: rgba(25, 217, 208, 0.28);
  border-color: var(--pure-teal);

  border-radius: 1rem;
  padding: 0.8rem 1.1rem;
  margin: 1rem;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
  color: #fff;
}
.btn-outline-secondary:hover {
  background-color: rgba(25, 217, 208, 0.35);
  border-color: var(--pure-teal);
  color: #fff;
}
/* .entry-content .btn-outline-secondary,
.tribe-events-single .btn-outline-secondary {
  min-width: 320px;
} */

/* Scroll to top */
#scrollToTopBtn {
  transform: translateY(150px);
  display: flex;
  position: fixed;
  bottom: 80px;
  right: 4px;
  font-size: 0.8rem;
  padding: 0.4rem 0.8rem !important;
  width: auto;
  height: auto;
  backdrop-filter: blur(10px);
  z-index: 1000;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
@media (min-width: 576px) {
  #scrollToTopBtn {
    bottom: 24px;
    right: 73px;
  }
}
@media (min-width: 992px) {
  #scrollToTopBtn {
    bottom: 20px;
  }
}

/* breadcrumb */

.breadcrumb {
  color: #fff;
  text-transform: uppercase;
  font-size: 0.8125rem;
  font-style: normal;
  font-weight: 400;
  line-height: 120%; /* 0.975rem */
  letter-spacing: -0.00488rem;
}

.breadcrumb a {
  color: var(--deep-space-lighter);
  text-decoration: none;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.breadcrumb i {
  color: var(--orange);
  /* color: var(--light-green); */
  margin: 0 0.5rem;
}

/* Page */

.entry-header {
  min-height: 25rem;
  overflow: hidden;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: nowrap;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-justify-content: space-between;
  -ms-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-items: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-align-content: center;
  -ms-align-content: center;
  align-content: center;
  /* background: linear-gradient(97deg, rgba(0, 31, 44, 0.00) 8.8%, #4C7B8D 104.78%), #001F2C; */
  background: linear-gradient(97deg, rgba(0, 31, 44, 0) 8.8%, #2a4552 104.78%),
    #001018;
  flex-direction: column;
}
@media (min-width: 992px) {
  .entry-header {
    flex-direction: row;
  }
}

.entry-header .entry-header-left {
  padding: 2rem;
  width: 100%;
}
@media (min-width: 992px) {
  .entry-header .entry-header-left {
    max-width: 70vw;
  }
}
.entry-header .page-thumbnail {
  width: 100%;
  height: 100%;
  min-height: 18rem;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  border-left: 1px solid var(--pure-teal);
  box-shadow: -2px 0 62px 0 rgba(0, 174, 157, 0.5);
}
@media (min-width: 992px) {
  .entry-header .page-thumbnail {
    max-width: 30vw;
    min-height: 25rem;
  }
}
.entry-content {
  padding: 3.75rem 1.5rem 0 1.5rem;
}
.entry-content-with-side-menu {
  margin-inline: unset;
}
@media (min-width: 1200px) {
  .entry-content-with-side-menu {
    margin-left: 33%;
  }
}
@media (min-width: 1580px) {
  .entry-content-with-side-menu {
    margin-left: unset;
    margin-inline: auto;
  }
}
h1.entry-title {
  width: fit-content;
  color: #fff;
  background: linear-gradient(
    90deg,
    var(--pure-teal) 0%,
    var(--deep-space-light) 100%
  );
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-family: "notesesa", sans-serif;
  font-size: 3rem;
  font-style: normal;
  font-weight: 700;
  line-height: 120%; /* 3.6rem */
  letter-spacing: -0.09rem;
}

.wp-block-group.has-link-color :has(.stretched-link) p {
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.wp-block-group.has-link-color:hover :has(.stretched-link) p {
  color: var(--pure-teal);
}
/* HOME PAGE */

.entry-header-home {
  min-height: 49rem;
  position: relative;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}
@media (min-width: 992px) {
  .entry-header-home {
    min-height: 46rem;
    height: calc(100vh - 252px);
    padding-top: calc(40vh - 252px);
  }
}
.entry-title-home {
  font-size: 3rem;
  font-style: normal;
  font-weight: 700;
  line-height: 120%; /* 3.6rem */
  letter-spacing: -0.09rem;
}
.home-highlighted-news-section {
  position: absolute;
  bottom: 2.5rem;
  right: 0;
  left: 0;
  padding-right: 0;
}

.home-highlighted-news {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  overflow: scroll;
  scrollbar-width: none; /* Firefox */
  -ms-overflow-style: none; /* IE and Edge */
}
.home-highlighted-news::-webkit-scrollbar {
  display: none; /* Chrome, Safari and Opera */
}

.home-highlighted-news-item {
  position: relative;
  border-radius: 0.25rem;
  background: #002130;
  display: flex;
  padding: 1rem;
  flex-direction: column;
  align-items: flex-start;
  gap: 1rem;
  min-width: 22rem;
  /* align-self: stretch; */
}
.home-highlighted-news-item:hover {
  background-color: #003344;
}
.home-highlighted-news-item-header {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.home-highlighted-news-item-header-date,
.home-highlighted-news-item-header-tags {
  color: #fff;
  font-family: var(--notesesa);
  font-size: 0.625rem;
  font-style: normal;
  font-weight: 400;
  line-height: 120%; /* 0.75rem */
  letter-spacing: 0.075rem;
  text-transform: uppercase;
}
.home-highlighted-news-item-header-tags {
  display: flex;
  gap: 0.625rem;
}
.home-highlighted-news-item-header-tag {
  display: grid;
  place-items: center;
  text-align: center;
  padding: 0.25rem 0.5rem;
  border-radius: 62.4375rem;
  border: 1px solid rgba(250, 250, 250, 0.1);
}
.home-highlighted-news-item-header-date {
  border-right: 1px solid rgba(255, 255, 255, 0.2);
  padding-right: 1rem;
  min-width: fit-content;
}
.home-highlighted-news-item-content {
  color: #fff;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 0.9375rem;
  font-style: normal;
  font-weight: 400;
  line-height: 150%; /* 1.40625rem */
  letter-spacing: 0.00938rem;
}

.all-news-home {
  background: var(--bg-color);
  padding: 0.5rem;
  margin-bottom: 0.5rem;
}
.all-news-home:hover {
  background: var(--deep-space);
  color: var(--pure-teal);
}

.esa-connectivity-numbers-section {
  background: var(
    linear-gradient(
      110deg,
      rgba(76, 181, 255, 0.02) -45.03%,
      rgba(0, 31, 44, 0.2) 26.33%
    ),
    #002130
  );
  padding-block: 6rem;
}
.esa-connectivity-number-item-value {
  color: var(--pure-teal);
  font-family: var(--notesesa);
  font-size: 1.5rem;
  font-style: normal;
  font-weight: 700;
  line-height: 150%; /* 2.25rem */
}
.esa-connectivity-number-item-label {
  color: rgba(255, 255, 255, 0.8);
  font-family: var(--notesesa);
  font-size: 0.6875rem;
  font-style: normal;
  font-weight: 400;
  line-height: 120%; /* 0.825rem */
  letter-spacing: 0.07563rem;
  text-transform: uppercase;
}
.esa-connectivity-numbers {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 1rem;
  margin-bottom: 4rem;
}

.careers-at-esa-connectivity-section,
.esa-connectivity-portfolio-section {
  padding-block: 6rem;
  background: linear-gradient(
    90deg,
    #001f2c 0%,
    rgba(0, 174, 157, 0.3) 50%,
    #001f2c 100%
  );
}

.help-your-project-grow-section {
  padding-block: 6rem;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}
.help-your-project-grow-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 1.5rem;
}
.help-your-project-grow-card {
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
}
.help-your-project-grow-card-title {
  color: #fff;
  text-align: center;
  font-family: var(--notesesa);
  font-size: 1.25rem;
  font-style: normal;
  font-weight: 700;
  line-height: 120%; /* 1.5rem */
  margin-bottom: 0;
}
.help-your-project-grow-card-description {
  color: #f5f5f5;
  text-align: center;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 0.9375rem;
  font-style: normal;
  font-weight: 400;
  line-height: 150%; /* 1.40625rem */
  letter-spacing: 0.00938rem;
}
.home-programmes-section {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  padding-block: 6rem;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}

.home-programmes-section .tabs-navigation {
  justify-content: center;
  text-align: center;
  display: flex;
  gap: 1rem;
  border: 0;
}
.home-programmes-section .tabs-navigation .nav-item .nav-link {
  background: transparent;
  border: 0;
  padding: 0;
  margin: 0;
  outline: none;
  color: #fff;
}

.home-programmes-section .tabs-navigation .nav-item {
  position: relative;
  display: grid;
  padding: 0.5rem 0.75rem;
  place-items: center;
  gap: 0.625rem;
  border-radius: 6.1875rem;
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: #fff;
  font-family: var(--notesesa);
  font-size: 0.875rem;
  font-style: normal;
  font-weight: 400;
  line-height: 100%; /* 0.875rem */
  letter-spacing: 0.09625rem;
  text-transform: uppercase;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.home-programmes-section .tabs-navigation .nav-item:has(.active) {
  border: 1px solid var(--pure-teal);
}
.home-programmes-section .tabs-navigation .nav-item:hover {
  border: 1px solid rgba(255, 255, 255, 0.95);
}
.home-programmes-section .tabs-content {
  padding: min(3.75rem, 4%);
}
.home-programmes-section .tab-paragraph {
  margin-bottom: 2.5rem;
}
.home-programmes-section .tabs-top-headline {
  border-bottom: 2px solid var(--pure-teal);
  color: #fff;
  padding-bottom: 0.5rem;
  margin-bottom: 1.5rem;
  font-family: Arial;
  font-size: 0.9375rem;
  font-style: normal;
  font-weight: 400;
  line-height: 150%; /* 1.40625rem */
  letter-spacing: 0.00938rem;
}

.home-portfolio-section {
  padding-block: 6rem;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}

.home-how-to-work-with-us-section {
  padding-block: 6rem;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}
.easy-steps {
  margin-top: 6rem;
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}
@media (min-width: 992px) {
  .easy-steps {
    grid-template-columns: repeat(4, 1fr);
  }
}
.easy-step-item {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1.5rem;
  border-radius: 0.5rem;
  background-color: #002130;
}
.easy-step-item-number {
  color: var(--pure-teal);
  font-family: var(--notesesa);
  font-size: 3rem;
  font-style: normal;
  font-weight: 700;
  line-height: 112%; /* 3.36rem */
  letter-spacing: -0.06rem;
}
.easy-step-item-title {
  color: #fff;
  font-family: var(--notesesa);
  font-size: 1.25rem;
  font-style: normal;
  font-weight: 700;
  line-height: 120%; /* 1.5rem */
}
.easy-step-item p {
  color: rgba(255, 255, 255, 0.8);
  font-size: 0.9375rem;
  font-style: normal;
  font-weight: 400;
  line-height: 150%; /* 1.40625rem */
  letter-spacing: 0.00938rem;
}

/* LATEST NEWS */

.latest-posts-grid-block {
  margin: 0;
  height: auto;
  min-height: 350px;
  overflow: scroll;
}

.posts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 2rem;
  list-style: none;
  padding: 0;
  margin: 0;
}

.post-item {
  background: var(--bg-color);
  border-radius: 8px;
  /* overflow: hidden; */
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.post-thumbnail {
  width: 100%;
  height: 200px;
  overflow: hidden;
  border-radius: 0.5rem;
}

.post-thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.post-item:hover .post-thumbnail img {
  transform: scale(1.05);
}

.post-content {
  padding: 1.5rem;
}

.post-date {
  color: #fff;
  font-family: var(--notesesa), sans-serif;
  font-size: 0.875rem;
  font-style: normal;
  font-weight: 400;
  line-height: 120%; /* 1.05rem */
  letter-spacing: 0.09625rem;
  text-transform: uppercase;
  margin-bottom: 0.5rem;
}

.post-title {
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1.4;
  margin: 0;
  color: #fafafa;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}

.post-item:hover .post-title {
  color: var(--pure-teal);
}

/* Responsive design */
@media (max-width: 768px) {
  .posts-grid {
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 1rem;
  }

  .post-content {
    padding: 1rem;
  }
}

@media (max-width: 480px) {
  .posts-grid {
    grid-template-columns: 1fr;
  }
}

/* No posts message */
.latest-posts-grid-block p {
  text-align: center;
  color: #666;
  font-style: italic;
  padding: 2rem;
}

/* Custom Gutenberg patterns */

.contact-card {
  overflow: hidden;
}
.contact-card::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("images/contact-card-bg.png");
  background-position: bottom center;
  background-repeat: no-repeat;
  background-size: contain;
  z-index: 0;
  pointer-events: none;
  /* mix-blend-mode: color-dodge; */
  filter: blur(30px);
}
.contact-card > * {
  position: relative;
  z-index: 9 !important;
}

.ur-frontend-form
  .ur-form-row
  .ur-form-grid
  #user-registration-tfa-footer
  .user-registration-Button {
  width: fit-content;
}

.green-box {
  border-radius: 0.5rem;
  padding: 1.5rem;
  background-color: var(--pure-teal);
  background-image: url("images/green-box-bg.jpg");
  background-position: top center;
  background-repeat: no-repeat;
  background-size: cover;
}
.green-box p {
  font-size: 0.9375rem;
  color: var(--black) !important;
}
.green-box h2 {
  font-size: 2.25rem;
  color: var(--black) !important;
  margin-bottom: 0;
}

/* Various blocks overrides */
.moonlight-and-assign-tabs .bootstrap-tabs .nav-tabs {
  justify-content: flex-start;
}
.moonlight-and-assign-tabs .bootstrap-tabs .tab-pane {
  padding-top: 0;
}

/* Footer */

footer {
  background-color: var(--deep-space);
  font-family: "notesesa", sans-serif;
}

footer a {
  text-decoration: none;
  color: #fff;
}
footer .footer-link {
  margin-left: 1.5rem;
}

.narrow-container {
  max-width: 42.5rem;
  margin: 0 auto;
}

.narrow-container > * {
  z-index: 1000;
}
/* Page with content menu */

.page-table-of-contents {
  width: 19rem;
  position: absolute;
  z-index: 10;
  top: 2rem;
  left: 2vw;
  padding: 1.5rem;
  margin-right: 1.5rem;
  border-radius: 0.5rem;
  background: linear-gradient(
      110deg,
      rgba(76, 181, 255, 0.02) -45.03%,
      rgba(0, 31, 44, 0.2) 26.33%
    ),
    rgba(0, 33, 48, 0.2);

  backdrop-filter: blur(25px);
  color: #fff;
  font-family: var(--notesesa), sans-serif;
  display: block;
  transform: translateX(calc(-19rem - 4vw));
  /* display: none; */
}

.page-table-of-contents-toggler {
  position: absolute;
  top: 1rem;
  right: -1.5rem;
  background: var(--deep-space);
  border: none;
  border-radius: 0.5rem;
  padding: 1rem;
  color: #fff;
  cursor: pointer;
  font-family: var(--notesesa), sans-serif;
  font-size: 0.875rem;
  font-style: normal;
  font-weight: 600;
  line-height: 120%; /* 1.05rem */
  letter-spacing: 0.04rem;
  text-transform: uppercase;
}

@media (min-width: 1200px) {
  .page-table-of-contents-toggler {
    display: none;
  }
}
.page-table-of-contents.show .page-table-of-contents-toggler {
  transform: rotate(180deg);
}
.page-table-of-contents-toggle {
  border: none;
  background: transparent;
  color: #fff;
  padding: 0;
  margin: 0;
  cursor: pointer;
  position: absolute;
  inset: 0;
}

.page-table-of-contents.show {
  transform: translateX(0);
  transition: all 0.3s ease;
}

@media (min-width: 1200px) {
  .page-table-of-contents {
    transform: translateX(0);
    transition: all 0.3s ease;
  }
}

.page-table-of-contents ul {
  list-style: none;
  padding: 0;
  margin: 1.5rem 0 0 0;
}
ul.wp-block-list li {
  color: rgba(255, 255, 255, 0.8);
}
.page-table-of-contents ul li {
  margin-bottom: 0.5rem;
}
.page-table-of-contents ul li a {
  border-left: 2px solid var(--pure-teal);
  padding-left: 0.5rem;
  text-decoration: none;
  font-size: 0.875rem;
  font-style: normal;
  font-weight: 400;
  line-height: 120%; /* 1.05rem */
  letter-spacing: 0.09625rem;
  text-transform: uppercase;
}
.page-table-of-contents ul li a:hover,
.page-table-of-contents ul li a.active {
  border-left: 2px solid var(--pure-teal);
  color: var(--pure-teal) !important;
}
.page-table-of-contents p {
  font-family: var(--notesesa), sans-serif;
  font-size: 1.125rem;
  font-style: normal;
  font-weight: 700;
  line-height: 140%; /* 1.575rem */
  letter-spacing: 0.0225rem;
  text-transform: uppercase;
}

/* News Page*/

.search-results-info {
  margin-bottom: 1.5rem;
}

.search-results-info p {
  color: #fff;
  font-size: 1rem;
  margin: 0;
}

.search-results-info strong {
  color: var(--pure-teal);
}

.news-sorting button {
  appearance: none;
  border: none;
  background: none;
  color: inherit;
  font: inherit;
  padding: 0;
  margin: 0;
  cursor: pointer;
  color: #fff;
  margin-bottom: 2rem;
}

.news-sorting button svg {
  opacity: 0.5;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.news-sorting button:hover svg {
  opacity: 1;
}

.news-card {
  border-radius: 0.5rem;
  border: 1px solid #00364b;
  background: #00293a;
  padding: 1.5rem;
  margin-bottom: 1rem;
  position: relative;
  transform: scale(1);
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.news-card:hover {
  box-shadow: 0 0 50px rgba(0, 174, 157, 0.3);
  transform: scale(1.015);
}
.news-card-inner {
  display: flex;
  flex-direction: column-reverse;
  justify-content: space-between;
  gap: 1.5rem;
}
@media (min-width: 992px) {
  .news-card-inner {
    flex-direction: row;
    gap: 1.5rem;
  }
}
.news-card-title {
  font-size: 1.25rem;
  margin-bottom: 0.5rem;
}
.news-card-date {
  color: #54a2bf;
  font-family: var(--notesesa), sans-serif;
  font-size: 0.6875rem;
  letter-spacing: 0.07563rem;
  text-transform: uppercase;
  margin-bottom: 1.5rem;
}
.news-card-excerpt {
  color: rgba(255, 255, 255, 0.8);
  text-overflow: ellipsis;
  font-size: 0.9375rem;
  line-height: 150%; /* 1.40625rem */
  letter-spacing: 0.00938rem;
  margin-bottom: 1.5rem;
}
.news-card-image {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  aspect-ratio: 4/3;
  max-width: 17.5rem;
  min-width: 17.5rem;
  width: 100%;
}
.news-pagination {
  overflow: hidden;
  width: fit-content;
  margin-top: 2rem;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: nowrap;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-justify-content: flex-start;
  -ms-justify-content: flex-start;
  justify-content: flex-start;
  -webkit-align-items: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-align-content: center;
  -ms-align-content: center;
  align-content: center;
  border-radius: 0.375rem;
  border: 1px solid #00364b;
}
.news-pagination .page-numbers {
  min-width: 3rem;
  border-left: 1px solid #00364b;
  border-right: 0;
  display: grid;
  place-items: center;
  padding: 0.75rem;
  color: #fff;
  font-family: var(--notesesa), sans-serif;
}
.news-pagination .page-numbers:last-of-type {
  border-right: 1px solid #00364b;
}
.news-pagination .page-numbers:hover,
.news-pagination .page-numbers.current {
  background: var(--pure-teal);
}
.news-pagination .page-numbers:hover svg {
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.news-pagination .page-numbers:hover svg {
  filter: brightness(2);
}

.news-search input[type="text"] {
  color: rgba(255, 255, 255, 0.8);
  font-size: 0.9375rem;
  border-radius: 0.375rem;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.04);
  padding: 0.8rem 2.5rem 0.8rem 0.5rem;
  background-image: url(images/search.svg);
  background-repeat: no-repeat;
  background-position: center right 0.75rem;
  background-size: 1rem;
  margin-bottom: 1rem;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
  width: 100%;
}
.news-search input[type="text"].has-reset {
  background-image: none;
}
.news-search input[type="text"]:focus {
  border: 1px solid var(--pure-teal);
  outline: none;
  box-shadow: none;
}
.filters-header {
  color: #fff;
  text-align: center;
  font-size: 1.1875rem;
  font-style: normal;
  font-weight: 500;
  line-height: 152%; /* 1.805rem */
  letter-spacing: 0.01188rem;
}
.filters-container {
  margin-top: 2rem;
  padding: 1.5rem;
  border-radius: 0.375rem;
  border-radius: 0.375rem;
  border: 1px solid #00364b;
  background: rgba(255, 255, 255, 0.02);
}
.filters-row {
  margin-block: 2rem;
}
.filters-row .filters-label {
  color: #54a2bf;
  font-family: var(--notesesa);
  font-size: 0.8125rem;
  font-style: normal;
  font-weight: 400;
  line-height: 100%; /* 0.8125rem */
  letter-spacing: 0.08125rem;
  text-transform: uppercase;
  margin: 0.5rem 0;
}
.filters-row .filters-link-container {
  border-left: 1px solid rgba(255, 255, 255, 0.2);
  padding-left: 0.5rem;
  display: flex;
  flex-direction: column;
}

.filters-row .filters-link-container .filters-link {
  display: flex;
  justify-content: space-between;
  color: #fff;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 0.75rem;
  font-style: normal;
  font-weight: 400;
  line-height: 140%; /* 1.05rem */
  letter-spacing: 0.0075rem;
  padding-block: 0.5rem;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.filters-row .filters-link-container .filters-link.active {
  color: var(--pure-teal) !important;
  font-weight: bold;
}
.filters-row .filters-link-container .filters-link:hover {
  color: var(--pure-teal) !important;
}

.filters-row .filters-link-container .filters-link .filters-link-number {
  display: grid;
  place-items: center;
  min-width: 1.25rem;
  padding: 0.3125rem 0.125rem;
  border-radius: 0.125rem;
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
  text-align: center;
  font-family: var(--notesesa);
  font-size: 0.625rem;
  font-style: normal;
  font-weight: 400;
  line-height: 100%; /* 0.625rem */
  letter-spacing: 0.03125rem;
}
.active-filters-list,
.filters-row .filters-chips-container {
  display: flex;
  gap: 1rem;
  border: 0;
  flex-wrap: wrap;
  max-height: none;
  overflow: visible;
  transition: max-height 0.3s ease;
}

.active-filters-list.collapsed {
  max-height: 11.125rem;
  overflow: hidden;
  position: relative;
}

.active-filters-list.collapsed::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3rem;
  background: linear-gradient(to bottom, transparent, var(--bg-color));
  pointer-events: none;
}
.active-filters-list .active-filter-item,
.filters-row .filters-chips-container .filters-chips {
  font-family: var(--notesesa);
  color: rgba(255, 255, 255, 0.8);
  padding: 0.5rem 0.75rem;
  font-size: 0.75rem;
  font-style: normal;
  font-weight: 400;
  line-height: 100%; /* 0.875rem */
  letter-spacing: 0.0875rem;
  text-transform: uppercase;
  border-radius: 6.1875rem;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: rgba(255, 255, 255, 0.04);
  overflow: hidden;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: nowrap;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-justify-content: center;
  -ms-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-align-content: center;
  -ms-align-content: center;
  align-content: center;
}
.filters-row .filters-chips-container .filters-chips.active,
.filters-row .filters-chips-container .filters-chips:hover {
  background: var(--pure-teal);
}
.filters-row .filters-chips-container .filters-chips.active {
  background: var(--pure-teal);
}

.active-filters-box {
  padding: 1.5rem;
  margin: 2rem 0 1rem 0;
  border-radius: 0.5rem;
  border: 1px dashed #00364b;
}
.active-filters-box .remove-filter-btn {
  background: none;
  color: #fff;
  cursor: pointer;
  font-size: 0.875rem;
  text-transform: uppercase;
  font-style: var(--notesesa);
  padding: 0;
  padding-bottom: 0px;
  margin-left: 0.75rem;
  border: 1px solid #fff;
  border-radius: 3rem;
  width: 1.1rem;
  height: 1rem;
  display: grid;
  padding-bottom: 1rem;
}
.reset-filters {
  border-radius: 0.25rem;
  background: rgba(0, 174, 157, 0.1);
  padding: 0.75rem 1rem;
  border: none;
  color: #fff;
  cursor: pointer;
  font-size: 0.875rem;
  text-transform: uppercase;
  font-style: var(--notesesa);
}
.reset-filters:hover {
  background: rgba(0, 174, 157, 0.2);
}

.show-all-filters-btn {
  margin-top: 1rem;
  border-radius: 0.25rem;
  background: rgba(0, 174, 157, 0.1);
  padding: 0.5rem 1rem;
  border: 1px solid rgba(0, 174, 157, 0.3);
  color: var(--pure-teal);
  cursor: pointer;
  font-size: 0.75rem;
  text-transform: uppercase;
  font-family: var(--notesesa);
  transition: all 0.2s ease;
}

.show-all-filters-btn:hover {
  background: rgba(0, 174, 157, 0.2);
  border-color: var(--pure-teal);
}

.gradient-separator {
  height: 0.0625rem;
  width: 100%;
  background: linear-gradient(
    90deg,
    rgba(0, 174, 157, 0.2) 0%,
    #fff 49.04%,
    rgba(0, 174, 157, 0.2) 100%
  );
  margin: 1rem 0;
}
.filters-container .accordion-item {
  background: none;
  border: 0;
  color: #fff;
}
.filters-container .accordion-button {
  height: 2rem;
  background: none;
  border: 0;
  padding: 0;
  color: var(--pure-teal);
  text-transform: uppercase;
  font-family: var(--notesesa), sans-serif;
  font-size: 0.875rem;
  box-shadow: none;
}
.filters-container .accordion-button::after {
  height: auto;
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M12 5l0 14' /%3E%3Cpath d='M5 12l14 0' /%3E%3C/svg%3E");
  font-size: 1.5rem;
  font-weight: bold;
  color: #fff;
  background: none;
  transition: transform 0.3s ease;
}
.filters-container .accordion-button[aria-expanded="true"]::after {
  transform: rotate(45deg);
}
.filters-container .accordion-button:focus,
.filters-container .accordion-button:hover {
  border: none;
  box-shadow: none;
}
.filters-container .accordion-header {
  border: 0;
}
.filters-container .accordion-body {
  padding: 1rem 0;
}

.accordion-search input[type="text"] {
  color: rgba(255, 255, 255, 0.8);
  font-size: 0.9375rem;
  border-radius: 0.375rem;
  border: 0;
  background: rgba(255, 255, 255, 0.04);
  padding: 0.8rem 2.5rem 0.8rem 0.5rem;
  background-image: url(images/search.svg);
  background-repeat: no-repeat;
  background-position: center right 0.75rem;
  background-size: 1rem;
  margin-bottom: 1rem;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
  width: 100%;
}

.accordion-search input[type="text"].has-reset {
  background-image: none;
}

.parent-term-wrapper {
  position: relative;
  display: block;
}

.parent-term-wrapper > .toggle-children {
  position: absolute;
  right: 0;
  top: 0;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  width: 40px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, 0.8);
  z-index: 2;
  flex-shrink: 0;
}

.parent-term-wrapper > .mt-checkbox {
  display: block;
  padding-right: 40px;
}

.parent-term-wrapper .mt-checkbox {
  position: relative;
}

.parent-term-wrapper .children-terms .mt-checkbox {
  padding-right: 0;
}

.parent-term-wrapper .toggle-children .chevron-icon {
  transition: transform 0.3s ease;
}

.parent-term-wrapper .children-terms {
  max-height: 0;
  overflow: hidden;
  padding-left: 30px;
  transition: max-height 0.3s ease;
}

.accordion-search input[type="text"]:focus {
  border: 1px solid var(--pure-teal);
  outline: none;
  box-shadow: none;
}
.accordion-search .form-control::placeholder {
  color: rgba(255, 255, 255, 0.5);
}

/* Single News */

.type-news_and_events .entry-content {
  position: relative;

  margin: 0;
  padding: 40px 0 0 0;
  background-color: #fff;
}
.type-news_and_events .entry-content * {
  color: var(--deep-space);
}
figcaption {
  font-size: 0.875rem;
  color: var(--deep-space-lighter) !important;
  text-align: left;
  font-style: italic;
}
.publication-date-label {
  color: #54a2bf !important;
  font-size: 0.75rem;
  letter-spacing: 0.0075rem;
}
.publication-date {
  font-family: var(--notesesa), sans-serif;
  font-size: 0.75rem;
  font-style: normal;
  font-weight: 400;
  letter-spacing: 0.0825rem;
  text-transform: uppercase;
}
.latest-news-container {
  padding: 2rem;
  border-radius: 0.5rem;
  background: #fafafa;
  backdrop-filter: blur(25px);
}
.latest-news-item {
  padding: 1rem;
  margin: 1rem 0;
  background-color: #fff;
}
.latest-news-date {
  color: #54a2bf !important;
  font-family: var(--notesesa), sans-serif;
  font-size: 0.75rem;
  letter-spacing: 0.0825rem;
  text-transform: uppercase;
  margin: 0.5rem 0 0 0;
  padding: 0;
}
.latest-news-small-text {
  font-size: 0.75rem;
  letter-spacing: 0.0075rem;
}
a.latest-news-title:hover {
  color: var(--pure-teal) !important;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.latest-news-item svg {
  fill: #003247 !important;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.latest-news-item:hover svg {
  fill: #54a2bf !important;
}

/* Single event */
.event-timetable ul {
  overflow: hidden;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: flex-start;
  -ms-justify-content: flex-start;
  justify-content: flex-start;
  -webkit-align-items: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-align-content: center;
  -ms-align-content: center;
  align-content: center;
  gap: 1rem;
  list-style: none;
  padding: 0;
  margin: 0 0 3rem 0;
}
.event-timetable ul li {
  background: var(--deep-space);
  border-radius: 0.5rem;
  padding: 1rem 1.5rem;
  min-width: 4rem;
  text-align: center;
  font-family: var(--notesesa);
}

.event-timetable ul li h2 {
  font-size: 2.25rem;
  margin: 0;
}
.event-timetable ul li p {
  font-size: 0.875rem;
  margin: 0;
}

.event-related-pages {
  overflow: hidden;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: flex-start;
  -ms-justify-content: flex-start;
  justify-content: flex-start;
  -webkit-align-items: flex-start;
  -ms-align-items: flex-start;
  align-items: flex-start;
  -webkit-align-content: flex-start;
  -ms-align-content: flex-start;
  align-content: flex-start;
  gap: 1rem;
}

/* Portfolio page */

.project-form-type-selection {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: nowrap;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-justify-content: space-between;
  -ms-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-items: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-align-content: center;
  -ms-align-content: center;
  align-content: center;
  gap: 1rem;
}
.project-form-type-selection .form-check {
  width: 50%;
  padding: 1rem 1rem 1rem 3rem;
  border-radius: 0.1875rem;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.04);
  display: flex;
  gap: 1rem;
}
.portfolio-message-banner {
  background-color: var(--black);
  color: var(--orange);
  font-size: 0.9375rem;

  padding: 1.35rem;
  text-align: center;
}

.portfolio-search {
  max-width: 21.125rem;
}
#portfolioTabs {
  display: flex;
  gap: 0.5rem;
  border: 0;
}

#portfolioTabs .nav-link {
  font-family: var(--notesesa);
  color: rgba(255, 255, 255, 0.8);
  border: none;
  border-radius: 6.1875rem;
  background: rgba(255, 255, 255, 0.04);
  font-size: 0.875rem;
  font-style: normal;
  font-weight: 400;
  line-height: 100%; /* 0.875rem */
  letter-spacing: 0.0875rem;
  text-transform: uppercase;
}
#portfolioTabs .nav-link:hover {
  background: rgba(255, 255, 255, 0.24);
}
#portfolioTabs .nav-link.active {
  background: var(--pure-teal);
}

.portfolio-card {
  min-height: 16.25rem;
  border-radius: 0.5rem;
  border: 1px solid #00364b;
  background: #00293a;
  padding: 1.5rem;
  margin-bottom: 1rem;
  position: relative;
  transform: scale(1);
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}

.portfolio-card-inner {
  display: flex;
  flex-direction: column-reverse;
  justify-content: space-between;
  gap: 1.5rem;
}

@media (min-width: 992px) {
  .portfolio-card-inner {
    flex-direction: row;
    gap: 1.5rem;
  }
}
.portfolio-card-label {
  margin-bottom: 1rem;
  color: #54a2bf;
  font-family: var(--notesesa);
  font-size: 0.6875rem;
  font-style: normal;
  font-weight: 400;
  line-height: 120%; /* 0.825rem */
  letter-spacing: 0.07563rem;
  text-transform: uppercase;
}
.portfolio-card-inner .portfolio-card-inner-left {
  display: flex;
  flex-direction: column;
}

.portfolio-card-inner .portfolio-card-inner-left .project-status-row {
  display: flex;
  gap: 1rem;
  justify-content: flex-start;
  align-items: center;
}

.project-status {
  font-family: var(--notesesa, sans-serif);
  font-size: 0.6875rem;
  font-style: normal;
  font-weight: 400;
  line-height: 120%; /* 0.825rem */
  letter-spacing: 0.07563rem;
  text-transform: uppercase;
  padding: 0.25rem 0.5rem;
  margin-right: 1rem;
  margin-bottom: 1rem;
}
.project-status-bar .project-status {
  margin-bottom: 0;
}
.single-partnership-projects .project-status {
  height: fit-content;
}
.project-contractors {
  margin-bottom: 1.5rem;
}
.project-status.status-completed {
  color: #21a3e4;
  border: 1px solid #21a3e4;
}
.project-status.status-ongoing {
  color: #ff6f00;
  border: 1px solid #ff6f00;
}
.project-status.status-heritage {
  color: #9d69ff;
  border: 1px solid #9d69ff;
}
.project-status-date {
  font-family: var(--notesesa, sans-serif);
  font-size: 0.6875rem;
  line-height: 120%; /* 0.825rem */
  letter-spacing: 0.07563rem;
  text-transform: uppercase;
}

.portfolio-card-title {
  font-size: 1.25rem;
  margin-bottom: 0.5rem;
  color: #fff;
  font-family: var(--notesesa);
  font-size: 1.25rem;
  font-style: normal;
  font-weight: 700;
  line-height: 120%; /* 1.5rem */
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.portfolio-card-title:hover {
  color: var(--pure-teal) !important;
}

.portfolio-card-title a:focus,
.portfolio-card-title a:visited,
.portfolio-card-title a:active {
  color: #fff;
}
.portfolio-card-date {
  color: #54a2bf;
  font-family: var(--notesesa), sans-serif;
  font-size: 0.6875rem;
  letter-spacing: 0.07563rem;
  text-transform: uppercase;
  margin-bottom: 1.5rem;
}
.partnership-project-short-description p {
  font-size: 0.9375rem;
}
a.contractor-name {
  color: #fff;
  font-size: 0.9375rem;
  font-style: normal;
  font-weight: 400;
  line-height: 150%; /* 1.40625rem */
  letter-spacing: 0.00938rem;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}

a.contractor-name::before {
  content: "";
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20' fill='none'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M8.22032 5.21934C8.36094 5.07889 8.55157 5 8.75032 5C8.94907 5 9.13969 5.07889 9.28032 5.21934L13.5303 9.46934C13.6708 9.60997 13.7497 9.80059 13.7497 9.99934C13.7497 10.1981 13.6708 10.3887 13.5303 10.5293L9.28032 14.7793C9.13814 14.9118 8.9501 14.9839 8.75579 14.9805C8.56149 14.9771 8.37611 14.8984 8.2387 14.761C8.10128 14.6235 8.02257 14.4382 8.01914 14.2439C8.01571 14.0496 8.08784 13.8615 8.22032 13.7193L11.9403 9.99934L8.22032 6.27934C8.07987 6.13871 8.00098 5.94809 8.00098 5.74934C8.00098 5.55059 8.07987 5.35997 8.22032 5.21934Z' fill='%2354A2BF'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-size: 1rem 1rem;
  width: 1rem;
  height: 1rem;
  display: inline-block;
  color: var(--pure-teal);
  font-size: 1rem;
  line-height: 1;
  /* margin-right: 0.5rem; */
  vertical-align: middle;
  -webkit-transition: color 0.2s ease;
  transition: color 0.2s ease;
}
a.contractor-name:hover {
  color: var(--pure-teal) !important;
}
.portfolio-card-arrow {
  margin-top: 1rem;
  opacity: 1;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.portfolio-card-arrow:hover {
  opacity: 0.75;
}

.project-tags {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.project-tags .project-tag {
  color: #fff;
  font-family: var(--notesesa, sans-serif);
  font-size: 0.65rem;
  font-style: normal;
  font-weight: 400;
  line-height: 120%; /* 0.825rem */
  letter-spacing: 0.07563rem;
  text-transform: uppercase;
  padding: 0.38rem 0.6rem;
  background-color: #00364b;
  border-radius: 3rem;
  display: inline-block;
}

/* Portfolio Page Tabs */
.tabs-buttons {
  display: flex;
  gap: 0.5rem;
  margin: 2rem 0;
  border-bottom: 2px solid var(--deep-space-lighter);
  flex-wrap: wrap;
}

.tab-button {
  background: transparent;
  border: none;
  padding: 0.75rem 1.5rem;
  font-family: var(--notesesa, sans-serif);
  font-size: 1rem;
  font-weight: 400;
  color: var(--deep-space-lighter);
  cursor: pointer;
  position: relative;
  transition: all 0.3s ease;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
}

.tab-button:hover {
  color: var(--pure-teal);
}

.tab-button.active {
  color: var(--pure-teal);
  border-bottom-color: var(--pure-teal);
  font-weight: 700;
}

.partnership-projects-tab,
.projects-tab,
.partners-tab {
  width: 100%;
  flex-wrap: wrap;
}

.page-template-page-porfolio .news-pagination{
	border:0;
	margin-bottom: 1rem;
}
.page-template-page-porfolio .pagination-prev,
.page-template-page-porfolio .pagination-next{
	  background: none;
	border:none;
	margin-inline:.15rem;
	color: #fff
	
}
.page-template-page-porfolio .pagination-page {
	  background: var(--deep-space);
	border:none;
	margin-inline:.15rem;
	color: #fff
	
}
/* Portfolio filters */
.portfolio-search-results-number {
  color: #fff;
  font-size: 0.75rem;
  font-style: normal;
  font-weight: 400;
  line-height: 140%;
  letter-spacing: 0.0075rem;
  background-color: rgba(255, 255, 255, 0.2);
  border-radius: 2px;
  padding: 2px;
  min-width: 20px;
  display: inline-block;
}
.portfolio-filters-container ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
  flex-wrap: wrap;
}

.portfolio-filters-container ul li {
  list-style: none;
  color: #fff;
  font-family: Arial;
  font-size: 0.75rem;
  font-style: normal;
  font-weight: 400;
  line-height: 140%; /* 1.05rem */
  letter-spacing: 0.0075rem;
  position: relative;
}

/* Hide checkbox completely */
.portfolio-filters-container ul li input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 0;
  height: 0;
}

/* Label as accordion header */
.portfolio-filters-container ul li > label {
  display: block;
  padding: 0.75rem 2rem 0.75rem 0;
  cursor: pointer;
  position: relative;
  transition: all 0.3s ease;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  user-select: none;
}

.portfolio-filters-container ul li > label:hover {
  color: var(--pure-teal);
}

/* Arrow indicator */
.portfolio-filters-container ul li > label::after {
  content: "›";
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%) rotate(0deg);
  transition: transform 0.3s ease;
  font-size: 1.25rem;
  line-height: 1;
  color: rgba(255, 255, 255, 0.5);
  cursor: pointer;
  padding: 0.5rem;
  margin-right: -0.5rem;
}

/* Active state - when checkbox is checked (filter applied) */
.portfolio-filters-container ul li input[type="checkbox"]:checked ~ label {
  color: var(--pure-teal);
  font-weight: 700;
  background-color: rgba(0, 174, 157, 0.1);
  border-left: 3px solid var(--pure-teal);
  padding-left: 0.5rem;
}

.portfolio-filters-container
  ul
  li
  input[type="checkbox"]:checked
  ~ label::after {
  color: var(--pure-teal);
}

/* Expanded state - rotate arrow when has children and is expanded */
.portfolio-filters-container ul li.is-expanded > label::after {
  transform: translateY(-50%) rotate(90deg);
}

/* Nested ul - accordion content */
.portfolio-filters-container ul li ul {
  margin-top: 0;
  margin-left: 1rem;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease-out;
}

/* Show nested ul only when expanded via arrow click */
.portfolio-filters-container ul li.is-expanded > ul {
  max-height: 2000px;
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
  transition: max-height 0.6s ease-in;
}
/* .loading-portfolio {
  position: fixed;
  background-color: rgba(255, 255, 255, 0.1);
  inset: 0;
  overflow: hidden;
  display: grid;
  place-items: center;
  z-index: 10000;
  backdrop-filter: blur(8px);
  padding: 0;
  margin: 0;
} */
/* Single Projects */

.type-projects .entry-content {
  position: relative;

  margin: 0;
  padding: 0;
  background-color: #fff;
}
.type-projects .entry-content * {
  color: var(--deep-space) !important;
}
.type-projects .entry-header-left {
  height: 100%;
  min-height: 25rem;
  padding-top: 5rem;
  position: relative;
}
.project-thumbnail {
  display: grid;
  place-items: center;
}
.project-thumbnail-container {
  width: 100%;
  max-width: 18rem;
  overflow: hidden;
  background-color: #fff;
  padding: 1.5rem 1.875rem;
  border-radius: 0.5rem;
}
.full-project-name {
  font-size: 1.125rem;
}
.project-thumbnail img {
  height: auto;
}
.project-status-bar {
  position: relative;
  bottom: 2rem;
  display: flex;
  margin-top: 1.5rem;
  flex-wrap: wrap;
  margin-top: 3rem;
  gap: 0.625rem;
}
@media (min-width: 576px) {
  .project-status-bar {
    position: absolute;
    gap: 1rem;
  }
}

.project-status-bar-item {
  border-radius: 6.1875rem;
  border: 1px solid rgba(255, 255, 255, 0.04);
  background: rgba(255, 255, 255, 0.04);
  display: flex;
  padding: 0.5rem 0.75rem;
  justify-content: center;
  align-items: center;
  gap: 0.625rem;
  font-family: var(--notesesa), sans-serif;
  text-transform: uppercase;
  font-size: 0.75rem;
  letter-spacing: 0.0875rem;
}
@media (min-width: 992px) {
  .project-status-bar-item {
    font-size: 0.875rem;
  }
}

.project-status-bar-label {
  color: var(--pure-teal);
  margin-bottom: 0.125rem;
}
.project-status-bar-value {
  color: #fff;
}
.project-status-bar-separator {
  color: var(--pure-teal);
}

.project-page-table-of-contents {
  width: fit-content;
  position: absolute;
  z-index: 1000;
  top: 2rem;
  left: 4vw;
  padding: 1.5rem;
  border-radius: 0.25rem;
  background: #fafafa;
  margin-right: 1.5rem;
  backdrop-filter: blur(25px);
  color: var(--deep-space);
  font-family: var(--notesesa), sans-serif;
  display: none;
}
@media (min-width: 992px) {
  .project-page-table-of-contents {
    display: block;
  }
}
.project-page-table-of-contents ul {
  list-style: none;
  padding: 0;
  margin: 1.5rem 0 0 0;
}
.project-page-table-of-contents ul li {
  margin-bottom: 0.5rem;
}
.project-page-table-of-contents ul li a {
  border-left: 2px solid var(--deep-space);
  padding-left: 0.5rem;
  text-decoration: none;
  font-size: 0.875rem;
  font-style: normal;
  font-weight: 400;
  line-height: 120%; /* 1.05rem */
  letter-spacing: 0.09625rem;
  text-transform: uppercase;
}
.project-page-table-of-contents ul li a:hover,
.project-page-table-of-contents ul li a.active {
  border-left: 2px solid var(--pure-teal);
  color: var(--pure-teal) !important;
}
.project-page-table-of-contents p {
  font-family: var(--notesesa), sans-serif;
  font-size: 1.125rem;
  font-style: normal;
  font-weight: 700;
  line-height: 140%; /* 1.575rem */
  letter-spacing: 0.0225rem;
  text-transform: uppercase;
}

.project-page-content-section {
  padding: 3rem 0;
  position: relative;
}
.project-page-content-section:first-child {
  padding-top: 0;
}
.project-page-content-section:nth-child(odd) {
  background-color: var(--neutral-space);
}

.project-tags-container .project-tags .tag {
  color: var(--deep-space-lighter);
  font-family: var(--notesesa), sans-serif;
  margin-right: 1rem;
}

.project-tags-container .project-tags .tag::before {
  content: "#";
}
.project-tags-container .project-tags .tag:hover {
  color: var(--pure-teal);
}
.project-documentation-item a:hover .project-documentation-title {
  color: var(--pure-teal) !important;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}

ul.project-related-links-list {
  list-style: none;
  padding: 0;
}
ul.project-related-links-list li {
  margin-bottom: 0.5rem;
  padding-left: 1.5rem;
  position: relative;
  font-size: 1rem;
}
ul.project-related-links-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.3rem;
  width: 1.2rem;
  height: 1.2rem;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none'%3E%3Cpath stroke='%23003247' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M10 6H6a2 2 0 0 0-2 2v10a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2v-4m-9-5l8-8m0 0v5m0-5h-5'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
}
ul.project-related-links-list li a {
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
ul.project-related-links-list li:hover a,
.project-companies-list a:hover {
  color: var(--pure-teal) !important;
}
ul.project-related-links-list li a:hover::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none'%3E%3Cpath stroke='%23003247' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M10 6H6a2 2 0 0 0-2 2v10a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2v-4m-9-5l8-8m0 0v5m0-5h-5'/%3E%3C/svg%3E");
}
.project-companies-list {
  margin-top: 2rem;
}
.project-company-item {
  display: flex;
  align-items: center;
  align-content: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
  border-bottom: 1px solid var(--deep-space-lighter);
  padding-bottom: 1.5rem;
}

.project-company-item-content {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding-left: 1.5rem;
  justify-content: space-between;
  width: 100%;
  height: 100%;
}

.project-company-item:last-child {
  border-bottom: none;
}

.project-company-item-title {
  display: flex;
  align-items: center;
}

.project-company-item:first-child .project-company-item-title::after {
  content: "prime contractor";
  font-family: var(--notesesa), sans-serif;
  font-size: 0.875rem;
  font-weight: 600;
  text-transform: uppercase;
  padding: 0.2rem 0.5rem;
  border-radius: 0.25rem;
  color: #fff;
  background-color: var(--pure-teal);

  margin-left: 1rem;
}

.project-company-item:not(:first-child) .project-company-item-title::after {
  content: "subcontractor";
  font-family: var(--notesesa), sans-serif;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  border: 1px solid var(--pure-teal);
  padding: 0.2rem 0.5rem;
  border-radius: 0.25rem;
  color: var(--pure-teal);
  margin-left: 1rem;
}

.company-thumbnail-container {
  width: 180px;
  aspect-ratio: 1;
  display: grid;
  place-items: center;
  background-color: #fff;
  padding: 1rem;
  border: 1px solid #f0f0f0;
  height: auto;
}

.project-company-label {
  font-family: var(--notesesa), sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--deep-space-lighter);
  letter-spacing: 0.075rem;
}

/* Companies */
.type-company .entry-content {
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0.1) 0.01%,
    rgba(0, 174, 157, 0) 100%
  );
}
.company-detail {
  margin-bottom: 1.5rem;
}
.company-detail-item {
  border-bottom: 1px solid var(--deep-space-lighter);
}
.company-detail-item:last-child {
  border-bottom: none;
}

.company-details-label {
  font-family: var(--notesesa), sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--deep-space-lighter);
  letter-spacing: 0.075rem;
}

.project-tags-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  padding: 1rem 0;
}
@media (min-width: 768px) {
  .project-tags-grid {
    grid-template-columns: 1fr 1fr;
  }
}
.project-tags-grid-title {
  letter-spacing: 0.05rem;
  font-size: 1.125rem;
}

@media (min-width: 992px) {
  .project-tags-grid-title {
    font-size: 1.5rem;
  }
}
a.project-tags-grid-title-small,
a.project-tags-grid-title-small:visited {
  font-family: var(--notesesa), sans-serif;
  font-size: 0.75rem;
  color: var(--pure-teal) !important;
  text-transform: uppercase;
  border-bottom: 1px solid var(--pure-teal);
}

a.project-tags-grid-title-small:hover {
  font-size: 0.75rem;
  color: #fff !important;
  text-transform: uppercase;
}
.project-tags-grid-item {
  background-color: var(--bg-color);
  padding: 2rem;
  border-radius: 0.5rem;
  display: flex;
  justify-content: space-between;
  flex-direction: column;
  position: relative;
}
.companies-project-tags-container {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  margin-top: 1.5rem;
}

.company-details-link {
  color: #fff !important;
}
.company-details-link:hover {
  color: var(--pure-teal) !important;
}

a.project-tags-grid-title,
a.project-tags-grid-title:visited {
  color: #fff !important;
  display: flex;
  justify-content: space-between;
  flex-wrap: nowrap;
  flex-direction: row;
  padding-right: 2rem;
}
a.project-tags-grid-title:hover {
  color: var(--pure-teal) !important;
}
a.project-tags-grid-title svg {
  min-width: 2.5rem;
  position: absolute;
  top: 2rem;
  right: 1rem;
  fill: #fff !important;
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
a.project-tags-grid-title:hover svg {
  fill: #00ae9d !important;
}

/* How to work with us */
.check-eligibility-section {
  padding-top: 6rem;
}
.check-eligibility-section select {
  background-color: var(--bg-color);
  border: 1px solid #00364b;
  color: #fff;
  padding: 0.5rem;
  border-radius: 0.25rem;
  font-family: var(--notesesa), sans-serif;
  font-size: 0.875rem;
}

.check-eligibility-bootstrap-tabs {
  width: 100%;
  min-height: 100px;
  background: transparent;
  border: none;
  padding: 0;
}
.check-eligibility-bootstrap-tabs .nav-link {
  font-family: "notesesa", sans-serif;
  font-size: 0.875rem;
  cursor: pointer;
  background: var(--bg-color, #6c757d);
  border-radius: 6.1875rem;
  border: 1px solid #ffffff66;
  letter-spacing: 0.0875rem;
  text-transform: uppercase;
  text-align: center;
  color: #fff;
  display: inline-block;
  padding: 8px 16px;
  margin: 5px;
  text-decoration: none;
}
.check-eligibility-bootstrap-tabs .nav-link.active {
  background: var(--bg-color, #6c757d);
  color: #fff;
  border: 1px solid var(--pure-teal, #00b3b0);
}
.check-eligibility-bootstrap-tabs .nav-tabs {
  margin: 0 0 2rem 0;
  border-bottom: 0;
  gap: 1rem;
  justify-content: center;
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
}

.check-eligibility-bootstrap-tabs .tab-pane {
  display: none;
  padding: 20px 0;
  background: transparent;
  border: none;
  min-height: 50px;
  margin-top: 1.5rem;
}
.check-eligibility-bootstrap-tabs .tab-pane.show.active {
  display: block;
}

.check-eligibility-bootstrap-tabs .tab-content-container {
  margin-top: 20px;
}

.check-eligibility-bootstrap-tabs .tab-pane > * {
  margin-bottom: 1rem;
}
.flag-img {
  width: 1.5rem;
  height: auto;
  margin-bottom: 1rem;
}
.check-eligibility-section .projects-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 2rem;
  list-style: none;
  padding: 0;
  margin: 0;
}
.check-eligibility-section .project-card {
  min-height: 16.25rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  border-radius: 0.5rem;
  border: 1px solid #00364b;
  background: #00293a;
  padding: 1.5rem;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.check-eligibility-section .project-card__title {
  color: #fff;
  font-family: var(--notesesa, sans-serif);
  font-size: 1.25rem;
  font-weight: normal;
  line-height: 120%;
  margin: 1rem 0;
    margin-bottom: 1rem;
}

.check-eligibility-section .project-card__content {
  padding: 1.5rem;
}
/* Documents Page */
.documents-grid {
  overflow: hidden;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: flex-start;
  -ms-justify-content: flex-start;
  justify-content: flex-start;
  -webkit-align-items: stretch;
  -ms-align-items: stretch;
  align-items: stretch;
  -webkit-align-content: flex-start;
  -ms-align-content: flex-start;
  align-content: flex-start;
  gap: 1.5rem;
  margin-top: 2rem;
}

.document-card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 14.1875rem;
  padding: 1.5rem;
  border-radius: 0.5rem;
  background: #00293a;
  border: 1px solid #00364b;
  transition: all 0.3s ease;
  overflow: hidden;
  flex: 1 1 100%;
}

@media (min-width: 992px) {
  .document-card {
    flex: 1 1 calc(33.333% - 1rem);
    max-width: calc(33.333% - 1rem);
  }
}

.document-card-content {
  position: relative;
  z-index: 1;
  flex: 1;
}

.document-card-title {
  color: #fff;
  font-family: var(--notesesa), sans-serif;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 130%;
  margin-bottom: 1.5rem;
  transition: color 0.3s ease;
}

.document-card-meta {
  display: flex;
  flex-direction: row;
  gap: 1.5rem;
}

.document-meta-item {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.document-meta-label {
  color: #54a2bf;
  font-family: Inter;
  font-size: 0.75rem;
  font-style: normal;
  font-weight: 400;
  line-height: 100%; /* 0.75rem */
  letter-spacing: 0.0075rem;
}

.document-meta-value {
  color: #fff;
  font-family: Arial, sans-serif;
  font-size: 0.9375rem;
  font-style: normal;
  font-weight: 400;
  line-height: 150%; /* 1.40625rem */
  letter-spacing: 0.00938rem;
}

.document-card-footer {
  margin-top: auto;
}

/* .document-download-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  background: rgba(0, 174, 157, 0.1);
  border: 1px solid var(--pure-teal);
  color: var(--pure-teal);
  transition: all 0.3s ease;
}

.document-download-link:hover {
  background: var(--pure-teal);
  color: #001f2c;
  transform: scale(1.1);
} */

.document-download-link svg {
  width: 1.25rem;
  height: 1.25rem;
}
/* .reset-search {
  font-size: 2rem;
  font-family: var(--notesesa), sans-serif;
  color: var(--pure-teal);
  cursor: pointer;
  position: absolute;
  right: 0;
  top: 0;
}
.reset-search input {
  margin: 0;
} */

/* FAQ Accordion Styles */
.faq-section {
  padding-block: 6rem;
}
.faq-section .accordion {
  background-color: transparent;
}

.faq-section .accordion-item {
  background-color: var(--bg-color);
  border: none;
  overflow: hidden;
}

.faq-section .accordion-button {
  background-color: transparent;
  color: #fff;
  font-size: 1.1875rem;
  font-style: normal;
  font-weight: 400;
  line-height: 152%; /* 1.805rem */
  letter-spacing: 0.01188rem;
  padding: 2rem 1rem;
  border: none;
  box-shadow: none;
  position: relative;
  text-align: left;
}

.faq-section .accordion-button:not(.collapsed) {
  background-color: rgba(0, 174, 157, 0.1);
  color: var(--pure-teal);
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.faq-section .accordion-button:hover {
  background-color: rgba(255, 255, 255, 0.08);
}

.faq-section .accordion-button:focus {
  box-shadow: none;
  border: none;
}

.faq-section .accordion-button::after {
  content: "";
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M12 5l0 14' /%3E%3Cpath d='M5 12l14 0' /%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-size: 1.5rem;
  background-position: center;
  width: 1.5rem;
  height: 1.5rem;
  flex-shrink: 0;
  margin-left: auto;
  transition: transform 0.3s ease;
}

.faq-section .accordion-button:not(.collapsed)::after {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%2300ae9d' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M12 5l0 14' /%3E%3Cpath d='M5 12l14 0' /%3E%3C/svg%3E");
  transform: rotate(45deg);
}

.faq-section .accordion-body {
  padding: 1.5rem;
  color: rgba(255, 255, 255, 0.8);
  font-size: 1rem;
  line-height: 1.6;
  background-color: rgba(0, 0, 0, 0.2);
}

.faq-section .accordion-body p {
  margin-bottom: 0.75rem;
}

.faq-section .accordion-body p:last-child {
  margin-bottom: 0;
}
.faq-page-info {
  font-size: 0.9375rem;
  font-family: var(--notesesa);
  color: var(--deep-space-lighter);
}

.related-links-and-contacts-section {
  background-image: url("images/contact-card-bg.png");
  padding-block: 3.75rem;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}

.work-related-links-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(500px, 1fr));
  gap: 1rem;
  padding: 1rem 0;
}

.work-related-links-grid .related-link-item {
  background-color: var(--bg-color);
  padding: 1rem;
  border-radius: 0.25rem;
  gap: 0.25rem;
  display: flex;
  flex-direction: column;
}
.work-related-links-grid .related-link-item:hover {
  background-color: var(--deep-space);
  -webkit-transition: all 0.3s 0s ease;
  -moz-transition: all 0.3s 0s ease;
  -o-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.related-link-title {
  font-size: 0.9375rem;
  font-style: normal;
  font-weight: 400;
  line-height: 150%; /* 1.40625rem */
  letter-spacing: 0.00938rem;
}
.related-link-label {
  color: var(--pure-teal);
  font-family: var(--notesesa);
  font-size: 0.75rem;
  font-style: normal;
  font-weight: 400;
  line-height: 120%; /* 0.9rem */
  letter-spacing: 0.0825rem;
  text-transform: uppercase;
}

.open-calls-box {
  border-radius: 0.5rem;
  background: rgba(0, 174, 157, 0.1);
  padding: 1.5rem;
}

.open-calls-box a {
  border-radius: 0.25rem;
  background: rgba(255, 255, 255, 0.1) !important;
  color: #fff !important;
  border: 0;
}

#back-to-top {
  position: fixed;
  bottom: 15px;
  right: 15px;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: #00ae9daa;
  color: #fff;
  border: none;
  cursor: pointer;
  display: flex;
  opacity: 0.5;
  /* display: flex; added with js in footer*/
  align-items: center;
  justify-content: center;
  font-size: 1rem;

  transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
  z-index: 1000;
}
#back-to-top:hover {
  opacity: 1;
  background-color: #00ae9d;
  color: #fff !important;
}

/* National delegation page */
.national-delegation-table td {
  vertical-align: top;
  text-align: left;
}

.national-delegation-table table.has-fixed-layout {
  border-collapse: collapse;
  width: 100%;
}

.national-delegation-table table.has-fixed-layout tr {
  border-bottom: 1px solid #ccc;
}

.national-delegation-table table.has-fixed-layout td {
  border: none;
  padding: 8px 6px;
}
table.has-fixed-layout td:first-child {
  width: 200px;
}