/*
    
    1 - FONTS
    2 - GENERAL HTML SETTINGS
    3 - COMMON STUCTURES
    4 - INDIVIDUAL PAGES

*/

/* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
                            1 - FONTS
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ */
@font-face {
    font-family: Alejandro;
    src: url('../fonts/Alejandro.otf');
}

@font-face {
    font-family: Montserrat-Regular;
    src: url('../fonts/Montserrat-Regular.ttf');
}

@font-face {
    font-family: Montserrat-Bold;
    src: url('../fonts/Montserrat-Bold.ttf');
}

@font-face {
    font-family: Gotham-Regular;
    src: url('../fonts/Gotham-Book.otf');
}

@font-face {
    font-family: Gotham-Medium;
    src: url('../fonts/Gotham-Medium.otf');
}

@font-face {
    font-family: Gotham-Bold;
    src: url('../fonts/Gotham-Bold.otf');
}

@font-face {
    font-family: SpaceGrotesk;
    src: url('../fonts/SpaceGrotesk.ttf');
}



/* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
                    2 - GENERAL HTML SETTINGS
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ */
*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    overflow-x: hidden;
    overflow-y: auto;
}

html.stop_scroll,
html.menu_open {
    overflow: hidden;
}

:root {
    font-size: 15px;
    --main-color: #23346a;
    --light-blue: #104396;
    --main-cream: #f6f4ef;
    --gotham: 'Gotham-Regular', sans-serif;
    --gotham-medium: 'Gotham-Medium', sans-serif;
    --gotham-bold: 'Gotham-Bold', sans-serif;
    --montserrat: 'Montserrat-Regular', var(--gotham);
    --montserrat-bold: 'Montserrat-Bold', var(--gotham-bold);
    --space: 'SpaceGrotesk', monospace;
    --max-body-width: 1300px;
    --side-padding: calc((100vw - var(--max-body-width)) / 2);
    --md-mg: 65px;
}

body {
    margin: 0;
    font-family: var(--gotham);
    width: 100vw;
    line-height: 1.3;
    overflow: hidden;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

::selection {
    color: #fff;
    background-color: var(--light-blue);
}

h1 {
    font-family: "Manier-Bold", serif;
    font-size: 3rem;
    letter-spacing: 0.1em;
    position: relative;
}

h2,
.title__default {
    font-family: var(--space);
    font-size: 2.6rem;
    font-weight: 400;
    letter-spacing: 0.01em;
    text-transform: none;
    color: var(--light-blue);
    position: relative;
}

h3 {
    font-family: "Manier-Medium", serif;
    font-size: 1.45rem;
    letter-spacing: 0.1em;
    position: relative;
}

h4 {
    font-family: "Manier-Bold", serif;
    font-size: 3rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

h5 {
    font-family: "Manier-Bold", serif;
    font-size: 2rem;
    letter-spacing: 0.1em;
    margin-bottom: 0.65rem;
}

a {
    position: relative;
    color: var(--main-color);
}

a:hover {
    color: var(--main-color);
    text-decoration: none;
}

b,
strong {
    font-family: var(--gotham-bold);
    font-weight: unset;
}

button {
    border: none;
    background-color: transparent;
    padding: 0;
}

button:focus,
input:focus,
textarea:focus {
    outline: none;
}

p:last-child {
    margin-bottom: 0 !important;
}


/* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
                        3 - COMMON STUCTURES
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ */
/* ----- Custom classes ----- */
a.underline-anim,
.underline-anim a:not(.button, .wp-element-button, .wp-block-button__link) {
    --underline-height: 0.1em;
    --main-color: var(--main-color);
    color: var(--main-color);
    display: inline !important;
    background-image: linear-gradient(var(--main-color), var(--main-color));
    background-repeat: no-repeat;
    background-position: bottom right;
    background-size: 0% var(--underline-height);
    padding-bottom: 3px;
}

a.underline-anim:hover,
.underline-anim a:not(.button, .wp-element-button, .wp-block-button__link):hover {
    color: var(--main-color);
    background-size: 100% var(--underline-height);
    background-position: bottom left;
}

a.underline-anim,
.underline-anim a:not(.button, .wp-element-button, .wp-block-button__link),
a.underline-anim:hover,
.underline-anim a:not(.button, .wp-element-button, .wp-block-button__link):hover {
    transition: background-size 0.4s, color 0.4s, background-image 0.4s ease;
    -webkit-transition: background-size 0.4s, color 0.4s, background-image 0.4s ease;
    -moz-transition: background-size 0.4s, color 0.4s, background-image 0.4s ease;
    -o-transition: background-size 0.4s, color 0.4s, background-image 0.4s ease;
}

.mobile-only {
    display: none;
}

.full-width {
    width: 100%;
}

.full_page {
    width: calc(100% + var(--side-padding) * 2);
    margin-left: calc(var(--side-padding) * -1);
}

.img_wrapper {
    margin-bottom: 0;
}

.img_wrapper img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.ratioed_img {
    position: relative;
}

.ratioed_img:before {
    content: '';
    display: block;
}

.ratioed_img img {
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    object-fit: cover;
    position: absolute;
}

.clearfix {
    display: block;
    width: 100%;
    height: 1px;
}

.side_padding {
    padding-left: var(--side-padding);
    padding-right: var(--side-padding);
}

/* Regular buttons */
.button,
.wp-element-button {
    font-family: var(--space);
    font-size: 14px;
    line-height: 1.3;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color: #000;
    border-radius: 5px;
    background-color: var(--main-cream);
    padding: 0.55em 1em 0.4em;
    display: block;
    width: max-content;
    position: relative;
    overflow: hidden;
    z-index: 1;
}

.button:before,
.wp-element-button:before {
    content: '';
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    position: absolute;
    background-color: var(--light-blue);
    transform-origin: bottom;
    transform: scaleY(0);
    z-index: -1;
}

.button.no_bg_hover {
    border: 2px solid var(--main-cream);
}

.button.no_bg_hover:before {
    display: none;
}

.button.no_bg_hover:hover {
    background-color: transparent;
}

.button:hover,
.wp-element-button:hover,
.hoverable_zone:hover .button,
.hoverable_zone:hover .wp-element-button {
    color: var(--main-cream) !important;
}

.button:hover:before,
.wp-element-button:hover:before,
.hoverable_zone:hover .button:before,
.hoverable_zone:hover .wp-element-button:before {
    transform: scaleY(1);
}

.button,
.wp-element-button,
.button:hover,
.wp-element-button:hover {
    transition: color 0.4s, background-color .4s ease;
}

/* Close button */
.close_bttn {
    --diameter: 30px;
    width: var(--diameter);
    height: var(--diameter);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    position: relative;
    background-color: transparent;
    border-radius: 100%;
}

.close_bttn,
.close_bttn:hover {
    transition: transform .4s ease;
}

.close_bttn:hover {
    transform: rotate(90deg);
}

.close_bttn span {
    width: 100%;
    display: block;
    border-bottom: 3px solid var(--light-blue);
    position: absolute;
}

.close_bttn span:nth-of-type(1) {
    transform: rotate(45deg);
}

.close_bttn span:nth-of-type(2) {
    transform: rotate(-45deg);
}


/* ----- Transitions ----- */
/* transform */
*:before,
*:hover:before,
*:focus:before,
*:after,
*:hover:after,
*:focus:after {
    transition: transform 0.4s ease-in-out;
    -webkit-transition: transform 0.4s ease-in-out;
    -moz-transition: transform 0.4s ease-in-out;
    -o-transition: transform 0.4s ease-in-out;
}

/* all */
.anim-all,
.anim-all:hover,
.anim-all:focus,
input,
input:hover,
input:focus,
textarea,
textarea:hover,
textarea:focus {
    transition-property: color, background-color, background-size, transform, width, clip-path, opacity, top, left, right, background-size, background-image;
    transition-duration: 0.4s;
    transition-timing-function: ease;
}

/* Parallaxes */
.parallax-anim {
    transition: all 0.5s ease-out;
    -webkit-transition: all 0.5s ease-out;
    -moz-transition: all 0.5s ease-out;
    -o-transition: all 0.5s ease-out;
}


/* ******************************************
                    NAVBAR
******************************************* */
.navbar {
    width: 100vw;
    top: 0;
    left: 0;
    padding-top: 75px;
    padding-inline: var(--side-padding);
    position: absolute;
    align-items: flex-start;
    z-index: 10;
}

.custom-logo-link {
    width: 100%;
    display: block;
}

.custom-logo-link img {
    width: 100%;
    height: auto;
}

.navbar .custom-logo-link {
    max-width: 250px;
}

.navbar__quote_bttn {
    font-family: var(--space);
    font-size: 13px;
    letter-spacing: 0.025em;
    text-transform: uppercase;
    border-radius: 5px;
    border: 1px solid var(--main-cream);
    background-color: var(--main-cream);
    margin-left: auto;
    margin-right: 57px;
    padding: 8px 10px;
    display: block;
    color: #000 !important;
}

.navbar__quote_bttn,
.navbar__quote_bttn:hover {
    transition: background-color .3s, color .3s ease;
}

@media (hover:hover) {
    .navbar__quote_bttn:hover {
        background-color: transparent;
        color: var(--main-cream) !important;
    }
}

.menu_toggle {
    width: 65px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    position: relative;
}

.menu_toggle:after {
    content: 'Menu';
    font-family: var(--space);
    font-size: 13px;
    letter-spacing: 0.05em;
    color: var(--main-cream);
    position: absolute;
    top: calc(100% + 5px);
    left: 0;
}

.menu_toggle span {
    width: 100%;
    display: block;
    border-bottom: 5px solid var(--main-cream);
    transition: max-width 0.3s ease;
}

.menu_toggle span:nth-child(1) {
    max-width: 75%;
    margin-right: auto;
    margin-bottom: 6px;
}

@media (hover:hover) {
    .menu_toggle:hover span {
        max-width: 100%;
    }
}


/* ******************************************
                    MENU
******************************************* */
.menu {
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 999;
    position: fixed;
    overflow: clip auto;
    --cut-height: 135px;
    --bttm-pad: 55px;
}

.menu_container {
    width: 100%;
    min-height: 100%;
    position: relative;
    overflow: hidden;
}

.menu__bg,
.menu__bg__part {
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    position: absolute;
}

.menu__bg,
.menu__bg__back {
    z-index: 0;
}

.menu__bg__part {
    transition: transform .65s ease;
}

.menu__bg__back {
    background-color: var(--main-cream);
    transform: scaleY(0);
    transform-origin: bottom;
    will-change: transform;
}

.menu__bg__main {
    height: calc(100% - var(--cut-height) - var(--bttm-pad));
    background-color: var(--main-color);
    transform: translateY(calc(-100% - var(--cut-height)));
    z-index: 1;
}

.menu__bg__main:after {
    content: '';
    height: var(--cut-height);
    top: 100%;
    left: 0;
    right: 0;
    position: absolute;
    background-color: var(--main-color);
    mask-image: url(../img/cut-menu.svg);
    mask-position: center top;
    mask-size: cover;
    mask-repeat: no-repeat;
    -webkit-mask-image: url(../img/cut-menu.svg);
    -webkit-mask-position: center top;
    -webkit-mask-size: cover;
    -webkit-mask-repeat: no-repeat;
}

.menu__content {
    width: 100%;
    position: relative;
    z-index: 1;
}

.menu .close_bttn {
    --diameter: 46px;
    position: absolute;
    right: var(--side-padding);
    top: 70px;
    opacity: 0;
}

.menu .close_bttn span {
    border-bottom: 4px solid var(--main-cream);
}

.menu__content__container {
    width: 100%;
    display: flex;
    align-items: flex-start;
    padding-top: 175px;
    padding-inline: var(--side-padding);
    /* padding-bottom: calc(20px + var(--cut-height) + var(--bttm-pad));*/
    padding-bottom: var(--cut-height);
}

.menu__logo {
    width: 50%;
    max-width: 370px;
    margin-left: 15px;
}

.menu__pages__container {
    width: 50%;
    margin-left: auto;
    padding-left: 3rem;
    position: relative;
}

.menu__ornament {
    width: 160px;
    top: calc(100% + 18px);
    left: -30px;
    position: absolute;
    display: block;
    opacity: 0;
    transform: translateX(-25%);
    transition: opacity .65s, transform .65s ease;
}

.menu__pages {
    padding: 0;
    margin: -7px 0 0 0;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.menu__pages li {
    font-family: var(--space);
    font-size: 2.2rem;
    font-weight: 300;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 0.3em;
    list-style-type: none;
}

.menu__pages li a {
    color: var(--main-cream);
    position: relative;
}

.menu__pages li a:after {
    content: '';
    left: 0;
    right: 0;
    bottom: -2px;
    border-bottom: 2px solid var(--main-cream);
    position: absolute;
    transform-origin: right;
    transform: scaleX(0);
}

@media (hover: hover) {
    .menu__pages li a:hover:after {
        transform: scaleX(1);
        transform-origin: left;
    }
}

.menu__pages li.current-menu-item a:after {
    transform: scaleX(1);
    transform-origin: left;
}

/* Lang changer */
.lang_changer {
    left: calc(var(--side-padding) + 130px);
    bottom: calc(32px + var(--bttm-pad));
    position: absolute;
    z-index: 2;
}

.lang_changer:before {
    content: '';
    width: 96px;
    border-bottom: 2px solid var(--light-blue);
    right: calc(100% + 35px);
    top: 50%;
    position: absolute;
    transform: scaleX(0);
    transform-origin: left;
}

.lang_changer ul {
    display: flex;
    flex-direction: row;
    align-items: center;
    margin: 0;
    padding: 0;
}

.lang_changer ul li {
    font-family: var(--space);
    font-size: 17px;
    line-height: 1;
    text-transform: uppercase;
    margin: 0 4px;
    padding: 0;
    list-style-type: none;
    opacity: 0;
    transition: opacity .65s ease;
}

.lang_changer ul li a {
    color: var(--main-color);
    border: 1px solid var(--light-blue);
    border-radius: 5px;
    padding: 3px 12px;
    display: block;
}

.lang_changer ul li.current_lang a {
    color: var(--main-cream);
    background-color: var(--light-blue);
    pointer-events: none;
}

.lang_changer ul li a,
.lang_changer ul li a:hover {
    transition: background-color .4s, color .4s ease;
}

@media (hover:hover) {
    .lang_changer ul li a:hover {
        color: var(--main-cream);
        background-color: var(--light-blue);
    }
}

/* Menu open */
.menu:not(.menu_open) {
    visibility: hidden;
    pointer-events: none;
}

.menu.menu_open:not(.menu_closing) .close_bttn {
    opacity: 1;
    transition-delay: .2s;
}

.menu.menu_open:not(.menu_closing) .menu__bg__main {
    transform: translateY(0);
}

.menu.menu_open:not(.menu_closing) .menu__bg__back {
    transform: scaleY(1);
}

.menu.menu_open:not(.menu_closing) .menu__ornament {
    opacity: 1;
    transform: translateX(0);
    transition-delay: .65s;
}

.menu.menu_open:not(.menu_closing) .lang_changer:before {
    transform: scaleX(1);
}

.menu.menu_open:not(.menu_closing) .lang_changer ul li {
    opacity: 1;
    transition-delay: calc(var(--index) * 0.15s + 0.3s);
}


/* ******************************************
                    FOOTER
******************************************* */
footer {
    padding: 7rem calc(var(--side-padding) + var(--md-mg));
    background-color: var(--main-color);
    position: relative;
}

footer,
footer a {
    color: #fff !important;
}

footer .underline-anim a:not(.button, .wp-element-button, .wp-block-button__link) {
    --main-color: var(--main-cream) !important;
}

.footer_cols {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-end;
}

.footer_col {
    z-index: 1;
}

.footer_slogan {
    font-family: var(--space);
    font-size: 4.2rem;
    font-weight: 400;
    line-height: 1.1;
    letter-spacing: 0.02em;
    max-width: 6em;
    position: relative;
    margin-bottom: -0.2em;
}

.footer_slogan .radial_svg {
    width: 1.95em;
    left: calc(100% - 0.85em);
    bottom: calc(100% - 0.9em);
    position: absolute;
    transform: rotate(90deg);
    animation: unset !important;
}

#footer-col-2 {
    display: flex;
    flex-direction: row;
    align-items: flex-end;
    gap: 0 65px;
}

.footer_sm_text {
    width: 18rem;
    font-size: 0.95rem;
    letter-spacing: 0.07em;
}

.footer_sm_text p:not(:last-child) {
    margin-bottom: 0.45em !important;
}

.footer__newsletter {
    margin-bottom: 3rem;
}

.footer__newsletter h2 {
    font-family: var(--space);
    font-size: 2.25rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--main-cream);
    margin-bottom: 12px;
}

.footer__newsletter .button {
    padding-inline: 1.7em;
}

.footer__decor {
    height: 240px;
    right: calc(var(--md-mg) * -1);
    bottom: 0;
    position: absolute;
    z-index: 0;
}

@media (min-width: 1199px) {
    footer.no_newsletter {
        padding-top: 11rem;
    }
}

footer.no_newsletter .footer__decor {
    height: 180px;
    right: 8%;
}

/* Social media */
.social_media {
    display: flex;
    flex-direction: row;
    gap: 7px;
}

.media-link {
    --diameter: 2em;
    width: var(--diameter);
    height: var(--diameter);
    font-size: 25px;
    color: var(--main-cream);
    padding-top: 1px;
    border-radius: 50%;
    border: 2px solid var(--main-cream);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.media-link:hover,
.media-link:focus {
    color: var(--main-color) !important;
    background-color: var(--main-cream);
}

a.design {
    font-size: 11px;
    letter-spacing: 0.01em;
    position: absolute;
    left: 0;
    top: calc(100% + 1rem);
}

a.design:before,
a.design:after {
    content: '';
    position: absolute;
    border-bottom: 1px solid #fff;
    left: 0;
}

a.design:before {
    width: 15px;
    top: -8px;
}

a.design:after {
    right: 0;
    bottom: -1px;
    transform-origin: right;
    transform: scaleX(0);
}

a.design:hover:after {
    transform-origin: left;
    transform: scaleX(1);
}


/* ******************************************
                    INPUTS
******************************************* */
input,
textarea {
    color: #000;
    border: none;
    background-color: transparent;
}

input:hover::placeholder,
textarea:hover::placeholder,
input:focus::placeholder,
textarea:focus::placeholder {
    color: #5e5e5e;
}

input::placeholder,
input:hover::placeholder,
input:focus::placeholder {
    transition: color .3s ease;
}

input:not([type="submit"], [type="checkbox"]),
textarea {
    width: 100%;
    font-family: var(--gotham);
    font-size: 1.25rem;
    letter-spacing: 0.1em;
    border-bottom: 1px solid #000;
    padding: 1rem 8px;
}

input:not([type="submit"], [type="checkbox"])[readonly="readonly"],
textarea[readonly="readonly"] {
    color: #979487;
    cursor: auto;
}

textarea {
    height: 8rem;
    padding-top: 1.5rem !important;
}

.wpcf7-spinner {
    position: absolute;
}

::placeholder {
    color: #000;
}

/* Acceptance CF7 */
.wpcf7-acceptance {
    font-size: 0.9rem;
    letter-spacing: 0.3px;
    padding-left: 10px;
    margin-top: 1.25em;
    display: block;
    position: absolute;
    right: 0;
    margin-top: 1rem;
}

.wpcf7-acceptance input {
    display: none;
}

.wpcf7-acceptance .wpcf7-list-item {
    margin: 0;
}

.wpcf7-acceptance a {
    --main-color: #000;
}

.wpcf7-acceptance .wpcf7-list-item-label:before {
    content: 'X';
    width: 17px;
    height: 17px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    padding-top: 1px;
    color: transparent;
    margin-right: 9px;
    border: 1px solid #000;
    cursor: pointer;
}

.wpcf7-acceptance input:checked+.wpcf7-list-item-label:before {
    color: #000;
}

/* Contact Form 7 - CF7 */
form.wpcf7-form br {
    display: none;
}

form.wpcf7-form .wpcf7-form-control-wrap {
    display: block;
}

.wpcf7-not-valid-tip {
    font-size: 12px;
    letter-spacing: 0;
    padding: 0 8px;
    margin-top: 6px;
}

.wpcf7 form .wpcf7-response-output {
    border: none;
    text-align: left;
    padding: 0;
    font-family: var(--gotham-bold);
    font-size: 0.9rem;
    line-height: 1.2rem;
    margin: 2rem 0 0 0;
}

.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output {
    color: #d81717;
}

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
    color: #e6a803;
}

.wpcf7 form.sent .wpcf7-response-output {
    color: #46b450;
}


/* ******************************************
                    POPUPS
******************************************* */
.popup_modal {
    width: 100%;
    height: fit-content;
    max-width: 750px;
    max-height: calc(100vh - 100px);
    overflow: hidden auto;
    top: 50%;
    left: 0;
    right: 0;
    margin: 0 auto;
    display: block;
    padding: 3rem 30px 30px;
    transform: translateY(-50%);
    background-color: #fff;
    position: fixed;
    clip-path: polygon(0 0, 100% 0, 100% 0, 0 0);
    z-index: 999;
}

.popup_modal .close-pop-up {
    position: absolute;
    top: 1.5rem;
    right: 2rem;
}

.popup_modal .close-pop-up:hover {
    transform: scale(1.3);
}

.popup_modal::-webkit-scrollbar {
    width: 8px;
}

.popup_modal::-webkit-scrollbar-track {
    background: transparent;
    margin: 0;
}

.popup_modal::-webkit-scrollbar-thumb {
    background: rgba(44, 44, 42, 0.3);
}

.popup_modal::-webkit-scrollbar-thumb:hover {
    background: rgba(44, 44, 42, 0.5);
}

.popup_modal::-webkit-scrollbar-thumb:active {
    background: rgba(44, 44, 42, 0.7);
}

.popup_modal.popup_active:not(.closing) {
    -webkit-animation: openPopup .4s cubic-bezier(.33, 1, .68, 1) forwards;
    animation: openPopup .4s cubic-bezier(.33, 1, .68, 1) forwards;
}

.popup_modal.closing {
    -webkit-animation: closePopup .2s cubic-bezier(.33, 1, .68, 1);
    animation: closePopup .2s cubic-bezier(.33, 1, .68, 1);
}

@keyframes openPopup {
    from {
        clip-path: polygon(0 0, 100% 0, 100% 0, 0 0);
    }

    to {
        clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
    }
}

@keyframes closePopup {
    from {
        clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
    }

    to {
        clip-path: polygon(0 0, 100% 0, 100% 0, 0 0);
    }
}


/* Background overlay */
.bg_overlay,
[data-ajax-bg] {
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.4);
    display: none;
    position: fixed;
    touch-action: none;
    z-index: 998;
}

[data-ajax-bg] .ajax_bg {
    pointer-events: none;
}

.bg_overlay.popup_active,
[data-ajax-bg].ajax_active {
    display: block;
    -webkit-animation: animFade .4s cubic-bezier(.33, 1, .68, 1);
    animation: animFade .4s cubic-bezier(.33, 1, .68, 1);
}

.bg_overlay.closing {
    opacity: 0;
    -webkit-animation: animFadeOut .4s cubic-bezier(.33, 1, .68, 1);
    animation: animFadeOut .4s cubic-bezier(.33, 1, .68, 1);
}

@keyframes animFade {
    from {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

@keyframes animFadeOut {
    from {
        opacity: 1
    }

    to {
        opacity: 0
    }
}

/* ====== Ajax popup  ============== */
/* Posts container */
[data-ajax-container] .lds-ring {
    top: 0;
}

[data-ajax-container].loading [data-ajax-content] {
    opacity: 0;
    pointer-events: none;
}

/* Popup */
[data-ajax-bg] {
    padding: 50px 0;
    overflow: auto;
    touch-action: pan-y;
}

[data-ajax-bg] .lds-ring div {
    border: 4px solid #fff;
    border-color: #fff transparent transparent transparent;
}

[data-ajax-modal] {
    display: none;
    margin: 0 auto;
    max-width: calc(100% - var(--side-padding) * 2);
    background-color: var(--main-cream);
    position: relative;
    z-index: 2;
}

[data-ajax-modal] button[data-close] {
    --diameter: 25px;
    width: var(--diameter);
    height: var(--diameter);
    display: block;
    position: absolute;
    top: calc(3.5rem - var(--diameter) / 2);
    right: 50px;
    z-index: 2;
}

[data-ajax-modal] button[data-close]:hover {
    transform: scale(1.2);
}

[data-ajax-modal] .popup_content {
    max-width: 830px;
    margin: 0 auto;
    padding-top: 3.5rem;
    padding-bottom: 12rem;
    position: relative;
}

[data-ajax-modal] [data-ajax-close] {
    margin-left: auto;
    margin-bottom: 4rem;
}

[data-ajax-modal] .modal_header,
[data-ajax-modal] .wp_content {
    --side-padding: 50px;
    padding-left: var(--side-padding);
    padding-right: var(--side-padding);
}

[data-ajax-modal] .modal_header {
    padding-bottom: 2rem;
}

[data-ajax-modal] figure.img_wrapper img {
    object-fit: cover;
}

[data-ajax-modal] .wp_content {
    padding-top: 3rem;
}

/* ====== Loading spinner  ============== */
.lds-ring {
    display: inline-block;
    position: absolute;
    width: 50px;
    height: 50px;
    top: calc(50% - 26px);
    left: calc(50% - 26px);
    opacity: 0;
    pointer-events: none;
}

.lds-ring div {
    box-sizing: border-box;
    display: block;
    position: absolute;
    width: 45px;
    height: 45px;
    margin: 5px;
    border: 4px solid #000;
    border-radius: 50%;
    animation: lds-ring 1.2s cubic-bezier(0.5, 0, 0.5, 1) infinite;
    border-color: #000 transparent transparent transparent;
}

.lds-ring div:nth-child(1) {
    animation-delay: -0.45s;
}

.lds-ring div:nth-child(2) {
    animation-delay: -0.3s;
}

.lds-ring div:nth-child(3) {
    animation-delay: -0.15s;
}

@keyframes lds-ring {
    0% {
        transform: rotate(0deg);
    }

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

.loading>.lds-ring {
    opacity: 1;
}


/* ******************************************
                CREAM CONTAINER
******************************************* */
.cut_container {
    --cut-height: 110px;
    --mg-top: 5rem;
    width: calc(100% + var(--side-padding) * 2);
    margin-left: calc(var(--side-padding) * -1);
    padding-inline: var(--side-padding);
    margin-top: calc(var(--cut-height) + var(--mg-top, 0));
    position: relative;
}

.cut_container:before {
    content: '';
    width: 100%;
    height: var(--cut-height);
    left: 0;
    bottom: 100%;
    position: absolute;
    display: block;
    mask-position: center bottom;
    mask-size: cover;
    mask-repeat: no-repeat;
    -webkit-mask-position: center bottom;
    -webkit-mask-size: cover;
    -webkit-mask-repeat: no-repeat;
}

.cut_container.cream_container,
.cut_container.cream_container:before {
    background-color: var(--main-cream);
}


/* ******************************************
                SLIDERS
******************************************* */
.slider {
    overflow: hidden;
    touch-action: pan-y;
}

.swiper-wrapper {
    display: flex;
    flex-direction: row;
}

.swiper-slide {
    flex-shrink: 0;
}


/* ******************************************
                COOKIES
******************************************* */
#cmplz-cookiebanner-container .cmplz-cookiebanner {
    max-width: 400px;
    min-width: unset;
    right: 10px;
    bottom: 10px;
    background-color: #fff;
    padding: 1.75rem 1.5rem 1rem;
    box-shadow: 0 0 11px rgb(0 0 0 / 7%);
    z-index: 99999999999;
    transition: margin 0.6s ease, opacity 0.6s ease;
    will-change: margin;
}

#cmplz-cookiebanner-container .cmplz-cookiebanner.cmplz-dismissed {
    margin-bottom: -50px;
    opacity: 0;
    display: grid;
    pointer-events: none;
}

#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-title {
    width: 100%;
    font-family: var(--gotham-bold);
    font-size: 1rem;
    text-transform: uppercase;
    display: block;
    grid-column-start: 1;
    grid-column-end: 3;
}

#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-buttons .cmplz-btn {
    font-size: 10px;
    font-family: var(--gotham-medium);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    line-height: 1.5;
    height: unset !important;
    transition: background-color 0.4s ease;
}

#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-buttons .cmplz-btn:not(.cmplz-accept) {
    background-color: #f2f2f2;
}

#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-buttons .cmplz-btn:not(.cmplz-accept):hover {
    background-color: #e5e5e5;
}

#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-close {
    margin-top: -13px;
    transition: 0.4s ease transform;
}

#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-close:hover {
    font-size: inherit;
    transform: rotate(90deg);
}

#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-close svg path {
    stroke: #fff;
    stroke-width: 60px;
}

#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-categories {
    margin-top: 1rem;
    margin-bottom: 0.5rem;
}

#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-categories .cmplz-category .cmplz-category-header .cmplz-category-title {
    font-family: var(--gotham-bold);
    font-size: 10px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-links.cmplz-information {
    display: none !important;
}

@media (max-width: 576px) {

    /* Cookies */
    #cmplz-cookiebanner-container .cmplz-cookiebanner {
        left: 10px;
        right: 10px;
        margin: 0 auto;
        width: calc(100% - 20px);
    }
}

/* Page button */
#cmplz-manage-consent .cmplz-manage-consent {
    display: none !important;
}


/* Cookies Policy Page */
main #cmplz-document {
    max-width: 100%;
}

#cmplz-document a {
    text-decoration: underline;
}

#cmplz-document h2,
.editor-styles-wrapper .cmplz-unlinked-mode h2,
#cmplz-document h3,
.editor-styles-wrapper .cmplz-unlinked-mode h3 {
    font-size: 1.3rem;
    letter-spacing: 0;
    padding: 0;
    text-transform: uppercase;
    margin-bottom: 0.4rem;
    margin-top: 2rem;
}

#cmplz-document p,
.editor-styles-wrapper .cmplz-unlinked-mode p,
#cmplz-document li,
.editor-styles-wrapper .cmplz-unlinked-mode li,
#cmplz-document td,
.editor-styles-wrapper .cmplz-unlinked-mode td {
    font-size: 1rem;
}

#cmplz-document .cmplz-subtitle,
.editor-styles-wrapper .cmplz-unlinked-mode .cmplz-subtitle {
    font-weight: 100;
    font-family: var(--gotham-medium);
    font-size: 1.1rem;
    margin-top: 0.5rem;
    margin-bottom: 0.25rem;
}

#cmplz-cookies-overview .cmplz-dropdown summary h3,
#cmplz-document .cmplz-dropdown summary h3,
.editor-styles-wrapper .cmplz-unlinked-mode .cmplz-dropdown summary h3 {
    font-family: var(--gotham-medium);
    font-size: 1rem;
}

#cmplz-cookies-overview .cmplz-dropdown h4,
#cmplz-document .cmplz-dropdown h4,
.editor-styles-wrapper .cmplz-unlinked-mode .cmplz-dropdown h4 {
    font-family: var(--gotham-bold);
    letter-spacing: 0;
}

#cmplz-cookies-overview .cmplz-dropdown p,
#cmplz-document .cmplz-dropdown p,
.editor-styles-wrapper .cmplz-unlinked-mode .cmplz-dropdown p,
#cmplz-cookies-overview .cmplz-dropdown h4,
#cmplz-document .cmplz-dropdown h4,
.editor-styles-wrapper .cmplz-unlinked-mode .cmplz-dropdown h4,
#cmplz-cookies-overview .cmplz-dropdown ul,
#cmplz-document .cmplz-dropdown ul,
.editor-styles-wrapper .cmplz-unlinked-mode .cmplz-dropdown ul {
    padding: 0;
}

#cmplz-document h5,
.editor-styles-wrapper .cmplz-unlinked-mode h5 {
    font-family: var(--gotham-medium);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-size: 12px;
}


/* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
                    4 - INDIVIDUAL PAGES
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ */
/* ******************************************
                QUOTE POPUP
******************************************* */
.popup_modal .close_bttn {
    margin-left: auto;
}

.popup_modal h2 {
    font-size: 2.25rem;
    margin-bottom: 0.75em;
}

.popup_modal.cream_form_fields {
    --form-gutter: 10px;
}

.popup_modal.cream_form_fields form .row {
    margin-inline: calc(var(--form-gutter) * -1);
}

.popup_modal.cream_form_fields form .col-6,
.popup_modal.cream_form_fields form .col-12 {
    padding-inline: var(--form-gutter);
}

.popup_modal.cream_form_fields form label {
    padding-left: 0;
    font-size: 1.05rem;
}

.popup_modal.cream_form_fields input:not([type="submit"], [type="checkbox"]),
.popup_modal.cream_form_fields textarea,
.cream_form_fields .wpcf7-checkbox .wpcf7-list-item label {
    letter-spacing: 0.05em;
    font-size: max(0.9rem, 12px);
}

.wpcf7-checkbox .wpcf7-list-item label {
    display: flex;
    flex-direction: row;
    align-items: center;
    line-height: 2;
}

.wpcf7-checkbox .wpcf7-list-item label input[type="checkbox"] {
    width: 18px;
    aspect-ratio: 1 / 1;
    margin-right: 5px;
}

.popup_modal.cream_form_fields .form_line {
    margin-bottom: 2.25rem;
}

.cream_form_fields .wpcf7-checkbox {
    display: block;
}

.cream_form_fields .wpcf7-checkbox .wpcf7-list-item.first {
    margin-left: 0;
}


/* ******************************************
                REGULAR HEADER
******************************************* */
.header_regular {
    height: 570px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
}

.header__title {
    font-size: 5rem;
    font-family: var(--space);
    font-weight: 400;
    letter-spacing: 0.025em;
    color: #fff;
    margin: 0;
    line-height: 1.1;
    margin-top: 1.25em;
    max-width: 11.5em;
}

.header__content {
    position: relative;
    z-index: 5;
}

.header__slogan {
    position: absolute;
    z-index: 2;
    width: 290px;
    right: 15%;
    top: 22.5%;
}

.header__slogan .radial_svg {
    animation: none;
}

.header__plus {
    position: absolute;
    z-index: 2;
    width: 45px;
    left: 5.5%;
    top: 49.5%;
}

.header__line {
    position: absolute;
    z-index: 2;
    width: 120px;
    left: 11%;
    bottom: 40px;
    border: none;
    border-bottom: 1px solid #fff;
    margin: 0;
}

.header__bg__overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 2;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    mix-blend-mode: luminosity;
}

.header__scroll {
    font-family: var(--space);
    color: #fff;
    font-size: 8.5px;
    letter-spacing: 0.1em;
    position: absolute;
    text-transform: uppercase;
    bottom: 0;
    z-index: 2;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.header__scroll .label {
    writing-mode: vertical-lr;
}

.header__scroll .label span {
    transform: rotate(180deg);
    display: block;
}

.header__scroll:after {
    content: '';
    width: 0;
    height: 25px;
    border-right: 1px solid #fff;
    position: relative;
    display: block;
    margin: 17px auto 0;
    animation: bannerHR 2.25s ease-in-out infinite;
}

@keyframes bannerHR {
    0% {
        transform-origin: top;
        transform: scaleY(0);
    }

    49% {
        transform-origin: top;
        transform: scaleY(1);
    }

    50% {
        transform-origin: bottom;
        transform: scaleY(1);
    }

    100% {
        transform-origin: bottom;
        transform: scaleY(0);
    }
}


/* ******************************************
                INTRO
******************************************* */
.page_intro {
    margin-top: 8.5rem;
}

.intro__orns .arrow_icon {
    --height: 31px;
    height: var(--height);
    top: calc(var(--height) / -2);
    left: 5px;
    position: absolute;
}

.intro__line {
    width: 85%;
    margin-left: auto;
    margin-right: -25px;
    display: block;
}

.intro__content {
    padding-left: var(--md-mg);
}

.intro__col__title {
    margin-top: -3.25rem;
}

.is_taller .intro__col__title {
    margin-top: -6rem;
}

.intro__content .title__default {
    max-width: 12em;
}

.intro__col__content {
    font-family: var(--space);
    font-size: 1.95rem;
    line-height: 1.2;
    margin-top: 3rem;
    position: relative;
    left: 1.5%;
}

.intro__content__container {
    max-width: 18em;
    margin: 0 auto;
}


/* ******************************************
                HOMEPAGE
******************************************* */
/* Header */
.header_home {
    width: 100vw;
    height: 100vh;
    min-height: 500px;
    margin-left: calc(var(--side-padding) * -1);
    position: relative;
}

.bg__img__container {
    width: calc(100% + var(--side-padding) * 2);
    height: 100vh;
    min-height: 500px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin-left: calc(var(--side-padding) * -1);
    padding-inline: var(--side-padding);
    position: relative;
    overflow: hidden;
}

.bg__img {
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    position: absolute;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    z-index: 1;
}

.bg__img__container .bg__img:after {
    content: '';
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    position: absolute;
    background-color: #000;
    opacity: 0.38;
}

.bg__img__content {
    text-align: center;
    color: #fff;
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    z-index: 2;
}

.header_home .header__bg__overlay {
    background-color: #000;
    opacity: 0.38;
}

.home_header__ornament {
    position: absolute;
    z-index: 2;
    top: 0;
    bottom: 0;
    height: 100%;
    width: 100%;
    left: 0;
}

.home_header__ornament svg {
    height: 100%;
    display: block;
    margin: 0 auto;
    position: relative;
    left: -4.5%;
}

.header_home .header__line {
    bottom: 19%;
    left: 6%;
}

.home_header__radial {
    position: absolute;
    z-index: 2;
    width: 135px;
    bottom: 10%;
    left: 16.5%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.home_header__radial:after {
    content: '';
    width: 58%;
    aspect-ratio: 1 / 1;
    position: absolute;
    border: 1px solid var(--main-cream);
    border-radius: 100%;
    display: block;
}

.header_home .header__scroll {
    left: -3.5%;
}

.home_header__slogan {
    font-family: var(--space);
    font-size: 5.25rem;
    color: #fff;
    max-width: 6em;
    line-height: 0.9;
    position: absolute;
    z-index: 5;
    top: 47%;
    left: 57.5%;
    transform: translateY(-50%);
}

.header__video {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    z-index: 0;
    object-fit: cover;
    pointer-events: none;
    user-select: none;
}

.header__titled_orn {
    position: absolute;
    z-index: 2;
    width: 160px;
    top: 108%;
}

.header_home .header__titled_orn {
    right: 31%;
}

/* Intro */
.home__intro__content {
    font-size: 1.2rem;
    letter-spacing: 0.05em;
    max-width: 30.5em;
    padding: 5rem 0 0;
}

.home__intro__content h2 {
    margin-bottom: 0.75em;
}

.home__intro__content h3 {
    font-family: var(--space);
    font-size: 2.5rem;
    font-weight: 400;
    letter-spacing: 0.025em;
    text-transform: uppercase;
}

.home__intro__content .wp-block-columns {
    --extra: 250px;
    width: calc(100% + var(--extra));
    margin-top: 3.5rem;
    margin-left: calc(var(--extra) * -0.4);
}

.home__intro__content .wp-block-columns figure {
    height: 125px;
    margin-bottom: 3rem;
}

.home__intro__content .wp-block-columns figure img {
    width: auto;
    height: 100%;
    object-fit: contain;
    object-position: center bottom;
}

.home__intro__content .wp-block-button {
    margin-inline: auto;
}

/* Numbers */
.numbers__container {
    padding: 4rem calc(var(--side-padding) + var(--md-mg)) 5rem;
}

.numbers__container:before {
    mask-image: url(../img/cut-cream.svg);
    -webkit-mask-image: url(../img/cut-cream.svg);
}

.numbers__container .title__orn {
    width: auto;
    height: 68px;
    display: block;
    margin-top: -52px;
    margin-left: -140px;
}

.numbers__container .radial_svg {
    width: 120px;
    right: 18.75%;
    top: -7px;
    position: absolute;
}

.numbers__company {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
    margin-top: 5.5rem;
}

.title__blue_bg {
    font-family: var(--space);
    font-size: 13px;
    font-weight: 300;
    letter-spacing: 0.025em;
    text-transform: uppercase;
    background-color: var(--light-blue);
    color: #fff;
    width: fit-content;
    padding: 8px 15px;
}

.number__block .title__blue_bg {
    margin-bottom: 23px;
}

.number__value {
    font-family: var(--space);
    font-size: 5.5rem;
    line-height: 1;
    letter-spacing: 0.025em;
    color: var(--light-blue);
    border: 5px solid var(--light-blue);
    padding: 5px 0.4em;
    display: flex;
    flex-direction: row;
    gap: 0.3em;
}

.number__value .num_span {
    color: transparent;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}

.number__value .num_span:after {
    content: var(--value);
    position: absolute;
    color: var(--light-blue);
}

/* Fleet */
.home__fleet.bg__img__container {
    min-height: 46rem;
}

.home__fleet .bg__img__content {
    margin-bottom: 6rem;
}

.home__fleet h2 {
    color: #fff;
}

.home__fleet h2 .line_2 {
    font-size: 3.1em;
    line-height: 1;
    text-transform: uppercase;
    margin-top: 8px;
}

.title__sanserif {
    font-family: var(--gotham);
    font-size: 1.6rem;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.home__fleet .button {
    font-size: 1rem;
    padding-inline: 1.1em;
}

.home__fleet__top {
    width: 520px;
    top: 90px;
    right: 0;
    position: absolute;
    display: block;
    z-index: 2;
}

.home__fleet__top path {
    vector-effect: non-scaling-stroke;
}

.home__fleet__tilted {
    width: 160px;
    height: auto;
    top: calc(100% - 30px);
    position: absolute;
    left: calc(100% - 16px);
    display: block;
}

.home__fleet__points {
    left: 0;
    right: 0;
    bottom: 65px;
    position: absolute;
    z-index: 2;
}

.fleet__point {
    font-size: 1.1rem;
    text-align: center;
    letter-spacing: 0.05em;
    color: #fff;
    max-width: 7.5em;
    transform: translateX(-50%);
    position: absolute;
}

.fleet__point:nth-child(odd) {
    top: 35%;
}

.fleet__point:nth-child(even) {
    bottom: 115%;
}

.fleet__point.point_1 {
    left: 22.5%;
}

.fleet__point.point_2 {
    left: 43%;
}

.fleet__point.point_3 {
    left: 63%;
}

.fleet__point.point_4 {
    left: 83%;
}

/* Map */
.map__map {
    width: calc(52% + var(--side-padding));
    margin-left: auto;
    margin-right: calc(var(--side-padding) * -1);
}

.map__options {
    top: 39.5%;
    left: var(--md-mg);
    position: absolute;
    z-index: 2;
}

.map__option {
    text-align: left;
    display: block;
    padding-block: 1em;
    transition: padding-left .4s ease;
    position: relative;
    z-index: 2;
}

.map__option.active {
    padding-left: 40px;
    cursor: auto;
}

.map__option:not(.active) .option__text {
    color: #c4c4b9;
}

@media (hover:hover) {
    .map__option:hover .title__default {
        color: var(--light-blue);
    }

    .map__option:hover .map__text {
        color: #000;
    }
}

.map__option .option__text {
    transition: color .4s ease;
}

.map__option .map__text {
    font-size: 1rem;
    letter-spacing: 0.1em;
    margin-top: 4px;
}

.map__options .orn_arrows {
    width: 160px;
    left: 0;
    bottom: calc(100% + 8px);
    position: absolute;
}

.map__options .separator {
    width: 51rem;
    left: -60px;
    top: 5.15rem;
    position: absolute;
}

.map__options_svg {
    opacity: 0;
    transition: opacity 0.4s ease;
}

.map__options_svg.active {
    opacity: 1;
}

.map__madrid__spinner {
    transform-origin: 22.55% 133%;
}

.map__paris__spinner {
    transform-origin: 43.23% 101.85%;
}

.map__porto__spinner {
    transform-origin: 7.7% 129.9%;
}

.map__pt_north__spinner {
    transform-origin: 11.9% 129.85%;
}

.map__coimbra__spinner {
    transform-origin: 6.77% 134.275%;
}

.map__lisbon__spinner {
    transform-origin: 5.2% 138.5%;
}

.map__london__spinner {
    transform-origin: 34.35% 85.49%;
}

.map__es_north__spinner {
    transform-origin: 26% 126.6%;
}

.map__spiner {
    --scale: 0.7;
    transform: scale(var(--scale));
    animation: spinner 2s linear infinite;
}

@keyframes spinner {
    from {
        transform: rotate(0deg) scale(var(--scale));
    }

    to {
        transform: rotate(360deg) scale(var(--scale));
    }
}

/* Certifications */
.certification_logos {
    --mg-top: 0px;
    padding-top: 2.75rem;
    padding-inline: calc(var(--side-padding) + var(--md-mg));
    padding-bottom: 6.55rem;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
}

.certification_logos:before {
    mask-image: url(../img/cut-cream-right.svg);
    -webkit-mask-image: url(../img/cut-cream-right.svg);
}

.certification_logos .title__default {
    max-width: 25rem;
    margin-bottom: 0;
}

.certification_logos .title__default:after {
    content: '';
    top: 0.5em;
    left: 5.2em;
    width: 4em;
    height: 50px;
    background-image: url(../img/tilted-blue.svg);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: left top;
    position: absolute;
}

[lang="en"] .certification_logos .title__default:after {
    left: 80%;
}

.certification_logos .slider {
    width: 54%;
    margin-top: 30px;
    margin-right: 25px;
    margin-left: auto;
}


/* ******************************************
                ABOUT
******************************************* */
.page-template-page-about .header__bg__overlay {
    background-image: url(../img/overlay-sobre.png);
}

.page-template-page-about .header__slogan {
    top: unset;
    right: unset;
    bottom: 18%;
    left: 12%;
}

.page-template-page-about .header__titled_orn,
.page-template-page-sustainability .header__titled_orn,
.page-template-page-fleet .header__titled_orn {
    display: none;
}

.big_text_center {
    text-align: center;
    margin: 6.5rem auto;
    font-size: 1.75rem;
    max-width: 29.5em;
    line-height: 1.15;
    letter-spacing: 0.015em;
}

/* Intro */
.img_fall_text {
    margin-top: 15px;
    margin-bottom: 6.75rem;
}


.img_fall__img {
    overflow: hidden;
    width: 93%;
    left: 25px;
}

.img_fall__img:before {
    padding-bottom: 105%;
}

.img_fall_text .img_col {
    position: relative;
    z-index: 2;
}

.img_fall_text .content_col {
    margin-top: 9.5rem;
    padding-block: 6.5rem;
    position: relative;
}

.img_fall_text .content_col::after {
    --height: 32px;
    content: '';
    position: absolute;
    height: var(--height);
    width: 86%;
    top: calc(var(--height) * -0.5);
    right: 25px;
    transform-origin: left;
    background-color: var(--light-blue);
}

.img_fall_text .content_col:before {
    content: '';
    position: absolute;
    z-index: -1;
    top: 0;
    left: -195px;
    right: calc(var(--side-padding) * -1);
    bottom: 0;
    background-color: var(--main-cream);
}

.img_fall_text .inner_content {
    font-size: 1.25rem;
    letter-spacing: 0.025em;
    margin-left: auto;
    max-width: 29em;
}

.img_fall_text h2 {
    margin-bottom: 0.9em;
}

/* Mission */
.mission_container {
    font-size: 1.3rem;
    letter-spacing: 0.025em;
    padding-left: var(--md-mg);
    margin-bottom: 9rem;
}

.mission_container h2 {
    margin-bottom: 0;
}

.subheading {
    font-family: var(--space);
    font-size: 2.15rem;
    font-weight: 400;
    line-height: 1.1;
    letter-spacing: 0.01em;
    text-transform: none;
    position: relative;
}

.mission_container .subheading {
    margin-bottom: 1.85em;
}

.mission_container h3 {
    font-family: var(--space);
    font-size: 1.95rem;
    font-weight: 400;
    letter-spacing: 0.025em;
    color: var(--light-blue);
    margin-bottom: 0;
}

.mission_container .inner_content {
    max-width: 28em;
}

.mission_img {
    width: calc(100% + var(--side-padding));
}

.mission_img:before {
    padding-bottom: 68%;
}

/* Central banner */
.central_banner {
    margin-bottom: 5.75rem
}

.central_banner__pretitle {
    font-family: var(--gotham);
    font-size: 1.5rem;
    letter-spacing: 0.075em;
    text-transform: uppercase;
    display: block;
    margin-bottom: 15px;
}

.central_banner__title.title__default {
    color: #fff;
    font-size: 4rem;
    margin-bottom: 0;
}

.central_banner__content .arrow {
    width: 30px;
    margin-top: 2.75rem;
    margin-bottom: -7rem;
}

/* Distinctions */
.distinctions {
    width: 100%;
    max-width: 1130px;
    position: relative;
    margin: 0 auto;
    padding-right: 35px;
}

.distinctions .ornament {
    width: 100%;
}

.distinctions .content_container {
    font-size: 1.2rem;
    line-height: 1.2;
    letter-spacing: 0.025em;
    max-width: 53.5%;
    margin-left: auto;
    margin-top: -5px;
}

.distinctions .content_container .content {
    max-width: 27em;
}

.distinctions h2 {
    margin-bottom: 0.5em;
}

/* Certifications */
.certifications {
    background-color: var(--main-cream);
    position: relative;
    margin-top: 6.25rem;
    padding-top: 4rem;
    padding-bottom: 6.5rem;
}

.certifications .head_orn {
    --height: 40px;
    width: 32.5%;
    height: var(--height);
    top: calc(var(--height) / -2);
    left: var(--side-padding);
    background-color: var(--light-blue);
    display: block;
    position: absolute;
    z-index: 2;
}

.certifications__header {
    display: flex;
    flex-direction: row;
    align-items: flex-end;
    justify-content: space-between;
    padding-left: var(--md-mg);
}

.certifications__header h2 {
    letter-spacing: 0.05em;
    margin: 0;
}

.certifications__header .title_orn {
    width: 160px;
    position: absolute;
    top: 122%;
    left: -1em;
}

.slide_controls {
    margin-bottom: 0.5rem;
    display: flex;
    flex-direction: row;
    align-items: center;
}

.slide_controls button {
    width: 65px;
    display: flex;
    align-items: center;
    justify-content: center;
    aspect-ratio: 1 / 1;
    border: 2px solid var(--light-blue);
    border-radius: 100%;
}

.slide_controls button,
.slide_controls button:hover,
.slide_controls button svg polyline {
    transition: background-color .4s, opacity .4s, stroke .4s ease;
}

.slide_controls button:has(svg.swiper-button-disabled) {
    opacity: 0.5;
    cursor: auto;
}

.slide_controls button:not(:has(svg.swiper-button-disabled)):hover {
    background-color: var(--light-blue);
    cursor: pointer;
}

.slide_controls button:not(:has(svg.swiper-button-disabled)):hover svg polyline {
    stroke: var(--main-cream) !important;
}

.slide_controls button svg {
    width: 30%;
    pointer-events: none;
}

.slide_controls button#next {
    margin-left: 16px;
}

.certification__slider {
    --top: 97px;
    margin-top: 2rem;
    padding-top: var(--top);
    overflow-x: clip;
    overflow-y: visible;
}

.certifications .slide-container {
    transition: opacity .3s ease;
}

.certifications .slide-container.changing {
    opacity: 0;
}

.certification__slider .swiper-slide {
    position: relative;
    top: calc(var(--top) * -1);
}

.certification__slider .swiper-slide.swiper-slide-active,
.certification__slider .swiper-slide.swiper-slide-prev {
    top: 0;
}

.certification__slider .slide_year {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    position: relative;
    max-width: 20rem;
    margin: 0 auto;
    left: 13%;
}

.certification__slider .year_container {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    --dot: 22px;
}

.certification__slider .year_text {
    font-family: var(--space);
    font-size: 2.5rem;
    font-weight: 400;
    letter-spacing: 0;
    margin-bottom: 9px;
    color: var(--light-blue);
    top: 0;
    transform: translateX(calc(-50% + var(--dot) / 2));
}

.certification__slider .year-dot {
    width: var(--dot);
    display: block;
    aspect-ratio: 1 / 1;
    background-color: var(--light-blue);
    border-radius: 100%;
}

.certification__slider .year_content {
    text-align: left;
    font-size: 1.25rem;
    letter-spacing: 0.025em;
    line-height: 1.2;
    margin-top: 43px;
}

.certification__slider .year_title {
    font-family: var(--gotham-medium);
    font-size: 1.75rem;
    letter-spacing: 0.025em;
    margin-bottom: 0.85em;
    text-transform: none;
    max-width: 15em;
}

.certifications .certification__slider__line_container {
    height: 95px;
    display: flex;
    flex-direction: column;
    align-items: center;
    width: calc(100% + var(--side-padding) * 2);
    overflow: hidden;
    position: absolute;
    left: calc(var(--side-padding) * -1);
    top: 64px;
}

.certifications .certification__slider__line {
    height: 100%;
    width: auto;
    display: block;
}

/* Quality */
.quality_certs {
    padding-block: 5.5rem;
}

.quality_certs .bg__img:after {
    content: '';
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    position: absolute;
    background: linear-gradient(90deg, rgba(0, 0, 0, 1) 11%, rgba(0, 0, 0, 0.25) 80%);
}

.quality_certs .bg__img__content {
    max-width: 500px;
    align-items: flex-start;
    text-align: left;
    margin-left: calc(var(--md-mg) * 1.75);
}

.quality_certs .title__default {
    color: #fff;
    max-width: 9em;
    margin-bottom: 0.8em;
}

.quality__cert__logo {
    width: 106px;
    aspect-ratio: 1 / 0.67;
    top: 7px;
    right: calc(100% + 35px);
    position: absolute;
    object-position: center top;
}

.quality_certs__cert {
    font-size: 1.05rem;
    letter-spacing: 0.07em;
    line-height: 1.25;
}

.quality_certs__cert h3 {
    font-family: var(--gotham);
    letter-spacing: 0.02em;
    max-width: 19em;
    margin-bottom: 1.25rem
}

.quality_certs hr {
    margin: 3rem 0;
    margin-left: 10px;
    border: none;
    border-bottom: 1px solid #fff;
    width: 100%;
    max-width: 28.5rem;
    display: block;
}

/* Message */
.founder_msg {
    padding-top: 10rem;
    margin-top: 40px;
    margin-bottom: 7rem;
}

.founder_msg .ornament {
    width: 80px;
    position: absolute;
    right: calc(50% + 55px);
    top: 0;
    margin: 0 auto;
}

.founder_msg__img__container {
    width: 370px;
    margin: 0 auto;
    left: -50px;
    position: relative;
}

.founder_msg__img {
    width: 100%;
    border-radius: 100%;
    overflow: hidden;
}

.founder_msg__img::before {
    padding-bottom: 100%;
}

.founder__signature {
    width: 46%;
    top: 33%;
    left: 66%;
    position: absolute;
    z-index: 2;
}

.founder_msg__content {
    font-size: 1.3rem;
    line-height: 1.2;
    letter-spacing: 0.025em;
    max-width: 31em;
    padding-top: 4rem;
    position: relative;
    left: -15px;
}

.founder_msg__content h2 {
    font-size: 3.75rem;
    margin-left: -0.075em;
    margin-bottom: 0.65em;
}


/* ******************************************
                SUSTAINABILITY
******************************************* */
.page-template-page-sustainability .header__bg__overlay {
    background-image: url(../img/overlay-sustentabilidade.png);
}

.sustainable_intro .intro__content__container {
    font-size: 1.75rem;
    max-width: 17em;
}

/* List */
.sust_container {
    margin-top: 4.5rem;
}

.sust_container__header {
    position: relative;
}

.sust_container__banner {
    width: 100%;
}

.sust_container__banner:before {
    padding-bottom: 38%;
}

.sust_container__header.has_banner .sust_container__title {
    position: absolute;
    left: 0;
    bottom: 0;
}

.sust_container__title {
    position: relative;
    z-index: 2;
    background-color: var(--light-blue);
    width: 100%;
    max-width: 37rem;
    padding: 4rem 6.5%;
}

.sust_container__title h2 {
    color: var(--main-cream);
    margin-bottom: 0;
}

.sust_container__title__orn {
    position: absolute;
    top: calc(100% - 5rem);
    right: 14%;
    width: 160px;
}

.cut_bttm {
    --bg-color: var(--main-cream);
    --cut-height: 135px;
    --mg-bottom: 3rem;
    --border-radius: 40px;
    position: relative;
    margin-bottom: calc(var(--cut-height) + var(--mg-bottom));
}

.cut_bttm:after {
    content: '';
    position: absolute;
    top: calc(100%);
    left: 0;
    width: 100%;
    background-color: var(--bg-color);
    height: var(--cut-height);
    border-bottom-right-radius: var(--border-radius);
    mask-image: url(../img/cut-bottom.svg);
    mask-position: center top;
    mask-size: cover;
    mask-repeat: no-repeat;
    -webkit-mask-image: url(../img/cut-bottom.svg);
    -webkit-mask-position: center top;
    -webkit-mask-size: cover;
    -webkit-mask-repeat: no-repeat;
    clip-path: polygon(var(--border-radius) 0, 100% 0, 100% 100%, var(--border-radius) 100%);
    -webkit-clip-path: polygon(var(--border-radius) 0, 100% 0, 100% 100%, var(--border-radius) 100%);
}

.cut_bttm_content {
    width: 100%;
    background-color: var(--bg-color);
    border-bottom-left-radius: var(--border-radius);
    margin-bottom: calc(var(--cut-height) + var(--mg-bottom));
}

.sust_container .cut_bttm_content {
    padding-top: 7.75rem;
    padding-inline: 40px;
}

.sust_container__content {
    width: 100%;
    max-width: 980px;
    margin-left: auto;
}

.sust_list {
    display: flex;
    flex-direction: row;
    align-items: center;
    padding-block: 2.25rem;
    --icon-width: 36%;
}

.sust_list:not(:last-child) {
    border-bottom: 1px solid var(--light-blue);
}

.sust_list__icon {
    width: var(--icon-width);
    display: flex;
    margin: 0;
    align-items: center;
    justify-content: center;
    padding-right: 25px;
}

.sust_list__icon img {
    display: block;
    width: 100%;
    max-width: 220px;
}

.sus_list__content {
    width: 100%;
    max-width: calc(100% - var(--icon-width));
    margin-left: auto;
    font-size: 1.25rem;
    letter-spacing: 0.025em;
}

.sus_list__content .inner_container {
    max-width: 29em;
}

.sus_list__content h3 {
    color: var(--light-blue);
    font-family: var(--space);
    font-size: 2rem;
    font-weight: 400;
    letter-spacing: 0;
    margin-bottom: 0.65em;
}

.sust_list.list_outro {
    margin-top: 2.75rem;
    align-items: flex-start;
}

.sust_list.list_outro .sust_list__icon img {
    max-width: 160px;
    margin-top: 7px;
    margin-left: 35px;
}

.sust_list.list_outro .sus_list__content {
    font-family: var(--space);
    font-size: 1.6rem;
    line-height: 1.2;
    font-weight: 400;
}

.sust_list.list_outro .sus_list__content .inner_container {
    max-width: 25em;
}

/* ESG */
.esg_container {
    --overlap: 29rem;
}

.esg_container .bg__img__container.has_overlap {
    padding-bottom: var(--overlap);
    margin-bottom: calc(var(--overlap) * -1);
}

.esg_container .bg__img__container .bg__img:after {
    opacity: 0.25;
}

.esg_container .bg__img__container .ornament {
    display: block;
    position: absolute;
    top: 6.75rem;
    left: calc(var(--side-padding) + 20px);
    width: 280px;
    z-index: 2;
}

.esg_container__content {
    --content-width: 810px;
    display: flex;
    flex-direction: row;
    padding-left: var(--md-mg);
    position: relative;
    align-items: flex-start;
    z-index: 2;
}

.esg__side_img {
    width: 100%;
    max-width: calc(100% - var(--content-width));
    margin-top: calc(var(--overlap) + 15rem);
}

.esg__side_img:before {
    padding-bottom: 123%;
}

.esg__content {
    width: 100%;
    max-width: var(--content-width);
    position: relative;
    margin-left: auto;
}

.esg__content-top {
    height: 145px;
    border-top-right-radius: 60px;
    background-color: var(--light-blue);
    mask-image: url(../img/cut-blue.svg);
    mask-position: center top;
    mask-size: cover;
    mask-repeat: no-repeat;
    -webkit-mask-image: url(../img/cut-blue.svg);
    -webkit-mask-position: center top;
    -webkit-mask-size: cover;
    -webkit-mask-repeat: no-repeat;
}

.esg__content-main {
    background-color: var(--main-cream);
    padding: 7.75rem 14%;
    font-size: 1.2rem;
    letter-spacing: 0.025em;
}

.esg__content-main h2 {
    margin-bottom: 1.5em;
}

.esg__logo {
    position: absolute;
    top: -63px;
    right: 9%;
    width: 165px;
    display: block;
}

/* Accordions */
.esg__content .accordions {
    margin-top: 5rem;
}

.accordions {
    width: 100%;
    --side-pad: 15px;
}

.accordion {
    width: calc(100% + var(--side-pad) * 2);
    margin-left: calc(var(--side-pad) * -1);
    border-top: 2px solid var(--light-blue);
}

.accordion:last-child {
    border-bottom: 2px solid var(--light-blue);
}

.accordion_header {
    --toggle: 35px;
    width: 100%;
    display: flex;
    flex-direction: row;
    cursor: pointer;
    padding: 15px calc(var(--side-pad) * 2) 15px var(--side-pad);
    align-items: center;
    justify-content: space-between;
}

.accordion_header.no_click {
    cursor: auto;
}

.accordion_title {
    width: 100%;
    max-width: calc(100% - var(--toggle));
    font-family: var(--space);
    color: var(--light-blue);
    margin-bottom: 0;
    font-weight: 400;
    font-size: 1.95rem;
    letter-spacing: 0.025em;
}

.accordion_toggle {
    width: var(--toggle);
    height: var(--toggle);
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}

.accordion_toggle span {
    position: absolute;
    display: block;
    width: 100%;
    border-bottom: 3px solid var(--light-blue);
    transition: transform .4s ease;
}

.accordion_toggle span:nth-child(2) {
    transform: rotate(90deg);
}

.accordion.open .accordion_toggle span:nth-child(2) {
    transform: rotate(0deg);
}

.accordion_body {
    width: 100%;
    display: none;
    padding: 5px var(--side-pad) 4rem;
}

/* CO2 */
.sustainable_co2 .title__default {
    max-width: 10em;
}

.sustainable_co2 .intro__col__content {
    font-family: var(--gotham);
    font-size: 1.25rem;
}

.sustainable_co2 .intro__content__container {
    max-width: 30em;
}

.sustainable_co2 .ornament {
    bottom: 0;
    right: 5%;
    width: 38%;
    position: absolute;
}

/* Reports */
.reports {
    width: 100%;
    max-width: calc(100% - var(--md-mg));
    font-family: var(--space);
    font-size: 1.95rem;
    color: var(--main-cream);
    border-radius: 40px;
    overflow: hidden;
    margin-top: 6.75rem;
    margin-bottom: 5.25rem;
    margin-inline: auto;
}

.reports_header {
    font-weight: 300;
    line-height: 1.2;
    padding-block: 3.5rem;
    background-color: var(--light-blue);
}

.reports_header .inner_container {
    width: 100%;
    max-width: 25em;
    margin: 0 auto;
}

.reports_single {
    padding-block: 2rem;
    background-color: #0a295f;
}

.reports_single:only-child {
    max-width: 100%;
    flex: unset;
}

.reports_single .inner_container {
    max-width: 14em;
    font-size: 0.85em;
    line-height: 1.2;
    font-weight: 300;
}

.reports_single .button {
    margin: 1.5rem auto 0;
}

.reports_body .row {
    justify-content: center;
}

.reports_body .row:nth-child(odd) .reports_single:nth-child(even),
.reports_body .row:nth-child(even) .reports_single:nth-child(odd) {
    background-color: #082150;
}


/* ******************************************
                    FLEET
******************************************* */
.page-template-page-fleet .header__bg__overlay {
    background-image: url(../img/overlay-frota.png);
}

.page-template-page-fleet .header__slogan {
    top: unset;
    right: unset;
    bottom: 25%;
    left: 15.5%;
}

.page-template-page-fleet .header__plus,
.page-template-page-fleet .header__line {
    display: none;
}

/* Intro */
.fleet_intro .title__default {
    max-width: 12.5em;
}

.intro__content__container {
    font-family: var(--gotham);
    font-size: 1.25rem;
    max-width: 24em;
}

/* Numbers */
.fleet_numbers {
    width: 100%;
    margin-top: 3rem;
    margin-bottom: 6rem;
}

.fleet_numbers .numbers {
    --border: 5px;
    font-family: var(--space);
    font-weight: 400;
    color: var(--light-blue);
    font-size: 5.5rem;
    letter-spacing: 0.025em;
    left: 16%;
    line-height: 1;
    position: relative;
}

.fleet_numbers .numbers span {
    width: max-content;
    border: var(--border) solid var(--light-blue)
}

.fleet_numbers .numbers .main {
    font-size: 1.1em;
    padding: 5px 0.4em;
}

.fleet_numbers .numbers .label {
    font-size: 0.45em;
    margin-left: 3.25em;
    font-weight: 500;
    padding: 0.35em 0.6em;
    margin-top: calc(var(--border) * -1);
}

.fleet_numbers .icon {
    --left: 30px;
    width: 100%;
    max-width: calc(700px + var(--left));
    margin: 0 auto;
    display: block;
    position: relative;
    left: var(--left);
    margin-top: -5.5rem;
}

.fleet_numbers .icon svg {
    width: 100%;
    max-width: 44%;
    margin-left: auto;
    display: block;
    margin-right: 19%;
    margin-bottom: -5px;
}

.fleet_numbers .icon hr {
    width: 100%;
    border: none;
    border-bottom: 8px solid var(--light-blue);
    margin: 0;
}

/* Fleet */
.fleet {
    padding-top: 110px;
    margin-bottom: 8rem;
}

.fleet__title_container {
    width: 81%;
    min-height: 300px;
    top: 0;
    right: 0;
    padding-top: 60px;
    position: absolute;
    border-top-right-radius: 40px;
    background-color: var(--light-blue);
    mask-image: url(../img/cut-fleet-blue.svg);
    mask-position: center top;
    mask-size: cover;
    mask-repeat: no-repeat;
    -webkit-mask-image: url(../img/cut-fleet-blue.svg);
    -webkit-mask-position: center top;
    -webkit-mask-size: cover;
    -webkit-mask-repeat: no-repeat;
}

.fleet__title_container h2 {
    color: var(--main-cream);
    line-height: 1.1;
    width: 100%;
    max-width: 50%;
    font-size: 3.5rem;
    letter-spacing: 0.025em;
    margin-bottom: 0;
    font-weight: 500;
    text-transform: uppercase;
    margin-left: auto;
}

.fleet__title_container h2 span {
    display: block;
}

.fleet__title_container h2 .line_2 {
    font-size: 1.2em;
}

.fleet__content {
    background-color: var(--main-cream);
    padding: 0 70px;
    position: relative;
    --cut-height: 155px;
    margin-top: var(--cut-height);
    padding-bottom: 6.5rem;
    border-bottom-left-radius: 50px;
    border-bottom-right-radius: 50px;
    z-index: 2;
}

.fleet__content:before {
    content: '';
    border-top-left-radius: 50px;
    position: absolute;
    top: calc(var(--cut-height) * -1 + 3px);
    left: 0;
    right: 0;
    background-color: var(--main-cream);
    height: var(--cut-height);
    mask-image: url(../img/cut-fleet-main.svg);
    mask-position: center top;
    mask-size: cover;
    mask-repeat: no-repeat;
    -webkit-mask-image: url(../img/cut-fleet-main.svg);
    -webkit-mask-position: center top;
    -webkit-mask-size: cover;
    -webkit-mask-repeat: no-repeat;
}

.fleet__content .title_orn {
    font-family: var(--space);
    text-transform: uppercase;
    color: #ecece1;
    font-weight: 400;
    line-height: 1;
    writing-mode: vertical-lr;
    position: absolute;
    transform: rotate(180deg);
    left: 120px;
    font-size: 15rem;
    top: -40px;
    letter-spacing: 0.05em;
}

.fleet__list {
    width: 100%;
    max-width: 800px;
    margin-left: auto;
    position: relative;
    z-index: 2;
}

.fleet__list_item {
    display: flex;
    flex-direction: row;
    align-items: center;
    padding-block: 2.3rem;
    --icon-width: 46%;
}

.fleet__list_item {
    border-bottom: 1px solid var(--light-blue);
}

.fleet__list_item__icon {
    width: var(--icon-width);
    height: 95px;
    display: flex;
    margin: 0;
    align-items: center;
    justify-content: center;
    position: relative;
}

.fleet__list_item__icon img {
    display: block;
    width: 100%;
    max-width: 230px;
    position: absolute;
}

.fleet__list_item__content {
    width: 100%;
    max-width: calc(100% - var(--icon-width));
    margin-left: auto;
    font-size: 1.25rem;
    letter-spacing: 0.025em;
}

.fleet__list_item__content .inner_container {
    max-width: 29em;
}

.fleet__list_item__content h3 {
    color: var(--light-blue);
    font-family: var(--space);
    font-size: 2.25rem;
    font-weight: 500;
    letter-spacing: 0;
    margin-bottom: 0;
}

.fleet__list_item__content .subheading {
    font-family: var(--gotham);
    display: block;
    font-size: 1.25rem;
    letter-spacing: 0.025em;
}

.fleet__list__imgs {
    width: 220px;
    padding: 0;
    top: 0;
    left: 0;
    position: fixed;
    overflow: hidden;
    pointer-events: none;
    z-index: 3;
}

.fleet__list__imgs:before {
    content: '';
    display: block;
    padding-bottom: 67%;
}

.fleet__list__imgs img {
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    display: block;
    position: absolute;
    object-fit: cover;
    object-position: center;
    opacity: 0;
    z-index: 1;
}

@media (hover: hover) {
    .fleet__list__imgs img.active {
        z-index: 2;
        opacity: 1;
    }
}



/* ******************************************
                SERVICES
******************************************* */
.page-template-page-services .header__bg__overlay {
    background-image: url(../img/overlay-servicos.png);
}

.page-template-page-services .header__titled_orn {
    left: -25%;
}

.services_intro .orn_24_7 {
    position: absolute;
    top: -40px;
    right: 11%;
    width: 140px;
}

.services_intro .orn_24_7 .radial_svg {
    animation: none;
}


/* Accordions */
.services_cut_bttm {
    --overlap: 7rem;
    margin-top: calc(var(--overlap) + 3.5rem);
}

.services_cut_bttm:after,
.technology_text:after {
    mask-image: url(../img/services-cut.svg);
    -webkit-mask-image: url(../img/services-cut.svg);
    top: calc(100% - 1px);
}

.services_cut_bttm .cut_bttm_content,
.technology_text .cut_bttm_content {
    border-top-right-radius: 55px;
}

.services_cut_bttm .figure_col {
    padding-bottom: 10rem;
}

.services_cut_bttm figure {
    max-width: 87%;
    margin-top: calc(var(--overlap) * -1);
}

.services_cut_bttm figure:before {
    padding-bottom: 119%;
}

.services_cut_bttm .figure_col .ornament {
    width: 160px;
    bottom: 40px;
    right: 29.5%;
    position: absolute;
}

.services_cut_bttm .content_col {
    padding-top: 8rem;
    padding-right: 15px;
    position: relative;
    left: -8%;
}

.services_cut_bttm .content_col:before {
    content: '';
    --height: 60px;
    height: var(--height);
    position: absolute;
    width: 89%;
    left: 0;
    top: calc(var(--height) * -0.33);
    background-color: var(--light-blue);
}

.services_cut_bttm h2 {
    margin-bottom: 1em;
}

.services_cut_bttm .accordions {
    --side-pad: 25px;
}

/* Logistics */
.logistics_contianer {
    padding-top: 2rem;
    margin-bottom: 7rem;
}

.logistics_contianer .intro__content {
    padding-left: 40px;
}

.logistics_contianer .intro__col__title {
    margin-top: -1rem;
    font-size: 1.25rem;
    letter-spacing: 0.025em;
    line-height: 1.2;
}

.logistics_contianer .inner_container {
    max-width: 21.5em;
}

.logistics_contianer h2 {
    margin-bottom: 1em;
}

.logistics_contianer .intro__content__container {
    max-width: 630px;
    margin-top: 2rem;
    position: relative;
    margin-left: 0;
}

/* Technology */
.techonology_banner.central_banner {
    margin-bottom: 0;
}

.techonology_banner .ornament {
    position: absolute;
    top: 30.5%;
    left: 12%;
    width: 160px;
    z-index: 2;
}

.technology_text {
    --mg-bottom: 6rem;
}

.technology_text .cut_bttm_content {
    padding-top: 8rem;
    margin-left: 0;
    padding-left: 55px;
    font-size: 1.25rem;
    letter-spacing: 0.025em;
    line-height: 1.2;
}

.technology_text .content_col {
    padding-right: 12%;
}

.technology_text .content_col h2 {
    margin-bottom: 1em;
    font-size: 2rem;
}

.technology_text .ornament {
    position: absolute;
    top: -190px;
    left: 0;
    background-color: var(--light-blue);
    height: 120px;
    width: 100%;
    z-index: 2;
}

.technology_text .icon_col svg {
    width: 270px;
    margin-top: 5rem;
    margin-left: auto;
    margin-right: 20%;
}


/* ******************************************
                NOTICIAS
******************************************* */
.blog .header__bg__overlay {
    background-image: url(../img/overlay-noticias.png);
}

.blog .header__titled_orn {
    bottom: 50%;
    top: unset;
    left: -40%;
    right: unset;
}

/* Categories */
.categories {
    margin: 5.75rem 0 5.5rem;
}

.categories ul {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    padding: 0;
    gap: 15px 10px;
    margin: 0;
}

.categories ul li {
    list-style-type: none;
}

.categories ul li a {
    display: block;
    font-family: var(--space);
    font-size: 1.2rem;
    color: #000;
    text-transform: uppercase;
    background-color: var(--main-cream);
    border-radius: 5px;
    padding: 8px 15px;
    letter-spacing: 0.05em;
    min-width: 7em;
    text-align: center;
}

.categories ul li a.active {
    background-color: var(--light-blue);
    color: var(--main-cream);
    pointer-events: none;
}

@media (hover:hover) {
    .categories ul li a:hover {
        background-color: var(--light-blue);
        color: var(--main-cream);
    }
}

.articles_container .no_results {
    font-family: var(--space);
    text-align: center;
    margin: 0 auto;
    padding: 10rem 0;
    font-size: 2rem;
}

/* Post card */
.articles_container .inner_wrapper {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    --cards: 3;
    --gap: 30px;
    gap: var(--gap);
}

.post_card {
    width: 100%;
    margin-bottom: 6rem;
    flex: 0 0 calc((100% - (var(--gap) * (var(--cards) - 1))) / var(--cards));
}

.post_card__thumbnail {
    width: 100%;
    display: block;
    overflow: hidden;
}

.post_card__thumbnail:before {
    padding-bottom: 90%;
}

.post_card__thumbnail img {
    transition: transform .65s ease;
}

.post_card__thumbnail:hover img {
    transform: scale(1.15);
}

.post_card__content {
    padding: 25px 15px 0;
}

.date {
    font-size: 12px;
    letter-spacing: 0.05em;
    display: block;
}

.post_card__title {
    font-family: var(--gotham-medium);
    color: var(--light-blue);
    display: block;
    margin-top: 1rem;
    font-size: 1.3rem;
    line-height: 1.2;
    letter-spacing: 0.025em;
}

.post_card__title,
.post_card__title:hover {
    transition: color .4s ease;
}

.post_card__excerpt {
    margin-top: 1.5em;
    letter-spacing: 0.05em;
    line-height: 1.2;
    text-overflow: ellipsis;
    overflow: hidden;
    display: -webkit-box;
    line-clamp: 3;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
}

.pagination_container {
    flex: 100%;
}

/* Popups */
.single_post__thumbnail {
    margin-bottom: 2.25rem;
}

.single_post__thumbnail:before {
    padding-bottom: 66%;
}

.single_post__title {
    font-family: var(--gotham-medium);
    font-size: 2.75rem;
    letter-spacing: 0.025em;
    color: var(--light-blue);
    line-height: 1.25;
    margin-left: -0.05em;
}

.popup_divider {
    --extra: 90px;
    width: calc(100% + var(--extra) * 2);
    border: none;
    border-bottom: 1px solid var(--light-blue);
    margin-left: calc(var(--extra) * -1);
    margin-block: 1.5rem;
    position: relative;
}

.popup_divider:after {
    content: '';
    --height: 8px;
    height: var(--height);
    position: absolute;
    left: calc(var(--extra) - 25px);
    width: 54%;
    background-color: var(--light-blue);
    top: calc(var(--height) / -2);
}

.single_post__content {
    font-size: 1.1rem;
    letter-spacing: 0.025em;
    padding-top: 1rem;
}

.back_bttn {
    font-family: var(--space);
    text-transform: none;
    letter-spacing: 0.1em;
    font-size: 14px;
    display: flex;
    flex-direction: row;
    align-items: center;
}

.back_bttn svg {
    width: 55px;
    margin-left: 25px;
    display: block;
    transition: transform .4s ease;
}

.back_bttn:hover svg {
    transform: translateX(-7px);
}

/* Pagination */
.navigation.pagination {
    width: 100%;
    margin: -4rem auto 6rem;
}

.pagination .nav-links {
    display: flex;
    flex-direction: row;
    align-items: center;
    flex-wrap: wrap;
    margin: 0 auto;
}

.pagination .page-numbers {
    min-width: 30px;
    height: 37px;
    border: none !important;
    background-color: transparent !important;
    color: #000 !important;
    font-size: 1.2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    margin: 0 10px;
}

.pagination .page-numbers:before {
    content: '';
    width: 2.2em;
    height: 2.2em;
    border-radius: 100%;
    background-color: var(--main-cream);
    transform-origin: center;
    transform: scale(0);
    transition: transform 0.35s, opacity 0.2s ease;
    position: absolute;
    opacity: 0;
    z-index: -1;
}

.pagination .page-numbers:not(.current):hover:before {
    transform: scale(1);
    opacity: 1;
}

.pagination .page-numbers.current {
    font-family: var(--gotham-bold);
    user-select: none;
    cursor: auto;
}


/* SINGLE POST */
.single_post_page {
    max-width: 830px;
    margin: 5rem auto 10rem;
}

.single_post_page .back_bttn {
    max-width: fit-content;
    margin-bottom: 2rem;
}


/* ******************************************
                RECRUITMENT
******************************************* */
.page-template-page-recruitment .header__bg__overlay {
    background-image: url(../img/overlay-recrutamento.png);
}


.page-template-page-recruitment .header__titled_orn,
.page-template-page-contacts .header__titled_orn {
    right: -7%;
}

.jobs_intro .intro__content__container {
    max-width: 27.5em;
    left: -6%;
    position: relative;
}

/* Posts */
.job_section {
    --left-pad: 35px;
    max-width: 1000px;
    margin-left: auto;
    padding-left: var(--left-pad);
}

.job_section h2 {
    margin-bottom: 1em;
}

.job_posts {
    margin-top: 6.5rem;
}

.job_posts .popup_divider {
    max-width: 730px;
    margin-bottom: 1.5rem;
}

.job_posts .popup_divider:after {
    width: 45%;
    left: calc(var(--extra) - 55px);
}

.job_posts__list {
    width: 100%;
    max-width: 640px;
}

.job_posts__list .job_post {
    color: #000;
    width: calc(100% + var(--left-pad));
    background-color: var(--main-cream);
    margin-bottom: 5px;
    padding: 20px var(--left-pad);
    text-align: left;
    margin-left: calc(var(--left-pad) * -1);
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
}

.job_posts__list .job_post h3 {
    font-family: var(--gotham);
    font-size: 1.5em;
    letter-spacing: 0.025em;
    margin: 0;
}

.job_posts__list .job_post .arrow {
    width: 35px;
    transition: transform .4s ease;
}

.job_posts__list .job_post:hover .arrow {
    transform: translateX(25%);
}

/* Popups */
.popup_divider.no_thick:after {
    display: none;
}

.popup_divider.is_job:not(.no_thick):after {
    width: 54%;
    left: 7%;
}

.popup_divider.is_job {
    width: calc(100% + var(--extra) * 2);
    max-width: unset;
}

.single_job__title {
    font-family: var(--gotham);
    font-size: 2.75rem;
    letter-spacing: 0.025em;
    margin: 1em 0;
}

.single_post__content.is_job h2 {
    color: #000;
    font-family: var(--gotham-medium);
    font-size: 1.5rem;
    margin-top: 1.25em;
    margin-bottom: 0.5em;
}

/* Job form */
.apply_job {
    margin-top: 8rem;
    margin-bottom: 5rem;
}

.apply_job .popup_divider {
    width: 540px;
    margin-left: -190px;
}

.apply_job .popup_divider:after {
    left: 25%;
    width: 61%;
}

.apply_job h3 {
    font-family: var(--space);
    font-size: 2.25rem;
    letter-spacing: 0.05em;
    margin-top: 2em;
    margin-bottom: 2rem;
}

.apply_job h3:not(:first-of-type) {
    margin-top: 1em;
}

.cream_form_fields .form_line {
    margin-bottom: 20px;
}

.cream_form_fields input:not([type="submit"], [type="checkbox"]),
.cream_form_fields textarea {
    border: none;
    background-color: var(--main-cream);
    padding-inline: 20px;
    font-size: 1rem;
}

.cream_form_fields select {
    font-family: var(--gotham);
    letter-spacing: 0.1em;
    border-bottom: 1px solid #000;
    padding: 1rem 8px;
    width: 100%;
    border: none;
    background-color: var(--main-cream);
    padding-inline: 20px;
    font-size: 1rem;
}

.apply_job .wpcf7cf_group h3 {
    margin-top: 1em;
}

.cream_form_fields form label {
    font-family: var(--gotham);
    font-size: 1.25rem;
    letter-spacing: 0.05em;
    padding-left: 20px;
}

.cream_form_fields form .wpcf7-acceptance {
    position: static;
    margin-left: 0;
    padding: 0;
}

.cream_form_fields form .wpcf7-acceptance label {
    padding: 0;
    margin: 0;
    font-size: 14px;
}

.cream_form_fields form .form_line.submit_line {
    margin-top: 1rem;
}

.cream_form_fields form #submit input[type="submit"] {
    background-color: var(--light-blue);
    color: #fff;
}

.cream_form_fields form #submit input[type="submit"]:hover,
.cream_form_fields form #submit input[type="submit"]:focus {
    background-color: var(--main-cream);
    color: #000 !important;
}


.button.popup_button {
    background-color: #fff;
    margin-top: 2.75rem;
    padding: 0.75em 2.25em;
}

.button.popup_button:hover {
    background-color: var(--light-blue);
}


/* ******************************************
                CONTACTS
******************************************* */
.page-template-page-contacts .header__bg__overlay {
    background-image: url(../img/overlay-contacts.png);
}

.contacts_intro .title__default {
    max-width: 11em;
}

/* Image */
.contacts_content .img_container {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding-top: 3rem;
}

.contact_img {
    position: relative;
    padding-top: 130px;
}

.contact_img .img_bg {
    aspect-ratio: 162 / 150;
    width: 83%;
    position: absolute;
    top: 0;
    right: 0;
    display: block;
    background-color: var(--light-blue);
    mask-image: url(../img/contact-cut-blue.svg);
    mask-position: center top;
    mask-size: cover;
    mask-repeat: no-repeat;
    -webkit-mask-image: url(../img/contact-cut-blue.svg);
    -webkit-mask-position: center top;
    -webkit-mask-size: cover;
    -webkit-mask-repeat: no-repeat;
    z-index: 1;
}

.contact_img .img_bg .ornament {
    width: 30.5%;
    display: block;
    position: absolute;
    top: 19%;
    right: 8.5%;
}

.contact_img figure {
    width: 89%;
    margin-right: auto;
    z-index: 2;
}

.contact_img figure::before {
    padding-bottom: 122%;
}

/* Content */
.contacts_content {
    margin-bottom: 8rem;
}

.contacts_content .content_container {
    width: 100%;
    max-width: 420px;
    margin: 0 auto;
    font-size: 1.25rem;
    line-height: 1.2;
    letter-spacing: 0.025em;
}

.contacts_content h2 {
    font-size: 1.75rem;
    font-weight: 500;
    margin-bottom: 0.35em;
    letter-spacing: 0;
}

.contacts_content h2:not(:first-child) {
    margin-top: 1.5em;
}

.contacts_content h3 {
    font-family: var(--space);
    font-size: 1.25rem;
    font-weight: 500;
    color: #000;
    letter-spacing: 0;
}

.contacts_content h3+h2 {
    margin-top: 0.6em !important;
}

.contacts_content a {
    color: #000;
    --main-color: #000 !important;
}

.contacts_content hr {
    --width: 620px;
    --height: calc(var(--width) * 0.26);
    width: var(--width);
    height: var(--height);
    display: block;
    background-size: contain;
    background-repeat: no-repeat;
    background-image: url(../img/contact-hr.svg);
    border: none;
    margin-top: 5rem;
    margin-bottom: calc(var(--height) * -0.74);
    margin-left: calc(var(--width) * -0.125);
}

/* Contact form */
.contact_form {
    width: 100%;
    max-width: 1040px;
    margin-right: 20px;
    margin-left: auto;
    --cut-height: 105px;
    position: relative;
    padding-top: var(--cut-height);
    border-top-right-radius: 30px;
    overflow: hidden;
}

.contact_form:before {
    --border-radius: 50px;
    content: '';
    width: 100%;
    position: absolute;
    left: 0;
    top: 0;
    height: var(--cut-height);
    background-color: var(--main-cream);
    mask-image: url(../img/contact-form-cut.svg);
    mask-position: center top;
    mask-size: cover;
    mask-repeat: no-repeat;
    -webkit-mask-image: url(../img/contact-form-cut.svg);
    -webkit-mask-position: center top;
    -webkit-mask-size: cover;
    -webkit-mask-repeat: no-repeat;
    clip-path: polygon(var(--border-radius) 0, 100% 0, 100% 100%, var(--border-radius) 100%);
    -webkit-clip-path: polygon(var(--border-radius) 0, 100% 0, 100% 100%, var(--border-radius) 100%);
}

.contact_form .inner_content {
    padding: 4rem 11% 6.5rem;
    border-top-left-radius: 50px;
    background-color: var(--main-cream);
}

.contact_form .form_content {
    width: 100%;
    max-width: 620px;
    margin-left: auto;
}

.contact_form h2 {
    margin-bottom: 1.5em;
}

.contact_form h2::before {
    content: '';
}

.contact_form .title_orn {
    height: 65%;
    top: 18%;
    position: absolute;
    right: calc(100% + 35px);
}

.form_line.is_first input {
    border-top: 1px solid #000;
}

.form_line.submit_line {
    margin-top: 2rem;
}

#submit input[type="submit"] {
    background-color: #fff;
    padding: 11px 2.5em;
    font-size: 1rem;
}

#submit input[type="submit"]:hover,
#submit input[type="submit"]:focus {
    background-color: var(--light-blue);
    color: var(--main-cream);
}

#submit input[type="submit"],
#submit input[type="submit"]:hover,
#submit input[type="submit"]:focus {
    transition: background-color .4s, color .4s ease;
}


/* ******************************************
                REGULAR PAGE
******************************************* */
.page-template-default .header__titled_orn {
    display: none;
}

.page-template-default .header__bg__overlay {
    background-color: #000;
    opacity: 0.38;
}

.regular_page {
    max-width: 900px;
    margin: 10rem auto;
    font-size: 1.15rem;
    line-height: 1.5;
    letter-spacing: 0.025em;
}

.regular_page h2 {
    margin-bottom: max(0.5em, 1rem);
}

.regular_page h2:not(:first-child) {
    margin-top: 1.5em;
}