/* ==========================================================================
HELPERS CLASSES
========================================================================== */

:root {
   interpolate-size: allow-keywords;
   --icon-angle: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23265294'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
   --bs-gutter-y: 1.5rem;
   --border-color: currentColor;
}

.mark,
mark {
   padding: unset;
   color: unset;
   background-color: unset;
}

.row {
   gap: var(--bs-gutter-x) 0;
   margin-block-start: unset;
   >* {
      margin-block-start: unset;
   }
}

figure {
   margin: unset;
}

b,
strong {
   font-weight: 700;
}

body.no-scroll {
   overflow: hidden;
   padding-inline-end: 0px;
}

summary {
   list-style: none;
}

summary::-webkit-details-marker {
   display: none;
}

.grecaptcha-badge {
   right: -300px !important;
}

input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
   -webkit-appearance: none;
   margin: 0;
}

h1,
h2,
h3,
h4,
h5,
h6,
p,
ul,
hr {
   margin-block-start: var(--wp--custom--main-size);
   margin-block-end: 0;
   &:first-child {
      margin-block-start: 0;
   }
}

a {
   outline: 0;
   &:hover,
   &:focus,
   &:active {
      outline: 0;
   }
}

.btn-close:focus,
.btn.active.focus,
.btn.active:focus,
.btn.focus,
.btn.focus:active,
.btn:active:focus,
.btn:focus {
   outline: 0;
   box-shadow: none;
}

.form-control:focus {
   border-color: none;
   box-shadow: none;
}

img {
   max-width: 100%;
   height: auto;
}

.map {
   line-height: 1;
   iframe {
      width: 100%;
   }
}

@media (max-width: 1199px) {
   .mobile-scroll::-webkit-scrollbar {
      display: none;
   }
   .mobile-scroll.list-posts.list-post-grid {
      width: 100vw;
      margin-inline: -1.5rem !important;
      padding-inline: 1.5rem;
      display: flex;
      flex-wrap: nowrap;
      gap: var(--wp--custom--main-size);
      overflow-x: auto;
      scrollbar-width: none;
      -webkit-overflow-scrolling: touch;
      -ms-overflow-style: -ms-autohiding-scrollbar;
      >* {
         flex: 1 0 min(90%, 400px);
      }
   }
}

.loading {
   background-color: rgba(255, 255, 255, .5);
   position: fixed;
   width: 100%;
   height: 100%;
   z-index: 99999;
   left: 0;
   top: 0;
   display: none;
   background-image: url(../images/loading-dark.svg);
   background-repeat: no-repeat;
   background-position: center;
}


/* ==========================================================================
FORMS
========================================================================== */

::placeholder {
   opacity: 0.8;
}

label {
   display: block;
}

select,
input[type='text'],
input[type='url'],
input[type='date'],
input[type='file'],
input[type='email'],
input[type='tel'],
input[type='number'],
input[type='password'],
input[type='number'],
input[type='file'],
input[type='search'],
textarea {
   display: block;
   width: 100%;
   padding: .531rem .75rem;
   line-height: 1.5;
   background-clip: padding-box;
   -webkit-appearance: none;
   -moz-appearance: none;
   appearance: none;
   transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
   background-color: #fff;
   border: 1px solid var(--border-color);
   border-radius: var(--wp--custom--border-radius);
   color: var(--wp--preset--color--primary);
   &:focus {
      outline: none;
      box-shadow: none;
   }
   &[readonly] {
      background-color: #e9ecef;
      opacity: 1;
   }
}

textarea {
   height: 120px;
}

select {
   -moz-padding-start: calc(0.75rem - 3px);
   line-height: 1.5;
   background-repeat: no-repeat;
   background-position: right 0.75rem center;
   background-size: 1.25rem auto;
   background-image: var(--icon-angle);
}

button,
input[type='button'],
input[type='submit'] {
   border: none;
   background: transparent;
   text-decoration: none;
   vertical-align: middle;
   cursor: pointer;
   -webkit-user-select: none;
   -moz-user-select: none;
   user-select: none;
   text-transform: uppercase;
   /* font-weight: 700; */
   letter-spacing: .08em;
   font-family: var(--wp--preset--font-family--heading);
}

.wp-block-read-more,
.wp-block-post-navigation-link a,
.wp-block-post-excerpt__more-link,
.wp-element-button,
.wp-block-button.is-style-outline .wp-element-button,
.wp-block-button__link,
.navigation.post-navigation .nav-links a,
.btn,
button,
.woocommerce .button,
input[type='button'],
input[type='submit'] {
   text-align: center;
   padding: var(--wp--custom--button-padding-y) var(--wp--custom--button-padding-x);
   border-width: var(--wp--custom--button-border-width);
   border-style: var(--wp--custom--button-border-style);
   border-radius: var(--wp--custom--button-border-radius);
   transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
   text-transform: uppercase;
   font-weight: 700;
}

.navigation.post-navigation .nav-links a,
.wp-block-read-more,
.wp-block-post-navigation-link a,
.wp-block-post-excerpt__more-link,
.btn-custom,
.xoo-wsc-ft-btn,
.xoo-wsc-body a.xoo-wsc-btn,
.woocommerce .button,
input[type='button'],
input[type='submit'] {
   text-decoration: none;
   background-color: var(--wp--preset--color--primary);
   color: #FFF;
   border-color: var(--wp--preset--color--primary);
   &:hover {
      color: #FFF;
      background-color: var(--wp--custom--color-primary-hover);
      border-color: var(--wp--custom--color-primary-hover);
      text-decoration: none;
   }
}

.wp-block-button {
   &.is-style-outline {
      .wp-block-button__link {
         &:hover {
            border-color: var(--wp--preset--color--primary);
            background-color: var(--wp--preset--color--primary);
            color: #FFFFFF;
         }
      }
   }
}

.wp-block-button {
   &.is-style-alternative {
      .wp-block-button__link {
         background-color: #FFF;
         border-color: #FFF;
         color: var(--wp--preset--color--primary);
         &:hover {
            background-color: var(--wp--preset--color--primary);
            border-color: var(--wp--preset--color--primary);
            color: #FFF;
         }
      }
   }
}

.btn-white {
   background-color: #FFF;
   border-color: #FFF;
   color: var(--wp--preset--color--primary);
   &:hover {
      background-color: transparent;
      border-color: #FFF;
      color: #FFF;
      text-decoration: none;
   }
}

.btn-link {
   --bs-btn-color: var(--wp--preset--color--primary);
   --bs-btn-hover-color: var(--wp--custom--color-primary-hover);
   --bs-btn-active-color: var(--wp--custom--color-primary-hover);
   --bs-btn-disabled-color: #6c757d;
}

.light-form {
   ::placeholder {
      opacity: 0.8;
      color: #FFF;
   }
   a,
   label {
      color: #FFF;
   }
   select,
   input[type='text'],
   input[type='url'],
   input[type='date'],
   input[type='file'],
   input[type='email'],
   input[type='tel'],
   input[type='number'],
   input[type='password'],
   input[type='number'],
   input[type='file'],
   input[type='search'],
   textarea {
      background: none;
      color: #FFF;
      border-color: currentColor;
   }
   select {
      background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23FFF'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
   }
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
   right: 0.75rem;
   height: 100%;
   background-repeat: no-repeat;
   background-size: 1.25rem auto;
   background-position: center;
   background-image: var(--icon-angle);
   b {
      display: none;
   }
}

body .select2-container,
body .ui-widget.ui-datepicker {
   z-index: 5 !important;
}

.select2-container--default {
   .select2-selection--single {
      border: 1px solid var(--border-color);
      border-radius: var(--wp--custom--border-radius);
      height: 40px;
      line-height: 40px;
      margin: 0;
      display: flex;
      align-items: center;
      .select2-selection__rendered {
         color: #000;
      }
   }
}

/* ==========================================================================
CF7
========================================================================== */

.wpcf7-form {
   .wpcf7-form-control-wrap {
      display: block;
   }
   .field-cf7 {
      margin-block-end: calc(var(--wp--custom--main-size) / 2);
      >p {
         margin: 0;
      }
      label {
         margin-block-end: 0.188rem;
      }
   }
   .wpcf7-list-item {
      margin: 0;
      display: block;
   }
   &.submitting {
      .wpcf7-submit {
         background-image: url(../images/loading-light.svg);
         background-repeat: no-repeat;
         background-position: center center;
         background-size: 1.25rem;
         color: transparent;
         pointer-events: none;
      }
   }
   .wpcf7-submit {
      min-width: 9.375rem;
   }
   .wpcf7-spinner {
      display: none !important;
   }
   .wpcf7-not-valid {
      border-color: #f00;
   }
   div.wpcf7-response-output {
      margin: 1rem 0;
      padding: 0.313rem;
      font-size: 0.875rem;
   }
   &.invalid .wpcf7-response-output {
      color: #8a6d3b;
      background-color: #fcf8e3;
      border: 1px solid #faebcc;
      border-radius: var(--wp--custom--border-radius);
   }
   &.sent .wpcf7-response-output {
      color: #3c763d;
      background-color: #dff0d8;
      border-color: #d6e9c6;
      border-radius: var(--wp--custom--border-radius);
   }
   span.wpcf7-not-valid-tip {
      font-size: 0.875rem;
      padding-block-start: 0.3125rem;
      display: block;
   }
   div.wpcf7-spam-blocked,
   div.wpcf7-mail-sent-ng {
      color: #a94442;
      background-color: #f2dede;
      border-color: #ebccd1;
   }
}

.wpcf7-field-group-remove,
.wpcf7-field-group-add {
   border: none;
   border-radius: var(--bs-accordion-border-radius);
   background-color: var(--wp--preset--color--primary);
   color: #FFF;
   font-size: 1.125rem;
   padding: 0.5rem 1.875rem;
   display: block;
   &:hover {
      color: #FFFF;
      background-color: #134A8C;
   }
}

.wpcf7-field-group-add {
   max-width: 200px;
   margin: 1rem auto;
}

.options-inline {
   .wpcf7-radio,
   .wpcf7-checkbox {
      display: flex;
      flex-wrap: wrap;
      gap: 0.5rem 1.5rem;
      label {
         font-weight: 400;
      }
   }
}

@media (min-width: 768px) {
   .cf7-two-cols {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      grid-gap: 0 calc(var(--wp--custom--main-size) / 2);
   }
}

/* ==========================================================================
WHATSAPP
========================================================================== */

.whatsapp-fixed {
   --wfb-space: calc(var(--wp--custom--main-size) / 2);
   position: fixed;
   bottom: var(--wfb-space);
   left: var(--wfb-space);
   z-index: 999;
   a {
      width: 3.125rem;
      height: 3.125rem;
      background-color: #25d366;
      display: flex;
      align-items: center;
      justify-content: center;
      border-radius: 50%;
      padding: 10px;
      background-size: 50%;
      background-repeat: no-repeat;
      background-position: center;
      background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23FFFFFF'%3e%3cpath fill-rule='evenodd' d='M13.601 2.326A7.85 7.85 0 0 0 7.994 0C3.627 0 .068 3.558.064 7.926c0 1.399.366 2.76 1.057 3.965L0 16l4.204-1.102a7.9 7.9 0 0 0 3.79.965h.004c4.368 0 7.926-3.558 7.93-7.93A7.9 7.9 0 0 0 13.6 2.326zM7.994 14.521a6.6 6.6 0 0 1-3.356-.92l-.24-.144-2.494.654.666-2.433-.156-.251a6.56 6.56 0 0 1-1.007-3.505c0-3.626 2.957-6.584 6.591-6.584a6.56 6.56 0 0 1 4.66 1.931 6.56 6.56 0 0 1 1.928 4.66c-.004 3.639-2.961 6.592-6.592 6.592m3.615-4.934c-.197-.099-1.17-.578-1.353-.646-.182-.065-.315-.099-.445.099-.133.197-.513.646-.627.775-.114.133-.232.148-.43.05-.197-.1-.836-.308-1.592-.985-.59-.525-.985-1.175-1.103-1.372-.114-.198-.011-.304.088-.403.087-.088.197-.232.296-.346.1-.114.133-.198.198-.33.065-.134.034-.248-.015-.347-.05-.099-.445-1.076-.612-1.47-.16-.389-.323-.335-.445-.34-.114-.007-.247-.007-.38-.007a.73.73 0 0 0-.529.247c-.182.198-.691.677-.691 1.654s.71 1.916.81 2.049c.098.133 1.394 2.132 3.383 2.992.47.205.84.326 1.129.418.475.152.904.129 1.246.08.38-.058 1.171-.48 1.338-.943.164-.464.164-.86.114-.943-.049-.084-.182-.133-.38-.232'/%3e%3c/svg%3e");
   }
   &.left {
      left: var(--wfb-space);
   }
   &.right {
      left: unset;
      right: var(--wfb-space);
   }
}

@media (min-width: 1200px) {
   .whatsapp-fixed {
      --wfb-space: calc(var(--wp--custom--main-size) / 1.5);
      bottom: var(--wfb-space);
      a {
         width: 3.75rem;
         height: 3.75rem;
         padding: 1rem;
         transition: background 0.3s ease-out;
         &:hover {
            background-color: #11b04c;
         }
      }
      &.left {
         left: var(--wfb-space);
      }
      &.right {
         right: var(--wfb-space);
      }
   }
}

.loader {
   width: 3rem;
   height: 3rem;
   border: 5px solid var(--wp--preset--color--primary);
   border-bottom-color: transparent;
   border-radius: 50%;
   display: inline-block;
   box-sizing: border-box;
   animation: loaderRotation 0.8s linear infinite;
}

@keyframes loaderRotation {
   0% {
      transform: rotate(0deg);
   }
   100% {
      transform: rotate(360deg);
   }
}

.alm-btn-wrap .alm-load-more-btn:before {
   background-image: url(../images/loading-dark.svg) !important;
}

.alm-btn-wrap .alm-load-more-btn {
   background: var(--wp--preset--color--primary) !important;
   &:hover {
      background: var(--wp--custom--color-primary-hover) !important;
   }
}

/* ==========================================================================
OWL CAROUSEL
========================================================================== */

.owl-carousel {
   --owl-button-size: 3.125rem;
   position: relative;
   &:not(.owl-loaded) {
      display: flex !important;
      opacity: 0;
   }
   .owl-stage {
      display: flex;
      flex-wrap: wrap;
   }
   &.owl-theme {
      .owl-nav {
         margin-block-start: var(--wp--custom--main-size);
         text-align: unset;
         display: flex;
         justify-content: center;
         gap: calc(var(--wp--custom--main-size) * .5);
         button {
            span {
               display: none;
            }
            &.owl-next {
               transform: rotate(180deg);
            }
         }
         [class*="owl-"] {
            transition: background-color 0.3s ease-out;
            width: var(--owl-button-size);
            height: var(--owl-button-size);
            overflow: hidden;
            background-color: #646464;
            background-image: url(../images/owl-arrow-white.svg);
            background-position: center;
            background-repeat: no-repeat;
            background-size: 17px auto;
            margin: 0;
            border-radius: 0;
         }
         [class*="owl-"] {
            margin-block: 0;
         }
         [class*="owl-"]:hover {
            background-color: #525252;
         }
         &.disabled {
            display: none;
         }
      }
      .owl-dots {
         margin-block-start: var(--wp--custom--main-size);
         line-height: 1;
         .owl-dot {
            span {
               width: 1rem;
               height: 1rem;
               margin: .25rem;
               background: none;
               border: 1px solid var(--wp--preset--color--primary);
               transition: background .3s ease-out;
            }
            &.active,
            &:hover {
               span {
                  background-color: var(--wp--custom--color-primary-hover);
                  opacity: 1;
               }
            }
         }
      }
      .owl-nav.disabled+.owl-dots {
         margin-block-start: var(--wp--custom--main-size);
      }
      .owl-carousel .owl-dots.disabled,
      .owl-carousel .owl-nav.disabled {
         display: none;
      }
   }
}

@media (min-width: 1400px) {
   .is-style-middle-arrows {
      .owl-carousel {
         position: relative;
         &.owl-theme {
            .owl-nav {
               margin-block-start: 0;
               position: absolute;
               top: 50%;
               transform: translateY(-50%);
               left: 0;
               width: 100%;
               pointer-events: none;
               justify-content: space-between;
               button {
                  margin: 0;
                  pointer-events: auto;
               }
               button.owl-prev {
                  margin-inline: var(--wp--custom--main-size);
               }
               button.owl-next {
                  margin-inline: var(--wp--custom--main-size);
               }
            }
         }
      }
   }
}

/* ==========================================================================
NAVIGATION
========================================================================== */

.navigation {
   padding-block-start: calc(var(--wp--custom--main-size) * 2);
   .screen-reader-text {
      display: none;
   }
   &.pagination {
      .nav-links {
         width: 100%;
         display: flex;
         justify-content: center;
         gap: calc(var(--wp--custom--main-size) / 1.5);
         font-size: 1.375rem;
         line-height: 1;
      }
      a,
      span {
         border: none;
         transition: opacity 0.3s ease-out;
         text-decoration: none;
      }
      a:hover,
      span.current {
         opacity: 0.5;
      }
   }
   &.post-navigation {
      padding: var(--wp--custom--main-size);
      padding-block-start: calc(var(--wp--custom--main-size) * 2);
      .nav-links {
         max-width: var(--wp--style--global--content-size);
         margin: 0 auto;
         display: flex;
         justify-content: space-between;
         .nav-next {
            margin-inline-start: auto;
         }
         a {
            min-width: 130px;
         }
      }
   }
}

nav.woocommerce-pagination,
.wp-block-query-pagination {
   padding-top: calc(var(--wp--custom--main-size) * 2);
   margin-block-start: 0;
   line-height: 1;
   .page-numbers {
      list-style: none;
   }
   .page-numbers,
   .wp-block-query-pagination-numbers {
      display: flex;
      justify-content: center;
      gap: calc(var(--wp--custom--main-size) / 1.5);
      font-size: 1.375rem;
      a,
      span {
         border: none;
         color: var(--wp--preset--color--primary);
         transition: opacity 0.3s ease-out;
         text-decoration: none;
      }
      a:hover,
      span.current {
         opacity: 0.5;
      }
   }
   .wp-block-query-pagination-previous-arrow,
   .wp-block-query-pagination-next-arrow {
      margin: 0;
      font-size: 1.375rem;
      line-height: 1;
   }
}

.wp-block-query-pagination>.wp-block-query-pagination-next,
.wp-block-query-pagination>.wp-block-query-pagination-numbers,
.wp-block-query-pagination>.wp-block-query-pagination-previous {
   margin: 0;
}

@media (min-width: 1200px) {
   nav.woocommerce-pagination,
   .wp-block-query-pagination,
   .navigation {
      padding-block-start: calc(var(--wp--custom--main-size) * 3);
   }
}

/* ==========================================================================
404
========================================================================== */

.error404 {
   display: grid;
   grid-template-rows: auto auto 1fr auto;
   min-height: 100vh;
   main {
      place-content: center;
   }
   section {
      h1 {
         line-height: 1;
      }
      h2 {
         line-height: 1;
      }
   }
}


/* ==========================================================================
BLOG
========================================================================== */

body.search-results,
body.single-post {
   main {
      --wp--style--global--content-size: 60rem;
   }
}

.book,
.post {
   .wp-block-post-featured-image {
      a {
         display: block;
      }
      img {
         max-width: none;
         width: 100%;
         aspect-ratio: 16/9;
         object-fit: cover;
         border-radius: var(--wp--custom--border-radius);
      }
   }
   .wp-block-post-terms {
      a {
         text-decoration: none;
      }
   }
   .wp-block-post-meta {
      font-size: 90%;
      display: flex;
      flex-wrap: wrap;
      gap: 0.75rem;
      >div:not(:last-child):after {
         margin-inline-start: 0.75rem;
         content: '|';
      }
   }
}

.wp-block-post-template,
.list-posts {
   .book,
   .post {
      --wp--custom--main-size: 1rem;
      display: flex;
      flex-direction: column;
      gap: var(--wp--custom--main-size);
      a {
         text-decoration: none;
      }
      .wp-block-post-title {
         font-size: 1.375rem;
      }
      .wrap-wp-block-post-excerpt {
         flex: 1;
         display: flex;
         flex-direction: column;
         gap: var(--wp--custom--main-size);
         .wp-block-post-excerpt {
            margin: 0;
         }
      }
   }
}

.list-posts {
   display: grid;
   gap: var(--wp--custom--main-size);
   grid-template-columns: repeat(auto-fill, minmax(min(19rem, 100%), 1fr));
}

@media (min-width: 1200px) {
   .wp-block-post-template.is-layout-grid,
   .list-posts {
      gap: calc(var(--wp--custom--main-size) * 1.5);
   }
}

.list-posts-search {
   article {
      padding-bottom: calc(var(--wp--custom--main-size) * 1.5);
      &:not(:last-child) {
         border-bottom: 1px solid rgba(0, 0, 0, 0.1);
      }
   }
}

body.search-no-results {
   main {
      --wp--style--global--content-size: 31.25rem;
      text-align: center;
      min-height: 60vh;
   }
}

/* ==========================================================================
BOOTSTRAP
========================================================================== */

.accordion {
   --bs-accordion-bg: none;
   --bs-accordion-active-bg: none;
   --bs-accordion-color: currentColor;
   --bs-accordion-active-color: currentColor;
   --bs-accordion-border-radius: 0;
   --bs-accordion-inner-border-radius: 0;
   --bs-accordion-btn-focus-box-shadow: none;
   --bs-accordion-border-color: transparent;
   --bs-accordion-btn-padding-x: 0;
   --bs-accordion-body-padding-x: 0;
   --bs-accordion-body-padding-y: var(--wp--custom--main-size);
   --bs-accordion-btn-icon: var(--icon-angle);
   --bs-accordion-btn-active-icon: var(--icon-angle);
   --bs-accordion-btn-color: currentColor;
}

.accordion-header {
   border-bottom: 1px solid currentColor;
}

@media (min-width: 1200px) {
   .accordion-button {
      font-size: 1.25rem;
   }
}

/* ==========================================================================
GENERAL
========================================================================== */

a:where(:not(.wp-element-button)) {
   transition: color .3s ease-out;
}

table {
   width: 100%;
   max-width: 100%;
   background-color: transparent;
   &:not(:first-child) {
      margin-block-start: var(--wp--custom--main-size);
   }
}

table:not(.variations) td,
table:not(.variations) th {
   padding: .3rem;
}

table:not(.variations) td,
table:not(.variations) th {
   border-top: 1px solid #dee2e6;
}

.container,
.container-xl,
.container-xxl {
   padding-inline: var(--wp--style--root--padding-left);
   max-width: 1320px;
}

.container-fluid {
   padding-inline: var(--wp--style--root--padding-left);
}

.section {
   padding-block: calc(var(--wp--custom--main-size) * 2);
   @media (min-width: 992px) {
      & {
         padding-block: calc(var(--wp--custom--main-size) * 2.5);
      }
   }
   @media (min-width: 1200px) {
      & {
         padding-block: calc(var(--wp--custom--main-size) * 3);
      }
   }
}

/* ==========================================================================
GUTENBERG
========================================================================== */

.is-style-d-none {
   display: none !important;
}

.wp-block-details {
   summary {
      border-bottom: 1px solid currentColor;
      position: relative;
      display: flex;
      align-items: center;
      width: 100%;
      padding: 0 0 1rem 0;
      line-height: 1.3;
      &:after {
         flex-shrink: 0;
         width: 1.25rem;
         height: 1.25rem;
         margin-inline-start: auto;
         content: "";
         background-repeat: no-repeat;
         background-image: var(--icon-angle);
         transition: transform 0.2s ease-in-out;
      }
   }
   &[open] {
      padding-block-end: var(--wp--custom--main-size);
      summary {
         &:after {
            transform: rotate(-180deg);
         }
      }
   }
   &.has-background {
      border-radius: var(--wp--custom--border-radius);
      summary {
         padding-inline: var(--wp--custom--main-size);
         padding-block-start: 1rem;
      }
      > :where(:not(summary)) {
         margin-inline: var(--wp--custom--main-size);
      }
   }
}

hr,
.wp-block-separator {
   opacity: unset;
   border-top: 1px solid currentColor;
   border-block-end: 0;
}

.has-global-padding>.wp-block-group.alignfull.has-background.is-layout-constrained {
   padding-inline: var(--wp--custom--main-size);
}

.wp-block-social-link {
   transition: opacity 0.3s ease-out;
   &:hover {
      transform: scale(1);
      opacity: 0.8;
   }
}

.wp-block-accordion-panel[aria-hidden="true"],
.wp-block-accordion-panel[inert] {
   display: block;
   margin-block-start: var(--wp--custom--main-size);
}

.wp-block-accordion {
   --accordin-space: 1rem;
   .wp-block-accordion-item {
      margin: 0;
      transition: height .25s ease, visibility .5s;
      .wp-block-accordion-heading {
         border-bottom: 1px solid currentColor;
         padding-block-end: var(--accordin-space);
         .wp-block-accordion-heading__toggle-title {
            font-size: 1.25rem;
         }
         .wp-block-accordion-heading__toggle {
            border-radius: 0;
            padding: 0;
         }
         .wp-block-accordion-heading__toggle-icon {
            color: transparent;
            background-image: var(--icon-angle);
            background-repeat: no-repeat;
            background-position: center;
            background-size: 25px auto;
         }
         &:hover .wp-block-accordion-heading__toggle-title {
            text-decoration: none;
         }
      }
      .wp-block-accordion-panel {
         box-sizing: unset;
         height: 0;
         overflow: clip;
         visibility: hidden;
         transition: height .25s ease, visibility .5s;
      }
      &.is-open {
         >.wp-block-accordion-heading .wp-block-accordion-heading__toggle-icon {
            transform: rotate(180deg);
         }
         .wp-block-accordion-panel {
            height: auto;
            visibility: visible;
            margin-block-end: calc(var(--accordin-space) * 2);
         }
      }
   }
}

ul.wp-block-list {
   list-style-type: square;
}

body {
   &.page-no-top-space {
      main {
         padding-block-start: 0;
      }
   }
   &.page-no-bottom-space {
      main {
         padding-block-end: 0;
      }
   }
}

/* ==========================================================================
HEADER
========================================================================== */

.main-header {
   z-index: 999;
   position: sticky;
   width: 100%;
   top: 0;
   padding-block: calc(var(--wp--custom--main-size) * .75);
   border-bottom: 1px solid currentColor;
   transition: background .2s ease-out, opacity .2s ease-out;
   transition-delay: .5s, 0s;
   background-color: #FFFFFF;
   &::after {
      content: '';
      position: absolute;
      bottom: 0;
      left: 0;
      width: 0;
      height: 1px;
      background-color: rgba(115, 113, 114, 1);
      z-index: 99;
      transition: width 1s cubic-bezier(.7, 0, .3, 1);
   }
   .wp-block-site-logo {
      img {
         max-width: 180px;
         transition: opacity .2s ease-out;
         transition-delay: .4s;
      }
      a {
         display: block;
         position: relative;
         &:after {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background-image: url(../images/logo-sign-brothers-light.svg);
            background-size: contain;
            background-repeat: no-repeat;
            background-position: center;
            opacity: 0;
            transition: opacity 0.2s ease-out;
            transition-delay: .5s;
         }
         &:before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            width: 97px;
            height: 97px;
            background-image: url(../images/icon-sign-brothers.svg);
            z-index: 5;
            opacity: 0;
            transition: opacity .2s .4s ease-out;
         }
      }
   }
   @media (min-width: 768px) {
      padding-block: var(--wp--custom--main-size);
      .wp-block-site-logo {
         img {
            max-width: 245px;
         }
      }
   }
}

@media (min-width: 1024px) {
   body {
      &.nav-hide {
         .main-header {
            opacity: 0;
            pointer-events: none;
         }
      }
      &.nav-scrolled {
         .main-header {
            .wp-block-site-logo {
               img {
                  transition: opacity .2s ease-out;
                  transition-delay: .5s;
               }
               a {
                  &:before {
                     opacity: 1;
                  }
               }
               img {
                  opacity: 0;
               }
            }
         }
      }
   }
}

/* ==========================================================================
MENU ICON
========================================================================== */

.hamburger {
   border: 2px solid var(--wp--preset--color--primary);
   padding: .5em .3em;
   width: 43px;
   height: 43px;
   transition: all .5s ease;
   .hamburger-box {
      width: 43px;
      .hamburger-inner,
      .hamburger-inner::after,
      .hamburger-inner::before {
         height: 2px;
         width: 100%;
      }
   }
   &:not(.is-active) {
      padding: .6em .3em;
      .hamburger-inner::before {
         top: 9px;
      }
      .hamburger-inner::after {
         top: 18px;
      }
   }
   &:hover,
   &.is-active {
      color: #FFF;
      background-color: var(--wp--preset--color--primary);
      border-color: currentColor;
      opacity: 1;
   }
   &:hover {
      border-color: var(--wp--preset--color--primary);
   }
}

/* ==========================================================================
FULLPAGE MENU
========================================================================== */

#fullpage-menu {
   background-color: var(--wp--preset--color--primary);
   padding-block-start: 80px;
   position: fixed;
   top: 0;
   left: 0;
   width: 100%;
   height: 100%;
   z-index: 997;
   clip-path: polygon(0 0, 100% 0, 100% 0%, 0 0%);
   transition: all .8s cubic-bezier(.7, 0, .3, 1);
   overflow-y: auto;
   .inner {
      width: 100%;
   }
   #main-navigation {
      ul.menu,
      ul.sub-menu {
         margin: 0;
         padding: 0;
         list-style: none;
      }
      ul.menu {
         flex-direction: column;
         text-transform: uppercase;
         a {
            border-bottom: 1px solid rgba(115, 113, 114, 1);
            color: #FFF;
            text-decoration: none;
            line-height: 1;
         }
         >li {
            >a {
               font-size: clamp(2rem, 1.4815rem + 2.5926vw, 3.75rem);
               padding: var(--wp--custom--main-size);
               display: block;
               transition: all .5s ease-out;
            }
         }
         .sub-menu {
            li {
               a {
                  display: block;
                  padding: calc(var(--wp--custom--main-size) * .5) var(--wp--custom--main-size);
                  text-transform: unset;
                  line-height: 1.2;
                  display: flex;
                  align-items: center;
                  gap: 0.75rem;
                  font-size: clamp(1rem, 0.8519rem + 0.7407vw, 1.5rem);
                  &:before {
                     content: '';
                     display: block;
                     width: 18px;
                     height: 14px;
                     background-image: url(../images/arrow-menu.svg);
                     background-position: center right;
                  }
               }
            }
         }
         &.current-menu-item {
            a {
               color: var(--wp--preset--color--primary);
            }
         }
      }
   }
   .contact-info {
      display: none;
   }
   @media (min-width: 992px) {
      padding-block-start: 92px;
      #main-navigation {
         ul.menu {
            height: calc(100vh - 92px);
            display: flex;
            flex-direction: column;
            position: relative;
            &::after {
               content: '';
               position: absolute;
               top: 0;
               left: 50%;
               width: 1px;
               height: 100%;
               background-color: rgba(115, 113, 114, 1);
            }
            >li {
               width: 50%;
               height: 20%;
               &.item-capabilities {
                  position: absolute;
                  right: 0;
                  top: 0;
                  .sub-menu {
                     height: 200%;
                     display: flex;
                     flex-direction: column;
                     li {
                        flex: 1;
                        a {
                           height: 100%;
                        }
                     }
                  }
               }
               &:nth-child(4) {
                  a {
                     border: none;
                  }
               }
               >a {
                  display: block;
                  height: 100%;
                  align-content: center;
                  padding-block: 0;
               }
            }
         }
      }
   }
   @media (min-width: 1200px) {
      #main-navigation {
         ul.menu {
            >li>a {
               &:hover {
                  background-color: #FFF;
                  color: var(--wp--preset--color--primary);
               }
            }
            .sub-menu {
               li {
                  a {
                     &:before {
                        /* width: 24px; */
                        transition: all .3s ease-out;
                     }
                     &:hover {
                        &:before {
                           width: 26px;
                        }
                     }
                  }
               }
            }
         }
      }
      .contact-info {
         position: absolute;
         width: 50%;
         left: 50%;
         bottom: 0;
         color: #FFF;
         padding: var(--wp--custom--main-size);
         font-weight: 400;
         h2 {
            margin-block-end: calc(var(--wp--custom--main-size) * .5);
         }
         figure {
            filter: brightness(0) invert(1);
            transform: translateY(3px);
         }
         .wp-block-group {
            padding: 0;
         }
         br {
            display: none;
         }
         p a {
            display: inline-block;
            color: currentColor;
            text-decoration: none;
            position: relative;
            &:after {
               transition: all 0.5s;
               content: '';
               position: absolute;
               right: 0;
               bottom: 0;
               width: 0;
               height: 1px;
               background-color: currentColor;
            }
            &:hover {
               &:after {
                  left: 0;
                  width: 100%;
               }
            }
         }
         @media (min-height: 650px) {
            display: block;
         }
      }
   }
}

body {
   &.show-menu {
      overflow: hidden;
      padding-right: 0px;
      .main-header {
         background-color: var(--wp--preset--color--primary);
         transition-delay: .5s;
         transition: background 0.2s ease-out, opacity 0.2s ease-out;
         transition-delay: 0s, 0s;
         &::after {
            width: 100%;
         }
         .wp-element-button {
            background-color: #FFF;
            color: var(--wp--preset--color--primary);
            &:hover {
               color: #FFF;
               background: transparent;
               border-color: #FFF;
            }
         }
         .wp-block-site-logo {
            a {
               &::before {
                  opacity: 0;
                  transition: opacity 0.2s ease-out;
                  transition-delay: 0;
               }
            }
         }
         .custom-logo-link {
            img {
               opacity: 0;
            }
         }
         a {
            &:after {
               opacity: 1;
               transition: opacity 0.2s ease-out;
               transition-delay: 0;
            }
         }
      }
      #fullpage-menu {
         clip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%);
      }
   }
}

/* ==========================================================================
FOOTER
========================================================================== */

.main-footer {
   p a {
      display: inline-block;
      position: relative;
      text-decoration: none;
      &:after {
         transition: all 0.5s;
         content: '';
         position: absolute;
         right: 0;
         bottom: 0;
         width: 0;
         height: 1px;
         background-color: currentColor;
      }
      &:hover {
         &:after {
            left: 0;
            width: 100%;
         }
      }
   }
   .power-by {
      strong {
         font-weight: 400;
      }
   }
   .row-icon {
      figure {
         line-height: 1.3;
      }
   }
   .bottom-footer {
      text-align: center;
   }
   .power-by {
      font-family: var(--wp--preset--font-family--heading);
      text-transform: uppercase;
      color: var(--wp--preset--color--primary);
      strong {
         color: var(--wp--preset--color--secondary);
      }
   }
   @media (max-width: 767px) {
      .top-footer {
         .wp-block-jupa-bootstrap-row-column:not(:last-child) {
            position: relative;
            &:after {
               content: '';
               position: absolute;
               bottom: 0;
               left: calc(var(--wp--custom--main-size) * -1);
               width: 100vw;
               height: 1px;
               background-color: currentColor;
            }
         }
         h2 {
            padding-block: var(--wp--custom--main-size);
            position: relative;
            display: flex;
            align-content: center;
            justify-content: space-between;
            &::after {
               content: '';
               width: 15px;
               height: 15px;
               background-image: var(--icon-angle);
               background-repeat: no-repeat;
               background-position: center;
               background-size: contain;
            }
            &+.wp-block-group {
               display: none;
               padding-block-end: var(--wp--custom--main-size);
            }
            &.show-info {
               &::after {
                  rotate: 180deg;
               }
               &+.wp-block-group {
                  display: block;
               }
            }
         }
      }
   }
   @media (min-width: 768px) {
      .top-footer {
         padding-block: calc(var(--wp--custom--main-size) * 2);
      }
   }
   @media (min-width: 1200px) {
      .top-footer {
         padding-block: calc(var(--wp--custom--main-size) * 3);
      }
      .bottom-footer {
         text-align: start;
      }
   }
}

/* ==========================================================================
HEADER PAGE
========================================================================== */

.header-page {
   background-color: var(--wp--preset--color--primary);
   position: relative;
   text-align: center;
   overflow: hidden;
   h1 {
      margin: 0;
      color: #FFFFFF;
   }
   .breadcrumbs {
      color: #FFFFFF;
      font-size: 0.875rem;
      a {
         color: #FFFFFF;
      }
   }
   @media (min-width: 768px) {
      padding-block: calc(var(--wp--custom--main-size) * 2);
   }
   @media (max-width: 991px) {
      .breadcrumbs {
         display: none;
      }
   }
   @media (min-width: 992px) {
      text-align: start;
      padding-block: calc(var(--wp--custom--main-size) * 3);
   }
}

/* ==========================================================================
CUSTOM
========================================================================== */

.row-icon {
   align-items: flex-start;
   figure {
      flex: 0 0 14px;
      line-height: 1;
   }
}

@media (min-width: 992px) {
   .row-fh .row,
   .section-fh {
      min-height: calc(100vh - 92px);
   }
   .row-contact {
      position: relative;
      .row-icon {
         br {
            display: none;
         }
      }
      &:after {
         content: '';
         position: absolute;
         top: 0;
         left: 50%;
         width: 1px;
         height: 100%;
         background-color: currentColor;
      }
   }
}

.page-id-10 {
   .footer-cta-line,
   .footer-cta {
      display: none;
   }
}

.owl-capabilities {
   .owl-carousel {
      position: relative;
      &.owl-theme {
         & .owl-nav {
            position: absolute;
            right: 0;
            bottom: 0;
            margin-block-start: 0;
            gap: 0;
         }
      }
   }
}

.our-standards-logo {
   display: flex;
   flex-wrap: wrap;
   justify-content: center;
   figure.aligncenter {
      padding: calc(var(--wp--custom--main-size) * .5);
      flex: 0 0 calc(100% / 3);
      margin: 0 !important;
   }
   img {
      aspect-ratio: 16/9;
      object-fit: contain;
      max-width: none;
      width: 100%;
   }
   @media (min-width: 768px) {
      figure.aligncenter {
         padding: var(--wp--custom--main-size);
         flex: 0 0 calc(100% / 5);
      }
   }
}

.wrap-fw {
   padding: calc(var(--wp--custom--main-size) * .5);
   .fw-owl {
      border: 1px solid currentColor;
      figcaption {
         margin: 0;
         font-family: var(--wp--preset--font-family--heading);
         text-align: center;
         text-transform: uppercase;
         height: 50px;
         align-content: center;
         transform: translateY(calc(var(--wp--custom--main-size) * .5));
         padding: 0 2rem;
         line-height: 1;
         font-size: clamp(0.875rem, 0.8380rem + 0.1852vw, 1rem);
         text-wrap: balance;
      }
      .owl-carousel {
         &.owl-theme {
            figure {
               padding: calc(var(--wp--custom--main-size) * .5);
               img {
                  aspect-ratio: 1/1;
                  object-fit: cover;
               }
            }
            .owl-nav {
               border-top: 1px solid currentColor;
               margin: 0;
               position: absolute;
               bottom: 0;
               width: 100%;
               justify-content: space-between;
               [class*="owl-"] {
                  background-color: transparent;
                  background-image: url(../images/owl-arrow.svg);
                  background-repeat: no-repeat;
                  background-size: 18px auto;
               }
            }
         }
      }
   }
   @media (min-width: 768px) {
      padding: var(--wp--custom--main-size);
      .fw-owl {
         figcaption {
            transform: translateY(var(--wp--custom--main-size));
         }
         .owl-carousel {
            &.owl-theme {
               figure {
                  padding: var(--wp--custom--main-size);
                  img {
                     aspect-ratio: 16/8.5;
                  }
               }
            }
         }
      }
   }
   @media (min-width: 1200px) {
      padding: calc(var(--wp--custom--main-size) * 2);
      .fw-owl {
         figcaption {
            transform: translateY(calc(var(--wp--custom--main-size) * 2));
         }
         .owl-carousel {
            &.owl-theme {
               figure {
                  padding: calc(var(--wp--custom--main-size) * 2);
               }
            }
         }
      }
   }
}


@media (min-width: 992px) {
   .text-approach {
      max-width: 480px;
      margin-inline: auto;
   }
   .img-about {
      img {
         object-fit: cover;
         aspect-ratio: 3/4;
      }
   }
}

.has-primary-background-color {
   :where(.wp-element-button, .wp-block-button__link) {
      color: var(--wp--preset--color--primary);
      background-color: #FFF;
      border-color: #FFF;
      &:hover {
         background: var(--wp--preset--color--primary);
         color: #FFF;
      }
   }
}

.hero-100-fh {
   min-height: calc(100vh - 80px);
   &.hero-curve-bottom {
      clip-path: polygon(100% 0%, 0% 0%, 0% 90%, 2% 90.01%, 4% 90.03%, 6% 90.06%, 8% 90.1%, 10% 90.15%, 13.33% 90.28%, 16.67% 90.45%, 20% 90.68%, 23.33% 90.96%, 26.67% 91.29%, 30% 91.67%, 33.33% 92.08%, 36.67% 92.53%, 40% 93.01%, 43.33% 93.51%, 46.67% 94.04%, 50% 94.59%, 53.33% 95.16%, 56.67% 95.74%, 60% 96.33%, 63.33% 96.9%, 66.67% 97.46%, 70% 97.99%, 73.33% 98.49%, 76.67% 98.94%, 80% 99.32%, 83.33% 99.61%, 86.67% 99.83%, 90% 99.94%, 94% 100%, 97% 100%, 100% 100%)
   }
   &.hero-curved {
      clip-path: polygon(100% 1%, 98% 1.01%, 96% 1.03%, 94% 1.06%, 92% 1.1%, 90% 1.15%, 86.67% 1.28%, 83.33% 1.45%, 80% 1.68%, 76.67% 1.96%, 73.33% 2.29%, 70% 2.67%, 66.67% 3.08%, 63.33% 3.53%, 60% 4.01%, 56.67% 4.51%, 53.33% 5.04%, 50% 5.59%, 46.67% 6.16%, 43.33% 6.74%, 40% 7.33%, 36.67% 7.9%, 33.33% 8.46%, 30% 8.99%, 26.67% 9.49%, 23.33% 9.94%, 20% 10.32%, 16.67% 10.61%, 13.33% 10.83%, 10% 10.94%, 6% 10.96%, 3% 10.98%, 0% 10.9%, 0% 99%, 0% 100%, 3% 99.98%, 6% 99.96%, 10% 99.94%, 13.33% 99.83%, 16.67% 99.61%, 20% 99.32%, 23.33% 98.94%, 26.67% 98.49%, 30% 97.99%, 33.33% 97.46%, 36.67% 96.9%, 40% 96.33%, 43.33% 95.74%, 46.67% 95.16%, 50% 94.59%, 53.33% 94.04%, 56.67% 93.51%, 60% 93.01%, 63.33% 92.53%, 66.67% 92.08%, 70% 91.67%, 73.33% 91.29%, 76.67% 90.96%, 80% 90.68%, 83.33% 90.45%, 86.67% 90.28%, 90% 90.15%, 92% 90.1%, 94% 90.06%, 96% 90.03%, 98% 90.01%, 100% 90%)
   }
   @media (max-width: 767px) {
      &.hero-curve-bottom {
         padding-block-end: calc(var(--wp--custom--main-size) * 4) !important;
      }
   }
   @media (min-width: 992px) {
      min-height: calc(100vh - 92px);
   }

}

.list-projects {
   display: grid;
   gap: 0;
   grid-template-columns: minmax(0, 1fr);
   article {
      padding: var(--wp--custom--main-size);
      padding-block-end: calc(var(--wp--custom--main-size) *.5);
      border-bottom: 1px solid currentColor;
      transition: background .5s ease-out;
      a {
         display: block;
         text-decoration: none;
         color: currentColor;
         transition: color .5s ease-out;
      }
      img {
         aspect-ratio: 1/1;
         object-fit: cover;
      }
      h3 {
         font-size: 1rem;
         margin-block-start: calc(var(--wp--custom--main-size) * .5);
      }
   }
   @media (min-width: 768px) {
      grid-template-columns: repeat(2, minmax(0, 1fr));
   }
   @media (min-width: 768px) and (max-width: 991px) {
      article {
         border-right: 1px solid currentColor;
         &:nth-child(2n + 2) {
            border-right: none;
         }
      }
   }
   @media (min-width: 992px) {
      grid-template-columns: repeat(3, minmax(0, 1fr));
      article {
         border-right: 1px solid currentColor;
         &:nth-child(3n + 2) {
            border-right: 1px solid currentColor;
         }
         &:nth-child(3n + 3) {
            border-right: none;
         }
      }
   }
   @media (min-width: 1200px) {
      article {
         &:hover {
            background-color: var(--wp--preset--color--primary);
            color: #FFF;
         }
      }
   }
}

.section-capabilities {
   scroll-margin-block-start: 80px;
   @media (min-width: 992px) {
      scroll-margin-block-start: 92px;
   }
}

.review-list {
   .review {
      font-size: 14px;
      .text-review {
         position: relative;
         padding-inline: var(--wp--custom--main-size);
         margin-block-end: calc(var(--wp--custom--main-size) * 2);
         &:after,
         &:before {
            content: '';
            position: absolute;
            width: 14px;
            height: 10px;
            background-image: url(../images/quote.svg);
         }
         &:before {
            top: 0;
            left: 0;
         }
         &:after {
            bottom: 0;
            right: 0;
            rotate: 180deg;
         }
      }
      h3 {
         font-size: 18px;
         letter-spacing: 0;
      }
   }
   .review-list-desktop {
      .review {
         padding: var(--wp--custom--main-size) 0;
         border-bottom: 1px solid currentColor;
      }
      @media (min-width: 768px) {
         display: grid;
         grid-template-columns: repeat(2, minmax(0, 1fr));
         .review {
            padding: calc(var(--wp--custom--main-size) * 1.5);
            &:nth-child(1),
            &:nth-child(2) {
               border-bottom: 1px solid currentColor;
            }
            &:nth-child(1),
            &:nth-child(3) {
               border-right: 1px solid currentColor;
            }
         }
      }
      @media (min-width: 1200px) {
         .review {
            padding: calc(var(--wp--custom--main-size) * 2);
         }
      }
   }
   .review-list-mobile {
      .review {
         padding-block: calc(var(--wp--custom--main-size) * 1.5);
         &:not(:last-child) {
            border-bottom: 1px solid currentColor;
         }
      }
      @media (min-width: 992px) {
         display: grid;
         grid-template-columns: repeat(2, minmax(0, 1fr));
         .review {
            padding: calc(var(--wp--custom--main-size) * 1.5);
            &:first-child {
               border-right: 1px solid currentColor;
            }
            &:not(:last-child) {
               border-bottom: none;
            }
         }
      }
   }
}

.owl-reviews.owl-theme {
   .owl-stage {
      display: block;
   }
   .owl-nav {
      justify-content: flex-end;
      [class*="owl-"] {
         background-color: transparent;
         background-image: url(../images/owl-arrow.svg);
         background-repeat: no-repeat;
         background-size: 18px auto;
         &:hover {
            opacity: .7;
            background-color: transparent;
         }
      }
   }
}

.row-bordered-home {
   .wp-block-jupa-bootstrap-row-column:nth-child(1) {
      border-bottom: 1px solid currentColor;
   }
   @media (min-width: 768px) {
      .wp-block-jupa-bootstrap-row-column:nth-child(1) {
         border-bottom: none;
         border-right: 1px solid currentColor;
      }
   }
}

.row-services-home {
   .wp-block-jupa-bootstrap-row-column:nth-child(1) {
      border-bottom: 1px solid currentColor;
   }
   @media (min-width: 768px) {
      .wp-block-jupa-bootstrap-row-column:nth-child(1) {
         border-bottom: none;
         border-right: 1px solid currentColor;
         .wp-block-group {
            position: sticky;
            top: 92px;
         }
      }
   }
}

.is-style-link-arrow {
   a {
      display: inline-flex;
      text-transform: uppercase;
      align-items: center;
      gap: 6px;
      font-weight: 500;
      font-family: var(--wp--preset--font-family--heading);
      text-decoration: none;
      &::after {
         content: '';
         display: block;
         width: 17px;
         height: 11px;
         background-image: url(../images/arrow-link.svg);
         background-position: 100% 50%;
         transition: width .2s ease-out;
      }
      &:hover {
         &::after {
            width: 25px;
         }
      }
   }
}

.has-white-color {
   .is-style-link-arrow {
      a {
         &::after {
            filter: brightness(0) invert(1);
         }
      }
   }
}

.scroll-down {
   &:after {
      content: '';
      position: absolute;
      bottom: var(--wp--custom--main-size);
      left: calc(50% - 25px);
      width: 50px;
      height: 50px;
      background-image: url(../images/scroll-down.svg);
      background-repeat: no-repeat;
      background-position: center;
      animation: scrollDown 2s linear infinite;
   }
}

@keyframes scrollDown {
   0% {
      transform: translateY(-20px);
   }
   50% {
      transform: translateY(0);
   }
   100% {
      transform: translateY(-20px);
   }
}

.page-id-6,
.page-id-8,
.home {
   main+hr {
      display: none;
   }
}

.list-logos {
   img {
      aspect-ratio: 4/3;
      object-fit: contain;
      object-position: center center;
   }
   &.list-logos-mobile {
      display: grid;
      gap: calc(var(--wp--custom--main-size) * 1.5);
      grid-template-columns: repeat(3, minmax(0, 1fr));
      max-width: 900px;
      margin-inline: auto;
   }
   .js-marquee {
      display: flex;
      gap: calc(var(--wp--custom--main-size) * 4);
      img {
         max-width: 130px;
      }
   }
   @media (min-width: 768px) {
      &.list-logos-mobile {
         grid-template-columns: repeat(6, minmax(0, 1fr));
         gap: calc(var(--wp--custom--main-size) * 2);
      }
   }
}

.js-marquee-wrapper {
   &:after {
      content: '';
      display: block;
      clear: both;
   }
}

.owl-logos.owl-theme {
   .owl-nav {
      [class*="owl-"] {
         background-color: transparent;
         background-image: url(../images/owl-arrow.svg);
         background-repeat: no-repeat;
         background-size: 18px auto;
         &:hover {
            opacity: .7;
            background-color: transparent;
         }
      }
   }
}

.offcanvas-project,
.single-project {
   .btn-close-project {
      --bs-btn-close-color: var(--wp--preset--color--primary);
      display: inline-block;
      color: currentColor;
   }
   .project-images {
      img {
         max-width: none;
         height: calc(55vh);
         object-fit: cover;
         width: 100%;
      }
   }
   @media (min-width: 992px) {
      .row-project {
         height: calc(100vh - 92px);
         position: relative;
         .project-images {
            border-left: 1px solid currentColor;
            position: absolute;
            width: 66.66666667%;
            right: 0;
            top: 0;
            img {
               height: calc(100vh - 92px);
            }
         }
      }
   }
}

.owl-project {
   &.owl-theme {
      .owl-nav {
         margin: 0;
         position: absolute;
         bottom: 0;
         width: 100%;
         justify-content: space-between;
         [class*="owl-"] {
            background-color: transparent;
            background-image: url(../images/owl-arrow.svg);
            background-repeat: no-repeat;
            background-size: 18px auto;
            &:hover {
               background-color: transparent;
            }
         }
      }
   }
   figure {
      position: relative;
      a {
         display: block;
      }
      figcaption {
         background-color: #FFF;
         padding: calc(var(--wp--custom--main-size) * .5) var(--wp--custom--main-size);
         position: absolute;
         left: 0;
         bottom: 0;
         width: 100%;
         text-align: center;
         text-transform: uppercase;
         font-weight: 500;
         min-height: 48px;
      }
   }
}

.offcanvas-project {
   border-bottom: 1px solid currentColor;
   --offset-top: 80px;
   background-color: #FFF;
   position: fixed;
   width: 100%;
   height: 100%;
   top: 0;
   left: 0;
   overflow-y: auto;
   z-index: 99;
   transition: all .7s cubic-bezier(.7, 0, .3, 1);
   transform: translateY(-105%);
   padding-top: var(--offset-top);
   &.hide-space-content {
      .hr-content,
      #project-content {
         display: none !important;
      }
   }
   @media (min-width: 992px) {
      --offset-top: 92px;
   }

}

body.show-project-offcanvas {
   .offcanvas-project {
      transform: translateY(0);
   }
}